X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_opermotd.cpp;h=b4a85e8890270efb39e65c5411361a708c200b74;hb=1484a054870bdfe94346057053d5c8e48a708232;hp=06b994c915927a8d97b86d975460a6d01b0dcd6f;hpb=211b24ba8cf6e21f435f145b0366adc8a3b62460;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_opermotd.cpp b/src/modules/m_opermotd.cpp index 06b994c91..b4a85e889 100644 --- a/src/modules/m_opermotd.cpp +++ b/src/modules/m_opermotd.cpp @@ -1,118 +1,121 @@ // opermotd module by typobox43 +using namespace std; + #include #include "users.h" #include "channels.h" #include "modules.h" +#include "helperfuncs.h" /* $ModDesc: Shows a message to opers after oper-up, adds /opermotd */ -FileReader* opermotd; -Server* Srv; - -void do_opermotd(char** parameters, int pcnt, userrec* user); - -void LoadOperMOTD() { +static FileReader* opermotd; +static Server* Srv; +void LoadOperMOTD() +{ ConfigReader* conf = new ConfigReader; std::string filename; filename = conf->ReadValue("opermotd","file",0); opermotd->LoadFile(filename); - + DELETE(conf); } -void ShowOperMOTD(userrec* user) { - - if(!opermotd->FileSize()) { - +void ShowOperMOTD(userrec* user) +{ + if(!opermotd->FileSize()) + { Srv->SendServ(user->fd,std::string("425 ") + user->nick + std::string(" :OPERMOTD file is missing")); return; - } Srv->SendServ(user->fd,std::string("375 ") + user->nick + std::string(" :- IRC Operators Message of the Day")); - for(int i=0; i != opermotd->FileSize(); i++) { - + for(int i=0; i != opermotd->FileSize(); i++) + { Srv->SendServ(user->fd,std::string("372 ") + user->nick + std::string(" :- ") + opermotd->GetLine(i)); - } Srv->SendServ(user->fd,std::string("376 ") + user->nick + std::string(" :- End of OPERMOTD")); } -void do_opermotd(char** parameters, int pcnt, userrec* user) { - - ShowOperMOTD(user); - -} +class cmd_opermotd : public command_t +{ + public: + cmd_opermotd () : command_t("OPERMOTD", 'o', 0) + { + this->source = "m_opermotd.so"; + } -class ModuleOpermotd : public Module { + void Handle (const char** parameters, int pcnt, userrec* user) + { + ShowOperMOTD(user); + } +}; +class ModuleOpermotd : public Module +{ + cmd_opermotd* mycommand; public: - - ModuleOpermotd() { - - Srv = new Server; - - Srv->AddCommand("OPERMOTD",do_opermotd,'o',0,"m_opermotd.so"); - + ModuleOpermotd(Server* Me) + : Module::Module(Me) + { + Srv = Me; + mycommand = new cmd_opermotd(); + Srv->AddCommand(mycommand); opermotd = new FileReader(); LoadOperMOTD(); - } - virtual ~ModuleOpermotd() { - - delete Srv; - + virtual ~ModuleOpermotd() + { } - virtual Version GetVersion() { - - return Version(1,0,0,1); - + virtual Version GetVersion() + { + return Version(1,0,0,1,VF_VENDOR); } - virtual void OnOper(userrec* user) { + void Implements(char* List) + { + List[I_OnRehash] = List[I_OnOper] = 1; + } + virtual void OnOper(userrec* user, const std::string &opertype) + { ShowOperMOTD(user); - } - virtual void OnRehash() { - + virtual void OnRehash(const std::string ¶meter) + { LoadOperMOTD(); - } }; -class ModuleOpermotdFactory : public ModuleFactory { - +class ModuleOpermotdFactory : public ModuleFactory +{ public: - - ModuleOpermotdFactory() { - + ModuleOpermotdFactory() + { } - ~ModuleOpermotdFactory() { - + ~ModuleOpermotdFactory() + { } - virtual Module* CreateModule() { - - return new ModuleOpermotd; - + virtual Module* CreateModule(Server* Me) + { + return new ModuleOpermotd(Me); } }; -extern "C" void* init_module(void) { - +extern "C" void* init_module(void) +{ return new ModuleOpermotdFactory; - }