Re: [tcpm] Privacy problems of TCP Fast Open

Michael Tuexen <michael.tuexen@lurchi.franken.de> Tue, 21 May 2019 19:57 UTC

Return-Path: <michael.tuexen@lurchi.franken.de>
X-Original-To: tcpm@ietfa.amsl.com
Delivered-To: tcpm@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id AFCE31200D6 for <tcpm@ietfa.amsl.com>; Tue, 21 May 2019 12:57:05 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.59
X-Spam-Level:
X-Spam-Status: No, score=-2.59 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, RCVD_IN_DNSWL_LOW=-0.7, T_SPF_HELO_PERMERROR=0.01] autolearn=ham autolearn_force=no
Received: from mail.ietf.org ([4.31.198.44]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id Vkbwfmv-q3jD for <tcpm@ietfa.amsl.com>; Tue, 21 May 2019 12:57:02 -0700 (PDT)
Received: from drew.franken.de (drew.ipv6.franken.de [IPv6:2001:638:a02:a001:20e:cff:fe4a:feaa]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 782A3120044 for <tcpm@ietf.org>; Tue, 21 May 2019 12:57:02 -0700 (PDT)
Received: from [IPv6:2003:cd:6f38:4a00:d9db:e8ce:b83f:a6ec] (p200300CD6F384A00D9DBE8CEB83FA6EC.dip0.t-ipconnect.de [IPv6:2003:cd:6f38:4a00:d9db:e8ce:b83f:a6ec]) (Authenticated sender: lurchi) by drew.franken.de (Postfix) with ESMTPSA id B8130721E2823; Tue, 21 May 2019 21:56:59 +0200 (CEST)
Content-Type: text/plain; charset="us-ascii"
Mime-Version: 1.0 (Mac OS X Mail 12.4 \(3445.104.11\))
From: Michael Tuexen <michael.tuexen@lurchi.franken.de>
In-Reply-To: <a6411190-fc9c-3f4d-470d-796023f68a1e@informatik.uni-hamburg.de>
Date: Tue, 21 May 2019 21:56:59 +0200
Cc: tcpm@ietf.org
Content-Transfer-Encoding: quoted-printable
Message-Id: <493C742D-0671-40EC-80B7-0C06171595C1@lurchi.franken.de>
References: <ba3887b6-1554-9a67-8834-4bb598cf18f0@informatik.uni-hamburg.de> <fd9f22b0-03ee-a1ef-ee97-02a93bf2648b@informatik.uni-hamburg.de> <4194EE28-DCDF-46A3-8D26-5920E55040FD@lurchi.franken.de> <4e151b52-cd6d-7145-4e0f-94c6f94eb20b@informatik.uni-hamburg.de> <DA807D25-9E7F-4EE3-8E8B-C9A0FC745C52@lurchi.franken.de> <5804f1d1-5f47-6f36-be9f-d13d9ad89b08@informatik.uni-hamburg.de> <090B342F-960D-4F0D-ABF4-5E29E6BAF2AA@lurchi.franken.de> <a6411190-fc9c-3f4d-470d-796023f68a1e@informatik.uni-hamburg.de>
To: sy@informatik.uni-hamburg.de
X-Mailer: Apple Mail (2.3445.104.11)
Archived-At: <https://mailarchive.ietf.org/arch/msg/tcpm/Jiq9XMahTV3rE4CqKrP5HvniKNk>
Subject: Re: [tcpm] Privacy problems of TCP Fast Open
X-BeenThere: tcpm@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: TCP Maintenance and Minor Extensions Working Group <tcpm.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/tcpm>, <mailto:tcpm-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/tcpm/>
List-Post: <mailto:tcpm@ietf.org>
List-Help: <mailto:tcpm-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/tcpm>, <mailto:tcpm-request@ietf.org?subject=subscribe>
X-List-Received-Date: Tue, 21 May 2019 19:57:06 -0000

> On 21. May 2019, at 21:22, Erik Sy <sy@informatik.uni-hamburg.de> wrote:
> 
> 
> On 5/21/19 18:34, Michael Tuexen wrote:
>>> On 21. May 2019, at 14:25, Erik Sy <sy@informatik.uni-hamburg.de> wrote:
>>> 
>>> 
>>> On 5/21/19 12:18, Michael Tuexen wrote:
>>>>> On 21. May 2019, at 09:52, Erik Sy <sy@informatik.uni-hamburg.de> wrote:
>>>>> 
>>>>> Hi Michael,
>>>>> 
>>>>> thanks for this question!
>>>>> 
>>>>> Yes, TFO cookies are bound to the clients (local) IP address. However, a
>>>>> client with a static local IP address in a home network will use the
>>>>> same TFO cookie independently of it's publicly visible IP address. As a
>>>>> result, TFO cookies present an independent tracking mechanism, which
>>>>> does not necessarily rely on the client's publicly visible IP address.
>>>> How often do the public addresses change?
>>> I do not have a general answer to your question. In the case of my home
>>> network, my ISP assigns me at least every 24 hours a new IPv4 address.
>> I also had this on my DSL line (I guess we both live in Germany),
>> but since my telephone line was moved to "all IP", the assignment stays
>> up for months.
>>> Additionally, I can initiate a change of my network's public IP address
>>> at anytime.
>> Sure.
>>> TFO cookies allow basically unlimited tracking periods because they do
>>> not have an expiration mechanism. Thus, even infrequently changed IP
>>> addresses can be correlated.
>> An implementation can do implement such a thing and even allow an API for it.
> 
> Yes, I agree with you that implementations can go beyond RFC 7413 and
> implement an expiration mechanism limiting feasible tracking periods.
> 
>> For testing I'm flushing the cookie cache quite often...
>>>> One could extend the TFO API in
>>>> a way that the application can request a new cookie by only sending 
>>>> a cookie request.
>>> I do not think this is an appropriate countermeasure.
>>> 
>>> From my perspective, caching TFO cookies in the kernel is a more
>>> fundamental privacy problem. This design requires applications to share
>>> a pool of TFO cookies, which allows tracking across several
>>> applications. For example, this prevents user's to separate their online
>>> activities across different browsers.
>> They would share the IP address. If they decide to trigger a new address
>> binding on the access router, why couldn't they trigger flushing the
>> cache?
> 
> Flushing the cache presents a performance versus privacy trade off
> because flushing increases the chance of a cache miss preventing a 0-RTT
> handshake.
Sure it does. It was just meant as an equivalent to resetting the
public IP address of your access router. This also affects all outgoing
connections.
> Thus, an application that often flushes the cache degrades the
> performance of all other applications sharing the same pool of TFO cookies.
> As a result, the application with the highest privacy requirements
> limits the TFO performance of all other applications.
> 
> Furthermore flushing has difficulties to separate applications running
> at the same time. For example, running a browser window in the normal
> browsing mode and another window in the private browsing mode
> (incognito). In this scenario, only excessive flushing can prevent an
> online tracker to link the user's online activities across both browser
> windows.
Can't they both be linked by the IP address being used?
> 
> From my perspective, an approach that delegates the caching to the
> application itself, is the better solution to address this privacy
> versus performance trade off. Moreover, I believe users tend to make the
How does this prevent "tracking by IP-address" compared to "tracking
by TFO cookie"?

Best regards
Michael
> application/browser vendor responsible to protect their privacy. Thus,
> these vendors require appropriate measures to control their users' privacy.
> 
> Best regards,
> Erik
> 
>> Best regards
>> Michael
>>>>> Returning to your example, onion routing does not necessarily protect
>>>>> you against tracking via TFO cookies.
>>>> Yepp, that is what I wanted to say. 
>>>> But using TFO in that case doesn't
>>>> make much sense.
>>> Yes, TFO does not make sense if user privacy is at stake. Thus, we
>>> should warn users about these risks of RFC 7413.
>>> 
>>> Best regards,
>>> Erik
>>> 
>>>