1 /*
2 ** Copyright (c) 2005-2008 Sendmail, Inc. and its suppliers.
3 ** All rights reserved.
4 **
5 ** Copyright (c) 2009, 2011, 2012, The Trusted Domain Project.
6 ** All rights reserved.
7 */
8
9 #include "build-config.h"
10
11 /* system includes */
12 #include <sys/types.h>
13 #include <assert.h>
14 #include <string.h>
15 #include <stdio.h>
16
17 #ifdef USE_GNUTLS
18 # include <gnutls/gnutls.h>
19 #endif /* USE_GNUTLS */
20
21 /* libopendkim includes */
22 #include "../dkim.h"
23 #include "t-testdata.h"
24
25 #define MAXHEADER 4096
26
27 #define SIG2 "v=1; a=rsa-sha1; c=nofws/simple; d=example.com; s=test;\r\n\tt=1172620939; bh=ll/0h2aWgG+D3ewmE4Y3pY7Ukz8=; h=Received:Received:\r\n\t Received:From:To:Date:Subject:Message-ID; b=bj9kVUbnBYfe9sVzH9lT45\r\n\tTFKO3eQnDbXLfgmgu/b5QgxcnhT9ojnV2IAM4KUO8+hOo5sDEu5Co/0GASH0vHpSV4P\r\n\t377Iwew3FxvLpHsVbVKgXzoKD4QSbHRpWNxyL6LypaaqFa96YqjXuYXr0vpb88hticn\r\n\t6I16//WThMz8fMU="
28
29 /*
30 ** MAIN -- program mainline
31 **
32 ** Parameters:
33 ** The usual.
34 **
35 ** Return value:
36 ** Exit status.
37 */
38
39 int
main(int argc,char ** argv)40 main(int argc, char **argv)
41 {
42 #ifdef TEST_KEEP_FILES
43 u_int flags;
44 #endif /* TEST_KEEP_FILES */
45 int nsigs;
46 DKIM_STAT status;
47 DKIM *dkim;
48 DKIM_LIB *lib;
49 DKIM_SIGINFO **sigs;
50 dkim_query_t qtype = DKIM_QUERY_FILE;
51 unsigned char hdr[MAXHEADER + 1];
52
53 printf("*** relaxed/simple rsa-sha1 verifying with bogus canonicalization\n");
54
55 #ifdef USE_GNUTLS
56 (void) gnutls_global_init();
57 #endif /* USE_GNUTLS */
58
59 /* instantiate the library */
60 lib = dkim_init(NULL, NULL);
61 assert(lib != NULL);
62
63 #ifdef TEST_KEEP_FILES
64 /* set flags */
65 flags = (DKIM_LIBFLAGS_TMPFILES|DKIM_LIBFLAGS_KEEPFILES);
66 (void) dkim_options(lib, DKIM_OP_SETOPT, DKIM_OPTS_FLAGS, &flags,
67 sizeof flags);
68 #endif /* TEST_KEEP_FILES */
69
70 (void) dkim_options(lib, DKIM_OP_SETOPT, DKIM_OPTS_QUERYMETHOD,
71 &qtype, sizeof qtype);
72 (void) dkim_options(lib, DKIM_OP_SETOPT, DKIM_OPTS_QUERYINFO,
73 KEYFILE, strlen(KEYFILE));
74
75 dkim = dkim_verify(lib, JOBID, NULL, &status);
76 assert(dkim != NULL);
77
78 snprintf(hdr, sizeof hdr, "%s: %s", DKIM_SIGNHEADER, SIG2);
79 status = dkim_header(dkim, hdr, strlen(hdr));
80 assert(status == DKIM_STAT_OK);
81
82 status = dkim_header(dkim, HEADER01, strlen(HEADER01));
83 assert(status == DKIM_STAT_OK);
84
85 status = dkim_header(dkim, HEADER02, strlen(HEADER02));
86 assert(status == DKIM_STAT_OK);
87
88 status = dkim_header(dkim, HEADER03, strlen(HEADER03));
89 assert(status == DKIM_STAT_OK);
90
91 status = dkim_header(dkim, HEADER04, strlen(HEADER04));
92 assert(status == DKIM_STAT_OK);
93
94 status = dkim_header(dkim, HEADER05, strlen(HEADER05));
95 assert(status == DKIM_STAT_OK);
96
97 status = dkim_header(dkim, HEADER06, strlen(HEADER06));
98 assert(status == DKIM_STAT_OK);
99
100 status = dkim_header(dkim, HEADER07, strlen(HEADER07));
101 assert(status == DKIM_STAT_OK);
102
103 status = dkim_header(dkim, HEADER08, strlen(HEADER08));
104 assert(status == DKIM_STAT_OK);
105
106 status = dkim_header(dkim, HEADER09, strlen(HEADER09));
107 assert(status == DKIM_STAT_OK);
108
109 status = dkim_eoh(dkim);
110 assert(status == DKIM_STAT_OK);
111
112 status = dkim_body(dkim, BODY00, strlen(BODY00));
113 assert(status == DKIM_STAT_OK);
114
115 status = dkim_body(dkim, BODY01, strlen(BODY01));
116 assert(status == DKIM_STAT_OK);
117
118 status = dkim_body(dkim, BODY01A, strlen(BODY01A));
119 assert(status == DKIM_STAT_OK);
120 status = dkim_body(dkim, BODY01B, strlen(BODY01B));
121 assert(status == DKIM_STAT_OK);
122 status = dkim_body(dkim, BODY01C, strlen(BODY01C));
123 assert(status == DKIM_STAT_OK);
124 status = dkim_body(dkim, BODY01D, strlen(BODY01D));
125 assert(status == DKIM_STAT_OK);
126 status = dkim_body(dkim, BODY01E, strlen(BODY01E));
127 assert(status == DKIM_STAT_OK);
128
129 status = dkim_body(dkim, BODY02, strlen(BODY02));
130 assert(status == DKIM_STAT_OK);
131
132 status = dkim_body(dkim, BODY03, strlen(BODY03));
133 assert(status == DKIM_STAT_OK);
134
135 status = dkim_body(dkim, BODY04, strlen(BODY04));
136 assert(status == DKIM_STAT_OK);
137
138 status = dkim_body(dkim, BODY03, strlen(BODY03));
139 assert(status == DKIM_STAT_OK);
140
141 status = dkim_body(dkim, BODY03, strlen(BODY03));
142 assert(status == DKIM_STAT_OK);
143
144 status = dkim_body(dkim, BODY05, strlen(BODY05));
145 assert(status == DKIM_STAT_OK);
146
147 status = dkim_body(dkim, BODY03, strlen(BODY03));
148 assert(status == DKIM_STAT_OK);
149
150 status = dkim_body(dkim, BODY03, strlen(BODY03));
151 assert(status == DKIM_STAT_OK);
152
153 status = dkim_eom(dkim, NULL);
154 assert(status == DKIM_STAT_CANTVRFY);
155
156 status = dkim_getsiglist(dkim, &sigs, &nsigs);
157 assert(status == DKIM_STAT_OK);
158 assert(nsigs == 1);
159 assert(dkim_sig_geterror(sigs[0]) == DKIM_SIGERROR_INVALID_HC);
160
161 status = dkim_free(dkim);
162 assert(status == DKIM_STAT_OK);
163
164 dkim_close(lib);
165
166 return 0;
167 }
168