Re: [TLS] TLS or HTTP issue?
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [TLS] TLS or HTTP issue?



It is likely XMPP is vulnerable. IMAP and SMTP are vulnerable. The only application protocol I've studied that I believe resists the vulnerability is POP3+STLS (even pops may be vulnerable).

I know of two ways to leverage the TLS re-negotiation vulnerability to attack applications:

1. Authenticating an otherwise un-trusted directive using credentials from an authorized user. As far as I know this attack only applies to HTTP-like protocols (including IPP, SIP, HTTP, WebDAV, CalDAV, etc.) due to the poor design of HTTP authentication, cookie and client certificate mechanisms. Application protocols like IMAP, POP, SMTP, XMPP, BEEP with cleanly separate not-authenticated and authenticated states are immune to this attack.

2. Having one authorized and authenticated TLS session decrypt data from a different TLS session. This attack is most severe for SMTP+STARTTLS+BDAT (since SMTP relays typically treat all senders as authenticated as long as the recipient is in the local domain), but impacts most application protocols that have a command to "send", "post", "put", "set an attribute" or perform any write operation that can subsequently be read back. In the case of IMAP, this can be used by one authorized IMAP user (someone with an account on the IMAP server) to potentially steal the login password of another IMAP user on the same server (with some IMAP client behavior caveats).

It is likely that XMPP is vulnerable to attack #2.

I would recommend anyone running an SMTP relay (port 25) to turn off both the STARTTLS and SMTP AUTH features immediately until this is resolved. An SMTP Submission server (port 587, RFC 4409, requires SMTP AUTH to submit mail) should keep STARTTLS enabled. Sites that have not made the split between SMTP relay and SMTP submission should do so -- they have different security properties and this is yet another reason they should be different services (either on different ports or different IP addresses).

		- Chris

--On November 6, 2009 9:59:11 -0700 Peter Saint-Andre <stpeter at stpeter.im> wrote:

-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1

On 11/5/09 2:00 PM, Nikos Mavrogiannopoulos wrote:
Eric Rescorla wrote:
TLS WG members will want to check out this announcement of a
new attack on the TLS renegotiation logic. See here:

http://www.extendedsubset.com/

The high-level summary is that the attacker negotiates TLS with the
server and then subsequently proxies the client's negotiation *over*
that channel. This allows the attacker to inject arbitrary content of
their choice in front of data sent from the TLS client to the TLS
server. This data will be treated by the server as if it came from the
client. Once the new handshake has finished, the attacker can't
do anything else useful.

 I'll become a bit pedantic and note here that this isn't really a TLS
issue. We have an initial server-authenticated only session and some
renegotiation of parameters over it to authenticate the client. However
TLS doesn't guarantee[0] that if the renegotiation is successful
authenticating the client, then the data from the initial session were
also by the same authenticated client.
 Think for example a session that it is anonymous (DH). Why one should
assume that commands over the anonymous connection are to be trusted if
a successful renegotiation follows?

So for me the issue is on HTTP's usage of the TLS protocol
renegotiation. After a TLS renegotiation for authentication the previous
command cache should have been cleared and reissued after negotiation.

I tend to agree. Some folks in the XMPP community have analyzed the use
of TLS in XMPP, and their preliminary conclusion is that XMPP is not
vulnerable to this attack because the client and server are required to
clear the security context and restart the XML stream after TLS
negotiation (or renegotiation). Those who did this analysis will publish
a brief report about their findings in the near future.

Peter

- --
Peter Saint-Andre
https://stpeter.im/


-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.4.8 (Darwin)
Comment: Using GnuPG with Mozilla - http://enigmail.mozdev.org/

iEYEARECAAYFAkr0Vd8ACgkQNL8k5A2w/vyeqQCgpzZakXwr62UdxAHdNyqwe4xe
WEUAoMPGdY94w+/+oAv9oYC0I9iu7hnI
=sjVM
-----END PGP SIGNATURE-----
_______________________________________________
TLS mailing list
TLS at ietf.org
https://www.ietf.org/mailman/listinfo/tls






Note: Messages sent to this list are the opinions of the senders and do not imply endorsement by the IETF.