[tor-bugs] #14059 [Tor Browser]: Revision of existing double key cookie logic to meet requirements

Tor Bug Tracker & Wiki blackhole at torproject.org
Tue Feb 3 13:05:10 UTC 2015


#14059: Revision of existing double key cookie logic to meet requirements
-------------------------+-------------------------------------------------
     Reporter:  michael  |      Owner:  michael
         Type:  defect   |     Status:  needs_information
     Priority:  normal   |  Milestone:
    Component:  Tor      |    Version:
  Browser                |   Keywords:  TorBrowserTeam201502R,
   Resolution:           |  GeorgKoppen201502R
Actual Points:           |  Parent ID:  #3246
       Points:           |
-------------------------+-------------------------------------------------
Description changed by michael:

Old description:

> Revise logic from #14058 to meet requirements implied in the #3246 mother
> bug and TBB online development meetings.
>
> Complete implementation of what is termed ''double keying'' as both 1st
> party hostname and 3rd party hostname are stored and conditionally used
> when constructing the ''Cookie'' HTTP header.
> ----
> = Nonfunctional requirements =
> == Adaption to common use cases ==
> Common browsing use cases involving cookies must be supported while
> protecting against crossdomain tracking violations.
>
> == Allow granular cookie inspection ==
> Fine grained cookie inspection must be enabled through new design of a
> user interface indexing either 1st or 3rd party URI contexts. This
> requirement does not specify the UI itself.
> ----
> = Functional requirements =
> == 3rd party cookie storage ==
> 3rd party cookies are stored under the usual conditions, according to the
> ''Set-Cookie'' HTTP header (RFC 6265.) Their storage structure enables
> 1st party association as a new measure.
>
> == 3rd party cookie retrieval ==
> 3rd party cookies are revealed according to host domain matching (RFC
> 6265) of 1st party URI contexts. This change mitigates the problem of
> identification across independent domains.
>
> == Legacy cookie behaviour ==
> New 3rd party isolation must not depend on legacy cookie behaviour
> configuraion '''(network.cookie.cookieBehavior.)'''
>
> == Conditional operation ==
> Double keyed cookie logic only influences runtime according to the
> configuration value '''(privacy.thirdparty.isolate.)'''

New description:

 Revise logic from #14058 to meet requirements implied in the #3246 mother
 bug and TBB online development meetings.

 Complete implementation of what is termed ''double keying'' as both 1st
 party hostname and 3rd party hostname are stored and conditionally used
 when constructing the ''Cookie'' HTTP header.
 ----
 = Nonfunctional requirements =
 == Adaption to common use cases ==
 Common browsing use cases involving cookies must be supported while
 protecting against crossdomain tracking violations. This includes travel
 reservations, shopping carts, surveys, comment providers, approval and
 rating systems, journalist drop boxes, and (one-time|two-factor)
 authentication systems.

 == Allow granular cookie inspection ==
 Fine grained cookie inspection must be enabled through new design of a
 user interface indexing either 1st or 3rd party URI contexts. This
 requirement does not specify the UI itself.
 ----
 = Functional requirements =
 == 3rd party cookie storage ==
 3rd party cookies are stored under the usual conditions, according to the
 ''Set-Cookie'' HTTP header (RFC 6265.) Their storage structure enables 1st
 party association as a new measure.

 == 3rd party cookie retrieval ==
 3rd party cookies are revealed according to host domain matching (RFC
 6265) of 1st party URI contexts. This change mitigates the problem of
 identification across independent domains.

 == Legacy cookie behaviour ==
 New 3rd party isolation must not depend on legacy cookie behaviour
 configuraion '''network.cookie.cookieBehavior.'''

 == Conditional operation ==
 The configuration value '''privacy.thirdparty.isolate''' influences
 control of 3rd party cookie transmission. The '''private browsing channel
 attribute''' plays a binary role in enabling transmission but depends on
 '''privacy.thirdparty.isolate.'''
 ----
 = Unclassified requirements =
 == Complementary research ==
 Mark Nottingham's [https://tools.ietf.org/html/draft-nottingham-safe-hint/
 IETF draft] and Alex Fowler's corresponding announcement of
 [https://blog.mozilla.org/privacy/2014/07/22/prefersafe-making-online-
 safety-simpler-in-firefox/ Prefer:Safe] include requirements relating to
 HTTP cookie control.

 The Mozilla B2G privacy panel and
 [https://blog.mozilla.org/privacy/2014/11/10/introducing-polaris-privacy-
 initiative-to-accelerate-user-focused-privacy-online/ announcement] of the
 [https://wiki.mozilla.org/Polaris Mozilla Polaris project] refer to 3rd
 party cookie control.

--

--
Ticket URL: <https://trac.torproject.org/projects/tor/ticket/14059#comment:14>
Tor Bug Tracker & Wiki <https://trac.torproject.org/>
The Tor Project: anonymity online


More information about the tor-bugs mailing list