2007-11-03 21:19:39 +00:00
|
|
|
/* +------------------------------------+
|
|
|
|
* | Inspire Internet Relay Chat Daemon |
|
|
|
|
* +------------------------------------+
|
|
|
|
*
|
|
|
|
* InspIRCd: (C) 2002-2007 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 __BANCACHE_H
|
|
|
|
#define __BANCACHE_H
|
|
|
|
|
2007-11-03 22:53:51 +00:00
|
|
|
#include <string>
|
|
|
|
|
|
|
|
class CoreExport BanCacheHit : public classbase
|
|
|
|
{
|
|
|
|
private:
|
2007-11-04 00:44:28 +00:00
|
|
|
InspIRCd *ServerInstance;
|
2007-11-03 22:53:51 +00:00
|
|
|
public:
|
2007-11-04 00:44:28 +00:00
|
|
|
std::string Type;
|
|
|
|
std::string Reason;
|
|
|
|
std::string IP;
|
|
|
|
|
|
|
|
BanCacheHit(InspIRCd *Instance, const std::string &ip, const std::string &type, const std::string &reason)
|
|
|
|
{
|
|
|
|
ServerInstance = Instance;
|
|
|
|
this->Type = type;
|
|
|
|
this->Reason = reason;
|
|
|
|
this->IP = ip;
|
|
|
|
}
|
2007-11-03 22:56:40 +00:00
|
|
|
};
|
2007-11-03 22:53:51 +00:00
|
|
|
|
|
|
|
// must be defined after class BanCacheHit.
|
2007-11-04 11:04:03 +00:00
|
|
|
#ifndef WIN32
|
2007-11-03 22:53:51 +00:00
|
|
|
typedef nspace::hash_map<std::string, BanCacheHit *, nspace::hash<std::string> > BanCacheHash;
|
2007-11-04 11:04:03 +00:00
|
|
|
#else
|
|
|
|
typedef nspace::hash_map<std::string, BanCacheHit*, nspace::hash_compare<string, less<string> > > BanCacheHash;
|
|
|
|
#endif
|
2007-11-03 22:53:51 +00:00
|
|
|
|
|
|
|
class CoreExport BanCacheManager : public classbase
|
|
|
|
{
|
|
|
|
private:
|
|
|
|
BanCacheHash *BanHash;
|
|
|
|
InspIRCd *ServerInstance;
|
|
|
|
public:
|
2007-11-04 00:44:28 +00:00
|
|
|
|
|
|
|
/** Creates and adds a Ban Cache item.
|
|
|
|
* @param ip The IP the item is for.
|
|
|
|
* @param type The type of ban cache item. std::string. .empty() means it's a negative match (user is allowed freely).
|
|
|
|
* @param reason The reason for the ban. Left .empty() if it's a negative match.
|
|
|
|
*/
|
|
|
|
BanCacheHit *AddHit(const std::string &ip, const std::string &type, const std::string &reason);
|
2007-11-03 22:53:51 +00:00
|
|
|
BanCacheHit *GetHit(const std::string &ip);
|
2007-11-04 00:44:28 +00:00
|
|
|
bool RemoveHit(BanCacheHit *b);
|
2007-11-03 22:53:51 +00:00
|
|
|
|
|
|
|
BanCacheManager(InspIRCd *Instance)
|
|
|
|
{
|
|
|
|
this->ServerInstance = Instance;
|
|
|
|
this->BanHash = new BanCacheHash();
|
|
|
|
}
|
2007-11-05 19:52:16 +00:00
|
|
|
|
|
|
|
void RehashCache();
|
2007-11-03 22:56:40 +00:00
|
|
|
};
|
2007-11-03 22:53:51 +00:00
|
|
|
|
2007-11-03 21:19:39 +00:00
|
|
|
#endif
|