X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_chgname.cpp;h=704e142bcb9f84e1d2197ee162f2ed88e1069ba8;hb=f25c4b7a2263f5f3ce9bb41ba56b43c0d3a6d124;hp=a4a31714b1bf367ee25f41b92e75d90b06f0ce1d;hpb=2b8ce39c6ea5e7a22fe39b21756f82051465f143;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_chgname.cpp b/src/modules/m_chgname.cpp index a4a31714b..704e142bc 100644 --- a/src/modules/m_chgname.cpp +++ b/src/modules/m_chgname.cpp @@ -2,8 +2,8 @@ * | Inspire Internet Relay Chat Daemon | * +------------------------------------+ * - * InspIRCd: (C) 2002-2007 InspIRCd Development Team - * See: http://www.inspircd.org/wiki/index.php/Credits + * InspIRCd: (C) 2002-2009 InspIRCd Development Team + * See: http://wiki.inspircd.org/Credits * * This program is free but copyrighted software; see * the file COPYING for details. @@ -12,49 +12,47 @@ */ #include "inspircd.h" -#include "users.h" -#include "modules.h" /* $ModDesc: Provides support for the CHGNAME command */ /** Handle /CHGNAME */ -class cmd_chgname : public command_t +class CommandChgname : public Command { public: - cmd_chgname (InspIRCd* Instance) : command_t(Instance,"CHGNAME", 'o', 2) + CommandChgname (InspIRCd* Instance) : Command(Instance,"CHGNAME", "o", 2, 2) { this->source = "m_chgname.so"; syntax = " "; + TRANSLATE3(TR_NICK, TR_TEXT, TR_END); } - - CmdResult Handle(const char** parameters, int pcnt, userrec *user) + + CmdResult Handle(const std::vector ¶meters, User *user) { - userrec* dest = ServerInstance->FindNick(parameters[0]); + User* dest = ServerInstance->FindNick(parameters[0]); if (!dest) { - user->WriteServ("401 %s %s :No such nick/channel", user->nick, parameters[0]); + user->WriteNumeric(ERR_NOSUCHNICK, "%s %s :No such nick/channel", user->nick.c_str(), parameters[0].c_str()); return CMD_FAILURE; } - - if (!*parameters[1]) + + if (parameters[1].empty()) { - user->WriteServ("NOTICE %s :*** GECOS must be specified", user->nick); + user->WriteServ("NOTICE %s :*** GECOS must be specified", user->nick.c_str()); return CMD_FAILURE; } - - if (strlen(parameters[1]) > MAXGECOS) + + if (parameters[1].length() > ServerInstance->Config->Limits.MaxGecos) { - user->WriteServ("NOTICE %s :*** GECOS too long", user->nick); + user->WriteServ("NOTICE %s :*** GECOS too long", user->nick.c_str()); return CMD_FAILURE; } - + if (IS_LOCAL(dest)) { - dest->ChangeName(parameters[1]); - ServerInstance->WriteOpers("%s used CHGNAME to change %s's real name to '%s'", user->nick, dest->nick, dest->fullname); - return CMD_LOCALONLY; /* name change routed by FNAME in spanningtree now */ + dest->ChangeName(parameters[1].c_str()); + ServerInstance->SNO->WriteGlobalSno('a', "%s used CHGNAME to change %s's real name to '%s'", user->nick.c_str(), dest->nick.c_str(), dest->fullname.c_str()); } /* route it! */ @@ -65,25 +63,23 @@ class cmd_chgname : public command_t class ModuleChgName : public Module { - cmd_chgname* mycommand; - - + CommandChgname cmd; + public: - ModuleChgName(InspIRCd* Me) : Module(Me) + ModuleChgName(InspIRCd* Me) : Module(Me), cmd(Me) { - mycommand = new cmd_chgname(ServerInstance); - ServerInstance->AddCommand(mycommand); + ServerInstance->AddCommand(&cmd); } - + virtual ~ModuleChgName() { } - + virtual Version GetVersion() { - return Version(1,1,0,0,VF_VENDOR,API_VERSION); + return Version("$Id$", VF_COMMON | VF_VENDOR, API_VERSION); } - + }; MODULE_INIT(ModuleChgName)