X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_chgname.cpp;h=37c7e9ff8d306525e4c906217849dc46d7f519ee;hb=697098bb47651b40ed9c768361d1a3b1ca452856;hp=8879401248e3290a42d4ada47be14eec8223b8e2;hpb=e4c1ae81efcfce5d5105c49bbb17356496e67ff1;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_chgname.cpp b/src/modules/m_chgname.cpp index 887940124..37c7e9ff8 100644 --- a/src/modules/m_chgname.cpp +++ b/src/modules/m_chgname.cpp @@ -2,7 +2,7 @@ * | Inspire Internet Relay Chat Daemon | * +------------------------------------+ * - * InspIRCd: (C) 2002-2007 InspIRCd Development Team + * InspIRCd: (C) 2002-2008 InspIRCd Development Team * See: http://www.inspircd.org/wiki/index.php/Credits * * This program is free but copyrighted software; see @@ -12,48 +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) { 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); + dest->ChangeName(parameters[1].c_str()); + ServerInstance->SNO->WriteToSnoMask('A', "%s used CHGNAME to change %s's real name to '%s'", user->nick.c_str(), dest->nick.c_str(), dest->fullname.c_str()); return CMD_LOCALONLY; /* name change routed by FNAME in spanningtree now */ } @@ -65,25 +64,26 @@ class cmd_chgname : public command_t class ModuleChgName : public Module { - cmd_chgname* mycommand; - - + CommandChgname* mycommand; + + public: ModuleChgName(InspIRCd* Me) : Module(Me) { - mycommand = new cmd_chgname(ServerInstance); + mycommand = new CommandChgname(ServerInstance); ServerInstance->AddCommand(mycommand); + } - + 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); +MODULE_INIT(ModuleChgName)