Re: [stir] Review of: draft-ietf-stir-passport-05

Victor Pascual <victor.pascual.avila@oracle.com> Sun, 31 July 2016 18:44 UTC

Return-Path: <victor.pascual.avila@oracle.com>
X-Original-To: stir@ietfa.amsl.com
Delivered-To: stir@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 23BE912B03F for <stir@ietfa.amsl.com>; Sun, 31 Jul 2016 11:44:55 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -5.506
X-Spam-Level:
X-Spam-Status: No, score=-5.506 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, HTML_MESSAGE=0.001, MIME_QP_LONG_LINE=0.001, RCVD_IN_DNSWL_MED=-2.3, RCVD_IN_MSPIKE_H3=-0.01, RCVD_IN_MSPIKE_WL=-0.01, RP_MATCHES_RCVD=-1.287, SPF_PASS=-0.001] 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 Z1j0CaPXoql9 for <stir@ietfa.amsl.com>; Sun, 31 Jul 2016 11:44:53 -0700 (PDT)
Received: from userp1040.oracle.com (userp1040.oracle.com [156.151.31.81]) (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 117EB12B011 for <stir@ietf.org>; Sun, 31 Jul 2016 11:44:53 -0700 (PDT)
Received: from aserv0021.oracle.com (aserv0021.oracle.com [141.146.126.233]) by userp1040.oracle.com (Sentrion-MTA-4.3.2/Sentrion-MTA-4.3.2) with ESMTP id u6VIicMD018795 (version=TLSv1 cipher=DHE-RSA-AES256-SHA bits=256 verify=OK); Sun, 31 Jul 2016 18:44:38 GMT
Received: from userv0121.oracle.com (userv0121.oracle.com [156.151.31.72]) by aserv0021.oracle.com (8.13.8/8.13.8) with ESMTP id u6VIib5f019599 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=OK); Sun, 31 Jul 2016 18:44:38 GMT
Received: from abhmp0002.oracle.com (abhmp0002.oracle.com [141.146.116.8]) by userv0121.oracle.com (8.13.8/8.13.8) with ESMTP id u6VIiZ2A032582; Sun, 31 Jul 2016 18:44:36 GMT
Received: from [192.168.1.34] (/83.32.133.0) by default (Oracle Beehive Gateway v4.0) with ESMTP ; Sun, 31 Jul 2016 11:44:34 -0700
References: <07e0eb16-6758-cdf1-c571-1f1ed768e741@dcrocker.net> <D3C152B2.1A69BA%jon.peterson@neustar.biz> <b096b541-c8af-9617-c9d7-5a1beb5230e8@dcrocker.net> <D3C16040.1A6A09%jon.peterson@neustar.biz> <d66d91f0-9ea2-6295-e749-e48ea37b4892@dcrocker.net> <D3C19686.1A6A4E%jon.peterson@neustar.biz> <dd60178b-fa24-5099-166c-f8a0093cb668@dcrocker.net> <7594FB04B1934943A5C02806D1A2204B476FE6CB@ESESSMB209.ericsson.se> <7f35b810-0eca-5140-060e-4aef03449c21@dcrocker.net> <D9F5ECF9-3ED0-478A-9261-2892AF9EAB8F@chriswendt.net> <7594FB04B1934943A5C02806D1A2204B477074D5@ESESSMB209.ericsson.se>
Mime-Version: 1.0 (1.0)
In-Reply-To: <7594FB04B1934943A5C02806D1A2204B477074D5@ESESSMB209.ericsson.se>
Content-Type: multipart/alternative; boundary="Apple-Mail-8975C242-323F-43B1-AF11-A01F428AFD57"
Content-Transfer-Encoding: 7bit
Message-Id: <BC7D5760-CFAB-491C-94AC-BA37C976DF6D@oracle.com>
X-Mailer: iPhone Mail (12D508)
From: Victor Pascual <victor.pascual.avila@oracle.com>
Date: Sun, 31 Jul 2016 20:44:30 +0200
To: Christer Holmberg <christer.holmberg@ericsson.com>
X-Source-IP: aserv0021.oracle.com [141.146.126.233]
Archived-At: <https://mailarchive.ietf.org/arch/msg/stir/OMqv0ALnSwLvv7Q-0SgccA76WK8>
Cc: Chris Wendt <chris-ietf@chriswendt.net>, "dcrocker@bbiw.net" <dcrocker@bbiw.net>, "Peterson, Jon" <jon.peterson@neustar.biz>, IETF STIR Mail List <stir@ietf.org>
Subject: Re: [stir] Review of: draft-ietf-stir-passport-05
X-BeenThere: stir@ietf.org
X-Mailman-Version: 2.1.17
Precedence: list
List-Id: Secure Telephone Identity Revisited <stir.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/stir>, <mailto:stir-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/stir/>
List-Post: <mailto:stir@ietf.org>
List-Help: <mailto:stir-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/stir>, <mailto:stir-request@ietf.org?subject=subscribe>
X-List-Received-Date: Sun, 31 Jul 2016 18:44:55 -0000

Fully agree

