-// operjoin module by typobox43
-
+/* +------------------------------------+
+ * | Inspire Internet Relay Chat Daemon |
+ * +------------------------------------+
+ *
+ * InspIRCd: (C) 2002-2007 InspIRCd Development Team
+ * See: http://www.inspircd.org/wiki/index.php/Credits
+ *
+ * This program is free but copyrighted software; see
+ * the file COPYING for details.
+ *
+ * ---------------------------------------------------
+ */
+
+#include "inspircd.h"
#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 {
+/* $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)
+ {
+ // skip delimiters at beginning.
+ string::size_type lastPos = str.find_first_not_of(",", 0);
+ // find first "non-delimiter".
+ string::size_type pos = str.find_first_of(",", lastPos);
+
+ while (string::npos != pos || string::npos != lastPos)
+ {
+ // found a token, add it to the vector.
+ tokens.push_back(str.substr(lastPos, pos - lastPos));
+ // skip delimiters. Note the "not_of"
+ lastPos = str.find_first_not_of(",", pos);
+ // find next "non-delimiter"
+ pos = str.find_first_of(",", lastPos);
+ }
+ return tokens.size();
+ }
public:
+ ModuleOperjoin(InspIRCd* Me) : Module(Me)
+ {
+ OnRehash(NULL, "");
+ }
- ModuleOperjoin() {
+ void Implements(char* List)
+ {
+ List[I_OnPostOper] = List[I_OnRehash] = 1;
+ }
- Srv = new Server;
- conf = new ConfigReader;
+ 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);
}
- virtual ~ModuleOperjoin() {
-
- delete Srv;
- delete conf;
-
+ virtual ~ModuleOperjoin()
+ {
}
- virtual Version GetVersion() {
-
- return Version(1,0,0,1);
-
+ virtual Version GetVersion()
+ {
+ return Version(1,1,0,1,VF_VENDOR,API_VERSION);
}
- virtual void OnOper(userrec* user) {
-
- if(operChan != "") {
-
- Srv->JoinUserToChannel(user,operChan,"");
-
- }
+ virtual void OnPostOper(userrec* user, const std::string &opertype)
+ {
+ 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()
- {
- }
+ public:
+ ModuleOperjoinFactory()
+ {
+ }
- virtual Module * CreateModule()
- {
- return new ModuleOperjoin;
- }
+ ~ModuleOperjoinFactory()
+ {
+ }
+ virtual Module * CreateModule(InspIRCd* Me)
+ {
+ return new ModuleOperjoin(Me);
+ }
};
-extern "C" void * init_module( void )
+extern "C" DllExport void * init_module( void )
{
- return new ModuleOperjoinFactory;
+ return new ModuleOperjoinFactory;
}
-