From 27e261780809073b5c776e535f8d2402c0df2ec7 Mon Sep 17 00:00:00 2001 From: Peter Powell Date: Fri, 15 Feb 2019 12:35:51 +0000 Subject: Move the close and jumpserver modules to inspircd-extras. - The close module is borderline useless. - The jumpserver numeric is supported by barely any clients and has various security problems. --- src/modules/m_close.cpp | 83 ------------------------------------------------- 1 file changed, 83 deletions(-) delete mode 100644 src/modules/m_close.cpp (limited to 'src/modules/m_close.cpp') diff --git a/src/modules/m_close.cpp b/src/modules/m_close.cpp deleted file mode 100644 index c2a94a6ff..000000000 --- a/src/modules/m_close.cpp +++ /dev/null @@ -1,83 +0,0 @@ -/* - * InspIRCd -- Internet Relay Chat Daemon - * - * Copyright (C) 2007 Dennis Friis - * Copyright (C) 2007 Carsten Valdemar Munk - * - * 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 . - */ - - -#include "inspircd.h" - -/** Handle /CLOSE - */ -class CommandClose : public Command -{ - public: - /* Command 'close', needs operator */ - CommandClose(Module* Creator) : Command(Creator,"CLOSE", 0) - { - flags_needed = 'o'; - } - - CmdResult Handle(User* src, const Params& parameters) CXX11_OVERRIDE - { - std::map closed; - - const UserManager::LocalList& list = ServerInstance->Users.GetLocalUsers(); - for (UserManager::LocalList::const_iterator u = list.begin(); u != list.end(); ) - { - // Quitting the user removes it from the list - LocalUser* user = *u; - ++u; - if (user->registered != REG_ALL) - { - ServerInstance->Users->QuitUser(user, "Closing all unknown connections per request"); - std::string key = ConvToStr(user->GetIPString())+"."+ConvToStr(user->server_sa.port()); - closed[key]++; - } - } - - int total = 0; - for (std::map::iterator ci = closed.begin(); ci != closed.end(); ci++) - { - src->WriteNotice("*** Closed " + ConvToStr(ci->second) + " unknown " + (ci->second == 1 ? "connection" : "connections") + - " from [" + ci->first + "]"); - total += ci->second; - } - if (total) - src->WriteNotice("*** " + ConvToStr(total) + " unknown " + (total == 1 ? "connection" : "connections") + " closed"); - else - src->WriteNotice("*** No unknown connections found"); - - return CMD_SUCCESS; - } -}; - -class ModuleClose : public Module -{ - CommandClose cmd; - public: - ModuleClose() - : cmd(this) - { - } - - Version GetVersion() CXX11_OVERRIDE - { - return Version("Provides /CLOSE functionality", VF_VENDOR); - } -}; - -MODULE_INIT(ModuleClose) -- cgit v1.2.3