]> code.citadel.org Git - citadel.git/blob - citadel/tests/dkimtester/dkimtester.c
minor tuning to previous commit
[citadel.git] / citadel / tests / dkimtester / dkimtester.c
1 // ***** TEST HARNESS *****
2 // This contains a private key that, at the time of writing, matches the DKIM public key for dev.citadel.org
3 // We can use the attached test message to validate a signature against that.
4
5 #include <stdio.h>
6 #include <syslog.h>
7 #include <libcitadel.h>
8
9 // This was easier than trying to figure out the header situation
10 void dkim_sign(StrBuf *email, char *pkey_in, char *domain, char *selector);
11
12 int main(int argc, char *argv[]) {
13
14         // display the greeting
15         fprintf(stderr,
16                 "\033[44m\033[1m╔════════════════════════════════════════════════════════════════════════╗\033[0m\n"
17                 "\033[44m\033[1m║ DKIM signature test program for Citadel                                ║\033[0m\n"
18                 "\033[44m\033[1m║ Copyright (c) 2024 by citadel.org (Art Cancro et al.)                  ║\033[0m\n"
19                 "\033[44m\033[1m║ This program is open source software.  Use, duplication, or disclosure ║\033[0m\n"
20                 "\033[44m\033[1m║ is subject to the terms of the GNU General Public license v3.          ║\033[0m\n"
21                 "\033[44m\033[1m╚════════════════════════════════════════════════════════════════════════╝\033[0m\n"
22         );
23
24         openlog("dkim", LOG_PERROR, LOG_USER);
25
26         // dkim.c can handle a PEM-encoded PKCS#7 private key that has had all of the newlines replaced by underscores.
27         // It will convert them back to newlines before importing the key.
28         // This is the format that Citadel Server uses to store the key in its configuration database.
29         char *private_key = "-----BEGIN PRIVATE KEY-----_MIIEvAIBADANBgkqhkiG9w0BAQEFAASCBKYwggSiAgEAAoIBAQDfuefcepokRrnp_SSDsxu+QDqeD8GL9QnZz/N6IxTdBv6Wc10ExBe2IjS5dKI7AvhSSEK0zGE8Hkpmw_eccbiepQqeueteWzAMZ1uT43bD3k7eye7vWobiOP9QtoYGR6sG25h2W5Tbc91W4f_dvYnxYVJjx8wIVF0f3o25v+rQueoo0HlvGyA9/xi9GAaJL05OmK1xnMJgSvW/Q8Q_zq7apf1D6XPXHuhv5tevElkZ5jlvM2w0cTVyAzMrUh6Rkcn9xM4/NPWYghBc3jO4_TrPnSrobQGrX0fcizE/FN6I0in0Ke8Z+gMM8NeFcsjvLZe9MpY9i0pw/ygLIh5t3_O4qpwC1JAgMBAAECggEAIwiTCMEAGzciDKhhagJ66BWLYMtHTP5X2zDZThSH4xlW_HznL4RfbCtuEy5y6we7h/L90x8ACPB7WRz7CkYrmsMvy9A7q0b2I1k10MyyVgqBJ_QdgMitv4YKYQK7+QbG/tNrS/lqVXUOz3iiDQSgkRpqOtUBWfkj0WD7vbhF99NDhV_dxaehFkKv3yNy0bXJlHJBJ6KtOUnDwub8TExh8dyj3kB8Qzj4I98shaXPNUSSaOw_zG6QG72yrxlMs495jkIPbF2JDidmLrX+oVISwKyaBWx+BkFV/KFAEKgaB5/nCw7+_qq/jxsmXim3HuQ3MIAjq1yw9aGRH1HMi8Gn7tYlNGwKBgQDy6EEKpuEiW9wwlI2+_GVuSkhSTTX1h6qK/ay8Jtyb8yJM/BxogAQlfjdgFixiZHy5MaomTbfeT2GDji553_+RsnZ60+g7FI9nHwabSxtuCQ+vjbFqCsdMPAiSeG0bEzo0zf5TjASdUtuZL0vXjl_yMZWDEuESoVNlYlvCOVkw2nvIwKBgQDryPuSq6PNVHRWsKRRs5ju4wKs/1ucBOg5_gCcN8lE03mFCWAlZhypE4/fAhTQ/a5KQoAzc0QZcXRueDyNsnc+QWw3/QWf8/fkV_HPfTWS3Dcuj+4RnWUucaZ/mKFlTC3+eNSlpyaPIMlCjXGsJ9GlPrsaAi9KPbD2v/_XcMq/PMOowKBgHVf7S3sfZVQthFzdxqIvksQ84hKRW/vJT1B2bTkH56+fQhTsjgM_yC64J85l7DjxbDnYsSngVWXHhOnvKV/nq0tbOcefcydCjsQREBNfvxvPajjTskgj_FAQRQlxPL0U4f4khBk9EXhJ+PZithaHjZpNl1YfTSp62x3Yz4kTSeHnpAoGAGn5m_5kArE7NdrzACBrwrfww7DL1Uyd8zSOLBgKutvEcQnqfNxSWO9la3TAarrESmH2Ic_j+Nc15wOsl/5FwdUf1/73qa2zJKtHlY28qSeo8uRqrIYeSCvnyP3wjBoLc2C8zlb_mGd6azdqr2DuYahHrcAzwjnC/6Zn+DXM7FOn7AkCgYBp1xxY88cCoF24yffkD3MC_ACUury4qRSDTGx6/qCCkIyWxg1vuiDrlPWhSwQznxHvovcfpdjdbWcFY87IK6mpG_aJHwMJ7Kw+baoxGPZWHwdg6BgvUCihe3xlcaq6rOBoLviD6FOzbogg++Tvi0LemG_y/wEs/mZkaRzW4n41ir0Xw==_-----END PRIVATE KEY-----";
30
31         char *domain = "dev.citadel.org";
32         char *selector = "foo";
33
34         // Sample message
35         StrBuf *email = NewStrBufPlain(HKEY(
36                 "From: Fred Bloggs <bloggs@dev.citadel.org>\r\n"
37                 "X-irrelevant-header: wow mom 303\r\n"
38                 "To: Bread Floggs <bf@example.com>\r\n"
39                 "Subject: The ultimate  test message\r\n"
40                 "Message-ID: <73294856-8726543-473298@dev.citadel.org>\r\n"
41                 "\r\n"
42                 "Hi.\r\n"
43                 "\r\n"
44                 "Bhille Disassemble.  Highly recommend.\r\n"
45                 "\r\n"
46                 "--Fred\r\n"
47
48
49         ));
50
51         // create signature
52         dkim_sign(email, private_key, domain, selector);
53
54         // Show the user what we did
55         printf("%s", (char *)ChrPtr(email));
56
57         FILE *fp;
58         printf("\033[34m-----\033[0m\n");
59         printf("Piping original version to test program (this should pass)\n");
60         fp = popen("./tester.pl | sed s/pass/\033[32mpass\033[0m/g | sed s/fail/\033[31mfail\033[0m/g", "w");
61         fwrite((char *)ChrPtr(email), StrLength(email), 1, fp);
62         pclose(fp);
63         printf("\033[34m-----\033[0m\n");
64         printf("Piping altered version to test program (this should fail)\n");
65         fp = popen("sed s/oggs/argh/g | ./tester.pl | sed s/pass/\033[32mpass\033[0m/g | sed s/fail/\033[31mfail\033[0m/g", "w");
66         fwrite((char *)ChrPtr(email), StrLength(email), 1, fp);
67         pclose(fp);
68         printf("\033[34m-----\033[0m\n");
69
70         // free some memory
71         FreeStrBuf(&email);
72
73         // exit the test program
74         return(0);
75 }