-/* +------------------------------------+
- * | Inspire Internet Relay Chat Daemon |
- * +------------------------------------+
+/*
+ * InspIRCd -- Internet Relay Chat Daemon
*
- * InspIRCd: (C) 2002-2007 InspIRCd Development Team
- * See: http://www.inspircd.org/wiki/index.php/Credits
+ * Copyright (C) 2007 Dennis Friis <peavey@inspircd.org>
+ * Copyright (C) 2007 John Brooks <john.brooks@dereferenced.net>
+ * Copyright (C) 2007 Robin Burchell <robin+git@viroteck.net>
+ * Copyright (C) 2006 Oliver Lupton <oliverlupton@gmail.com>
*
- * This program is free but copyrighted software; see
- * the file COPYING for details.
+ * This file is part of InspIRCd. InspIRCd is free software: you can
+ * redistribute it and/or modify it under the terms of the GNU General Public
+ * License as published by the Free Software Foundation, version 2.
*
- * ---------------------------------------------------
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
+ * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
+ * details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
-#include "users.h"
-#include "modules.h"
-#include "inspircd.h"
-/* $ModDesc: Provides support for the SETIDENT command */
+#include "inspircd.h"
/** Handle /SETIDENT
*/
-class cmd_setident : public command_t
+class CommandSetident : public Command
{
public:
- cmd_setident (InspIRCd* Instance) : command_t(Instance,"SETIDENT", 'o', 1)
+ CommandSetident(Module* Creator) : Command(Creator,"SETIDENT", 1)
{
- this->source = "m_setident.so";
- syntax = "<new-ident>";
+ allow_empty_last_param = false;
+ flags_needed = 'o'; syntax = "<new-ident>";
}
- CmdResult Handle(const char** parameters, int pcnt, userrec *user)
+ CmdResult Handle(const std::vector<std::string>& parameters, User *user)
{
- size_t len = 0;
- for(const char* x = parameters[0]; *x; x++, len++)
+ if (parameters[0].size() > ServerInstance->Config->Limits.IdentMax)
{
- if(((*x >= 'A') && (*x <= '}')) || strchr(".-0123456789", *x))
- continue;
-
- user->WriteServ("NOTICE %s :*** Invalid characters in ident", user->nick);
+ user->WriteNotice("*** SETIDENT: Ident is too long");
return CMD_FAILURE;
}
- if (len > IDENTMAX)
+
+ if (!ServerInstance->IsIdent(parameters[0]))
{
- user->WriteServ("NOTICE %s :*** Ident is too long", user->nick);
+ user->WriteNotice("*** SETIDENT: Invalid characters in ident");
return CMD_FAILURE;
}
user->ChangeIdent(parameters[0]);
- ServerInstance->WriteOpers("%s used SETIDENT to change their ident to '%s'", user->nick, user->ident);
+ ServerInstance->SNO->WriteGlobalSno('a', "%s used SETIDENT to change their ident to '%s'", user->nick.c_str(), user->ident.c_str());
return CMD_SUCCESS;
}
};
-
class ModuleSetIdent : public Module
{
- cmd_setident* mycommand;
-
- public:
- ModuleSetIdent(InspIRCd* Me) : Module::Module(Me)
- {
-
- mycommand = new cmd_setident(ServerInstance);
- ServerInstance->AddCommand(mycommand);
- }
-
- virtual ~ModuleSetIdent()
- {
- }
-
- virtual Version GetVersion()
- {
- return Version(1,1,0,0,VF_VENDOR,API_VERSION);
- }
-
-};
+ CommandSetident cmd;
-// stuff down here is the module-factory stuff. For basic modules you can ignore this.
-
-class ModuleSetIdentFactory : public ModuleFactory
-{
public:
- ModuleSetIdentFactory()
+ ModuleSetIdent() : cmd(this)
{
}
-
- ~ModuleSetIdentFactory()
- {
- }
-
- virtual Module * CreateModule(InspIRCd* Me)
+
+ Version GetVersion() CXX11_OVERRIDE
{
- return new ModuleSetIdent(Me);
+ return Version("Provides support for the SETIDENT command", VF_VENDOR);
}
-
};
-
-extern "C" void * init_module( void )
-{
- return new ModuleSetIdentFactory;
-}
-
+MODULE_INIT(ModuleSetIdent)