]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_chanfilter.cpp
Argh, i give up
[user/henk/code/inspircd.git] / src / modules / m_chanfilter.cpp
index 901494b9578f0ff94e7b5c4718f7b3a8623b5dfa..53a0ff0334ba5a9232d5888d3d5e3cd87419694b 100644 (file)
  * ---------------------------------------------------
  */
 
+#define _CRT_SECURE_NO_DEPRECATE
+#define _SCL_SECURE_NO_DEPRECATE
+
 #include "inspircd.h"
-#include "users.h"
-#include "channels.h"
-#include "modules.h"
-#include "hashcomp.h"
 #include "u_listmode.h"
 
 /* $ModDesc: Provides channel-specific censor lists (like mode +G but varies from channel to channel) */
@@ -28,7 +27,7 @@ class ChanFilter : public ListModeBase
  public:
        ChanFilter(InspIRCd* Instance) : ListModeBase(Instance, 'g', "End of channel spamfilter list", "941", "940", false, "chanfilter") { }
        
-       virtual bool ValidateParam(userrec* user, chanrec* chan, std::string &word)
+       virtual bool ValidateParam(User* user, Channel* chan, std::string &word)
        {
                if ((word.length() > 35) || (word.empty()))
                {
@@ -39,18 +38,18 @@ class ChanFilter : public ListModeBase
                return true;
        }
        
-       virtual bool TellListTooLong(userrec* user, chanrec* chan, std::string &word)
+       virtual bool TellListTooLong(User* user, Channel* chan, std::string &word)
        {
                user->WriteServ("939 %s %s %s :Channel spamfilter list is full",user->nick, chan->name, word.c_str());
                return true;
        }
        
-       virtual void TellAlreadyOnList(userrec* user, chanrec* chan, std::string &word)
+       virtual void TellAlreadyOnList(User* user, Channel* chan, std::string &word)
        {
                user->WriteServ("937 %s %s :The word %s is already on the spamfilter list",user->nick, chan->name,word.c_str());
        }
        
-       virtual void TellNotSet(userrec* user, chanrec* chan, std::string &word)
+       virtual void TellNotSet(User* user, Channel* chan, std::string &word)
        {
                user->WriteServ("938 %s %s :No such spamfilter word is set",user->nick, chan->name);
        }
@@ -67,27 +66,25 @@ class ModuleChanFilter : public Module
                : Module(Me)
        {
                cf = new ChanFilter(ServerInstance);
-               if (!ServerInstance->AddMode(cf, 'g'))
+               if (!ServerInstance->AddMode(cf))
                        throw ModuleException("Could not add new modes!");
-       }
 
-       void Implements(char* List) 
-       { 
-               cf->DoImplements(List);
-               List[I_OnCleanup] = List[I_OnChannelDelete] = List[I_OnRehash] = List[I_OnUserPreMessage] = List[I_OnUserPreNotice] = List[I_OnSyncChannel] = 1;
+               cf->DoImplements(this);
+               Implementation eventlist[] = { I_OnCleanup, I_OnChannelDelete, I_OnRehash, I_OnUserPreMessage, I_OnUserPreNotice, I_OnSyncChannel };
+               ServerInstance->Modules->Attach(eventlist, this, 6);
        }
 
-       virtual void OnChannelDelete(chanrec* chan)
+       virtual void OnChannelDelete(Channel* chan)
        {
                cf->DoChannelDelete(chan);
        }
 
-       virtual void OnRehash(userrec* user, const std::string &parameter)
+       virtual void OnRehash(User* user, const std::string &parameter)
        {
                cf->DoRehash();
        }
 
-       virtual int ProcessMessages(userrec* user,chanrec* chan,std::string &text)
+       virtual int ProcessMessages(User* user,Channel* chan,std::string &text)
        {
                if (!IS_LOCAL(user) || CHANOPS_EXEMPT(ServerInstance, 'g') && chan->GetStatus(user) == STATUS_OP)
                        return 0;
@@ -113,11 +110,11 @@ class ModuleChanFilter : public Module
                return 0;
        }
 
-       virtual int OnUserPreMessage(userrec* user,void* dest,int target_type, std::string &text, char status, CUList &exempt_list)
+       virtual int OnUserPreMessage(User* user,void* dest,int target_type, std::string &text, char status, CUList &exempt_list)
        {
                if (target_type == TYPE_CHANNEL)
                {
-                       return ProcessMessages(user,(chanrec*)dest,text);
+                       return ProcessMessages(user,(Channel*)dest,text);
                }
                else return 0;
        }
@@ -127,12 +124,12 @@ class ModuleChanFilter : public Module
                cf->DoCleanup(target_type, item);
        }
        
-       virtual int OnUserPreNotice(userrec* user,void* dest,int target_type, std::string &text, char status, CUList &exempt_list)
+       virtual int OnUserPreNotice(User* user,void* dest,int target_type, std::string &text, char status, CUList &exempt_list)
        {
                return OnUserPreMessage(user,dest,target_type,text,status,exempt_list);
        }
        
-       virtual void OnSyncChannel(chanrec* chan, Module* proto, void* opaque)
+       virtual void OnSyncChannel(Channel* chan, Module* proto, void* opaque)
        {
                cf->DoSyncChannel(chan, proto, opaque);
        }
@@ -145,31 +142,8 @@ class ModuleChanFilter : public Module
        virtual ~ModuleChanFilter()
        {
                ServerInstance->Modes->DelMode(cf);
-               DELETE(cf);
-       }
-};
-
-
-class ModuleChanFilterFactory : public ModuleFactory
-{
- public:
-       ModuleChanFilterFactory()
-       {
+               delete cf;
        }
-       
-       ~ModuleChanFilterFactory()
-       {
-       }
-       
-       virtual Module * CreateModule(InspIRCd* Me)
-       {
-               return new ModuleChanFilter(Me);
-       }
-       
 };
 
-
-extern "C" DllExport void * init_module( void )
-{
-       return new ModuleChanFilterFactory;
-}
+MODULE_INIT(ModuleChanFilter)