]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_blockcaps.cpp
Update $ModDep lines so that these properly depend on their headers in the makefile
[user/henk/code/inspircd.git] / src / modules / m_blockcaps.cpp
index 8e5685398ef9d91d1822b8e96d85a050ce7319a1..830b05ae96ace029d2982c81038e20eaad637706 100644 (file)
 #include "users.h"
 #include "channels.h"
 #include "modules.h"
-#include "helperfuncs.h"
+#include "inspircd.h"
+#include "mode.h"
 
 /* $ModDesc: Provides support for channel mode +P to block all-CAPS channel messages and notices */
 
+
+/** Handles the +P channel mode
+ */
 class BlockCaps : public ModeHandler
 {
-       BlockCaps() : ModeHandler('P', 0, 0, false, MODETYPE_CHANNEL, false) { }
+ public:
+       BlockCaps(InspIRCd* Instance) : ModeHandler(Instance, 'P', 0, 0, false, MODETYPE_CHANNEL, false) { }
 
        ModeAction OnModeChange(userrec* source, userrec* dest, chanrec* channel, std::string &parameter, bool adding)
        {
@@ -32,7 +37,7 @@ class BlockCaps : public ModeHandler
                {
                        if (!channel->IsModeSet('P'))
                        {
-                               channel->SetCustomMode('P',true);
+                               channel->SetMode('P',true);
                                return MODEACTION_ALLOW;
                        }
                }
@@ -40,7 +45,7 @@ class BlockCaps : public ModeHandler
                {
                        if (channel->IsModeSet('P'))
                        {
-                               channel->SetCustomMode('P',false);
+                               channel->SetMode('P',false);
                                return MODEACTION_ALLOW;
                        }
                }
@@ -51,28 +56,23 @@ class BlockCaps : public ModeHandler
 
 class ModuleBlockCAPS : public Module
 {
-       Server *Srv;
+       
        BlockCaps* bc;
 public:
        
-       ModuleBlockCAPS(Server* Me) : Module::Module(Me)
+       ModuleBlockCAPS(InspIRCd* Me) : Module::Module(Me)
        {
-               Srv = Me;
-               bc = new BlockCaps;
-               Srv->AddMode(bc, 'P');
+               
+               bc = new BlockCaps(ServerInstance);
+               ServerInstance->AddMode(bc, 'P');
        }
 
        void Implements(char* List)
        {
-               List[I_On005Numeric] = List[I_OnUserPreMessage] = List[I_OnUserPreNotice] = 1;
-       }
-
-       virtual void On005Numeric(std::string &output)
-       {
-               InsertMode(output, "P", 4);
+               List[I_OnUserPreMessage] = List[I_OnUserPreNotice] = 1;
        }
 
-       virtual int OnUserPreMessage(userrec* user,void* dest,int target_type, std::string &text, char status)
+       virtual int OnUserPreMessage(userrec* user,void* dest,int target_type, std::string &text, char status, CUList &exempt_list)
        {
                if (target_type == TYPE_CHANNEL)
                {
@@ -89,25 +89,27 @@ public:
                                        }
                                }
                                
-                               WriteServ(user->fd, "404 %s %s :Can't send all-CAPS to channel (+P set)", user->nick, c->name);
+                               user->WriteServ( "404 %s %s :Can't send all-CAPS to channel (+P set)", user->nick, c->name);
                                return 1;
                        }
                }
                return 0;
        }
-       
-       virtual int OnUserPreNotice(userrec* user,void* dest,int target_type, std::string &text, char status)
+
+       virtual int OnUserPreNotice(userrec* user,void* dest,int target_type, std::string &text, char status, CUList &exempt_list)
        {
-               return OnUserPreMessage(user,dest,target_type,text,status);
+               return OnUserPreMessage(user,dest,target_type,text,status,exempt_list);
        }
-       
+
        virtual ~ModuleBlockCAPS()
        {
+               ServerInstance->Modes->DelMode(bc);
+               DELETE(bc);
        }
-       
+
        virtual Version GetVersion()
        {
-               return Version(1,0,0,0,VF_STATIC|VF_VENDOR);
+               return Version(1,1,0,0,VF_COMMON|VF_VENDOR,API_VERSION);
        }
 };
 
@@ -123,7 +125,7 @@ class ModuleBlockCAPSFactory : public ModuleFactory
        {
        }
        
-       virtual Module * CreateModule(Server* Me)
+       virtual Module * CreateModule(InspIRCd* Me)
        {
                return new ModuleBlockCAPS(Me);
        }