]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_nonicks.cpp
Converted more stuff to 'Implements' system
[user/henk/code/inspircd.git] / src / modules / m_nonicks.cpp
index d465251525d7f5d02efca9b59509e8e2b92fc05d..c2b18b49b09b92c37a723bcda69eff610b154ad6 100644 (file)
@@ -1,47 +1,92 @@
+/*       +------------------------------------+
+ *       | Inspire Internet Relay Chat Daemon |
+ *       +------------------------------------+
+ *
+ *  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.
+ *
+ * ---------------------------------------------------
+ */
+
+using namespace std;
+
 #include <stdio.h>
 #include <string>
 #include "users.h"
 #include "channels.h"
 #include "modules.h"
+#include "helperfuncs.h"
+#include "hashcomp.h"
 
 /* $ModDesc: Provides support for unreal-style GLOBOPS and umode +g */
 
-Server *Srv;
-
 class ModuleNoNickChange : public Module
 {
+       Server *Srv;
+       
  public:
-       ModuleNoNickChange()
+       ModuleNoNickChange(Server* Me)
+               : Module::Module(Me)
        {
-               Srv = new Server;
+               Srv = Me;
                
                Srv->AddExtendedMode('N',MT_CHANNEL,false,0,0);
        }
        
        virtual ~ModuleNoNickChange()
        {
-               delete Srv;
        }
        
        virtual Version GetVersion()
        {
-               return Version(1,0,0,1);
+               return Version(1,0,0,1,VF_STATIC|VF_VENDOR);
        }
+
+        virtual void On005Numeric(std::string &output)
+        {
+                std::stringstream line(output);
+                std::string temp1, temp2;
+                while (!line.eof())
+                {
+                        line >> temp1;
+                        if (temp1.substr(0,10) == "CHANMODES=")
+                        {
+                                // append the chanmode to the end
+                                temp1 = temp1.substr(10,temp1.length());
+                                temp1 = "CHANMODES=" + temp1 + "N";
+                        }
+                        temp2 = temp2 + temp1 + " ";
+                }
+               if (temp2.length())
+                       output = temp2.substr(0,temp2.length()-1);
+        }
        
        virtual int OnUserPreNick(userrec* user, std::string newnick)
        {
-               if (!strcasecmp(user->server,Srv->GetServerName().c_str()))
+               irc::string server = user->server;
+               irc::string me = Srv->GetServerName().c_str();
+               if (server == me)
                {
-                       for (int i =0; i != MAXCHANS; i++)
+                       for (int i =0; i < user->chans.size(); i++)
                        {
                                if (user->chans[i].channel != NULL)
                                {
                                        chanrec* curr = user->chans[i].channel;
                                        if (curr->IsCustomModeSet('N'))
                                        {
-                                               // don't allow the nickchange, theyre on at least one channel with +N set
-                                               WriteServ(user->fd,"447 %s :Can't change nickname while on %s (+N is set)",user->nick,curr->name);
-                                               return 1;
+                                               if (!strchr(user->modes,'o'))
+                                               {
+                                                       // don't allow the nickchange, theyre on at least one channel with +N set
+                                                       // and theyre not an oper
+                                                       WriteServ(user->fd,"447 %s :Can't change nickname while on %s (+N is set)",user->nick,curr->name);
+                                                       return 1;
+                                               }
                                        }
                                }
                        }
@@ -77,9 +122,9 @@ class ModuleNoNickChangeFactory : public ModuleFactory
        {
        }
        
-       virtual Module * CreateModule()
+       virtual Module * CreateModule(Server* Me)
        {
-               return new ModuleNoNickChange;
+               return new ModuleNoNickChange(Me);
        }
        
 };