]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_chanprotect.cpp
Fix these too!
[user/henk/code/inspircd.git] / src / modules / m_chanprotect.cpp
index c3acc40858251c08a742e2d1bbabc989a2fab18b..060f81eb9add0d68962ff38b67383d78456ca091 100644 (file)
@@ -278,6 +278,7 @@ class ModuleChanProtect : public Module
        
        bool FirstInGetsFounder;
        bool QAPrefixes;
+       bool booting;
        ChanProtect* cp;
        ChanFounder* cf;
        char* dummyptr;
@@ -287,7 +288,9 @@ class ModuleChanProtect : public Module
        ModuleChanProtect(InspIRCd* Me) : Module::Module(Me)
        {       
                /* Load config stuff */
+               booting = true;
                OnRehash("");
+               booting = false;
 
                /* Initialise module variables */
 
@@ -325,9 +328,28 @@ class ModuleChanProtect : public Module
                 * stack-allocate it locally.
                 */
                ConfigReader Conf(ServerInstance);
+
+               bool old_qa = QAPrefixes;
                
                FirstInGetsFounder = Conf.ReadFlag("options","noservices",0);
                QAPrefixes = Conf.ReadFlag("options","qaprefixes",0);
+
+               /* Did the user change the QA prefixes on the fly?
+                * If so, remove all instances of the mode, and reinit
+                * the module with prefixes enabled.
+                */
+               if ((old_qa != QAPrefixes) && (!booting))
+               {
+                       ServerInstance->Modes->DelMode(cp);
+                       ServerInstance->Modes->DelMode(cf);
+                       DELETE(cp);
+                       DELETE(cf);
+                       cp = new ChanProtect(ServerInstance,QAPrefixes);
+                       cf = new ChanFounder(ServerInstance,QAPrefixes);
+                       ServerInstance->AddMode(cp, 'a');
+                       ServerInstance->AddMode(cf, 'q');
+                       ServerInstance->WriteOpers("*** WARNING: +qa prefixes were enabled or disabled via a REHASH. Clients will probably need to reconnect to pick up this change.");
+               }
        }
        
        virtual void OnUserJoin(userrec* user, chanrec* channel)