1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123
|
/*
PowerDNS Versatile Database Driven Nameserver
Copyright (C) 2006 - 2015 PowerDNS.COM BV
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License version 2 as
published by the Free Software Foundation
Additionally, the license of this program contains a special
exception which allows to distribute the program in binary form when
it is linked against OpenSSL.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#include "rec_channel.hh"
#include <iostream>
#include "pdnsexception.hh"
#include "arguments.hh"
#include "namespaces.hh"
ArgvMap &arg()
{
static ArgvMap arg;
return arg;
}
static void initArguments(int argc, char** argv)
{
arg().set("config-dir","Location of configuration directory (recursor.conf)")=SYSCONFDIR;
arg().set("socket-dir",string("Where the controlsocket will live, ")+LOCALSTATEDIR+" when unset and not chrooted" )="";
arg().set("chroot","switch to chroot jail")="";
arg().set("process","When controlling multiple recursors, the target process number")="";
arg().set("timeout", "Number of seconds to wait for the recursor to respond")="5";
arg().set("config-name","Name of this virtual configuration - will rename the binary image")="";
arg().setCmd("help","Provide this helpful message");
arg().setCmd("version","Show the version of this program");
arg().laxParse(argc,argv);
if(arg().mustDo("help") || arg().getCommands().empty()) {
cout<<"syntax: rec_control [options] command, options as below: "<<endl<<endl;
cout<<arg().helpstring(arg()["help"])<<endl;
cout<<"In addition, 'rec_control help' can be used to retrieve a list\nof available commands from PowerDNS"<<endl;
exit(arg().mustDo("help") ? 0 : 99);
}
if(arg().mustDo("version")) {
cout<<"rec_control version "<<VERSION<<endl;
exit(0);
}
string configname=::arg()["config-dir"]+"/recursor.conf";
if (::arg()["config-name"] != "")
configname=::arg()["config-dir"]+"/recursor-"+::arg()["config-name"]+".conf";
cleanSlashes(configname);
if(!::arg().preParseFile(configname.c_str(), "socket-dir", ""))
cerr<<"Warning: unable to parse configuration file '"<<configname<<"'"<<endl;
if(!::arg().preParseFile(configname.c_str(), "chroot", ""))
cerr<<"Warning: unable to parse configuration file '"<<configname<<"'"<<endl;
arg().laxParse(argc,argv); // make sure the commandline wins
if (::arg()["socket-dir"].empty()) {
if (::arg()["chroot"].empty())
::arg().set("socket-dir") = LOCALSTATEDIR;
else
::arg().set("socket-dir") = ::arg()["chroot"] + "/";
} else if (!::arg()["chroot"].empty()) {
::arg().set("socket-dir") = ::arg()["chroot"] + "/" + ::arg()["socket-dir"];
}
}
int main(int argc, char** argv)
try
{
initArguments(argc, argv);
RecursorControlChannel rccS;
string sockname="pdns_recursor";
if (arg()["config-name"] != "")
sockname+="-"+arg()["config-name"];
if(!arg()["process"].empty())
sockname+="."+arg()["process"];
sockname.append(".controlsocket");
rccS.connect(arg()["socket-dir"], sockname);
const vector<string>&commands=arg().getCommands();
string command;
for(unsigned int i=0; i< commands.size(); ++i) {
if(i>0)
command+=" ";
command+=commands[i];
}
rccS.send(command);
string receive=rccS.recv(0, arg().asNum("timeout"));
if(receive.compare(0, 7, "Unknown") == 0) {
cerr<<receive<<endl;
return 1;
}
cout<<receive;
return 0;
}
catch(PDNSException& ae)
{
cerr<<"Fatal: "<<ae.reason<<"\n";
return 1;
}
|