annotate src/md5/hmactest.c @ 179:ec3fe72a3e99

Fixed an important bug with folded headers! g_strconcat() returns a *copy* of the string, but hdr->value still pointed to the old header (which probably was a memory leak, too). If the folded part had been quite small it was likely that the new string was at the same position as the old one, thus making everything go well. But if pretty long headers were folded several times it was likely that the new string was allocated somewhere else in memory, thus breaking things. In result mails to lots of recipients (folded header) were frequently only sent to the ones in the first line. Sorry for the inconvenience.
author meillo@marmaro.de
date Fri, 03 Jun 2011 09:52:17 +0200
parents ca99aa7f052a
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
08114f7dcc23 this is masqmail-0.2.21 from oliver kurth
meillo@marmaro.de
parents:
diff changeset
1 #include <stdio.h>
08114f7dcc23 this is masqmail-0.2.21 from oliver kurth
meillo@marmaro.de
parents:
diff changeset
2 #include <stdlib.h>
08114f7dcc23 this is masqmail-0.2.21 from oliver kurth
meillo@marmaro.de
parents:
diff changeset
3 #include <sys/time.h>
08114f7dcc23 this is masqmail-0.2.21 from oliver kurth
meillo@marmaro.de
parents:
diff changeset
4 #include <string.h>
08114f7dcc23 this is masqmail-0.2.21 from oliver kurth
meillo@marmaro.de
parents:
diff changeset
5 #include "md5.h"
08114f7dcc23 this is masqmail-0.2.21 from oliver kurth
meillo@marmaro.de
parents:
diff changeset
6 #include "hmac_md5.h"
08114f7dcc23 this is masqmail-0.2.21 from oliver kurth
meillo@marmaro.de
parents:
diff changeset
7
165
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
8 /*
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
9 instead of pad0_copy(d, s, sz) use:
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
10 memset(d, 0, sz);
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
11 memcpy(d, s, strlen(s));
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
12
10
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
13 static void
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
14 pad0_copy(char *d, char *s, int sz)
0
08114f7dcc23 this is masqmail-0.2.21 from oliver kurth
meillo@marmaro.de
parents:
diff changeset
15 {
10
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
16 int i = 0;
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
17 while (*s && (i < sz)) {
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
18 *(d++) = *(s++);
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
19 i++;
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
20 }
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
21 while (i <= sz) {
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
22 *(d++) = 0;
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
23 i++;
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
24 }
0
08114f7dcc23 this is masqmail-0.2.21 from oliver kurth
meillo@marmaro.de
parents:
diff changeset
25 }
165
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
26 */
0
08114f7dcc23 this is masqmail-0.2.21 from oliver kurth
meillo@marmaro.de
parents:
diff changeset
27
10
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
28 int
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
29 main()
0
08114f7dcc23 this is masqmail-0.2.21 from oliver kurth
meillo@marmaro.de
parents:
diff changeset
30 {
10
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
31 int i;
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
32 char digest[16];
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
33 char *msgid = "<1896.697170952@postoffice.reston.mci.net>";
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
34 char secret[65];
0
08114f7dcc23 this is masqmail-0.2.21 from oliver kurth
meillo@marmaro.de
parents:
diff changeset
35
165
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
36
10
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
37 hmac_md5("<48157.953508124@mail.class-c.net>", 34, "no!SpamAtAll", 12, digest);
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
38 for (i = 0; i < 16; i++)
165
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
39 printf("%.2x", 0xFF & (unsigned int) digest[i]);
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
40 printf("\n\n");
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
41
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
42
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
43 puts("---- The next two should be equal");
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
44
0
08114f7dcc23 this is masqmail-0.2.21 from oliver kurth
meillo@marmaro.de
parents:
diff changeset
45
10
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
46 hmac_md5(msgid, strlen(msgid), "tanstaaftanstaaf", 16, digest);
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
47 for (i = 0; i < 16; i++)
165
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
48 printf("%.2x", 0xFF & (unsigned int) digest[i]);
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
49 printf("\n\n");
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
50
0
08114f7dcc23 this is masqmail-0.2.21 from oliver kurth
meillo@marmaro.de
parents:
diff changeset
51
165
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
52 /* pad0_copy(secret, "tanstaaftanstaaf", 64); */
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
53 /* let's do it easier ... */
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
54 memset(secret, 0, sizeof(secret));
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
55 memcpy(secret, "tanstaaftanstaaf", 16);
10
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
56 hmac_md5(msgid, strlen(msgid), secret, 64, digest);
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
57 for (i = 0; i < 16; i++)
165
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
58 printf("%.2x", 0xFF & (unsigned int) digest[i]);
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
59 printf("\n\n");
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
60
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
61
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
62 puts("---- Following are the test vectors from RFC 2104");
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
63
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
64
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
65 char* d01 = "Hi There";
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
66 char k01[16];
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
67 for (i=0; i<16; i++) {
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
68 k01[i] = 0x0b;
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
69 }
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
70 printf("9294727a3638bb1c13f48ef8158bfc9d (should be)\n");
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
71 hmac_md5(d01, strlen(d01), k01, sizeof(k01), digest);
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
72 for (i = 0; i < 16; i++) {
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
73 printf("%.2x", 0xFF & (unsigned int) digest[i]);
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
74 }
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
75 printf(" (was computed)\n\n");
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
76
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
77
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
78 char* d02 = "what do ya want for nothing?";
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
79 char* k02 = "Jefe";
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
80 printf("750c783e6ab0b503eaa86e310a5db738 (should be)\n");
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
81 hmac_md5(d02, strlen(d02), k02, strlen(k02), digest);
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
82 for (i = 0; i < 16; i++) {
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
83 printf("%.2x", 0xFF & (unsigned int) digest[i]);
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
84 }
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
85 printf(" (was computed)\n\n");
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
86
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
87
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
88 char d03[50];
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
89 for (i=0; i<sizeof(d03); i++) {
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
90 d03[i] = 0xdd;
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
91 }
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
92 char k03[16];
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
93 for (i=0; i<sizeof(k03); i++) {
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
94 k03[i] = 0xaa;
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
95 }
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
96 printf("56be34521d144c88dbb8c733f0e8b3f6 (should be)\n");
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
97 hmac_md5(d03, sizeof(d03), k03, sizeof(k03), digest);
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
98 for (i = 0; i < 16; i++) {
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
99 printf("%.2x", 0xFF & (unsigned int) digest[i]);
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
100 }
ca99aa7f052a improved hmactest
meillo@marmaro.de
parents: 162
diff changeset
101 printf(" (was computed)\n\n");
0
08114f7dcc23 this is masqmail-0.2.21 from oliver kurth
meillo@marmaro.de
parents:
diff changeset
102
10
26e34ae9a3e3 changed indention and line wrapping to a more consistent style
meillo@marmaro.de
parents: 0
diff changeset
103 exit(0);
0
08114f7dcc23 this is masqmail-0.2.21 from oliver kurth
meillo@marmaro.de
parents:
diff changeset
104 }