Back to index

opendkim  2.6.2
Defines | Functions | Variables
t-test129.c File Reference
#include "build-config.h"
#include <sys/types.h>
#include <assert.h>
#include <string.h>
#include <stdio.h>
#include "../dkim.h"
#include "t-testdata.h"

Go to the source code of this file.

Defines

#define MAXHEADER   4096
#define AUTHRESHDR   "Authentication-Results"
#define AUTHRESVAL   "example.net; dkim=pass header.i=@example.com"
#define JOBID1   "testing1"
#define JOBID2   "testing2"
#define JOBID3   "testing3"
#define FALSE   0
#define TRUE   1
#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="

Functions

int main (int argc, char **argv)

Variables

static char t_test129_c_id [] = "@(#)$Id: t-test129.c,v 1.2 2009/12/08 19:14:27 cm-msk Exp $"
const u_char * signhdrs []

Define Documentation

#define AUTHRESHDR   "Authentication-Results"

Definition at line 30 of file t-test129.c.

#define AUTHRESVAL   "example.net; dkim=pass header.i=@example.com"

Definition at line 31 of file t-test129.c.

#define FALSE   0

Definition at line 38 of file t-test129.c.

#define JOBID1   "testing1"

Definition at line 33 of file t-test129.c.

#define JOBID2   "testing2"

Definition at line 34 of file t-test129.c.

#define JOBID3   "testing3"

Definition at line 35 of file t-test129.c.

#define MAXHEADER   4096

Definition at line 28 of file t-test129.c.

#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="

Definition at line 44 of file t-test129.c.

#define TRUE   1

Definition at line 41 of file t-test129.c.


Function Documentation

int main ( int  argc,
char **  argv 
)

Definition at line 92 of file t-test129.c.

