#include "users.h"
#include "channels.h"
#include "modules.h"
+#include "inspircd.h"
/* $ModDesc: Provides support for SANICK command */
-static Server *Srv;
+
+
class cmd_sanick : public command_t
{
public:
- cmd_sanick () : command_t("SANICK", 'o', 2)
+ cmd_sanick (InspIRCd* Instance) : command_t(Instance,"SANICK", 'o', 2)
{
this->source = "m_sanick.so";
+ syntax = "<nick> <new-nick>";
}
- void Handle (char **parameters, int pcnt, userrec *user)
+ CmdResult Handle (const char** parameters, int pcnt, userrec *user)
{
- userrec* source = Srv->FindNick(std::string(parameters[0]));
+ userrec* source = ServerInstance->FindNick(parameters[0]);
if (source)
{
- if (Srv->IsUlined(source->server))
+ if (ServerInstance->ULine(source->server))
+ {
+ user->WriteServ("990 %s :Cannot use an SA command on a u-lined client",user->nick);
+ return CMD_FAILURE;
+ }
+ std::string oldnick = user->nick;
+ if (ServerInstance->IsNick(parameters[1]))
{
- WriteServ(user->fd,"990 %s :Cannot use an SA command on a u-lined client",user->nick);
- return;
+ if (source->ForceNickChange(parameters[1]))
+ {
+ ServerInstance->WriteOpers(oldnick+" used SANICK to change "+std::string(parameters[0])+" to "+parameters[1]);
+ return CMD_SUCCESS;
+ }
+ else
+ {
+ /* We couldnt change the nick */
+ ServerInstance->WriteOpers(oldnick+" failed SANICK (from "+std::string(parameters[0])+" to "+parameters[1]+")");
+ return CMD_FAILURE;
+ }
}
- if (Srv->IsNick(std::string(parameters[1])))
+ else
{
- // 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]));
+ user->WriteServ("NOTICE %s :*** Invalid nickname '%s'", user->nick, parameters[1]);
}
+
+ return CMD_FAILURE;
}
+
+ return CMD_FAILURE;
}
};
{
cmd_sanick* mycommand;
public:
- ModuleSanick(Server* Me)
+ ModuleSanick(InspIRCd* Me)
: Module::Module(Me)
{
- Srv = Me;
- mycommand = new cmd_sanick();
- Srv->AddCommand(mycommand);
+
+ mycommand = new cmd_sanick(ServerInstance);
+ ServerInstance->AddCommand(mycommand);
}
virtual ~ModuleSanick()
{
}
- virtual Module * CreateModule(Server* Me)
+ virtual Module * CreateModule(InspIRCd* Me)
{
return new ModuleSanick(Me);
}