File: rawmd5.c

package info (click to toggle)
atheme-services 7.2.12-2.1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 17,256 kB
  • sloc: ansic: 95,899; sh: 8,462; php: 5,032; perl: 3,327; makefile: 1,279; sed: 16; ruby: 15; python: 3
file content (59 lines) | stat: -rw-r--r-- 1,278 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
/*
 * Copyright (c) 2009 Atheme Development Group
 * Rights to this code are as documented in doc/LICENSE.
 *
 * Raw MD5 password encryption, as used by e.g. Anope 1.8.
 * Hash functions are not designed to encrypt passwords directly,
 * but we need this to convert some Anope databases.
 */

#include "atheme.h"

DECLARE_MODULE_V1
(
	"crypto/rawmd5", false, _modinit, _moddeinit,
	PACKAGE_STRING,
	VENDOR_STRING
);

#define RAWMD5_PREFIX "$rawmd5$"

static const char *rawmd5_crypt_string(const char *key, const char *salt)
{
	static char output[2 * 16 + sizeof(RAWMD5_PREFIX)];
	md5_state_t ctx;
	unsigned char digest[16];
	int i;

	md5_init(&ctx);
	md5_append(&ctx, (const unsigned char *)key, strlen(key));
	md5_finish(&ctx, digest);

	strcpy(output, RAWMD5_PREFIX);
	for (i = 0; i < 16; i++)
		sprintf(output + sizeof(RAWMD5_PREFIX) - 1 + i * 2, "%02x",
				255 & digest[i]);

	return output;
}

static crypt_impl_t rawmd5_crypt_impl = {
	.id = "rawmd5",
	.crypt = &rawmd5_crypt_string,
};

void _modinit(module_t *m)
{
	crypt_register(&rawmd5_crypt_impl);
}

void _moddeinit(module_unload_intent_t intent)
{
	crypt_unregister(&rawmd5_crypt_impl);
}

/* vim:cinoptions=>s,e0,n0,f0,{0,}0,^0,=s,ps,t0,c3,+s,(2s,us,)20,*30,gs,hs
 * vim:ts=8
 * vim:sw=8
 * vim:noexpandtab
 */