{
#ifdef TEST_KEEP_FILES
       u_int flags;
#endif /* TEST_KEEP_FILES */
       DKIM_STAT status;
       uint64_t fixed_time;
       dkim_sigkey_t key;
       DKIM *dkim;
       DKIM *resign;
       DKIM_LIB *lib;
       dkim_query_t qtype = DKIM_QUERY_FILE;
       unsigned char hdr[MAXHEADER + 1];
       unsigned char hdr2[MAXHEADER + 1];

       key = KEY;

#ifdef USE_GNUTLS
       (void) gnutls_global_init();
#endif /* USE_GNUTLS */

       /* instantiate the library */
       lib = dkim_init(NULL, NULL);
       assert(lib != NULL);

       if (!dkim_libfeature(lib, DKIM_FEATURE_RESIGN))
       {
              printf("*** relaxed/simple rsa-sha1 re-signing without header binding SKIPPED\n");
              dkim_close(lib);
              return 0;
       }

       printf("*** relaxed/simple rsa-sha1 re-signing without header binding\n");

#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 */

       /* test mode */
       (void) dkim_options(lib, DKIM_OP_SETOPT, DKIM_OPTS_QUERYMETHOD,
                           &qtype, sizeof qtype);
       (void) dkim_options(lib, DKIM_OP_SETOPT, DKIM_OPTS_QUERYINFO,
                           KEYFILE, strlen(KEYFILE));

       /* fix signing time */
       fixed_time = 1172620939;
       (void) dkim_options(lib, DKIM_OP_SETOPT, DKIM_OPTS_FIXEDTIME,
                           &fixed_time, sizeof fixed_time);

       /* restrict signed headers */
       (void) dkim_options(lib, DKIM_OP_SETOPT, DKIM_OPTS_SIGNHDRS,
                           signhdrs, sizeof(u_char **));

       dkim = dkim_verify(lib, JOBID1, NULL, &status);
       assert(dkim != NULL);

       snprintf(hdr, sizeof hdr, "%s: %s", DKIM_SIGNHEADER, SIG2);
       status = dkim_header(dkim, hdr, strlen(hdr));
       assert(status == DKIM_STAT_OK);

       status = dkim_header(dkim, HEADER01, strlen(HEADER01));
       assert(status == DKIM_STAT_OK);

       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);

       resign = dkim_sign(lib, JOBID2, NULL, key, SELECTOR, DOMAIN,
                          DKIM_CANON_RELAXED, DKIM_CANON_SIMPLE,
                          DKIM_SIGN_RSASHA1, -1L, &status);
       assert(resign != NULL);

       status = dkim_resign(dkim, resign, TRUE);
       assert(status == DKIM_STAT_INVALID);

       status = dkim_resign(resign, dkim, FALSE);
       assert(status == DKIM_STAT_OK);

       status = dkim_eoh(dkim);
       assert(status == DKIM_STAT_OK);

       snprintf(hdr, sizeof hdr, "%s: %s", DKIM_SIGNHEADER, SIG2);
       status = dkim_header(resign, hdr, strlen(hdr));
       assert(status == DKIM_STAT_OK);

       status = dkim_header(resign, HEADER01, strlen(HEADER01));
       assert(status == DKIM_STAT_OK);

       status = dkim_header(resign, HEADER02, strlen(HEADER02));
       assert(status == DKIM_STAT_OK);

       status = dkim_header(resign, HEADER03, strlen(HEADER03));
       assert(status == DKIM_STAT_OK);

       status = dkim_header(resign, HEADER04, strlen(HEADER04));
       assert(status == DKIM_STAT_OK);

       status = dkim_header(resign, HEADER05, strlen(HEADER05));
       assert(status == DKIM_STAT_OK);

       status = dkim_header(resign, HEADER06, strlen(HEADER06));
       assert(status == DKIM_STAT_OK);

       status = dkim_header(resign, HEADER07, strlen(HEADER07));
       assert(status == DKIM_STAT_OK);

       status = dkim_header(resign, HEADER08, strlen(HEADER08));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY00, strlen(BODY00));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(resign, BODY00, strlen(BODY00));
       assert(status == DKIM_STAT_INVALID);

       status = dkim_body(dkim, BODY01, strlen(BODY01));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY01A, strlen(BODY01A));
       assert(status == DKIM_STAT_OK);
       status = dkim_body(dkim, BODY01B, strlen(BODY01B));
       assert(status == DKIM_STAT_OK);
       status = dkim_body(dkim, BODY01C, strlen(BODY01C));
       assert(status == DKIM_STAT_OK);
       status = dkim_body(dkim, BODY01D, strlen(BODY01D));
       assert(status == DKIM_STAT_OK);
       status = dkim_body(dkim, BODY01E, strlen(BODY01E));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY02, strlen(BODY02));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY03, strlen(BODY03));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY04, strlen(BODY04));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY03, strlen(BODY03));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY03, strlen(BODY03));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY05, strlen(BODY05));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY03, strlen(BODY03));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY03, strlen(BODY03));
       assert(status == DKIM_STAT_OK);

       status = dkim_eom(resign, NULL);
       assert(status == DKIM_STAT_INVALID);

       status = dkim_eom(dkim, NULL);
       assert(status == DKIM_STAT_OK);

       snprintf(hdr, sizeof hdr, "%s: %s", AUTHRESHDR, AUTHRESVAL);
       status = dkim_header(resign, hdr, strlen(hdr));
       assert(status == DKIM_STAT_OK);

       status = dkim_eoh(resign);
       assert(status == DKIM_STAT_OK);

       status = dkim_eom(resign, NULL);
       assert(status == DKIM_STAT_OK);

       memset(hdr, '\0', sizeof hdr);
       status = dkim_getsighdr(resign, hdr, sizeof hdr,
                               strlen(DKIM_SIGNHEADER) + 2);
       assert(status == DKIM_STAT_OK);

       status = dkim_free(dkim);
       assert(status == DKIM_STAT_INVALID);

       status = dkim_free(resign);
       assert(status == DKIM_STAT_OK);

       status = dkim_free(dkim);
       assert(status == DKIM_STAT_OK);

       /* now see if that one was valid */
       dkim = dkim_verify(lib, JOBID3, NULL, &status);
       assert(dkim != NULL);

       snprintf(hdr2, sizeof hdr2, "%s: %s", DKIM_SIGNHEADER, hdr);
       status = dkim_header(dkim, hdr2, strlen(hdr2));
       assert(status == DKIM_STAT_OK);

       snprintf(hdr2, sizeof hdr2, "%s: %s", DKIM_SIGNHEADER, SIG2);
       status = dkim_header(dkim, hdr2, strlen(hdr2));
       assert(status == DKIM_STAT_OK);

       status = dkim_header(dkim, HEADER01, strlen(HEADER01));
       assert(status == DKIM_STAT_OK);

       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);

       snprintf(hdr, sizeof hdr, "%s: %s", AUTHRESHDR, AUTHRESVAL);
       status = dkim_header(dkim, hdr, strlen(hdr));
       assert(status == DKIM_STAT_OK);

       status = dkim_eoh(dkim);
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY00, strlen(BODY00));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY01, strlen(BODY01));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY01A, strlen(BODY01A));
       assert(status == DKIM_STAT_OK);
       status = dkim_body(dkim, BODY01B, strlen(BODY01B));
       assert(status == DKIM_STAT_OK);
       status = dkim_body(dkim, BODY01C, strlen(BODY01C));
       assert(status == DKIM_STAT_OK);
       status = dkim_body(dkim, BODY01D, strlen(BODY01D));
       assert(status == DKIM_STAT_OK);
       status = dkim_body(dkim, BODY01E, strlen(BODY01E));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY02, strlen(BODY02));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY03, strlen(BODY03));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY04, strlen(BODY04));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY03, strlen(BODY03));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY03, strlen(BODY03));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY05, strlen(BODY05));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY03, strlen(BODY03));
       assert(status == DKIM_STAT_OK);

       status = dkim_body(dkim, BODY03, strlen(BODY03));
       assert(status == DKIM_STAT_OK);

       status = dkim_eom(dkim, NULL);
       assert(status == DKIM_STAT_OK);

       status = dkim_free(dkim);
       assert(status == DKIM_STAT_OK);

       dkim_close(lib);

       return 0;
}

Here is the call graph for this function:


Variable Documentation

const u_char* signhdrs[]

Definition at line 47 of file t-test129.c.

char t_test129_c_id[] = "@(#)$Id: t-test129.c,v 1.2 2009/12/08 19:14:27 cm-msk Exp $" [static]

Definition at line 9 of file t-test129.c.