-// operjoin module by typobox43
-
-using namespace std;
-
-#include "users.h"
-#include "channels.h"
-#include "modules.h"
-#include "helperfuncs.h"
-
-/* $ModDesc: Forces opers to join a specified channel on oper-up */
-
-Server *Srv;
-
-class ModuleOperjoin : public Module {
-
+/* +------------------------------------+
+ * | Inspire Internet Relay Chat Daemon |
+ * +------------------------------------+
+ *
+ * InspIRCd: (C) 2002-2008 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"
+
+/* $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;
+ bool override;
+
+ int tokenize(const std::string &str, std::vector<std::string> &tokens)
+ {
+ // skip delimiters at beginning.
+ std::string::size_type lastPos = str.find_first_not_of(",", 0);
+ // find first "non-delimiter".
+ std::string::size_type pos = str.find_first_of(",", lastPos);
+
+ while (std::string::npos != pos || std::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, "");
+ Implementation eventlist[] = { I_OnPostOper, I_OnRehash };
+ ServerInstance->Modules->Attach(eventlist, this, 2);
+ }
- ModuleOperjoin() {
-
- Srv = new Server;
- conf = new ConfigReader;
+ virtual void OnRehash(User* user, const std::string ¶meter)
+ {
+ ConfigReader* conf = new ConfigReader(ServerInstance);
+
operChan = conf->ReadValue("operjoin", "channel", 0);
+ override = conf->ReadFlag("operjoin", "override", "0", 0);
+ operChans.clear();
+ if (!operChan.empty())
+ tokenize(operChan,operChans);
- }
-
- virtual ~ModuleOperjoin() {
-
- delete Srv;
delete conf;
-
}
- virtual Version GetVersion() {
-
- return Version(1,0,0,1,VF_VENDOR);
-
+ virtual ~ModuleOperjoin()
+ {
}
- virtual void OnOper(userrec* user) {
-
- if(operChan != "") {
-
- Srv->JoinUserToChannel(user,operChan,"");
-
- }
-
+ virtual Version GetVersion()
+ {
+ return Version(1,2,0,1,VF_VENDOR,API_VERSION);
}
-};
-
-class ModuleOperjoinFactory : public ModuleFactory
-{
- public:
- ModuleOperjoinFactory()
- {
- }
-
- ~ModuleOperjoinFactory()
- {
- }
+ virtual void OnPostOper(User* user, const std::string &opertype, const std::string &opername)
+ {
+ if (!IS_LOCAL(user))
+ return;
- virtual Module * CreateModule()
- {
- return new ModuleOperjoin;
- }
+ for(std::vector<std::string>::iterator it = operChans.begin(); it != operChans.end(); it++)
+ if (ServerInstance->IsChannel(it->c_str()))
+ Channel::JoinUser(ServerInstance, user, it->c_str(), override, "", false, ServerInstance->Time());
+ }
};
-extern "C" void * init_module( void )
-{
- return new ModuleOperjoinFactory;
-}
-
+MODULE_INIT(ModuleOperjoin)