Debug: output dmarc library version
authorJeremy Harris <jgh146exb@wizmail.org>
Tue, 4 May 2021 15:08:18 +0000 (16:08 +0100)
committerJeremy Harris <jgh146exb@wizmail.org>
Tue, 4 May 2021 15:08:18 +0000 (16:08 +0100)
src/src/dmarc.c
src/src/dmarc.h
src/src/exim.c

index 5328f4f7da48f279bddb8eb3bb848479a5b0aab7..599ecc4542f0d23b7bb10dacb67d19a67edbc8c0 100644 (file)
@@ -51,21 +51,34 @@ static dmarc_exim_p dmarc_policy_description[] = {
   { US"reject",     DMARC_RECORD_P_REJECT },
   { NULL,           0 }
 };
+
+
+void 
+dmarc_version_report(FILE *f)
+{ 
+const char *implementation, *version;
+
+fprintf(f, "Library version: dmarc: Compile: %d.%d.%d.%d\n",
+  (OPENDMARC_LIB_VERSION & 0xff000000) >> 24, (OPENDMARC_LIB_VERSION & 0x00ff0000) >> 16,
+  (OPENDMARC_LIB_VERSION & 0x0000ff00) >> 8, OPENDMARC_LIB_VERSION & 0x000000ff);
+}
+
+
 /* Accept an error_block struct, initialize if empty, parse to the
- * end, and append the two strings passed to it.  Used for adding
- * variable amounts of value:pair data to the forensic emails. */
+end, and append the two strings passed to it.  Used for adding
+variable amounts of value:pair data to the forensic emails. */
 
 static error_block *
 add_to_eblock(error_block *eblock, uschar *t1, uschar *t2)
 {
 error_block *eb = store_malloc(sizeof(error_block));
-if (eblock == NULL)
+if (!eblock)
   eblock = eb;
 else
   {
   /* Find the end of the eblock struct and point it at eb */
   error_block *tmp = eblock;
-  while(tmp->next != NULL)
+  while(tmp->next)
     tmp = tmp->next;
   tmp->next = eb;
   }
@@ -76,8 +89,8 @@ return eblock;
 }
 
 /* dmarc_init sets up a context that can be re-used for several
-   messages on the same SMTP connection (that come from the
-   same host with the same HELO string) */
+messages on the same SMTP connection (that come from the
+same host with the same HELO string) */
 
 int
 dmarc_init()
index ef967e0b7232ab6bdf9a8b7455857e21a8bdd1d3..f3c29b00a1e4cdbb3dcb71763283c0163e0dc0c0 100644 (file)
@@ -17,6 +17,7 @@
 # endif /* SUPPORT_SPF */
 
 /* prototypes */
+void dmarc_version_report(FILE *);
 int dmarc_init();
 int dmarc_store_data(header_line *);
 int dmarc_process();
index a3983f88d02594162bc88910e4c3a540c0e7387d..3e08f0376fbe2019738ddd4c1ac46167030999ce 100644 (file)
@@ -1138,6 +1138,9 @@ show_db_version(fp);
 #ifdef SUPPORT_I18N
   utf8_version_report(fp);
 #endif
+#ifdef SUPPORT_DMARC
+  dmarc_version_report(fp);
+#endif
 #ifdef SUPPORT_SPF
   spf_lib_version_report(fp);
 #endif