> On 31 Jul 2016, at 19:54, Christer Holmberg <christer.holmberg@ericsson.com> wrote:
> 
> Hi,
> 
> I agree with Chris. JWT is NOT a mechanism to sign any arbitrary JSON structure. JWT is a mechanism to sign data, and it uses a specific JSON structure (header, claims etc) for doing so. In addition, it provides a mechanism to signal what data/algorithm is used to calculate the signature.
> 
> Regards,
> 
> Christer
> 
> Sent from my Windows Phone
> From: Chris Wendt
> Sent: ‎31/‎07/‎2016 00:08
> To: dcrocker@bbiw.net
> Cc: Christer Holmberg; Peterson, Jon; IETF STIR Mail List
> Subject: Re: [stir] Review of: draft-ietf-stir-passport-05
> 
> Hi Dave,
> 
> I’m not following your argument that because there isn’t a JSON object to sign, we can’t use JWT?
> In general, most/all uses of JWT don’t sign an existing object, a set of claims are constructed into a JSON payload that is signed.
> There are JWT defined claims precisely defined to create a secure token intentionally meant to be only signed in a JWT.
> 
> So to me, we are more than appropriately using JSON and JWT.
> 
> It is in 4474bis, we define the exact information to construct the JSON payload object to be signed, so please refer to that.
> 
> There are many advantages to using the JWT construct both for STIR charter specifically and elsewhere.
> 
> Is that a bad thing?
> 
> -Chris
> 
> > On Jul 30, 2016, at 9:03 AM, Dave Crocker <dhc@dcrocker.net> wrote:
> > 
> > Christer,
> > 
> > Thanks for the background...
> > 
> > On 7/30/2016 4:30 AM, Christer Holmberg wrote:
> >> I am the one who originally suggested the usage of JWT. I don't
> >> understand the claim that JWT is "outside the context of SIP". JWT is a
> >> generic/standardized mechanism how to calculate and encode a signature,
> > 
> > Actually, it isn't.
> > 
> > It's own opening text [RFC 7519] says it is "a compact, URL-safe means of representing claims to be transferred between two parties" but more importantly for this issue, it goes on to say:
> > 
> >   "encoded as a JSON object that is used as the payload of a JSON
> >   Web Signature (JWS) structure or as the plaintext of a JSON Web
> >   Encryption (JWE) structure"
> > 
> > That is, it provides value-added functions... to a JSON object (structure).  However SIP doesn't have a JSON object to sign.  So the working group has had to invent a JSON-based abstraction of SIP header information and then sign it.
> > 
> > Now it has to invent an encoding for the resulting signature.  It would have to do that for a SIP call, no matter the signature's computational abstraction, but because that abstraction is actually an independent format, it wound up distracting the wg from doing a complete job -- so far, after 3 years -- of defining all the details for a complete authentication mechanism.
> > 
> > From what I can tell of the email record for the wg, the unfortunate part of the discussion about choices here was to count JSON/JWT as something other than an abstraction.
> > 
> > Signing an object requires defining the data over which the signature will be made, and how that data will be fed into the signing algorithm. Necessarily, that defines an abstraction of the data.  (Canonicalization seems to be a common component of that abstraction, for example.)
> > 
> > There might be nothing different or better (or, probably, worse) about JWT in those terms; I haven't tried to evaluate it in those terms.  The problem is that its existence as a distinct format has caused the working group to worry about that new and independent object as distinct from the SIP data being signed, rather than as a computational result that then needs to be stored into the SIP header.  So all of the discussion about what to do with the JWT object is additional wg overhead and, IMO, a complete distraction for the primary task of the working group.  (My guess is that there is also added overall system complexity, but I won't press that concern, at this point.)
> > 
> > Arguments that it's a general mechanism for use in other aspects of this space are always appealing. However they are, so far, without merit in the working group context: There are no specifications for any of those other uses.
> > 
> > And the wg still hasn't resolved the very basic and very essential step of putting the signature into the SIP header.
> > 
> > 
> > 
> >>     If we would NOT use JWT we would
> >> probably have to define more STIR-specific procedures regarding the
> >> calculating/encoding of the signature ourselves. It's better to use a
> >> standardized mechanism in my opinion.
> > 
> > Well, yeah, I thought/think that too, which was why I originally suggested adapting DKIM. (DANE might be another relevant choice.)  DKIM offers an extremely high point of departure for SIP header signing.  The continued lack of complete specification details about use with SIP demonstrates that JWT doesn't.
> > 
> > 
> >> I am also the one who raised the encoding issue in Berlin. But that was
> >> not related to the usage of JWT as such, but to the fact that we don't
> >> carry the encoded JWT object in one piece in the SIP message. We "split"
> >> the object into two pieces, and carry one piece as the Identity header
> >> field value, and the other piece as the canon header field parameter
> >> value.
> > 
> > Right.  And the point I'm raising is not about the details of that choice but the fact that it still hasn't been made at this very late stage.
> > 
> > Besides merely being a missing, essential bit of system specification, it suggests that the wg is still not completely clear about the concrete use of this capability.
> > 
> > 
> > d/
> > -- 
> > 
> >  Dave Crocker
> >  Brandenburg InternetWorking
> >  bbiw.net
> > 
> > _______________________________________________
> > stir mailing list
> > stir@ietf.org
> > https://www.ietf.org/mailman/listinfo/stir
> 
> _______________________________________________
> stir mailing list
> stir@ietf.org
> https://www.ietf.org/mailman/listinfo/stir