diff options
author | Phil Pennock <pdp@exim.org> | 2011-03-24 02:37:39 -0400 |
---|---|---|
committer | Phil Pennock <pdp@exim.org> | 2011-03-24 02:37:39 -0400 |
commit | da80c2a8ed49427334af613c00df65ae301cacdd (patch) | |
tree | 456907305413d0d268603568783e21c8693a566f /src | |
parent | 084c1d8c14da86888bbffc31a54246dc6e2e8147 (diff) |
Extra paranoia around STARTTLS-with-data-in-buffer.
Diffstat (limited to 'src')
-rw-r--r-- | src/src/smtp_in.c | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/src/src/smtp_in.c b/src/src/smtp_in.c index 2ef697702..500000be4 100644 --- a/src/src/smtp_in.c +++ b/src/src/smtp_in.c @@ -3844,6 +3844,23 @@ while (done <= 0) toomany = FALSE; cmd_list[CMD_LIST_STARTTLS].is_mail_cmd = FALSE; + /* There's an attack where more data is read in past the STARTTLS command + before TLS is negotiated, then assumed to be part of the secure session + when used afterwards; we use segregated input buffers, so are not + vulnerable, but we want to note when it happens and, for sheer paranoia, + ensure that the buffer is "wiped". + Pipelining sync checks will normally have protected us too, unless disabled + by configuration. */ + + if (receive_smtp_buffered()) + { + DEBUG(D_any) + debug_printf("Non-empty input buffer after STARTTLS; naive attack?"); + if (tls_active < 0) + smtp_inend = smtp_inptr = smtp_inbuffer; + /* and if TLS is already active, tls_server_start() should fail */ + } + /* Attempt to start up a TLS session, and if successful, discard all knowledge that was obtained previously. At least, that's what the RFC says, and that's what happens by default. However, in order to work round YAEB, |