diff options
author | Jeremy Harris <jgh146exb@wizmail.org> | 2018-08-09 20:37:42 +0100 |
---|---|---|
committer | Jeremy Harris <jgh146exb@wizmail.org> | 2018-08-09 21:19:17 +0100 |
commit | 8a6b4e02cd384193a5566e8601bdd97249b22284 (patch) | |
tree | de684b5461dca9486b14313e34ce21f7d1bf6286 /src | |
parent | 20751c768578c81f5136f58b4bd98109716894b0 (diff) |
Fix cutthrough delivery for more than one iteration of address redirection. Bug 2296
Diffstat (limited to 'src')
-rw-r--r-- | src/src/verify.c | 19 |
1 files changed, 14 insertions, 5 deletions
diff --git a/src/src/verify.c b/src/src/verify.c index 35b21a54d..6411899c8 100644 --- a/src/src/verify.c +++ b/src/src/verify.c @@ -1070,6 +1070,8 @@ no_conn: && !sx.lmtp ) { + address_item * parent, * caddr; + HDEBUG(D_acl|D_v) debug_printf_indent("holding verify callout open for %s\n", cutthrough.delivery ? "cutthrough delivery" : "potential further verifies and delivery"); @@ -1092,12 +1094,16 @@ no_conn: cutthrough.host.address = string_copy(host->address); store_pool = oldpool; } - cutthrough.addr = *addr; /* Save the address_item for later logging */ + + /* Save the address_item and parent chain for later logging */ + cutthrough.addr = *addr; cutthrough.addr.next = NULL; cutthrough.addr.host_used = &cutthrough.host; - if (addr->parent) - *(cutthrough.addr.parent = store_get(sizeof(address_item))) = - *addr->parent; + for (caddr = &cutthrough.addr, parent = addr->parent; + parent; + parent = parent->parent) + *(caddr->parent = store_get(sizeof(address_item))) = *parent; + ctblock.buffer = ctbuffer; ctblock.buffersize = sizeof(ctbuffer); ctblock.ptr = ctbuffer; @@ -1194,7 +1200,7 @@ return yield; one was requested and a recipient-verify wasn't subsequently done. */ int -open_cutthrough_connection( address_item * addr ) +open_cutthrough_connection(address_item * addr) { address_item addr2; int rc; @@ -1942,6 +1948,9 @@ while (addr_new) #endif rc = do_callout(addr, host_list, &tf, callout, callout_overall, callout_connect, options, se_mailfrom, pm_mailfrom); +#ifdef SUPPORT_TLS + deliver_set_expansions(NULL); +#endif } } else |