X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_sanick.cpp;h=6c07d08cec55140a43826fb04f23ab08c29beeac;hb=c4458ecc70025aeac7ca87115ed0a698e7bbcdad;hp=a95caa02849e9b910024761a94c09f9623e129d1;hpb=2aa149d631b11208f2cfea7b9475edf76044e1ca;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_sanick.cpp b/src/modules/m_sanick.cpp index a95caa028..6c07d08ce 100644 --- a/src/modules/m_sanick.cpp +++ b/src/modules/m_sanick.cpp @@ -1,4 +1,20 @@ -// Sanick and +g support module by C.J.Edwards +/* +------------------------------------+ + * | Inspire Internet Relay Chat Daemon | + * +------------------------------------+ + * + * InspIRCd is copyright (C) 2002-2006 ChatSpike-Dev. + * E-mail: + * + * + * + * 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 #include @@ -8,39 +24,57 @@ /* $ModDesc: Provides support for SANICK command */ -Server *Srv; - -void handle_sanick(char **parameters, int pcnt, userrec *user) +static Server *Srv; + +class cmd_sanick : public command_t { - userrec* source = Srv->FindNick(std::string(parameters[0])); - if (source) + public: + cmd_sanick () : command_t("SANICK", 'o', 2) + { + this->source = "m_sanick.so"; + } + + void Handle (const char** parameters, int pcnt, userrec *user) { - if (Srv->IsNick(std::string(parameters[1]))) + userrec* source = Srv->FindNick(std::string(parameters[0])); + if (source) { - Srv->SendOpers(std::string(user->nick)+" used SANICK to change "+std::string(source->nick)+" to "+parameters[1]); - Srv->ChangeUserNick(source,std::string(parameters[1])); + if (Srv->IsUlined(source->server)) + { + WriteServ(user->fd,"990 %s :Cannot use an SA command on a u-lined client",user->nick); + return; + } + if (Srv->IsNick(std::string(parameters[1]))) + { + // FIX by brain: Cant use source->nick here because if it traverses a server link then + // source->nick becomes invalid as the object data moves in memory. + Srv->SendOpers(std::string(user->nick)+" used SANICK to change "+std::string(parameters[0])+" to "+parameters[1]); + Srv->ChangeUserNick(source,std::string(parameters[1])); + } } } -} +}; class ModuleSanick : public Module { + cmd_sanick* mycommand; public: - ModuleSanick() + ModuleSanick(Server* Me) + : Module::Module(Me) { - Srv = new Server; - Srv->AddCommand("SANICK",handle_sanick,'o',2); + Srv = Me; + mycommand = new cmd_sanick(); + Srv->AddCommand(mycommand); } virtual ~ModuleSanick() { - delete Srv; } virtual Version GetVersion() { - return Version(1,0,0,1); + return Version(1,0,0,1,VF_VENDOR); } }; @@ -58,9 +92,9 @@ class ModuleSanickFactory : public ModuleFactory { } - virtual Module * CreateModule() + virtual Module * CreateModule(Server* Me) { - return new ModuleSanick; + return new ModuleSanick(Me); } };