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/simple; d=example.com; s=test;\r\n\tt=1172620939; bh=ll/0h2aWgG+D3ewmE4Y3pY7Ukz8=;\r\n\th=Received:Received:Received:From:To:Date:Subject:Message-ID;\r\n\tb=Q4G/ki/5soDXGxs43JfV+qEKDr5X3GgTDNeZqWL3zLLC5DXWWzmnKRcU8NH4Wsfkh\r\n\t o5tMo4NRmqnB2eZtozsyXdHo2ekUPLxuAQJomM4JHaPTfsraHwkibQIkPpW5hf/Rc2\r\n\t 0QgP48iQBjxqcOSn/Vwk5QDup4Qj1vgOxBqTqwdg="
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 	DKIM_STAT status;
46 	uint64_t fixed_time;
47 	DKIM *dkim;
48 	DKIM_LIB *lib;
49 	dkim_sigkey_t key;
50 	unsigned char hdr[MAXHEADER + 1];
51 
52 	printf("*** relaxed/simple rsa-sha1 signing\n");
53 
54 #ifdef USE_GNUTLS
55 	(void) gnutls_global_init();
56 #endif /* USE_GNUTLS */
57 
58 	/* instantiate the library */
59 	lib = dkim_init(NULL, NULL);
60 	assert(lib != NULL);
61 
62 #ifdef TEST_KEEP_FILES
63 	/* set flags */
64 	flags = (DKIM_LIBFLAGS_TMPFILES|DKIM_LIBFLAGS_KEEPFILES);
65 	(void) dkim_options(lib, DKIM_OP_SETOPT, DKIM_OPTS_FLAGS, &flags,
66 	                    sizeof flags);
67 #endif /* TEST_KEEP_FILES */
68 
69 	key = KEY;
70 
71 	dkim = dkim_sign(lib, JOBID, NULL, key, SELECTOR, DOMAIN,
72 	                 DKIM_CANON_RELAXED, DKIM_CANON_SIMPLE,
73 	                 DKIM_SIGN_RSASHA1, -1L, &status);
74 	assert(dkim != NULL);
75 
76 	/* fix signing time */
77 	fixed_time = 1172620939;
78 	(void) dkim_options(lib, DKIM_OP_SETOPT, DKIM_OPTS_FIXEDTIME,
79 	                    &fixed_time, sizeof fixed_time);
80 
81 	status = dkim_header(dkim, HEADER02, strlen(HEADER02));
82 	assert(status == DKIM_STAT_OK);
83 
84 	status = dkim_header(dkim, HEADER03, strlen(HEADER03));
85 	assert(status == DKIM_STAT_OK);
86 
87 	status = dkim_header(dkim, HEADER04, strlen(HEADER04));
88 	assert(status == DKIM_STAT_OK);
89 
90 	status = dkim_header(dkim, HEADER05, strlen(HEADER05));
91 	assert(status == DKIM_STAT_OK);
92 
93 	status = dkim_header(dkim, HEADER06, strlen(HEADER06));
94 	assert(status == DKIM_STAT_OK);
95 
96 	status = dkim_header(dkim, HEADER07, strlen(HEADER07));
97 	assert(status == DKIM_STAT_OK);
98 
99 	status = dkim_header(dkim, HEADER08, strlen(HEADER08));
100 	assert(status == DKIM_STAT_OK);
101 
102 	status = dkim_header(dkim, HEADER09, strlen(HEADER09));
103 	assert(status == DKIM_STAT_OK);
104 
105 	status = dkim_eoh(dkim);
106 	assert(status == DKIM_STAT_OK);
107 
108 	status = dkim_body(dkim, BODY00, strlen(BODY00));
109 	assert(status == DKIM_STAT_OK);
110 
111 	status = dkim_body(dkim, BODY01, strlen(BODY01));
112 	assert(status == DKIM_STAT_OK);
113 
114 	status = dkim_body(dkim, BODY01A, strlen(BODY01A));
115 	assert(status == DKIM_STAT_OK);
116 	status = dkim_body(dkim, BODY01B, strlen(BODY01B));
117 	assert(status == DKIM_STAT_OK);
118 	status = dkim_body(dkim, BODY01C, strlen(BODY01C));
119 	assert(status == DKIM_STAT_OK);
120 	status = dkim_body(dkim, BODY01D, strlen(BODY01D));
121 	assert(status == DKIM_STAT_OK);
122 	status = dkim_body(dkim, BODY01E, strlen(BODY01E));
123 	assert(status == DKIM_STAT_OK);
124 
125 	status = dkim_body(dkim, BODY02, strlen(BODY02));
126 	assert(status == DKIM_STAT_OK);
127 
128 	status = dkim_body(dkim, BODY03, strlen(BODY03));
129 	assert(status == DKIM_STAT_OK);
130 
131 	status = dkim_body(dkim, BODY04, strlen(BODY04));
132 	assert(status == DKIM_STAT_OK);
133 
134 	status = dkim_body(dkim, BODY03, strlen(BODY03));
135 	assert(status == DKIM_STAT_OK);
136 
137 	status = dkim_body(dkim, BODY03, strlen(BODY03));
138 	assert(status == DKIM_STAT_OK);
139 
140 	status = dkim_body(dkim, BODY05, strlen(BODY05));
141 	assert(status == DKIM_STAT_OK);
142 
143 	status = dkim_body(dkim, BODY03, strlen(BODY03));
144 	assert(status == DKIM_STAT_OK);
145 
146 	status = dkim_body(dkim, BODY03, strlen(BODY03));
147 	assert(status == DKIM_STAT_OK);
148 
149 	status = dkim_eom(dkim, NULL);
150 	assert(status == DKIM_STAT_OK);
151 
152 	memset(hdr, '\0', sizeof hdr);
153 	status = dkim_getsighdr(dkim, hdr, sizeof hdr,
154 	                        strlen(DKIM_SIGNHEADER) + 2);
155 	assert(status == DKIM_STAT_OK);
156 	assert(strcmp(SIG2, hdr) == 0);
157 
158 	status = dkim_free(dkim);
159 	assert(status == DKIM_STAT_OK);
160 
161 	dkim_close(lib);
162 
163 	return 0;
164 }
165