diff options
author | Sadie Powell <sadie@witchery.services> | 2020-04-04 13:18:24 +0100 |
---|---|---|
committer | Sadie Powell <sadie@witchery.services> | 2020-04-04 13:25:10 +0100 |
commit | fe23e07f024c2cbcb05007f3ed70c9acf632a2f0 (patch) | |
tree | 5b4e16a90627a78d4726de574e608384d7b55846 /include/commands/cmd_whowas.h | |
parent | 5c6b063067587547a8f15e81c1d789f9bcd9974b (diff) |
Squish the cmd_whowas header.
There's no reason for this to be in a header and it can't be used
by anything else.
Diffstat (limited to 'include/commands/cmd_whowas.h')
-rw-r--r-- | include/commands/cmd_whowas.h | 211 |
1 files changed, 0 insertions, 211 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; -}; |