Re: [Ace] Transporting different types of cnf objects - CBOR vs JSON

Carsten Bormann <cabo@tzi.org> Wed, 02 October 2019 13:05 UTC

Return-Path: <cabo@tzi.org>
X-Original-To: ace@ietfa.amsl.com
Delivered-To: ace@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id E4DDC120019 for <ace@ietfa.amsl.com>; Wed, 2 Oct 2019 06:05:01 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -4.198
X-Spam-Level:
X-Spam-Status: No, score=-4.198 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, RCVD_IN_DNSWL_MED=-2.3, SPF_HELO_NONE=0.001, SPF_NONE=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 VUj0tKDJTQIH for <ace@ietfa.amsl.com>; Wed, 2 Oct 2019 06:04:59 -0700 (PDT)
Received: from gabriel-vm-2.zfn.uni-bremen.de (gabriel-vm-2.zfn.uni-bremen.de [134.102.50.17]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 49E1712000F for <ace@ietf.org>; Wed, 2 Oct 2019 06:04:59 -0700 (PDT)
Received: from [10.159.97.60] (ewa_guest_internet_sthlm_nat2.ericsson.net [192.176.1.97]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by gabriel-vm-2.zfn.uni-bremen.de (Postfix) with ESMTPSA id 46jxF52qRZzycT; Wed, 2 Oct 2019 15:04:57 +0200 (CEST)
Content-Type: text/plain; charset="utf-8"
Mime-Version: 1.0 (Mac OS X Mail 11.5 \(3445.9.1\))
From: Carsten Bormann <cabo@tzi.org>
In-Reply-To: <CAA7SwCO_jb8aFW+hX9sf6pxm07=LGZ2tLtwv6u92k11zyexVbw@mail.gmail.com>
Date: Wed, 02 Oct 2019 15:04:56 +0200
Cc: Jim Schaad <ietf@augustcellars.com>, Ludwig Seitz <ludwig.seitz@ri.se>, ace@ietf.org
X-Mao-Original-Outgoing-Id: 591714294.919346-2f44c50a1ebcd12956fb22dba089bda3
Content-Transfer-Encoding: quoted-printable
Message-Id: <586CDF5F-F0E4-4514-8AB7-AAA383CA23FB@tzi.org>
References: <000201d51814$34a85fc0$9df91f40$@augustcellars.com> <9a0bbcd4-6055-729c-7ca8-205d0a1fd681@ri.se> <010901d51b04$92788a10$b7699e30$@augustcellars.com> <CAA7SwCPunMN6S0xwVd0nCKx_zwdGbgj-UVPOa7hRq6gMv7WUAg@mail.gmail.com> <CAA7SwCO_jb8aFW+hX9sf6pxm07=LGZ2tLtwv6u92k11zyexVbw@mail.gmail.com>
To: Cigdem Sengul <cigdem.sengul@gmail.com>
X-Mailer: Apple Mail (2.3445.9.1)
Archived-At: <https://mailarchive.ietf.org/arch/msg/ace/RuhDg9nW6ivZEKpblJUfSfGci6E>
Subject: Re: [Ace] Transporting different types of cnf objects - CBOR vs JSON
X-BeenThere: ace@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: "Authentication and Authorization for Constrained Environments \(ace\)" <ace.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/ace>, <mailto:ace-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/ace/>
List-Post: <mailto:ace@ietf.org>
List-Help: <mailto:ace-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/ace>, <mailto:ace-request@ietf.org?subject=subscribe>
X-List-Received-Date: Wed, 02 Oct 2019 13:05:02 -0000

There is no strong interdependency between Web transfer protocol (HTTPS/CoAPS) and data format.
COSE works great over HTTPS, and if it must be, you can ship JOSE over CoAPS.

Grüße, Carsten


> On Oct 2, 2019, at 14:00, Cigdem Sengul <cigdem.sengul@gmail.com> wrote:
> 
> Hello all, 
> 
> I am trying to implement this discussion in the draft.  A point is raised about COSE keys in JSON messages. 
> Could it be possible to go with:
> (1) HTTPS - application/ace+json - jwt - jose - PoP for JWT
> or
> (2) CoAP - application/ace+cbor - cwt - cose - PoP for CWT
> without mixing anything?
> 
> (1) we thought to describe by default in the document, and (2) we said MAY be supported. 
> Is there a problem with this approach?
> 
> Thanks,
> --Cigdem 
> 
> 
> On Tue, Jun 4, 2019 at 9:29 PM Cigdem Sengul <cigdem.sengul@gmail.com> wrote:
> Hello,
> Yes, we thought supporting JSON option would be good, though indeed there is no issue with transporting CBOR.. 
> If there are no other concerns, we can define the new media type in the MQTT draft. 
> Will add the issue to GitHub repo.
> 
> --Cigdem 
> 
> On Tue, Jun 4, 2019 at 7:37 PM Jim Schaad <ietf@augustcellars.com> wrote:
> 
> 
> > -----Original Message-----
> > From: Ace <ace-bounces@ietf.org> On Behalf Of Ludwig Seitz
> > Sent: Monday, June 3, 2019 11:51 PM
> > To: ace@ietf.org
> > Subject: Re: [Ace] Transporting different types of cnf objects - CBOR vs JSON
> > 
> > On 01/06/2019 02:51, Jim Schaad wrote:
> > > Ludwig,
> > >
> > > I have been doing some adaptions of my codebase for dealing with the
> > > MQTT specification.  In the process of this, I have identified the
> > > following items that I think needs some discussion.  They may not need
> > > changes in any documents and maybe should get a new document.
> > >
> > > 1.  The MQTT document is using the content type "application/json"
> > > over HTTPS for transporting messages.  Does there need to be an
> > > "application/ace+json" defined as a media type, but not necessarily a
> > > CBOR media type?  I think the answer may be yes, but it could be a new
> > document.
> > >
> > I would argue that the first draft using such a media type would be the right
> > place to specify it. However I'm not sure using JSON is the right approach for
> > an ACE specification at all, aren't we supposed to cater for the constrained
> > world?
> > What is there to prevent us from transporting CBOR over HTTP?
> 
> There would be no reason that one cannot transport CBOR over HTTP.  During the discussions for these drafts Hannes was very explicit that he wanted to be able to use JSON rather than CBOR with the protocol that was defined by ACE.  This would mean that there needs to be an ability to use JSON with the ACE framework document.
> 
> I would have no problems with the statement that the MQTT document would be a good place to define the new media type.
> 
> > 
> > > 2.  If I use a "COSE_Key" confirmation method inside of an
> > > application/ace+json message, there is a potential problem and it
> > > could be dealt with in a number of different ways.
> > > *  The JWT confirmation method is identified as "jwk".  The COSE key
> > > must be translated into JOSE even if there is no equivalent key in
> > > JOSE.  I.e. that is a fatal error
> > > *  This does not make sense and the confirmation method should be
> > > changed to "cwk" so that either key format could be used in either
> > encoding.
> > >
> > 
> > If we use JSON messages mixing in COSE becomes awkward. If the use case
> > calls for JSON, I'd argue it should also use RFC7800 instead of draft-ietf-ace-
> > cwt-proof-of-possession.
> 
> I would not have a problem with this, it was one of the options above.  I was just expanding my code to allow for JSON to be used and ran into this.  I just wanted to get a clear group decision on this before I put things into stone.
> 
> Jim
> 
> > 
> > > 3.  If the confirmation is changed, you would need to convert the COSE
> > > key to a binary string, base64 encoded it and pass as a string when
> > > occurring in a JSON encoding.  There is not any other valid way to do
> > > this (except see above of just converting the key format).  However,
> > > the opposite of putting a JOSE key into a COSE confirmation has three
> > > different options that could be used.
> > > *  Encode the JOSE key to a string and pass as a string
> > > *  Encode the JOSE key top level map as CBOR but leave all of the
> > > elements alone.
> > > *  Encode the JOSE key in CBOR including conversion of base64 strings
> > > to binary data.
> > > (My first preference is probably the second option, but either of the
> > > first two make sense.)
> > >
> > > Jim
> > >
> > 
> > I'm still unsure that there is a good use case for transporting JOSE keys in
> > CBOR, but if such a case turns up, I would agree that touching the encoding
> > as little as possible is a good idea (=option 1 or 2).
> > 
> > /Ludwig
> > 
> > --
> > Ludwig Seitz, PhD
> > Security Lab, RISE
> > Phone +46(0)70-349 92 51
> 
> 
> _______________________________________________
> Ace mailing list
> Ace@ietf.org
> https://www.ietf.org/mailman/listinfo/ace
> _______________________________________________
> Ace mailing list
> Ace@ietf.org
> https://www.ietf.org/mailman/listinfo/ace