From ca5af9f34d3bce42335e70572a763094064cfd4b Mon Sep 17 00:00:00 2001 From: typobox43 Date: Sat, 17 Jul 2004 23:02:09 +0000 Subject: Initial commit git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@844 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/modules/m_operjoin.cpp | 76 +++++++++++++++++++++++++++++ src/modules/m_opermotd.cpp | 118 +++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 194 insertions(+) create mode 100644 src/modules/m_operjoin.cpp create mode 100644 src/modules/m_opermotd.cpp diff --git a/src/modules/m_operjoin.cpp b/src/modules/m_operjoin.cpp new file mode 100644 index 000000000..587793acb --- /dev/null +++ b/src/modules/m_operjoin.cpp @@ -0,0 +1,76 @@ +// operjoin module by typobox43 + +#include "users.h" +#include "channels.h" +#include "modules.h" + +/* $ModDesc: Forces opers to join a specified channel on oper-up */ + +Server *Srv; + +class ModuleOperjoin : public Module { + + private: + + std::string operChan; + ConfigReader* conf; + + public: + + ModuleOperjoin() { + + Srv = new Server; + conf = new ConfigReader; + + operChan = conf->ReadValue("operjoin", "channel", 0); + + } + + virtual ~ModuleOperjoin() { + + delete Srv; + delete conf; + + } + + virtual Version GetVersion() { + + return Version(1,0,0,1); + + } + + virtual void OnOper(userrec* user) { + + if(operChan != "") { + + Srv->JoinUserToChannel(user,operChan,""); + + } + + } + +}; + +class ModuleOperjoinFactory : public ModuleFactory +{ + public: + ModuleOperjoinFactory() + { + } + + ~ModuleOperjoinFactory() + { + } + + virtual Module * CreateModule() + { + return new ModuleOperjoin; + } + +}; + +extern "C" void * init_module( void ) +{ + return new ModuleOperjoinFactory; +} + diff --git a/src/modules/m_opermotd.cpp b/src/modules/m_opermotd.cpp new file mode 100644 index 000000000..ef2ad89e7 --- /dev/null +++ b/src/modules/m_opermotd.cpp @@ -0,0 +1,118 @@ +// opermotd module by typobox43 + +#include +#include "users.h" +#include "channels.h" +#include "modules.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() { + + ConfigReader* conf = new ConfigReader; + std::string filename; + + filename = conf->ReadValue("opermotd","file",0); + + opermotd->LoadFile(filename); + +} + +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++) { + + 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 ModuleOpermotd : public Module { + + public: + + ModuleOpermotd() { + + Srv = new Server; + + Srv->AddCommand("OPERMOTD",do_opermotd,'o',0); + + opermotd = new FileReader(); + LoadOperMOTD(); + + } + + virtual ~ModuleOpermotd() { + + delete Srv; + + } + + virtual Version GetVersion() { + + return Version(1,0,0,1); + + } + + virtual void OnOper(userrec* user) { + + ShowOperMOTD(user); + + } + + virtual void OnRehash() { + + LoadOperMOTD(); + + } + +}; + +class ModuleOpermotdFactory : public ModuleFactory { + + public: + + ModuleOpermotdFactory() { + + } + + ~ModuleOpermotdFactory() { + + } + + virtual Module* CreateModule() { + + return new ModuleOpermotd; + + } + +}; + +extern "C" void* init_module(void) { + + return new ModuleOpermotdFactory; + +} -- cgit v1.2.3