From ae888e9cf9bd0b41edfbc4231d0435a23441509e Mon Sep 17 00:00:00 2001 From: w00t Date: Sun, 4 Nov 2007 00:44:28 +0000 Subject: Remove some unnecessary headers from places, commit working BanCacheManager skeleton. Work in progress, ignore it for now. Doesn't do anything, either. git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@8487 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/bancache.cpp | 47 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 47 insertions(+) (limited to 'src') diff --git a/src/bancache.cpp b/src/bancache.cpp index 0c5f00502..fe23fd0b7 100644 --- a/src/bancache.cpp +++ b/src/bancache.cpp @@ -16,4 +16,51 @@ #include "inspircd.h" #include "bancache.h" +BanCacheHit *BanCacheManager::AddHit(const std::string &ip, const std::string &type, const std::string &reason) +{ + BanCacheHit *b; + + + if (this->BanHash->find(ip) != this->BanHash->end()) // can't have two cache entries on the same IP, sorry.. + return NULL; + + b = new BanCacheHit(ServerInstance, ip, type, reason); + + this->BanHash->insert(std::make_pair(ip, b)); + return b; +} + +BanCacheHit *BanCacheManager::GetHit(const std::string &ip) +{ + BanCacheHash::iterator i = this->BanHash->find(ip); + + if (i == this->BanHash->end()) + return NULL; // free and safe + else + return i->second; // hit. +} + +bool BanCacheManager::RemoveHit(BanCacheHit *b) +{ + BanCacheHash::iterator i; + + if (!b) + return false; // I don't think so. + + i = this->BanHash->find(b->IP); + + if (i == this->BanHash->end()) + { + // err.. + ServerInstance->Log(DEBUG, "BanCacheManager::RemoveHit(): I got asked to remove a hit that wasn't in the hash(?)"); + } + else + { + this->BanHash->erase(b->IP); + } + + delete b; + return true; +} + -- cgit v1.2.3