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.
7 #include <libcitadel.h>
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);
12 int main(int argc, char *argv[]) {
14 // display the greeting
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"
24 openlog("dkim", LOG_PERROR, LOG_USER);
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-----";
31 char *domain = "dev.citadel.org";
32 char *selector = "foo";
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"
44 "Bhille Disassemble. Highly recommend.\r\n"
52 dkim_sign(email, private_key, domain, selector);
54 // Show the user what we did
55 printf("%s", (char *)ChrPtr(email));
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);
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);
68 printf("\033[34m-----\033[0m\n");
73 // exit the test program