2008-01-13 02:59:06 +00:00
|
|
|
/* +------------------------------------+
|
|
|
|
* | Inspire Internet Relay Chat Daemon |
|
|
|
|
* +------------------------------------+
|
|
|
|
*
|
|
|
|
* InspIRCd: (C) 2002-2008 InspIRCd Development Team
|
|
|
|
* See: http://www.inspircd.org/wiki/index.php/Credits
|
|
|
|
*
|
|
|
|
* This program is free but copyrighted software; see
|
|
|
|
* the file COPYING for details.
|
|
|
|
*
|
|
|
|
* ---------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __USERMANAGER_H
|
|
|
|
#define __USERMANAGER_H
|
|
|
|
|
2008-02-02 20:55:16 +00:00
|
|
|
#include <list>
|
|
|
|
|
2008-01-13 03:37:25 +00:00
|
|
|
/** A list of ip addresses cross referenced against clone counts */
|
|
|
|
typedef std::map<irc::string, unsigned int> clonemap;
|
|
|
|
|
2008-01-13 02:59:06 +00:00
|
|
|
class CoreExport UserManager : public classbase
|
|
|
|
{
|
|
|
|
private:
|
|
|
|
InspIRCd *ServerInstance;
|
2008-01-13 03:37:25 +00:00
|
|
|
|
|
|
|
/** Map of local ip addresses for clone counting
|
|
|
|
*/
|
|
|
|
clonemap local_clones;
|
2008-01-13 02:59:06 +00:00
|
|
|
public:
|
|
|
|
UserManager(InspIRCd *Instance)
|
|
|
|
{
|
|
|
|
ServerInstance = Instance;
|
|
|
|
}
|
2008-01-13 03:37:25 +00:00
|
|
|
|
2008-02-02 20:55:16 +00:00
|
|
|
|
|
|
|
/** Client list, a hash_map containing all clients, local and remote
|
|
|
|
*/
|
|
|
|
user_hash* clientlist;
|
|
|
|
|
|
|
|
/** Client list stored by UUID. Contains all clients, and is updated
|
|
|
|
* automatically by the constructor and destructor of User.
|
|
|
|
*/
|
|
|
|
user_hash* uuidlist;
|
|
|
|
|
|
|
|
/** Local client list, a vector containing only local clients
|
|
|
|
*/
|
|
|
|
std::vector<User*> local_users;
|
|
|
|
|
|
|
|
/** Oper list, a vector containing all local and remote opered users
|
|
|
|
*/
|
|
|
|
std::list<User*> all_opers;
|
|
|
|
|
|
|
|
/** Number of unregistered users online right now.
|
|
|
|
* (Unregistered means before USER/NICK/dns)
|
|
|
|
*/
|
|
|
|
int unregistered_count;
|
|
|
|
|
2008-01-13 03:37:25 +00:00
|
|
|
/** Map of global ip addresses for clone counting
|
|
|
|
* XXX - this should be private, but m_clones depends on it currently.
|
|
|
|
*/
|
|
|
|
clonemap global_clones;
|
|
|
|
|
2008-01-13 03:51:04 +00:00
|
|
|
/** Add a client to the system.
|
|
|
|
* This will create a new User, insert it into the user_hash,
|
|
|
|
* initialize it as not yet registered, and add it to the socket engine.
|
|
|
|
* @param Instance a pointer to the server instance
|
|
|
|
* @param socket The socket id (file descriptor) this user is on
|
|
|
|
* @param port The port number this user connected on
|
|
|
|
* @param iscached This variable is reserved for future use
|
|
|
|
* @param ip The IP address of the user
|
|
|
|
* @return This function has no return value, but a call to AddClient may remove the user.
|
|
|
|
*/
|
|
|
|
void AddClient(InspIRCd* Instance, int socket, int port, bool iscached, int socketfamily, sockaddr* ip);
|
|
|
|
|
2008-01-13 03:37:25 +00:00
|
|
|
/** Add a user to the local clone map
|
|
|
|
* @param user The user to add
|
|
|
|
*/
|
|
|
|
void AddLocalClone(User *user);
|
|
|
|
|
|
|
|
/** Add a user to the global clone map
|
|
|
|
* @param user The user to add
|
|
|
|
*/
|
|
|
|
void AddGlobalClone(User *user);
|
|
|
|
|
|
|
|
/** Remove all clone counts from the user, you should
|
|
|
|
* use this if you change the user's IP address
|
|
|
|
* after they have registered.
|
|
|
|
* @param user The user to remove
|
|
|
|
*/
|
|
|
|
void RemoveCloneCounts(User *user);
|
|
|
|
|
|
|
|
/** Return the number of global clones of this user
|
|
|
|
* @param user The user to get a count for
|
|
|
|
* @return The global clone count of this user
|
|
|
|
*/
|
|
|
|
unsigned long GlobalCloneCount(User *user);
|
|
|
|
|
|
|
|
/** Return the number of local clones of this user
|
|
|
|
* @param user The user to get a count for
|
|
|
|
* @return The local clone count of this user
|
|
|
|
*/
|
|
|
|
unsigned long LocalCloneCount(User *user);
|
|
|
|
|
2008-01-17 12:17:09 +00:00
|
|
|
/** Return a count of users, unknown and known connections
|
|
|
|
* @return The number of users
|
|
|
|
*/
|
|
|
|
unsigned int UserCount();
|
|
|
|
|
|
|
|
/** Return a count of fully registered connections only
|
|
|
|
* @return The number of registered users
|
|
|
|
*/
|
|
|
|
unsigned int RegisteredUserCount();
|
2008-01-13 03:37:25 +00:00
|
|
|
|
2008-01-17 12:17:09 +00:00
|
|
|
/** Return a count of opered (umode +o) users only
|
|
|
|
* @return The number of opers
|
|
|
|
*/
|
|
|
|
unsigned int OperCount();
|
2008-01-13 03:37:25 +00:00
|
|
|
|
2008-01-17 12:17:09 +00:00
|
|
|
/** Return a count of unregistered (before NICK/USER) users only
|
|
|
|
* @return The number of unregistered (unknown) connections
|
|
|
|
*/
|
|
|
|
unsigned int UnregisteredUserCount();
|
2008-01-13 03:37:25 +00:00
|
|
|
|
2008-01-17 12:17:09 +00:00
|
|
|
/** Return a count of local users on this server only
|
|
|
|
* @return The number of local users
|
|
|
|
*/
|
|
|
|
unsigned int LocalUserCount();
|
2008-02-02 20:55:16 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** Number of users with a certain mode set on them
|
|
|
|
*/
|
|
|
|
int ModeCount(const char mode);
|
|
|
|
|
|
|
|
/** Send a server notice to all local users
|
|
|
|
* @param text The text format string to send
|
|
|
|
* @param ... The format arguments
|
|
|
|
*/
|
2008-02-13 18:22:19 +00:00
|
|
|
void ServerNoticeAll(const char* text, ...);
|
2008-02-02 20:55:16 +00:00
|
|
|
|
|
|
|
/** Send a server message (PRIVMSG) to all local users
|
|
|
|
* @param text The text format string to send
|
|
|
|
* @param ... The format arguments
|
|
|
|
*/
|
2008-02-13 18:22:19 +00:00
|
|
|
void ServerPrivmsgAll(const char* text, ...);
|
2008-02-02 20:55:16 +00:00
|
|
|
|
|
|
|
/** Send text to all users with a specific set of modes
|
|
|
|
* @param modes The modes to check against, without a +, e.g. 'og'
|
|
|
|
* @param flags one of WM_OR or WM_AND. If you specify WM_OR, any one of the
|
|
|
|
* mode characters in the first parameter causes receipt of the message, and
|
|
|
|
* if you specify WM_OR, all the modes must be present.
|
|
|
|
* @param text The text format string to send
|
|
|
|
* @param ... The format arguments
|
|
|
|
*/
|
|
|
|
void WriteMode(const char* modes, int flags, const char* text, ...);
|
2008-01-13 02:59:06 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|