summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authordanieldg <danieldg@e03df62e-2008-0410-955e-edbf42e46eb7>2010-02-09 05:05:09 +0000
committerdanieldg <danieldg@e03df62e-2008-0410-955e-edbf42e46eb7>2010-02-09 05:05:09 +0000
commit30ebb6b404236002478a0b570d0ab559d4effd13 (patch)
tree2c9c22d2e462d0eca35acb58a972fbfd9c90fc46
parent2bebd9500a2e27844df6bc148f6d8aaad0dd7943 (diff)
This module isn't supposed to be part of 2.0; it will be third-party until 2.1
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@12409 e03df62e-2008-0410-955e-edbf42e46eb7
-rw-r--r--src/modules/m_authcache.cpp114
1 files changed, 0 insertions, 114 deletions
diff --git a/src/modules/m_authcache.cpp b/src/modules/m_authcache.cpp
deleted file mode 100644
index c87938f85..000000000
--- a/src/modules/m_authcache.cpp
+++ /dev/null
@@ -1,114 +0,0 @@
-/* +------------------------------------+
- * | Inspire Internet Relay Chat Daemon |
- * +------------------------------------+
- *
- * InspIRCd: (C) 2002-2010 InspIRCd Development Team
- * See: http://wiki.inspircd.org/Credits
- *
- * This program is free but copyrighted software; see
- * the file COPYING for details.
- *
- * ---------------------------------------------------
- */
-
-#include "inspircd.h"
-#include "account.h"
-#include "ssl.h"
-
-// Password description - method, authdata
-typedef std::pair<std::string, std::string> passdesc;
-typedef std::multimap<std::string,passdesc> AuthMap;
-
-class ModuleAuthCache : public Module
-{
- AuthMap usernames;
-
- public:
- ModuleAuthCache()
- {
- }
-
- void init()
- {
- Implementation eventlist[] = { I_OnCheckReady, I_OnDecodeMetaData, I_OnSyncNetwork };
- ServerInstance->Modules->Attach(eventlist, this, 3);
- }
-
- void OnSyncNetwork(Module* proto, void* opaque)
- {
- for(AuthMap::iterator it = usernames.begin(); it != usernames.end(); it++)
- proto->ProtoSendMetaData(opaque, NULL, "authcache", it->second.first +
- " " + it->first + " " + it->second.second);
- }
-
- void OnDecodeMetaData(Extensible* dest, const std::string& name, const std::string& value)
- {
- if (dest || name != "authcache")
- return;
- irc::spacesepstream splitter(value);
- std::string method, id, data;
- splitter.GetToken(method);
- splitter.GetToken(id);
- data = splitter.GetRemaining();
-
- std::pair<AuthMap::iterator, AuthMap::iterator> it = usernames.equal_range(id);
- while (it.first != it.second)
- {
- if (it.first->second.first == method)
- {
- usernames.erase(it.first);
- break;
- }
- it.first++;
- }
-
- if (!data.empty())
- {
- usernames.insert(std::make_pair(id, std::make_pair(method, data)));
- }
- }
-
- ModResult OnCheckReady(LocalUser* user)
- {
- std::string login;
-
- std::pair<AuthMap::iterator, AuthMap::iterator> it = usernames.equal_range(user->nick);
- while (it.first != it.second)
- {
- if (!ServerInstance->PassCompare(user, it.first->second.second, user->password, it.first->second.first))
- login = user->nick;
- it.first++;
- }
-
- SocketCertificateRequest req(&user->eh, this);
- req.Send();
- if (req.cert)
- {
- it = usernames.equal_range(req.cert->GetFingerprint());
- while (it.first != it.second)
- {
- if (it.first->second.first == "sslfp")
- login = it.first->second.second;
- it.first++;
- }
- }
-
- if (!login.empty())
- {
- AccountExtItem* ext = GetAccountExtItem();
- if (ext)
- {
- ext->set(user, login);
- AccountEvent(this, user, login).Send();
- }
- }
- return MOD_RES_PASSTHRU;
- }
-
- Version GetVersion()
- {
- return Version("Provides an authorization cache for user accounts", VF_OPTCOMMON | VF_VENDOR);
- }
-};
-
-MODULE_INIT(ModuleAuthCache)