typedef unsigned char byte;
typedef unsigned int dword;
#else
-typedef uint8_t byte;
-typedef uint32_t dword;
+typedef uint8_t byte;
+typedef uint32_t dword;
#endif
/* collect four bytes into one word: */
{
if (key)
{
+ ServerInstance->Logs->Log("m_ripemd160.so", DEBUG, "initialize with custom mdbuf");
MDbuf[0] = key[0];
MDbuf[1] = key[1];
MDbuf[2] = key[2];
}
else
{
+ ServerInstance->Logs->Log("m_ripemd160.so", DEBUG, "initialize with default mdbuf");
MDbuf[0] = 0x67452301UL;
MDbuf[1] = 0xefcdab89UL;
MDbuf[2] = 0x98badcfeUL;
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)) */
static byte hashcode[RMDsize/8]; /* for final hash-value */
dword X[16]; /* current 16-word chunk */
return (byte *)hashcode;
}
- unsigned int* key;
- char* chars;
+ unsigned int* currkey;
+ const char* chars;
public:
- ModuleRIPEMD160(InspIRCd* Me) : Module(Me), key(NULL), chars("0123456789abcdef")
+ ModuleRIPEMD160(InspIRCd* Me) : Module(Me), currkey(NULL), chars("0123456789abcdef")
{
ServerInstance->Modules->PublishInterface("HashRequest", this);
Implementation eventlist[] = { I_OnRequest };
HashRequest* SHA = (HashRequest*)request;
if (strcmp("KEY", request->GetId()) == 0)
{
- this->key = (unsigned int*)SHA->GetKeyData();
+ this->currkey = (unsigned int*)SHA->GetKeyData();
}
else if (strcmp("HEX", request->GetId()) == 0)
{
- this->chars = (char*)SHA->GetOutputs();
+ 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;
- static char* data;
- data = (char*)RMD((byte *)SHA->GetHashData().data(),SHA->GetHashData().length(), key);
- for (int i = 0, j = 0; i < RMDsize / 8; i++)
+ for (int i = 0; i < RMDsize / 8; i++)
{
- data[j++] = chars[data[i] / 16];
- data[j++] = chars[data[i] % 16];
- data[j] = '\0';
+ output[j++] = chars[data[i] / 16];
+ output[j++] = chars[data[i] % 16];
+ ServerInstance->Logs->Log("m_ripemd160", DEBUG, "Hash: %02x", data[i]);
}
- return data;
+ output[j] = '\0';
+ return output;
}
else if (strcmp("NAME", request->GetId()) == 0)
{
else if (strcmp("RESET", request->GetId()) == 0)
{
this->chars = "0123456789abcdef";
- this->key = NULL;
+ this->currkey = NULL;
}
return NULL;
}
return Version(1, 2, 0, 1, VF_VENDOR|VF_SERVICEPROVIDER, API_VERSION);
}
-};
\ No newline at end of file
+};
+
+MODULE_INIT(ModuleRIPEMD160)
+