X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_ripemd160.cpp;h=44e16c86fe89a88a9799a22b0673864b15bef31d;hb=46e56dedd37abe33af4e8b970d5b83729dc1ef05;hp=3e94efb0ac2509b304d6ad097b8744a3219bfcba;hpb=7e843c22e16c81054bad18073d24fe1a07026431;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/modules/m_ripemd160.cpp b/src/modules/m_ripemd160.cpp index 3e94efb0a..44e16c86f 100644 --- a/src/modules/m_ripemd160.cpp +++ b/src/modules/m_ripemd160.cpp @@ -2,7 +2,7 @@ * | Inspire Internet Relay Chat Daemon | * +------------------------------------+ * - * InspIRCd: (C) 2002-2009 InspIRCd Development Team + * InspIRCd: (C) 2002-2010 InspIRCd Development Team * See: http://wiki.inspircd.org/Credits * * This program is free but copyrighted software; see @@ -149,9 +149,7 @@ typedef uint32_t dword; } -const char* const chars = "0123456789abcdef"; - -class ModuleRIPEMD160 : public Module +class RIProv : public HashProvider { void MDinit(dword *MDbuf, unsigned int* key) @@ -438,44 +436,33 @@ class ModuleRIPEMD160 : public Module return (byte *)hashcode; } - - public: - - ModuleRIPEMD160() +public: + std::string sum(const std::string& data) { - ServerInstance->Modules->PublishInterface("HashRequest", this); + char* rv = (char*)RMD((byte*)data.data(), data.length(), NULL); + return std::string(rv, RMDsize / 8); } - virtual ~ModuleRIPEMD160() + std::string sumIV(unsigned int* IV, const char* HexMap, const std::string &sdata) { - ServerInstance->Modules->UnpublishInterface("HashRequest", this); + return ""; } - void OnRequest(Request& request) + RIProv(Module* m) : HashProvider(m, "hash/ripemd160") {} +}; + +class ModuleRIPEMD160 : public Module +{ + public: + RIProv mr; + ModuleRIPEMD160() : mr(this) { - if (strcmp("HASH", request.id) == 0) - { - char res[41]; - HashRequest& req = static_cast(request); - unsigned char* data = (unsigned char*)RMD((byte*)req.data.data(), req.data.length(), NULL); - int j = 0; - for (int i = 0; i < RMDsize / 8; i++) - { - res[j++] = chars[data[i] / 16]; - res[j++] = chars[data[i] % 16]; - } - res[j] = '\0'; - req.result = res; - } - else if (strcmp("NAME", request.id) == 0) - { - static_cast(request).response = "ripemd160"; - } + ServerInstance->Modules->AddService(mr); } - virtual Version GetVersion() + Version GetVersion() { - return Version("Allows for RIPEMD-160 encrypted oper passwords", VF_VENDOR|VF_SERVICEPROVIDER, API_VERSION); + return Version("Provides RIPEMD-160 hashing", VF_VENDOR); } };