]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_restrictchans.cpp
Annotations
[user/henk/code/inspircd.git] / src / modules / m_restrictchans.cpp
index 54113aead53194fcb3d13f73c28c8fdc56c7f04f..1b7d4104a50bcbacf1c19cd1f870f543f948885a 100644 (file)
 using namespace std;
 
 #include <stdio.h>
+#include <map>
 #include "users.h"
 #include "channels.h"
 #include "modules.h"
-#include "helperfuncs.h"
+
+#include "inspircd.h"
 
 /* $ModDesc: Only opers may create new channels if this module is loaded */
 
-Server *Srv;
-        
 class ModuleRestrictChans : public Module
 {
+       
+
+       std::map<irc::string,int> allowchans;
+
+       void ReadConfig()
+       {
+               ConfigReader* MyConf = new ConfigReader(ServerInstance);
+               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)
+       ModuleRestrictChans(InspIRCd* Me)
                : Module::Module(Me)
        {
-               Srv = Me;
+               
+               ReadConfig();
+       }
+
+       virtual void OnRehash(const 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 ((!*user->oper) && (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)
                        {
-                               WriteServ(user->fd,"530 %s %s :Only IRC operators may create new channels",user->nick,cname,cname);
+                               user->WriteServ("530 %s %s :Only IRC operators may create new channels",user->nick,cname,cname);
                                return 1;
                        }
                }
@@ -77,7 +102,7 @@ class ModuleRestrictChansFactory : public ModuleFactory
        {
        }
        
-       virtual Module * CreateModule(Server* Me)
+       virtual Module * CreateModule(InspIRCd* Me)
        {
                return new ModuleRestrictChans(Me);
        }