X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_chgname.cpp;h=37c7e9ff8d306525e4c906217849dc46d7f519ee;hb=697098bb47651b40ed9c768361d1a3b1ca452856;hp=d25e51426d4f34d4a8879f17c23c7138082e1c42;hpb=454bce0e6bd4a8172f380c9fb2498be9428e3bac;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_chgname.cpp b/src/modules/m_chgname.cpp index d25e51426..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,36 +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].empty()) + { + user->WriteServ("NOTICE %s :*** GECOS must be specified", user->nick.c_str()); + return CMD_FAILURE; + } + + if (parameters[1].length() > ServerInstance->Config->Limits.MaxGecos) + { + 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 */ } @@ -53,50 +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); } - -}; - -// stuff down here is the module-factory stuff. For basic modules you can ignore this. -class ModuleChgNameFactory : public ModuleFactory -{ - public: - ModuleChgNameFactory() - { - } - - ~ModuleChgNameFactory() - { - } - - virtual Module * CreateModule(InspIRCd* Me) - { - return new ModuleChgName(Me); - } - }; - -extern "C" DllExport void * init_module( void ) -{ - return new ModuleChgNameFactory; -} - +MODULE_INIT(ModuleChgName)