/* +------------------------------------+
- * | UnrealIRCd v4.0 |
+ * | Inspire Internet Relay Chat Daemon |
* +------------------------------------+
*
- * UnrealIRCd 4.0 (C) 2007 Carsten Valdemar Munk
+ * 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.
+ *
+ * ---------------------------------------------------
+ *
+ * Based on the UnrealIRCd 4.0 (1.1.x fork) module
+ *
+ * UnrealIRCd 4.0 (C) 2007 Carsten Valdemar Munk
* This program is free but copyrighted software; see
* the file COPYING for details.
*
*/
#include "inspircd.h"
-#include "users.h"
-#include "channels.h"
-#include "modules.h"
/* $ModDesc: Provides /CLOSE functionality */
/** Handle /CLOSE
*/
-class cmd_close : public command_t
+class CommandClose : public Command
{
public:
/* Command 'close', needs operator */
- cmd_close (InspIRCd* Instance) : command_t(Instance,"CLOSE", 'o', 0)
+ CommandClose(Module* Creator) : Command(Creator,"CLOSE", 0)
{
- this->source = "m_close.so";
- }
+ flags_needed = 'o'; }
- CmdResult Handle (const char** parameters, int pcnt, userrec *user)
+ CmdResult Handle (const std::vector<std::string> ¶meters, User *src)
{
std::map<std::string,int> closed;
- for (std::vector<userrec*>::iterator u = ServerInstance->local_users.begin(); u != ServerInstance->local_users.end(); u++)
+ std::vector<User*>::reverse_iterator u = ServerInstance->Users->local_users.rbegin();
+ while (u != ServerInstance->Users->local_users.rend())
{
- if ((*u)->registered != REG_ALL)
+ User* user = *u++;
+ if (user->registered != REG_ALL)
{
- userrec::QuitUser(ServerInstance, *u, "Closing all unknown connections per request");
- std::string key = ConvToStr((*u)->GetIPString())+"."+ConvToStr((*u)->GetPort());
+ ServerInstance->Users->QuitUser(user, "Closing all unknown connections per request");
+ std::string key = ConvToStr(user->GetIPString())+"."+ConvToStr(user->GetServerPort());
closed[key]++;
}
}
int total = 0;
for (std::map<std::string,int>::iterator ci = closed.begin(); ci != closed.end(); ci++)
{
- user->WriteServ("NOTICE %s :*** Closed %d unknown connection%s from [%s]",user->nick,(*ci).second,((*ci).second>1)?"s":"",(*ci).first.c_str());
+ src->WriteServ("NOTICE %s :*** Closed %d unknown connection%s from [%s]",src->nick.c_str(),(*ci).second,((*ci).second>1)?"s":"",(*ci).first.c_str());
total += (*ci).second;
}
if (total)
- user->WriteServ("NOTICE %s :*** %i unknown connection%s closed",user->nick,total,(total>1)?"s":"");
+ src->WriteServ("NOTICE %s :*** %i unknown connection%s closed",src->nick.c_str(),total,(total>1)?"s":"");
else
- user->WriteServ("NOTICE %s :*** No unknown connections found",user->nick);
-
- return CMD_LOCALONLY;
+ src->WriteServ("NOTICE %s :*** No unknown connections found",src->nick.c_str());
+
+ return CMD_SUCCESS;
}
};
class ModuleClose : public Module
{
- cmd_close* newcommand;
+ CommandClose cmd;
public:
- ModuleClose(InspIRCd* Me)
- : Module(Me)
+ ModuleClose()
+ : cmd(this)
{
- // Create a new command
- newcommand = new cmd_close(ServerInstance);
- ServerInstance->AddCommand(newcommand);
+ ServerInstance->AddCommand(&cmd);
}
virtual ~ModuleClose()
virtual Version GetVersion()
{
- return Version(1, 1, 0, 0, VF_VENDOR, API_VERSION);
+ return Version("Provides /CLOSE functionality", VF_VENDOR, API_VERSION);
}
};