RE: Review of draft-williams-exp-tcp-host-id-opt-07

<mohamed.boucadair@orange.com> Tue, 02 February 2016 13:58 UTC

Return-Path: <mohamed.boucadair@orange.com>
X-Original-To: ietf@ietfa.amsl.com
Delivered-To: ietf@ietfa.amsl.com
Received: from localhost (ietfa.amsl.com [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 727551B2B0B for <ietf@ietfa.amsl.com>; Tue, 2 Feb 2016 05:58:03 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.599
X-Spam-Level:
X-Spam-Status: No, score=-2.599 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, FREEMAIL_FROM=0.001, RCVD_IN_DNSWL_LOW=-0.7, SPF_PASS=-0.001, UNPARSEABLE_RELAY=0.001] autolearn=ham
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 mzQDGu7-_s86 for <ietf@ietfa.amsl.com>; Tue, 2 Feb 2016 05:58:00 -0800 (PST)
Received: from relais-inet.francetelecom.com (relais-ias91.francetelecom.com [193.251.215.91]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 982191B2B09 for <ietf@ietf.org>; Tue, 2 Feb 2016 05:57:59 -0800 (PST)
Received: from omfedm06.si.francetelecom.fr (unknown [xx.xx.xx.2]) by omfedm12.si.francetelecom.fr (ESMTP service) with ESMTP id F2E6018C9A4; Tue, 2 Feb 2016 14:57:57 +0100 (CET)
Received: from Exchangemail-eme2.itn.ftgroup (unknown [10.114.31.24]) by omfedm06.si.francetelecom.fr (ESMTP service) with ESMTP id C50FE27C069; Tue, 2 Feb 2016 14:57:57 +0100 (CET)
Received: from OPEXCLILMA3.corporate.adroot.infra.ftgroup ([fe80::60a9:abc3:86e6:2541]) by OPEXCLILM7D.corporate.adroot.infra.ftgroup ([fe80::9044:c5ee:4dd2:4f16%19]) with mapi id 14.03.0279.002; Tue, 2 Feb 2016 14:57:57 +0100
From: mohamed.boucadair@orange.com
To: S Moonesamy <sm+ietf@elandsys.com>, Brandon Williams <brandon.williams@akamai.com>, Dan Wing <dwing@cisco.com>
Subject: RE: Review of draft-williams-exp-tcp-host-id-opt-07
Thread-Topic: Review of draft-williams-exp-tcp-host-id-opt-07
Thread-Index: AQHRW6AZ7mDWFhInEEiCTL+/lU/fup8Yu0mw
Date: Tue, 02 Feb 2016 13:57:56 +0000
Message-ID: <787AE7BB302AE849A7480A190F8B933008CD0FEB@OPEXCLILMA3.corporate.adroot.infra.ftgroup>
References: <6.2.5.6.2.20160129225434.06db0028@elandnews.com>
In-Reply-To: <6.2.5.6.2.20160129225434.06db0028@elandnews.com>
Accept-Language: fr-FR, en-US
Content-Language: fr-FR
X-MS-Has-Attach:
X-MS-TNEF-Correlator:
x-originating-ip: [10.168.234.3]
Content-Type: text/plain; charset="iso-8859-1"
Content-Transfer-Encoding: quoted-printable
MIME-Version: 1.0
X-PMX-Version: 6.2.1.2478543, Antispam-Engine: 2.7.2.2107409, Antispam-Data: 2016.2.2.125716
Archived-At: <http://mailarchive.ietf.org/arch/msg/ietf/I7wBfxKspNCBQ_yx6ZMIIjCuuFE>
Cc: "ietf@ietf.org" <ietf@ietf.org>, "rfc-ise@rfc-editor.org" <rfc-ise@rfc-editor.org>
X-BeenThere: ietf@ietf.org
X-Mailman-Version: 2.1.15
Precedence: list
List-Id: IETF-Discussion <ietf.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/ietf>, <mailto:ietf-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/ietf/>
List-Post: <mailto:ietf@ietf.org>
List-Help: <mailto:ietf-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/ietf>, <mailto:ietf-request@ietf.org?subject=subscribe>
X-List-Received-Date: Tue, 02 Feb 2016 13:58:03 -0000

Dear SM,

Thank you for the review. 

Please see inline.

Cheers,
Med

> -----Message d'origine-----
> De : S Moonesamy [mailto:sm+ietf@elandsys.com]
> Envoyé : samedi 30 janvier 2016 21:48
> À : Brandon Williams; BOUCADAIR Mohamed IMT/OLN; Dan Wing
> Cc : rfc-ise@rfc-editor.org; ietf@ietf.org
> Objet : Review of draft-williams-exp-tcp-host-id-opt-07
> 
> Hello,
> 
> I am reviewing draft-williams-exp-tcp-host-id-opt-07 for the
> Independent Stream.
> 
> Overall, the document is well-written.

[Med] Thank you.

  I suggest reviewing the usage
> of the RFC 2119 key words as it makes the document look like a
> document about compliance.  The intended status of the document is
> "Experimental".  How long will this experiment last?

[Med] The document includes a dedicated section for the experiments goals (https://tools.ietf.org/html/draft-williams-exp-tcp-host-id-opt-07#section-1.2). The implicit exit criteria is when the refinements mentioned in that section are met.   

> 
> The Abstract states that "proposals discussed in the IETF [which]
> have identified benefits to more distinctly identifying the hosts
> that are hidden behind a shared address/prefix sharing device or
> application-layer proxy".  Is the sentence:
> 
>    (i)   misleading
> 
>    (ii)  one-sided
> 
>    (iii) any other alternative
> 
> I'll choose (ii) as the sentence mentions benefits only.  I did not
> see any mention of "IETF" in Section 1.  Why is "IETF" mentioned in
> the Abstract?  I looked at the proposals referenced in
> draft-williams-exp-tcp-host-id-opt-07 and they are from one of the
> authors of this draft and from the same companies.  Isn't that self-
> citation?

[Med] There are a variety of documents that were discussed within IETF about revealing the original IP address. Some examples are listed below:

* https://tools.ietf.org/html/rfc6967 (which cites other documents)
* https://tools.ietf.org/html/rfc7239 (Standards Track)
* https://tools.ietf.org/html/draft-ietf-dnsop-edns-client-subnet-06 
 
Saying that, if you think that the text is not neutral we are open to reword it. 

> 
>  From Section 1 of the draft:
> 
>    "The purpose of this document is to describe a TCP HOST_ID option
>     that is currently deployed on the Internet using the TCP
>     experimental option codepoint including discussion of related
>     design, deployment, and privacy considerations."
> 
> I suggest focusing on the above if that is the purpose of the
> document.  Could the authors please explain which of the bullet
> points in Section 2 of RFC 4846 is applicable to this document?
> 

[Med] Bullet 11 is applicable to this document, IMO. Bullet 1 and 3 would work too.

>    "Specification of multiple option formats to serve the purpose of
>     host identification increases the burden for potential implementers
>     and presents interoperability challenges as well.  This document
>     defines a common TCP option format that supersedes all three of the
>     above proposals."
> 
> Does that mean that Akamai, Cisco and France Telecom have agreed on a
> common TCP option format and have implemented that?

[Med] Having multiple formats of a TCP option that is targeting a similar problem is not a good signal for interoperability. The format in the specification is what we agreed among three of us. Pointers to the initial format proposals are included in the draft. 

> 
>    "The option defined in this document uses the TCP experimental option
>     codepoint sharing mechanism defined in [RFC6994] and is intended to
>     allow broad deployment of the mechanism on the public Internet."
> 
> Is it the opinion of the authors of this draft that it isn't
> worthwhile to get IETF Consensus on a mechanism for broad deployment
> on the public Internet?

[Med] We tried that path...You may check tcpm archives, fwiw.  

> 
> In Section 1.2:
> 
>    "In particular, documentation of the mechanism is expected to provide
>     opportunities for engagement with a broader range of both application
>     and middleware implementations in order to develop a more complete
>     picture of how well the option meets the use-case requirements."
> 
> How does publication in the Independent Stream provide "opportunities
> for engagement"?

[Med] An RFC is ideal for stable and permanent publication. Having such permanent access is an opportunity for engagement. 

> 
> In Section 4.1:
> 
>    "The HOST_ID option value MUST correlate to IP addresses and/or TCP
>     port numbers that were changed by the inserting host/device (i.e.,
>     some of the IP address and/or port number bits are used to generate
>     the HOST_ID)."
> 
> The above is a requirement for "fingerprinting".  The document then
> provides examples that satisfy the requirement.  I suggest making the
> requirement clear instead of taking a "requirement by example" approach.

[Med] One of the goals of this effort is to help tweaking which values can (not) be included in the option. This is why we are listing those as examples. 

> 
> In Section 6:
> 
>    "The content of the HOST_ID option SHOULD NOT be used for purposes
>     that require a trust relationship between the sender and the receiver
>     (e.g. billing and/or subscriber policy enforcement)."
> 
> Why shouldn't the HOST_ID be used for purposes that require trust
> relationships?  The sentence which follows the quoted text (see
> above) states that the "SHOULD" is a requirement.  From what I
> understand, the paragraph is explaining the difference between
> "SHOULD" and "MUST".  I got lost in reading the Security
> Considerations Section.

[Med] The reason is that the option is not reliable: a device in the path can alter its content or an illegitimate node can spoof the IP address and the content of the host_id option. 

Relying on the option for billing purposes, for instance, when both the entity that injects the option and the one that consumes it are not within the same administrative domain is not recommended. We didn't use MUST because that limitation may not be valid for intra-domain deployments.

> 
> Section 7 states that NAT "is sometimes specifically intended to
> provide anonymity".  Are there any references for that?

[Med] see https://www.eff.org/issues/open-wireless for an example. 

> 
>    "The HOST_ID option MUST NOT provide client identification information
>     that was not publicly visible in IP packets for the TCP flows
> processed
>     by the inserting host, such as subscriber information linked to the IP
>     address."
> 
> Why is the above a RFC 2119 "MUST NOT"?

[Med] This is the limit we fixed for this option by design: the option cannot reveal information that was not revealed by the originating host.

> 
> Why is Section 8 relevant?  This draft is not intended to be an IETF
> specification.

[Med] Because PM is a recurrent comment we receive. It is fair to include such discussion to avoid misinterpretations. Even with that section, we are still receiving comments saying that the document is asking for a globally unique identifier... which is not true! 

Also, we wanted to clarify that this document does not make things worse than IPv6. 

> 
> "Fance" is misspelled.

[Med] Thank you for catching that.

> 
> Regards,
> S. Moonesamy