]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_restrictchans.cpp
Just to mess with om's head, remove helperfuncs.h from everywhere
[user/henk/code/inspircd.git] / src / modules / m_restrictchans.cpp
index 93c16a8bf0b3f0f22a27ea970d36bb1b2f66c8ed..1b7d4104a50bcbacf1c19cd1f870f543f948885a 100644 (file)
@@ -2,7 +2,7 @@
  *       | Inspire Internet Relay Chat Daemon |
  *       +------------------------------------+
  *
- *  Inspire is copyright (C) 2002-2004 ChatSpike-Dev.
+ *  InspIRCd is copyright (C) 2002-2006 ChatSpike-Dev.
  *                       E-mail:
  *                <brain@chatspike.net>
  *               <Craig@chatspike.net>
  * ---------------------------------------------------
  */
 
+using namespace std;
+
 #include <stdio.h>
+#include <map>
 #include "users.h"
 #include "channels.h"
 #include "modules.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()
+       ModuleRestrictChans(InspIRCd* Me)
+               : Module::Module(Me)
+       {
+               
+               ReadConfig();
+       }
+
+       virtual void OnRehash(const std::string &parameter)
+       {
+               ReadConfig();
+       }
+
+       void Implements(char* List)
        {
-               Srv = new Server;
+               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;
                        }
                }
@@ -48,12 +82,11 @@ class ModuleRestrictChans : public Module
        
        virtual ~ModuleRestrictChans()
        {
-               delete Srv;
        }
        
        virtual Version GetVersion()
        {
-               return Version(1,0,0,0,0);
+               return Version(1,0,0,1,VF_VENDOR);
        }
 };
 
@@ -69,9 +102,9 @@ class ModuleRestrictChansFactory : public ModuleFactory
        {
        }
        
-       virtual Module * CreateModule()
+       virtual Module * CreateModule(InspIRCd* Me)
        {
-               return new ModuleRestrictChans;
+               return new ModuleRestrictChans(Me);
        }
        
 };