summaryrefslogtreecommitdiff
path: root/usr.sbin/smtpd/mta_report.c
diff options
context:
space:
mode:
Diffstat (limited to 'usr.sbin/smtpd/mta_report.c')
-rw-r--r--usr.sbin/smtpd/mta_report.c139
1 files changed, 139 insertions, 0 deletions
diff --git a/usr.sbin/smtpd/mta_report.c b/usr.sbin/smtpd/mta_report.c
new file mode 100644
index 00000000000..6e53151333a
--- /dev/null
+++ b/usr.sbin/smtpd/mta_report.c
@@ -0,0 +1,139 @@
+/* $OpenBSD: mta_report.c,v 1.1 2018/11/30 15:33:40 gilles Exp $ */
+
+/*
+ * Copyright (c) 2018 Gilles Chehade <gilles@poolp.org>
+ *
+ * Permission to use, copy, modify, and distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+#include <sys/types.h>
+#include <sys/queue.h>
+#include <sys/tree.h>
+#include <sys/socket.h>
+#include <sys/uio.h>
+
+#include <netinet/in.h>
+
+#include <ctype.h>
+#include <errno.h>
+#include <event.h>
+#include <imsg.h>
+#include <limits.h>
+#include <inttypes.h>
+#include <openssl/ssl.h>
+#include <resolv.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <unistd.h>
+#include <vis.h>
+
+#include "smtpd.h"
+#include "log.h"
+#include "ssl.h"
+#include "rfc5322.h"
+
+void
+mta_report_link_connect(uint64_t qid, const char *rdns,
+ const struct sockaddr_storage *ss_src,
+ const struct sockaddr_storage *ss_dest)
+{
+ m_create(p_lka, IMSG_MTA_REPORT_LINK_CONNECT, 0, 0, -1);
+ m_add_time(p_lka, time(NULL));
+ m_add_id(p_lka, qid);
+ m_add_string(p_lka, rdns);
+ m_add_sockaddr(p_lka, (const struct sockaddr *)ss_src);
+ m_add_sockaddr(p_lka, (const struct sockaddr *)ss_dest);
+ m_close(p_lka);
+}
+
+void
+mta_report_link_tls(uint64_t qid, const char *ssl)
+{
+ m_create(p_lka, IMSG_MTA_REPORT_LINK_TLS, 0, 0, -1);
+ m_add_time(p_lka, time(NULL));
+ m_add_id(p_lka, qid);
+ m_add_string(p_lka, ssl);
+ m_close(p_lka);
+}
+
+void
+mta_report_link_disconnect(uint64_t qid)
+{
+ m_create(p_lka, IMSG_MTA_REPORT_LINK_DISCONNECT, 0, 0, -1);
+ m_add_time(p_lka, time(NULL));
+ m_add_id(p_lka, qid);
+ m_close(p_lka);
+}
+
+void
+mta_report_tx_begin(uint64_t qid, uint32_t msgid)
+{
+ m_create(p_lka, IMSG_MTA_REPORT_TX_BEGIN, 0, 0, -1);
+ m_add_time(p_lka, time(NULL));
+ m_add_id(p_lka, qid);
+ m_add_u32(p_lka, msgid);
+ m_close(p_lka);
+}
+
+void
+mta_report_tx_envelope(uint64_t qid, uint32_t msgid, uint64_t evpid)
+{
+ m_create(p_lka, IMSG_MTA_REPORT_TX_ENVELOPE, 0, 0, -1);
+ m_add_time(p_lka, time(NULL));
+ m_add_id(p_lka, qid);
+ m_add_u32(p_lka, msgid);
+ m_add_id(p_lka, evpid);
+ m_close(p_lka);
+}
+
+void
+mta_report_tx_commit(uint64_t qid, uint32_t msgid, size_t msgsz)
+{
+ m_create(p_lka, IMSG_MTA_REPORT_TX_COMMIT, 0, 0, -1);
+ m_add_time(p_lka, time(NULL));
+ m_add_id(p_lka, qid);
+ m_add_u32(p_lka, msgid);
+ m_add_size(p_lka, msgsz);
+ m_close(p_lka);
+}
+
+void
+mta_report_tx_rollback(uint64_t qid, uint32_t msgid)
+{
+ m_create(p_lka, IMSG_MTA_REPORT_TX_ROLLBACK, 0, 0, -1);
+ m_add_time(p_lka, time(NULL));
+ m_add_id(p_lka, qid);
+ m_add_u32(p_lka, msgid);
+ m_close(p_lka);
+}
+
+void
+mta_report_protocol_client(uint64_t qid, const char *command)
+{
+ m_create(p_lka, IMSG_MTA_REPORT_PROTOCOL_CLIENT, 0, 0, -1);
+ m_add_time(p_lka, time(NULL));
+ m_add_id(p_lka, qid);
+ m_add_string(p_lka, command);
+ m_close(p_lka);
+}
+
+void
+mta_report_protocol_server(uint64_t qid, const char *response)
+{
+ m_create(p_lka, IMSG_MTA_REPORT_PROTOCOL_SERVER, 0, 0, -1);
+ m_add_time(p_lka, time(NULL));
+ m_add_id(p_lka, qid);
+ m_add_string(p_lka, response);
+ m_close(p_lka);
+}