]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_ripemd160.cpp
DLLFactory--
[user/henk/code/inspircd.git] / src / modules / m_ripemd160.cpp
index 963c45f18b8579fda27145c9aea00c3fcd84a01d..15eab59cfe437ae7c742fa49eb29a7fefdd8da7e 100644 (file)
@@ -407,7 +407,7 @@ class ModuleRIPEMD160 : public Module
        byte *RMD(byte *message, dword length, unsigned int* key)
        {
                ServerInstance->Logs->Log("m_ripemd160", DEBUG, "RMD: '%s' length=%u", (const char*)message, length);
-               dword         MDbuf[RMDsize/32];   /* contains (A, B, C, D(E))   */
+               dword         MDbuf[RMDsize/32];   /* contains (A, B, C, D(E))   */
                static byte   hashcode[RMDsize/8]; /* for final hash-value         */
                dword         X[16];               /* current 16-word chunk        */
                unsigned int  i;                   /* counter                      */
@@ -437,16 +437,11 @@ class ModuleRIPEMD160 : public Module
                return (byte *)hashcode;
        }
 
-       unsigned int* currkey;
-       const char* chars;
-
  public:
 
-       ModuleRIPEMD160(InspIRCd* Me) : Module(Me), currkey(NULL), chars("0123456789abcdef")
+       ModuleRIPEMD160()
        {
                ServerInstance->Modules->PublishInterface("HashRequest", this);
-               Implementation eventlist[] = { I_OnRequest };
-               ServerInstance->Modules->Attach(eventlist, this, 1);
        }
 
        virtual ~ModuleRIPEMD160()
@@ -454,47 +449,23 @@ class ModuleRIPEMD160 : public Module
                ServerInstance->Modules->UnpublishInterface("HashRequest", this);
        }
 
-
-       virtual const char* OnRequest(Request* request)
+       void OnRequest(Request& request)
        {
-               HashRequest* SHA = (HashRequest*)request;
-               if (strcmp("KEY", request->GetId()) == 0)
-               {
-                       this->currkey = (unsigned int*)SHA->GetKeyData();
-               }
-               else if (strcmp("HEX", request->GetId()) == 0)
-               {
-                       this->chars = SHA->GetOutputs();
-               }
-               else if (strcmp("SUM", request->GetId()) == 0)
-               {
-                       static char output[MAXBUF];
-                       unsigned char* data = (unsigned char*)RMD((byte *)SHA->GetHashData().data(),SHA->GetHashData().length(), currkey);
-                       int j = 0;
-                       for (int i = 0; i < RMDsize / 8; i++)
-                       {
-                               output[j++] = chars[data[i] / 16];
-                               output[j++] = chars[data[i] % 16];
-                               ServerInstance->Logs->Log("m_ripemd160", DEBUG, "Hash: %02x", data[i]);
-                       }
-                       output[j] = '\0';
-                       return output;
-               }
-               else if (strcmp("NAME", request->GetId()) == 0)
+               if (strcmp("HASH", request.id) == 0)
                {
-                       return "ripemd160";
+                       HashRequest& req = static_cast<HashRequest&>(request);
+                       char* data = (char*)RMD((byte*)req.data.data(), req.data.length(), NULL);
+                       req.binresult.assign(data, RMDsize / 8);
                }
-               else if (strcmp("RESET", request->GetId()) == 0)
+               else if (strcmp("NAME", request.id) == 0)
                {
-                       this->chars = "0123456789abcdef";
-                       this->currkey = NULL;
+                       static_cast<HashNameRequest&>(request).response = "ripemd160";
                }
-               return NULL;
        }
 
        virtual Version GetVersion()
        {
-               return Version("$Id$", VF_VENDOR|VF_SERVICEPROVIDER, API_VERSION);
+               return Version("Allows for RIPEMD-160 encrypted oper passwords", VF_VENDOR|VF_SERVICEPROVIDER, API_VERSION);
        }
 
 };