/* ** Copyright (c) 2005-2007 Sendmail, Inc. and its suppliers. ** All rights reserved. */ #ifndef lint static char t_test57_c_id[] = "@(#)$Id: t-test57.c,v 1.7 2007/07/27 05:39:47 msk Exp $"; #endif /* !lint */ /* system includes */ #include #include #include #include #include #include /* libdkim includes */ #include "dkim.h" #include "t-testdata.h" /* libsm includes */ #include #define MAXHEADER 4096 #define SIG1 "v=1; a=rsa-sha256; c=relaxed/simple; d=example.com; s=test; t=1172620939; bh=TRy6u0KYixKENCPL95G1Y1uwclQ9rWthX6rFgE7gWb8=; h=Received:Received:Received:From:To:Date:Subject:Message-ID; b=aMDMwcz08Na0zYLrEZnUMBUipMh3blE+pWiBSvX+t2ynaDUGTqd27xuR5JddL9y1T6h0LkUMIcijsPBWa1WWfKL23QceksV75Y1/Tt6gmVi3SdVAoJbbZImrOaAQ3YQAn64dp1vI0Z8gSashYlwy+7gtmVSLAj/fpcAF6yNDPuE=" #define SIG2 "v=1; a=rsa-sha256; c=relaxed/simple; d=example.com; s=test;\r\n\tt=1172620939; bh=TRy6u0KYixKENCPL95G1Y1uwclQ9rWthX6rFgE7gWb8=;\r\n\th=Received:Received:Received:From:To:Date:Subject:Message-ID; b=aMD\r\n\tMwcz08Na0zYLrEZnUMBUipMh3blE+pWiBSvX+t2ynaDUGTqd27xuR5JddL9y1T6h0Lk\r\n\tUMIcijsPBWa1WWfKL23QceksV75Y1/Tt6gmVi3SdVAoJbbZImrOaAQ3YQAn64dp1vI0\r\n\tZ8gSashYlwy+7gtmVSLAj/fpcAF6yNDPuE=" /* ** MAIN -- program mainline ** ** Parameters: ** The usual. ** ** Return value: ** Exit status. */ int main(int argc, char **argv) { #ifndef DKIM_SIGN_RSASHA256 printf("*** relaxed/simple rsa-sha256 signing random chunk sizes SKIPPED\n"); #else /* ! DKIM_SIGN_RSASHA256 */ u_int wlen = LARGEBODYSIZE; u_int remain; # ifdef TEST_KEEP_FILES u_int flags; # endif /* TEST_KEEP_FILES */ DKIM_STAT status; time_t fixed_time; u_char *start; u_char *end; DKIM *dkim; DKIM_LIB *lib; dkim_sigkey_t key; struct timeval t; unsigned char hdr[MAXHEADER + 1]; unsigned char body[LARGEBODYSIZE]; printf("*** relaxed/simple rsa-sha256 signing random chunk sizes\n"); /* instantiate the library */ lib = dkim_init(NULL, NULL); assert(lib != NULL); # ifdef TEST_KEEP_FILES /* set flags */ flags = (DKIM_LIBFLAGS_TMPFILES|DKIM_LIBFLAGS_KEEPFILES); (void) dkim_options(lib, DKIM_OP_SETOPT, DKIM_OPTS_FLAGS, &flags, sizeof flags); # endif /* TEST_KEEP_FILES */ key = KEY; dkim = dkim_sign(lib, JOBID, NULL, key, SELECTOR, DOMAIN, DKIM_CANON_RELAXED, DKIM_CANON_SIMPLE, DKIM_SIGN_RSASHA256, -1L, &status); assert(dkim != NULL); /* fix signing time */ fixed_time = 1172620939; (void) dkim_options(lib, DKIM_OP_SETOPT, DKIM_OPTS_FIXEDTIME, &fixed_time, sizeof fixed_time); status = dkim_header(dkim, HEADER02, strlen(HEADER02)); assert(status == DKIM_STAT_OK); status = dkim_header(dkim, HEADER03, strlen(HEADER03)); assert(status == DKIM_STAT_OK); status = dkim_header(dkim, HEADER04, strlen(HEADER04)); assert(status == DKIM_STAT_OK); status = dkim_header(dkim, HEADER05, strlen(HEADER05)); assert(status == DKIM_STAT_OK); status = dkim_header(dkim, HEADER06, strlen(HEADER06)); assert(status == DKIM_STAT_OK); status = dkim_header(dkim, HEADER07, strlen(HEADER07)); assert(status == DKIM_STAT_OK); status = dkim_header(dkim, HEADER08, strlen(HEADER08)); assert(status == DKIM_STAT_OK); status = dkim_header(dkim, HEADER09, strlen(HEADER09)); assert(status == DKIM_STAT_OK); status = dkim_eoh(dkim); assert(status == DKIM_STAT_OK); memset(body, '\0', sizeof body); while (wlen > strlen(GIBBERISH)) { sm_strlcat(body, GIBBERISH, sizeof body); wlen -= strlen(GIBBERISH); } /* random-length chunks */ (void) gettimeofday(&t, NULL); srandom(t.tv_usec); start = body; remain = strlen(body); end = body + remain; while (start < end) { wlen = random() % sizeof body + 1; if (wlen > remain) wlen = remain; printf("%d... ", wlen); status = dkim_body(dkim, start, wlen); assert(status == DKIM_STAT_OK); start += wlen; remain -= wlen; } printf("done!\n"); status = dkim_body(dkim, CRLF, strlen(CRLF)); assert(status == DKIM_STAT_OK); status = dkim_eom(dkim, NULL); assert(status == DKIM_STAT_OK); memset(hdr, '\0', sizeof hdr); status = dkim_getsighdr(dkim, hdr, sizeof hdr, 0, 0); assert(status == DKIM_STAT_OK); assert(strcmp(SIG1, hdr) == 0); memset(hdr, '\0', sizeof hdr); status = dkim_getsighdr(dkim, hdr, sizeof hdr, 75, strlen(DKIM_SIGNHEADER) + 2); assert(status == DKIM_STAT_OK); assert(strcmp(SIG2, hdr) == 0); status = dkim_free(dkim); assert(status == DKIM_STAT_OK); dkim_close(lib); #endif /* ! DKIM_SIGN_RSASHA256 */ return 0; }