summaryrefslogtreecommitdiff
path: root/mail/postfix27/files/patch-src__smtpd__smtpd.c
blob: f08cfea86de9fc6dd8bea62105cba79e339a1604 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
--- src/smtpd/smtpd.c.orig	2008-03-24 16:38:05.000000000 -0300
+++ src/smtpd/smtpd.c	2008-03-24 16:48:38.000000000 -0300
@@ -2108,14 +2108,14 @@
     if (smtpd_milters != 0
 	&& SMTPD_STAND_ALONE(state) == 0
 	&& (state->saved_flags & MILTER_SKIP_FLAGS) == 0) {
+	PUSH_STRING(saved_sender, state->sender, STR(state->addr_buf)); 
 	err = milter_mail_event(smtpd_milters,
 				milter_argv(state, argc - 2, argv + 2));
 	if (err != 0) {
 	    /* Log reject etc. with correct sender information. */
-	    PUSH_STRING(saved_sender, state->sender, STR(state->addr_buf));
 	    err = check_milter_reply(state, err);
-	    POP_STRING(saved_sender, state->sender);
 	}
+	POP_STRING(saved_sender, state->sender);
 	if (err != 0) {
 	    /* XXX Reset access map side effects. */
 	    mail_reset(state);
@@ -2362,14 +2362,14 @@
 	}
 	if (smtpd_milters != 0
 	    && (state->saved_flags & MILTER_SKIP_FLAGS) == 0) {
+	    PUSH_STRING(saved_rcpt, state->recipient, STR(state->addr_buf));
 	    err = milter_rcpt_event(smtpd_milters,
 				    milter_argv(state, argc - 2, argv + 2));
 	    if (err != 0) {
 		/* Log reject etc. with correct recipient information. */
-		PUSH_STRING(saved_rcpt, state->recipient, STR(state->addr_buf));
 		err = check_milter_reply(state, err);
-		POP_STRING(saved_rcpt, state->recipient);
 	    }
+	    POP_STRING(saved_rcpt, state->recipient);
 	    if (err != 0) {
 		smtpd_chat_reply(state, "%s", err);
 		return (-1);