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=relaxed/relaxed; d=example.com; s=test;\r\n\tt=1172620939; bh=Z9ONHHsBrKN0pbfrOu025VfbdR4=; l=340;\r\n\th=Received:Received:Received:From:To:Date:Subject:Message-ID;\r\n\tb=MGX4UPq8C9b0OStHs/99x1P92eN03t0TXVveQukipj6O67Eie9KZerqH9pmCKgUIf\r\n\t OqxlJf22RlnbCw+FvYPT2nWGWf3o5pHenroLB5Fgu80i/g+xGbD7JkZRJTNUG1Co2t\r\n\t r6q263XUmcXP1tdrr+28AgW9t+U33zWu87UdV3es="
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 	u_int flags;
43 	DKIM_STAT status;
44 	uint64_t fixed_time;
45 	DKIM *dkim;
46 	DKIM_LIB *lib;
47 	dkim_sigkey_t key;
48 	unsigned char hdr[MAXHEADER + 1];
49 
50 	printf("*** relaxed/relaxed rsa-sha1 signing with lengths\n");
51 
52 #ifdef USE_GNUTLS
53 	(void) gnutls_global_init();
54 #endif /* USE_GNUTLS */
55 
56 	/* instantiate the library */
57 	lib = dkim_init(NULL, NULL);
58 	assert(lib != NULL);
59 
60 #ifdef TEST_KEEP_FILES
61 	/* set flags */
62 	flags = (DKIM_LIBFLAGS_TMPFILES|DKIM_LIBFLAGS_KEEPFILES);
63 	(void) dkim_options(lib, DKIM_OP_SETOPT, DKIM_OPTS_FLAGS, &flags,
64 	                    sizeof flags);
65 #endif /* TEST_KEEP_FILES */
66 
67 	(void) dkim_options(lib, DKIM_OP_GETOPT, DKIM_OPTS_FLAGS, &flags,
68 	                    sizeof flags);
69 	flags |= DKIM_LIBFLAGS_SIGNLEN;
70 	(void) dkim_options(lib, DKIM_OP_SETOPT, DKIM_OPTS_FLAGS, &flags,
71 	                    sizeof flags);
72 
73 	key = KEY;
74 
75 	dkim = dkim_sign(lib, JOBID, NULL, key, SELECTOR, DOMAIN,
76 	                 DKIM_CANON_RELAXED, DKIM_CANON_RELAXED,
77 	                 DKIM_SIGN_RSASHA1, -1L, &status);
78 	assert(dkim != NULL);
79 
80 	/* fix signing time */
81 	fixed_time = 1172620939;
82 	(void) dkim_options(lib, DKIM_OP_SETOPT, DKIM_OPTS_FIXEDTIME,
83 	                    &fixed_time, sizeof fixed_time);
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_OK);
155 
156 	memset(hdr, '\0', sizeof hdr);
157 	status = dkim_getsighdr(dkim, hdr, sizeof hdr,
158 	                        strlen(DKIM_SIGNHEADER) + 2);
159 	assert(status == DKIM_STAT_OK);
160 	assert(strcmp(SIG2, hdr) == 0);
161 
162 	status = dkim_free(dkim);
163 	assert(status == DKIM_STAT_OK);
164 
165 	dkim_close(lib);
166 
167 	return 0;
168 }
169