summaryrefslogtreecommitdiff
path: root/usr.sbin/smtpd
diff options
context:
space:
mode:
authorEric Faurot <eric@cvs.openbsd.org>2011-10-09 18:39:55 +0000
committerEric Faurot <eric@cvs.openbsd.org>2011-10-09 18:39:55 +0000
commitad03e2c7c7cab0cccdb501682fc29d230896cddc (patch)
treedceaf0773380012682d8e3af7bad545aea21a10e /usr.sbin/smtpd
parentc45e61c7b6744c0dd8c3296ed9a6ef961a772ac6 (diff)
show messages sent between processes in debug mode
ok gilles@ chl@
Diffstat (limited to 'usr.sbin/smtpd')
-rw-r--r--usr.sbin/smtpd/control.c4
-rw-r--r--usr.sbin/smtpd/lka.c4
-rw-r--r--usr.sbin/smtpd/mda.c4
-rw-r--r--usr.sbin/smtpd/mfa.c4
-rw-r--r--usr.sbin/smtpd/mta.c4
-rw-r--r--usr.sbin/smtpd/queue.c4
-rw-r--r--usr.sbin/smtpd/runner.c4
-rw-r--r--usr.sbin/smtpd/smtp.c10
-rw-r--r--usr.sbin/smtpd/smtpd.c114
-rw-r--r--usr.sbin/smtpd/smtpd.h3
10 files changed, 139 insertions, 16 deletions
diff --git a/usr.sbin/smtpd/control.c b/usr.sbin/smtpd/control.c
index 3be91e81407..9dd53fe9721 100644
--- a/usr.sbin/smtpd/control.c
+++ b/usr.sbin/smtpd/control.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: control.c,v 1.60 2011/09/01 19:56:49 eric Exp $ */
+/* $OpenBSD: control.c,v 1.61 2011/10/09 18:39:53 eric Exp $ */
/*
* Copyright (c) 2008 Pierre-Yves Ritschard <pyr@openbsd.org>
@@ -66,6 +66,8 @@ control_imsg(struct imsgev *iev, struct imsg *imsg)
struct ctl_conn *c;
struct reload *reload;
+ log_imsg(PROC_CONTROL, iev->proc, imsg);
+
if (iev->proc == PROC_SMTP) {
switch (imsg->hdr.type) {
case IMSG_SMTP_ENQUEUE:
diff --git a/usr.sbin/smtpd/lka.c b/usr.sbin/smtpd/lka.c
index 581a72e86d3..3ba0514430f 100644
--- a/usr.sbin/smtpd/lka.c
+++ b/usr.sbin/smtpd/lka.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: lka.c,v 1.127 2011/05/16 21:05:51 gilles Exp $ */
+/* $OpenBSD: lka.c,v 1.128 2011/10/09 18:39:53 eric Exp $ */
/*
* Copyright (c) 2008 Pierre-Yves Ritschard <pyr@openbsd.org>
@@ -61,6 +61,8 @@ lka_imsg(struct imsgev *iev, struct imsg *imsg)
struct map *map;
void *tmp;
+ log_imsg(PROC_LKA, iev->proc, imsg);
+
if (imsg->hdr.type == IMSG_DNS_HOST || imsg->hdr.type == IMSG_DNS_MX ||
imsg->hdr.type == IMSG_DNS_PTR) {
dns_async(iev, imsg->hdr.type, imsg->data);
diff --git a/usr.sbin/smtpd/mda.c b/usr.sbin/smtpd/mda.c
index 9f3dd26e0af..eaef4e7bd62 100644
--- a/usr.sbin/smtpd/mda.c
+++ b/usr.sbin/smtpd/mda.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: mda.c,v 1.59 2011/08/29 21:43:08 chl Exp $ */
+/* $OpenBSD: mda.c,v 1.60 2011/10/09 18:39:53 eric Exp $ */
/*
* Copyright (c) 2008 Gilles Chehade <gilles@openbsd.org>
@@ -57,6 +57,8 @@ mda_imsg(struct imsgev *iev, struct imsg *imsg)
struct delivery_mda *d_mda;
struct mailaddr *maddr;
+ log_imsg(PROC_MDA, iev->proc, imsg);
+
if (iev->proc == PROC_QUEUE) {
switch (imsg->hdr.type) {
case IMSG_MDA_SESS_NEW:
diff --git a/usr.sbin/smtpd/mfa.c b/usr.sbin/smtpd/mfa.c
index 22e5a19827c..b2c02918ee9 100644
--- a/usr.sbin/smtpd/mfa.c
+++ b/usr.sbin/smtpd/mfa.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: mfa.c,v 1.62 2011/09/27 18:53:24 chl Exp $ */
+/* $OpenBSD: mfa.c,v 1.63 2011/10/09 18:39:53 eric Exp $ */
/*
* Copyright (c) 2008 Gilles Chehade <gilles@openbsd.org>
@@ -54,6 +54,8 @@ mfa_imsg(struct imsgev *iev, struct imsg *imsg)
{
struct filter *filter;
+ log_imsg(PROC_MFA, iev->proc, imsg);
+
if (iev->proc == PROC_SMTP) {
switch (imsg->hdr.type) {
case IMSG_MFA_HELO:
diff --git a/usr.sbin/smtpd/mta.c b/usr.sbin/smtpd/mta.c
index 70ac092fd4b..c727307ecd6 100644
--- a/usr.sbin/smtpd/mta.c
+++ b/usr.sbin/smtpd/mta.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: mta.c,v 1.113 2011/08/29 21:43:09 chl Exp $ */
+/* $OpenBSD: mta.c,v 1.114 2011/10/09 18:39:53 eric Exp $ */
/*
* Copyright (c) 2008 Pierre-Yves Ritschard <pyr@openbsd.org>
@@ -65,6 +65,8 @@ mta_imsg(struct imsgev *iev, struct imsg *imsg)
struct dns *dns;
struct ssl *ssl;
+ log_imsg(PROC_MTA, iev->proc, imsg);
+
if (iev->proc == PROC_QUEUE) {
switch (imsg->hdr.type) {
case IMSG_BATCH_CREATE:
diff --git a/usr.sbin/smtpd/queue.c b/usr.sbin/smtpd/queue.c
index 593b4651c0f..12ea1bd0d8a 100644
--- a/usr.sbin/smtpd/queue.c
+++ b/usr.sbin/smtpd/queue.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: queue.c,v 1.106 2011/09/01 19:56:49 eric Exp $ */
+/* $OpenBSD: queue.c,v 1.107 2011/10/09 18:39:53 eric Exp $ */
/*
* Copyright (c) 2008 Gilles Chehade <gilles@openbsd.org>
@@ -51,6 +51,8 @@ queue_imsg(struct imsgev *iev, struct imsg *imsg)
struct ramqueue_batch *rq_batch;
int fd, ret;
+ log_imsg(PROC_QUEUE, iev->proc, imsg);
+
if (iev->proc == PROC_SMTP) {
e = imsg->data;
diff --git a/usr.sbin/smtpd/runner.c b/usr.sbin/smtpd/runner.c
index 2a559bf0522..33f9b7f6af9 100644
--- a/usr.sbin/smtpd/runner.c
+++ b/usr.sbin/smtpd/runner.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: runner.c,v 1.118 2011/09/18 21:37:53 gilles Exp $ */
+/* $OpenBSD: runner.c,v 1.119 2011/10/09 18:39:53 eric Exp $ */
/*
* Copyright (c) 2008 Gilles Chehade <gilles@openbsd.org>
@@ -70,6 +70,8 @@ runner_imsg(struct imsgev *iev, struct imsg *imsg)
{
struct envelope *e;
+ log_imsg(PROC_RUNNER, iev->proc, imsg);
+
switch (imsg->hdr.type) {
case IMSG_QUEUE_COMMIT_MESSAGE:
e = imsg->data;
diff --git a/usr.sbin/smtpd/smtp.c b/usr.sbin/smtpd/smtp.c
index b2946208075..8ea6d9465ec 100644
--- a/usr.sbin/smtpd/smtp.c
+++ b/usr.sbin/smtpd/smtp.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: smtp.c,v 1.91 2011/09/01 20:17:47 gilles Exp $ */
+/* $OpenBSD: smtp.c,v 1.92 2011/10/09 18:39:54 eric Exp $ */
/*
* Copyright (c) 2008 Gilles Chehade <gilles@openbsd.org>
@@ -61,6 +61,8 @@ smtp_imsg(struct imsgev *iev, struct imsg *imsg)
struct ssl *ssl;
struct dns *dns;
+ log_imsg(PROC_SMTP, iev->proc, imsg);
+
if (iev->proc == PROC_LKA) {
switch (imsg->hdr.type) {
case IMSG_DNS_PTR:
@@ -83,7 +85,6 @@ smtp_imsg(struct imsgev *iev, struct imsg *imsg)
case IMSG_MFA_HELO:
case IMSG_MFA_MAIL:
case IMSG_MFA_RCPT:
- log_debug("smtp: got imsg_mfa_helo/mail/rcpt");
case IMSG_MFA_DATALINE:
ss = imsg->data;
s = session_lookup(ss->id);
@@ -99,7 +100,6 @@ smtp_imsg(struct imsgev *iev, struct imsg *imsg)
switch (imsg->hdr.type) {
case IMSG_QUEUE_CREATE_MESSAGE:
- log_debug("smtp: imsg_queue_create_message returned");
s = session_lookup(ss->id);
if (s == NULL)
return;
@@ -108,7 +108,6 @@ smtp_imsg(struct imsgev *iev, struct imsg *imsg)
return;
case IMSG_QUEUE_MESSAGE_FILE:
- log_debug("smtp: imsg_queue_message_file returned");
s = session_lookup(ss->id);
if (s == NULL) {
close(imsg->fd);
@@ -125,7 +124,6 @@ smtp_imsg(struct imsgev *iev, struct imsg *imsg)
return;
case IMSG_QUEUE_TEMPFAIL:
- log_debug("smtp: got imsg_queue_tempfail");
skey.s_id = ss->id;
s = SPLAY_FIND(sessiontree, &env->sc_sessions, &skey);
if (s == NULL)
@@ -138,7 +136,6 @@ smtp_imsg(struct imsgev *iev, struct imsg *imsg)
return;
case IMSG_QUEUE_COMMIT_ENVELOPES:
- log_debug("smtp: got imsg_queue_commit_envelopes");
s = session_lookup(ss->id);
if (s == NULL)
return;
@@ -146,7 +143,6 @@ smtp_imsg(struct imsgev *iev, struct imsg *imsg)
return;
case IMSG_QUEUE_COMMIT_MESSAGE:
- log_debug("smtp: got imsg_queue_commit_message");
s = session_lookup(ss->id);
if (s == NULL)
return;
diff --git a/usr.sbin/smtpd/smtpd.c b/usr.sbin/smtpd/smtpd.c
index e52b1257004..dcfb03a841a 100644
--- a/usr.sbin/smtpd/smtpd.c
+++ b/usr.sbin/smtpd/smtpd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: smtpd.c,v 1.130 2011/09/01 19:56:49 eric Exp $ */
+/* $OpenBSD: smtpd.c,v 1.131 2011/10/09 18:39:54 eric Exp $ */
/*
* Copyright (c) 2008 Gilles Chehade <gilles@openbsd.org>
@@ -89,6 +89,8 @@ parent_imsg(struct imsgev *iev, struct imsg *imsg)
struct auth_backend *auth_backend;
int fd;
+ log_imsg(PROC_PARENT, iev->proc, imsg);
+
if (iev->proc == PROC_SMTP) {
switch (imsg->hdr.type) {
case IMSG_PARENT_SEND_CONFIG:
@@ -1111,3 +1113,113 @@ imsg_dispatch(int fd, short event, void *p)
}
SPLAY_GENERATE(childtree, child, entry, child_cmp);
+
+const char * proc_to_str(int);
+const char * imsg_to_str(int);
+
+void
+log_imsg(int to, int from, struct imsg *imsg)
+{
+ log_debug("imsg: %s <- %s: %s (len=%zu)",
+ proc_to_str(to),
+ proc_to_str(from),
+ imsg_to_str(imsg->hdr.type),
+ imsg->hdr.len - IMSG_HEADER_SIZE);
+}
+
+#define CASE(x) case x : return #x
+
+const char *
+proc_to_str(int proc)
+{
+ switch (proc) {
+ CASE(PROC_PARENT);
+ CASE(PROC_SMTP);
+ CASE(PROC_MFA);
+ CASE(PROC_LKA);
+ CASE(PROC_QUEUE);
+ CASE(PROC_MDA);
+ CASE(PROC_MTA);
+ CASE(PROC_CONTROL);
+ CASE(PROC_RUNNER);
+ default:
+ return "PROC_???";
+ }
+}
+
+const char *
+imsg_to_str(int type)
+{
+ switch(type) {
+ CASE(IMSG_NONE);
+ CASE(IMSG_CTL_OK);
+ CASE(IMSG_CTL_FAIL);
+ CASE(IMSG_CTL_SHUTDOWN);
+ CASE(IMSG_CTL_VERBOSE);
+ CASE(IMSG_CONF_START);
+ CASE(IMSG_CONF_SSL);
+ CASE(IMSG_CONF_LISTENER);
+ CASE(IMSG_CONF_MAP);
+ CASE(IMSG_CONF_MAP_CONTENT);
+ CASE(IMSG_CONF_RULE);
+ CASE(IMSG_CONF_RULE_SOURCE);
+ CASE(IMSG_CONF_FILTER);
+ CASE(IMSG_CONF_END);
+ CASE(IMSG_CONF_RELOAD);
+ CASE(IMSG_LKA_MAIL);
+ CASE(IMSG_LKA_RCPT);
+ CASE(IMSG_LKA_SECRET);
+ CASE(IMSG_LKA_RULEMATCH);
+ CASE(IMSG_MDA_SESS_NEW);
+ CASE(IMSG_MDA_DONE);
+
+ CASE(IMSG_MFA_HELO);
+ CASE(IMSG_MFA_MAIL);
+ CASE(IMSG_MFA_RCPT);
+ CASE(IMSG_MFA_DATALINE);
+
+ CASE(IMSG_QUEUE_CREATE_MESSAGE);
+ CASE(IMSG_QUEUE_SUBMIT_ENVELOPE);
+ CASE(IMSG_QUEUE_COMMIT_ENVELOPES);
+ CASE(IMSG_QUEUE_REMOVE_MESSAGE);
+ CASE(IMSG_QUEUE_COMMIT_MESSAGE);
+ CASE(IMSG_QUEUE_TEMPFAIL);
+ CASE(IMSG_QUEUE_PAUSE_LOCAL);
+ CASE(IMSG_QUEUE_PAUSE_OUTGOING);
+ CASE(IMSG_QUEUE_RESUME_LOCAL);
+ CASE(IMSG_QUEUE_RESUME_OUTGOING);
+
+ CASE(IMSG_QUEUE_MESSAGE_UPDATE);
+ CASE(IMSG_QUEUE_MESSAGE_FD);
+ CASE(IMSG_QUEUE_MESSAGE_FILE);
+ CASE(IMSG_QUEUE_SCHEDULE);
+ CASE(IMSG_QUEUE_REMOVE);
+
+ CASE(IMSG_RUNNER_REMOVE);
+ CASE(IMSG_RUNNER_SCHEDULE);
+
+ CASE(IMSG_BATCH_CREATE);
+ CASE(IMSG_BATCH_APPEND);
+ CASE(IMSG_BATCH_CLOSE);
+ CASE(IMSG_BATCH_DONE);
+
+ CASE(IMSG_PARENT_ENQUEUE_OFFLINE);
+ CASE(IMSG_PARENT_FORWARD_OPEN);
+ CASE(IMSG_PARENT_FORK_MDA);
+
+ CASE(IMSG_PARENT_AUTHENTICATE);
+ CASE(IMSG_PARENT_SEND_CONFIG);
+
+ CASE(IMSG_STATS);
+ CASE(IMSG_SMTP_ENQUEUE);
+ CASE(IMSG_SMTP_PAUSE);
+ CASE(IMSG_SMTP_RESUME);
+
+ CASE(IMSG_DNS_HOST);
+ CASE(IMSG_DNS_HOST_END);
+ CASE(IMSG_DNS_MX);
+ CASE(IMSG_DNS_PTR);
+ default:
+ return "IMSG_???";
+ }
+}
diff --git a/usr.sbin/smtpd/smtpd.h b/usr.sbin/smtpd/smtpd.h
index 4a06bb839e1..da6d9713544 100644
--- a/usr.sbin/smtpd/smtpd.h
+++ b/usr.sbin/smtpd/smtpd.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: smtpd.h,v 1.240 2011/09/19 13:10:47 chl Exp $ */
+/* $OpenBSD: smtpd.h,v 1.241 2011/10/09 18:39:54 eric Exp $ */
/*
* Copyright (c) 2008 Gilles Chehade <gilles@openbsd.org>
@@ -1225,3 +1225,4 @@ u_int32_t evpid_to_msgid(u_int64_t);
u_int64_t msgid_to_evpid(u_int32_t);
u_int32_t filename_to_msgid(char *);
u_int64_t filename_to_evpid(char *);
+void log_imsg(int, int, struct imsg*);