* ---------------------------------------------------
*/
+#include "inspircd.h"
#include "users.h"
#include "channels.h"
#include "modules.h"
-#include "inspircd.h"
-
/* $ModDesc: Forces opers to join the specified channel(s) on oper-up */
-
-
class ModuleOperjoin : public Module
{
private:
std::string operChan;
- ConfigReader* conf;
-
+ std::vector<std::string> operChans;
int tokenize(const string &str, std::vector<std::string> &tokens)
{
}
public:
- ModuleOperjoin(InspIRCd* Me)
- : Module::Module(Me)
+ ModuleOperjoin(InspIRCd* Me) : Module(Me)
{
-
- conf = new ConfigReader(ServerInstance);
- operChan = conf->ReadValue("operjoin", "channel", 0);
+ OnRehash(NULL, "");
}
void Implements(char* List)
List[I_OnPostOper] = List[I_OnRehash] = 1;
}
- virtual void OnRehash(const std::string ¶meter)
+ virtual void OnRehash(userrec* user, const std::string ¶meter)
{
+ ConfigReader* conf = new ConfigReader(ServerInstance);
+
+ operChan = conf->ReadValue("operjoin", "channel", 0);
+ operChans.clear();
+ if (!operChan.empty())
+ tokenize(operChan,operChans);
+
DELETE(conf);
- conf = new ConfigReader(ServerInstance);
}
virtual ~ModuleOperjoin()
{
- DELETE(conf);
}
virtual Version GetVersion()
virtual void OnPostOper(userrec* user, const std::string &opertype)
{
- if(operChan != "")
- {
- std::vector<std::string> operChans;
- tokenize(operChan,operChans);
- for(std::vector<std::string>::iterator it = operChans.begin(); it != operChans.end(); it++)
- chanrec::JoinUser(ServerInstance, user, it->c_str(), false);
- }
+ if (!IS_LOCAL(user))
+ return;
+ for(std::vector<std::string>::iterator it = operChans.begin(); it != operChans.end(); it++)
+ if (ServerInstance->IsChannel(it->c_str()))
+ chanrec::JoinUser(ServerInstance, user, it->c_str(), false, "", ServerInstance->Time(true));
}
};
-class ModuleOperjoinFactory : public ModuleFactory
-{
- public:
- ModuleOperjoinFactory()
- {
- }
-
- ~ModuleOperjoinFactory()
- {
- }
-
- virtual Module * CreateModule(InspIRCd* Me)
- {
- return new ModuleOperjoin(Me);
- }
-};
-
-extern "C" void * init_module( void )
-{
- return new ModuleOperjoinFactory;
-}
+MODULE_INIT(ModuleOperjoin)