diff options
author | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2006-01-19 19:10:18 +0000 |
---|---|---|
committer | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2006-01-19 19:10:18 +0000 |
commit | 265ff48624afc2a008d1f688ca1f50ea898cfa98 (patch) | |
tree | 5b170c4fabc8bc93bc3b9eccc6fccbabbd20be60 /src/modules | |
parent | 9a7b1fb30d71936f057c0c0ee0fa5e711042311e (diff) |
Added <allowchannel:name> to allow specific channels
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@2822 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src/modules')
-rw-r--r-- | src/modules/m_restrictchans.cpp | 31 |
1 files changed, 28 insertions, 3 deletions
diff --git a/src/modules/m_restrictchans.cpp b/src/modules/m_restrictchans.cpp index 54113aead..0ca0dd921 100644 --- a/src/modules/m_restrictchans.cpp +++ b/src/modules/m_restrictchans.cpp @@ -17,6 +17,7 @@ using namespace std; #include <stdio.h> +#include <map> #include "users.h" #include "channels.h" #include "modules.h" @@ -28,22 +29,46 @@ Server *Srv; class ModuleRestrictChans : public Module { + + std::map<irc::string,int> allowchans; + + void ReadConfig() + { + ConfigReader* MyConf = new ConfigReader(); + allowchans.clear(); + for (int i = 0; i < MyConf->Enumerate("allowchannel"); i++) + { + std::string txt; + txt = MyConf->ReadValue("allowchannel", "name", i); + irc::string channel = txt.c_str(); + allowchans[channel] = 1; + } + delete MyConf; + } + public: ModuleRestrictChans(Server* Me) : Module::Module(Me) { Srv = Me; + ReadConfig(); + } + + virtual void OnRehash(std::string parameter) + { + ReadConfig(); } void Implements(char* List) { - List[I_OnUserPreJoin] = 1; + List[I_OnUserPreJoin] = List[I_OnRehash] = 1; } virtual int OnUserPreJoin(userrec* user, chanrec* chan, const char* cname) { - // user is not an oper - if (!strchr(user->modes,'o')) + irc::string x = cname; + // user is not an oper and its not in the allow list + if ((!strchr(user->modes,'o')) && (allowchans.find(x) == allowchans.end())) { // channel does not yet exist (record is null, about to be created IF we were to allow it) if (!chan) |