]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_noinvite.cpp
Commit patch from danieldg that makes a ton of stuff const-safe for latest warn-happy...
[user/henk/code/inspircd.git] / src / modules / m_noinvite.cpp
index 42de38b547343be5c405bc30d2a0194ee4a77051..cff191db061eb5b4b4c6dce90641ab5418ddff06 100644 (file)
-/*   +------------------------------------+
- *   | Inspire Internet Relay Chat Daemon |
- *   +------------------------------------+
+/*       +------------------------------------+
+ *       | Inspire Internet Relay Chat Daemon |
+ *       +------------------------------------+
+ *
+ *  InspIRCd: (C) 2002-2008 InspIRCd Development Team
+ * See: http://www.inspircd.org/wiki/index.php/Credits
  *
- *  Inspire is copyright (C) 2002-2004 ChatSpike-Dev.
- *                   E-mail:
- *            <brain@chatspike.net>
- *            <Craig@chatspike.net>
- * 
- * Written by Craig Edwards, Craig McLure, and others.
  * This program is free but copyrighted software; see
- * the file COPYING for details.
+ *            the file COPYING for details.
  *
  * ---------------------------------------------------
  */
 
-using namespace std;
-
-#include <stdio.h>
-#include "users.h"
-#include "channels.h"
-#include "modules.h"
-#include "helperfuncs.h"
+#include "inspircd.h"
 
 /* $ModDesc: Provides support for unreal-style channel mode +V */
 
-class ModuleNoInvite : public Module
+class NoInvite : public ModeHandler
 {
-       Server *Srv;
-       
-       public:
-               ModuleNoInvite(Server* Me)
-                       : Module::Module(Me)
-               {
-                       Srv = Me;
-                       Srv->AddExtendedMode('V',MT_CHANNEL,false,0,0);
-               }
+ public:
+       NoInvite(InspIRCd* Instance) : ModeHandler(Instance, 'V', 0, 0, false, MODETYPE_CHANNEL, false) { }
 
-               void Implements(char* List)
+       ModeAction OnModeChange(User* source, User* dest, Channel* channel, std::string &parameter, bool adding)
+       {
+               if (adding)
                {
-                       List[I_On005Numeric] = List[I_OnUserPreInvite] = List[I_OnExtendedMode] = 1;
-               }
-
-               virtual void On005Numeric(std::string &output)
-               {
-                       std::stringstream line(output);
-                       std::string temp1, temp2;
-
-                       while (!line.eof())
+                       if (!channel->IsModeSet('V'))
                        {
-                               line >> temp1;
-                               if (temp1.substr(0,10) == "CHANMODES=")
-                               {
-                                       // append the chanmode to the end
-                                       temp1 = temp1.substr(10,temp1.length());
-                                       temp1 = "CHANMODES=" + temp1 + "V";
-                               }
-                               temp2 = temp2 + temp1 + " ";
+                               channel->SetMode('V',true);
+                               return MODEACTION_ALLOW;
                        }
-                       if (temp2.length())
-                               output = temp2.substr(0,temp2.length()-1);
                }
-
-
-               virtual int OnUserPreInvite(userrec* user,userrec* dest,chanrec* channel)
+               else
                {
-                       if (channel->IsCustomModeSet('V'))
+                       if (channel->IsModeSet('V'))
                        {
-                               WriteServ(user->fd,"492 %s %s :Can't invite %s to channel (+V set)",user->nick, channel->name, dest->nick);
-                               return 1;
-                       }
-                       return 0;
-               }
-       
-               virtual int OnExtendedMode(userrec* user, void* target, char modechar, int type, bool mode_on, string_list &params)
-               {
-                       // check if this is our mode character...
-                       if ((modechar == 'V') && (type == MT_CHANNEL))
-                       {
-                               return 1;
-                       }
-                       else
-                       {
-                               return 0;
+                               channel->SetMode('V',false);
+                               return MODEACTION_ALLOW;
                        }
                }
 
-               virtual ~ModuleNoInvite()
-               {
-               }
-       
-               virtual Version GetVersion()
-               {
-                       return Version(1,0,0,0,VF_STATIC|VF_VENDOR);
-               }
+               return MODEACTION_DENY;
+       }
 };
 
-
-class ModuleNoInviteFactory : public ModuleFactory
+class ModuleNoInvite : public Module
 {
-       public:
-               ModuleNoInviteFactory()
-               {
-               }
-       
-               ~ModuleNoInviteFactory()
-               {
-               }
-       
-               virtual Module * CreateModule(Server* Me)
+       NoInvite *ni;
+ public:
+
+       ModuleNoInvite(InspIRCd* Me) : Module(Me)
+       {
+               ni = new NoInvite(ServerInstance);
+               if (!ServerInstance->Modes->AddMode(ni))
+                       throw ModuleException("Could not add new modes!");
+               Implementation eventlist[] = { I_OnUserPreInvite };
+               ServerInstance->Modules->Attach(eventlist, this, 1);
+       }
+
+
+       virtual int OnUserPreInvite(User* user,User* dest,Channel* channel, time_t timeout)
+       {
+               if (channel->IsModeSet('V'))
                {
-                       return new ModuleNoInvite(Me);
+                       user->WriteServ("492 %s %s :Can't invite %s to channel (+V set)",user->nick, channel->name, dest->nick);
+                       return 1;
                }
+               return 0;
+       }
+
+       virtual ~ModuleNoInvite()
+       {
+               ServerInstance->Modes->DelMode(ni);
+               delete ni;
+       }
        
+       virtual Version GetVersion()
+       {
+               return Version(1,1,0,0,VF_COMMON|VF_VENDOR,API_VERSION);
+       }
 };
 
-
-extern "C" void * init_module( void )
-{
-       return new ModuleNoInviteFactory;
-}
-
+MODULE_INIT(ModuleNoInvite)