Gen-art LC review: draft-holmerg-dispatch-iotl-03.txt

Robert Sparks <rjsparks@nostrum.com> Thu, 18 December 2014 21:09 UTC

Return-Path: <rjsparks@nostrum.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 13B121A1B87; Thu, 18 Dec 2014 13:09:31 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.91
X-Spam-Level:
X-Spam-Status: No, score=-1.91 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, T_RP_MATCHES_RCVD=-0.01] 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 ik_-PGlo5mLY; Thu, 18 Dec 2014 13:09:29 -0800 (PST)
Received: from nostrum.com (raven-v6.nostrum.com [IPv6:2001:470:d:1130::1]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 2C41D1A6FD6; Thu, 18 Dec 2014 13:09:29 -0800 (PST)
Received: from unnumerable.local (pool-71-96-107-228.dllstx.fios.verizon.net [71.96.107.228]) (authenticated bits=0) by nostrum.com (8.14.9/8.14.7) with ESMTP id sBIL9St6048239 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=OK); Thu, 18 Dec 2014 15:09:28 -0600 (CST) (envelope-from rjsparks@nostrum.com)
X-Authentication-Warning: raven.nostrum.com: Host pool-71-96-107-228.dllstx.fios.verizon.net [71.96.107.228] claimed to be unnumerable.local
Message-ID: <54934283.5090905@nostrum.com>
Date: Thu, 18 Dec 2014 15:09:23 -0600
From: Robert Sparks <rjsparks@nostrum.com>
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.10; rv:31.0) Gecko/20100101 Thunderbird/31.3.0
MIME-Version: 1.0
To: draft-holmberg-dispatch-iotl@tools.ietf.org, dispatch@ietf.org, "ietf@ietf.org" <ietf@ietf.org>
Subject: Gen-art LC review: draft-holmerg-dispatch-iotl-03.txt
Content-Type: text/plain; charset="utf-8"; format="flowed"
Content-Transfer-Encoding: 7bit
Archived-At: http://mailarchive.ietf.org/arch/msg/ietf/qeqGqzEWLPnuIWKLBXA-ivERp84
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: <http://www.ietf.org/mail-archive/web/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: Thu, 18 Dec 2014 21:09:31 -0000

I am the assigned Gen-ART reviewer for this draft. For background on
Gen-ART, please see the FAQ at

<http://wiki.tools.ietf.org/area/gen/trac/wiki/GenArtfaq>.

Please resolve these comments along with any other Last Call comments
you may receive.

Document: draft-holmberg-dispatch-iotl-03
Reviewer: Robert Sparks
Review Date: 18-Dec-2014
IETF LC End Date: 8-Jan-2015
IESG Telechat date: Not on an upcoming telechat agenda

Summary: Almost ready for publication as a Proposed Standard but has 
issues that need to be addressed

There are only a few issues to address:

Major Issue 1: It makes no sense to publish a standards track RFC that 
says behavior on general networks is undefined. I've reviewed all of the 
list traffic about this document, and I understand how the text that's 
currently in the document got there, but it's not the best way to deal 
with the concern that caused it to be introduced. The original concern 
was that the document didn't provide enough detail to tell what the 
presence or absence of the values meant, and whether there was an 
associate d change to the semantics of the protocol. While the 
description is thin, I think there has been enough shown to know that 
the semantics of the protocol are not being changed.

So, instead, the document should just recognize that devices that don't 
implement this specification will do what RFC 3261 requires them to do 
with unknown URI parameters: ignore them. This document sufficiently 
describes what the values it defines means to elements that _do_ 
implement this specification. They provide additional information to 
upper layers (ultimately, transaction users as 3261 defines them), and 
those upper layers might make forwarding decisions using it, just like 
they can use _anything_ at their disposal. The basic semantics of the 
SIP protocol are unaffected.

To resolve this issue, I suggest removing the text that occurs in 
several places saying that this is applicable only to 3gpp networks, and 
add a short sentence reminding the reader that RFC3261 expects new URI 
parameters to be standardized and defines how unknown URI parameters are 
handled.

Major Issue 2: The document suggests that implementations violate what 
RFC3261 requires them to do. Specifically, it says "An entity that 
understands the 'iotl' parameter MUST NOT, from a SIP request, remove 
'iotl' parameters from SIP URIs associated with other entities, unless 
the entity has means to determine that the 'iotl' parameter does not 
represent a valid traffic leg." RFC3261 requires that MUST NOT, and it 
does not allow the "unless" clause. It is not ok for an entity to change 
some other entities URIs in, say, Route, Service-Route, Path, and 
similar places under any circumstances.

My suggested resolution is to remove the unless clause, and change the 
first part of the sentence to note that this is what 3261 requires.

Major issue 3: The Security considerations section is incomplete. Please 
discuss the ramifications of something maliciously providing an 
incorrect value in the parameter. What are the ramifications if someone 
does violate protocol and changes or removes a value in transit?

Minor issue 1: It is unclear where you expect these URIs to occur. I 
have a good feel only after reading the list traffic. I suggest you be 
explicit in 5.1 that you expect these to be placed in Service-Route and 
Path header field values, hence to occur in Route header field values, 
and Request-URIs.

Minor issue 2: Why do you say "This document does not specify the usage 
of the 'iotl' parameter within a SIP URI of a Record-Route header field. 
Would it create an interoperability problem if someone put one there? 
Because if they do, it will end up in Route header fields later. If 
that's ok, please strike the sentence. If it's not, then you need to say 
MUST NOT place the parameter in URIs in Record-Route header field values.

Nits/editorial comments:

Since you are providing an extension point for other values, someone 
will ask if you need a registry for those values. I suggest explicitly 
saying we are not creating a registry at this time but expect to do so 
if the extension point is ever used to head that conversation off.

"dialogue" appears in a couple of places. Since we're talking about the 
3261 term, I suggest using "dialog" consistently.

The sentence (which occurs in the abstract and introduction) "The 
directionality in traffic legs relates to a SIP request creating a 
dialogue and stand-alone SIP request." does not parse. What is it trying 
to say, and why is it important?