diff options
-rw-r--r-- | include/commands/cmd_whowas.h | 211 | ||||
-rw-r--r-- | src/coremods/core_whowas.cpp | 147 |
2 files changed, 146 insertions, 212 deletions
diff --git a/include/commands/cmd_whowas.h b/include/commands/cmd_whowas.h deleted file mode 100644 index 692338992..000000000 --- a/include/commands/cmd_whowas.h +++ /dev/null @@ -1,211 +0,0 @@ -/* - * InspIRCd -- Internet Relay Chat Daemon - * - * Copyright (C) 2013, 2018 Sadie Powell <sadie@witchery.services> - * Copyright (C) 2012, 2014-2015 Attila Molnar <attilamolnar@hush.com> - * Copyright (C) 2012 Robby <robby@chatbelgie.be> - * Copyright (C) 2010 Craig Edwards <brain@inspircd.org> - * Copyright (C) 2009 Daniel De Graaf <danieldg@inspircd.org> - * Copyright (C) 2007 Robin Burchell <robin+git@viroteck.net> - * Copyright (C) 2007 Dennis Friis <peavey@inspircd.org> - * - * 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/>. - */ - - -#pragma once - -#include "modules.h" - -namespace WhoWas -{ - /** One entry for a nick. There may be multiple entries for a nick. - */ - struct Entry - { - /** Real host - */ - const std::string host; - - /** Displayed host - */ - const std::string dhost; - - /** Ident - */ - const std::string ident; - - /** Server name - */ - const std::string server; - - /** Real name - */ - const std::string real; - - /** Signon time - */ - const time_t signon; - - /** Initialize this Entry with a user - */ - Entry(User* user); - }; - - /** Everything known about one nick - */ - struct Nick : public insp::intrusive_list_node<Nick> - { - /** A group of users related by nickname - */ - typedef std::deque<Entry*> List; - - /** Container where each element has information about one occurrence of this nick - */ - List entries; - - /** Time this nick was added to the database - */ - const time_t addtime; - - /** Nickname whose information is stored in this class - */ - const std::string nick; - - /** Constructor to initialize fields - */ - Nick(const std::string& nickname); - - /** Destructor, deallocates all elements in the entries container - */ - ~Nick(); - }; - - class Manager - { - public: - struct Stats - { - /** Number of currently existing WhoWas::Entry objects - */ - size_t entrycount; - }; - - /** Add a user to the whowas database. Called when a user quits. - * @param user The user to add to the database - */ - void Add(User* user); - - /** Retrieves statistics about the whowas database - * @return Whowas statistics as a WhoWas::Manager::Stats struct - */ - Stats GetStats() const; - - /** Expires old entries - */ - void Maintain(); - - /** Updates the current configuration which may result in the database being pruned if the - * new values are lower than the current ones. - * @param NewGroupSize Maximum number of nicks allowed in the database. In case there are this many nicks - * in the database and one more is added, the oldest one is removed (FIFO). - * @param NewMaxGroups Maximum number of entries per nick - * @param NewMaxKeep Seconds how long each nick should be kept - */ - void UpdateConfig(unsigned int NewGroupSize, unsigned int NewMaxGroups, unsigned int NewMaxKeep); - - /** Retrieves all data known about a given nick - * @param nick Nickname to find, case insensitive (IRC casemapping) - * @return A pointer to a WhoWas::Nick if the nick was found, NULL otherwise - */ - const Nick* FindNick(const std::string& nick) const; - - /** Returns true if WHOWAS is enabled according to the current configuration - * @return True if WHOWAS is enabled according to the configuration, false if WHOWAS is disabled - */ - bool IsEnabled() const; - - /** Constructor - */ - Manager(); - - /** Destructor - */ - ~Manager(); - - private: - /** Order in which the users were added into the map, used to remove oldest nick - */ - typedef insp::intrusive_list_tail<Nick> FIFO; - - /** Sets of users in the whowas system - */ - typedef TR1NS::unordered_map<std::string, WhoWas::Nick*, irc::insensitive, irc::StrHashComp> whowas_users; - - /** Primary container, links nicknames tracked by WHOWAS to a list of records - */ - whowas_users whowas; - - /** List of nicknames in the order they were inserted into the map - */ - FIFO whowas_fifo; - - /** Max number of WhoWas entries per user. - */ - unsigned int GroupSize; - - /** Max number of cumulative user-entries in WhoWas. - * When max reached and added to, push out oldest entry FIFO style. - */ - unsigned int MaxGroups; - - /** Max seconds a user is kept in WhoWas before being pruned. - */ - unsigned int MaxKeep; - - /** Shrink all data structures to honor the current settings - */ - void Prune(); - - /** Remove a nick (and all entries belonging to it) from the database - * @param it Iterator to the nick to purge - */ - void PurgeNick(whowas_users::iterator it); - - /** Remove a nick (and all entries belonging to it) from the database - * @param nick Nick to purge - */ - void PurgeNick(WhoWas::Nick* nick); - }; -} - -/** Handle /WHOWAS. These command handlers can be reloaded by the core, - * and handle basic RFC1459 commands. Commands within modules work - * the same way, however, they can be fully unloaded, where these - * may not. - */ -class CommandWhowas : public Command -{ - public: - /** Manager handling all whowas database related tasks - */ - WhoWas::Manager manager; - - CommandWhowas(Module* parent); - /** Handle command. - * @param parameters The parameters to the comamnd - * @param user The user issuing the command - * @return A value from CmdResult to indicate command success or failure. - */ - CmdResult Handle(User* user, const Params& parameters) CXX11_OVERRIDE; -}; diff --git a/src/coremods/core_whowas.cpp b/src/coremods/core_whowas.cpp index a0e4ffc6a..9f208a026 100644 --- a/src/coremods/core_whowas.cpp +++ b/src/coremods/core_whowas.cpp @@ -25,7 +25,6 @@ #include "inspircd.h" -#include "commands/cmd_whowas.h" #include "modules/stats.h" enum @@ -38,6 +37,152 @@ enum RPL_WHOWASIP = 652 }; +namespace WhoWas +{ + /** One entry for a nick. There may be multiple entries for a nick. */ + struct Entry + { + /** Real host */ + const std::string host; + + /** Displayed host */ + const std::string dhost; + + /** Ident */ + const std::string ident; + + /** Server name */ + const std::string server; + + /** Real name */ + const std::string real; + + /** Signon time */ + const time_t signon; + + /** Initialize this Entry with a user */ + Entry(User* user); + }; + + /** Everything known about one nick */ + struct Nick : public insp::intrusive_list_node<Nick> + { + /** A group of users related by nickname */ + typedef std::deque<Entry*> List; + + /** Container where each element has information about one occurrence of this nick */ + List entries; + + /** Time this nick was added to the database */ + const time_t addtime; + + /** Nickname whose information is stored in this class */ + const std::string nick; + + /** Constructor to initialize fields */ + Nick(const std::string& nickname); + + /** Destructor, deallocates all elements in the entries container */ + ~Nick(); + }; + + class Manager + { + public: + struct Stats + { + /** Number of currently existing WhoWas::Entry objects */ + size_t entrycount; + }; + + /** Add a user to the whowas database. Called when a user quits. + * @param user The user to add to the database + */ + void Add(User* user); + + /** Retrieves statistics about the whowas database + * @return Whowas statistics as a WhoWas::Manager::Stats struct + */ + Stats GetStats() const; + + /** Expires old entries */ + void Maintain(); + + /** Updates the current configuration which may result in the database being pruned if the + * new values are lower than the current ones. + * @param NewGroupSize Maximum number of nicks allowed in the database. In case there are this many nicks + * in the database and one more is added, the oldest one is removed (FIFO). + * @param NewMaxGroups Maximum number of entries per nick + * @param NewMaxKeep Seconds how long each nick should be kept + */ + void UpdateConfig(unsigned int NewGroupSize, unsigned int NewMaxGroups, unsigned int NewMaxKeep); + + /** Retrieves all data known about a given nick + * @param nick Nickname to find, case insensitive (IRC casemapping) + * @return A pointer to a WhoWas::Nick if the nick was found, NULL otherwise + */ + const Nick* FindNick(const std::string& nick) const; + + /** Returns true if WHOWAS is enabled according to the current configuration + * @return True if WHOWAS is enabled according to the configuration, false if WHOWAS is disabled + */ + bool IsEnabled() const; + + /** Constructor */ + Manager(); + + /** Destructor */ + ~Manager(); + + private: + /** Order in which the users were added into the map, used to remove oldest nick */ + typedef insp::intrusive_list_tail<Nick> FIFO; + + /** Sets of users in the whowas system */ + typedef TR1NS::unordered_map<std::string, WhoWas::Nick*, irc::insensitive, irc::StrHashComp> whowas_users; + + /** Primary container, links nicknames tracked by WHOWAS to a list of records */ + whowas_users whowas; + + /** List of nicknames in the order they were inserted into the map */ + FIFO whowas_fifo; + + /** Max number of WhoWas entries per user. */ + unsigned int GroupSize; + + /** Max number of cumulative user-entries in WhoWas. + * When max reached and added to, push out oldest entry FIFO style. + */ + unsigned int MaxGroups; + + /** Max seconds a user is kept in WhoWas before being pruned. */ + unsigned int MaxKeep; + + /** Shrink all data structures to honor the current settings */ + void Prune(); + + /** Remove a nick (and all entries belonging to it) from the database + * @param it Iterator to the nick to purge + */ + void PurgeNick(whowas_users::iterator it); + + /** Remove a nick (and all entries belonging to it) from the database + * @param nick Nick to purge + */ + void PurgeNick(WhoWas::Nick* nick); + }; +} + +class CommandWhowas : public Command +{ + public: + // Manager handling all whowas database related tasks + WhoWas::Manager manager; + + CommandWhowas(Module* parent); + CmdResult Handle(User* user, const Params& parameters) CXX11_OVERRIDE; +}; + CommandWhowas::CommandWhowas( Module* parent) : Command(parent, "WHOWAS", 1) { |