Re: [OAUTH-WG] Recommendations for browser-based apps

Neil Madden <neil.madden@forgerock.com> Wed, 20 September 2017 05:21 UTC

Return-Path: <neil.madden@forgerock.com>
X-Original-To: oauth@ietfa.amsl.com
Delivered-To: oauth@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id E104313308A for <oauth@ietfa.amsl.com>; Tue, 19 Sep 2017 22:21:45 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.999
X-Spam-Level:
X-Spam-Status: No, score=-1.999 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, HTML_MESSAGE=0.001, MIME_QP_LONG_LINE=0.001, RCVD_IN_DNSWL_NONE=-0.0001, SPF_PASS=-0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (1024-bit key) header.d=forgerock.com
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 FAQX0SPg16X9 for <oauth@ietfa.amsl.com>; Tue, 19 Sep 2017 22:21:43 -0700 (PDT)
Received: from mail-wr0-x236.google.com (mail-wr0-x236.google.com [IPv6:2a00:1450:400c:c0c::236]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 9F903133063 for <oauth@ietf.org>; Tue, 19 Sep 2017 22:21:42 -0700 (PDT)
Received: by mail-wr0-x236.google.com with SMTP id 108so1147767wra.5 for <oauth@ietf.org>; Tue, 19 Sep 2017 22:21:42 -0700 (PDT)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=forgerock.com; s=google; h=mime-version:subject:from:in-reply-to:date:cc :content-transfer-encoding:message-id:references:to; bh=gz7YpeC5UOYY8CemIJeHPOZ/db3pAHhrpGsmruI1LIM=; b=AhTZ973De319er6uh6JOki9P1yYdo+2fFNkLT/eBeaLq4K6b3hFYndDHccumvQec5o r5h1CaV66UY5e2FOaacRSed0Nk3GS72Ldi8dQCB7+oTSNv3phpq2kyJC+xBGTX2rbWM/ T5IxMM2k0/Yr6oCiFRQVoX/c7i8wLvi3Rya/E=
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:subject:from:in-reply-to:date:cc :content-transfer-encoding:message-id:references:to; bh=gz7YpeC5UOYY8CemIJeHPOZ/db3pAHhrpGsmruI1LIM=; b=TqzBQrELKpc0qtNKtR2NvWGiMdloBZrXTJ2calQIellB/JAxc2/hIdejgguILSrdDw fYr0xSm/V/8m8b9VCEnghk0IGePeRVCOAx8CLLcZIZNevOYvrg0UNVfP1Ya33OfixmyV pU4wG2ZVPPnxBaaDaZnGUEngd2hH/jXv7wjnmNYYvmtzPI7O8X7D1IeT9VL5Eyias45U SM3xfiPAX046Hs7SPHGsPLXaf/UkLUf2DV/FxKVCcv6eMXsIhW74V7lqocb9heIoRyz9 bKRMslbghBWyqx0K6p/r3u0VmEakK/gzYYf/Fk0xxRjN0OSVwxOoRqNl2n5YphHJXdpk nq5w==
X-Gm-Message-State: AHPjjUg4Y+F+K8ner+YefOrpIwSnhYg06ti0cQljtOATtgo6MkmoIIZA GleiPSbwfCbwDhBy8mgVsXxqVy4GMcwT5ywQ95Txqkpqh5omhEzyIu889PSCX3iLfEPkpNPACcT l1rwuIxVnahI/RetupvftR4ELSSAnvstrR5ZsHil6Fpsvhs7BKT/GdYOSjOR6E9lF8w==
X-Google-Smtp-Source: AOwi7QD+o5r/TNrLAjfDwaXgJwK0VF1fcEy1Kj+Gxhtuu3xNUmWtfopODP0IljMGbjdzKiN6vnMZRQ==
X-Received: by 10.223.199.196 with SMTP id y4mr3461088wrg.181.1505884900610; Tue, 19 Sep 2017 22:21:40 -0700 (PDT)
Received: from [192.168.1.2] (132.147.199.146.dyn.plus.net. [146.199.147.132]) by smtp.gmail.com with ESMTPSA id d9sm921924wrd.37.2017.09.19.22.21.39 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 19 Sep 2017 22:21:39 -0700 (PDT)
Content-Type: multipart/alternative; boundary="Apple-Mail-0A3125A8-3619-4FAD-A681-3CD32C86C302"
Mime-Version: 1.0 (1.0)
From: Neil Madden <neil.madden@forgerock.com>
X-Mailer: iPhone Mail (14G60)
In-Reply-To: <1A823C26-FC05-48C1-A2E1-7B2B6A2607BB@manicode.com>
Date: Wed, 20 Sep 2017 06:21:38 +0100
Cc: Bill Burke <bburke@redhat.com>, OAuth WG <oauth@ietf.org>
Content-Transfer-Encoding: 7bit
Message-Id: <555F5261-7F4B-4BFD-8911-A8BFD675EE3F@forgerock.com>
References: <CAKAMr-Dws2RVRLv+xTa7j2zk+yhpCpYN-jUgxFos+j--Abv4uQ@mail.gmail.com> <CABRXCmwKDOSQQrDdCVBkDWSi85A7FL_R9d9sNzgdBTE_HyKDMw@mail.gmail.com> <14E11D6D-3CA4-4945-93B5-96F40D17463E@oracle.com> <CAOahYUwYT-mFrdN-FvZArNCmVMn8G6X8504Z9EFY_rZ7A328qA@mail.gmail.com> <7630385B-8366-4B11-A5CA-BEE18F96AB8B@ve7jtb.com> <5C40C2B2-A673-4940-8376-55D448271A4C@gmail.com> <CABRXCmwDQ_uZXDaaX6gxn_J_FnaCDucA-5uZwF6K1uHMQs6nzw@mail.gmail.com> <1A823C26-FC05-48C1-A2E1-7B2B6A2607BB@manicode.com>
To: Jim Manico <jim@manicode.com>
Archived-At: <https://mailarchive.ietf.org/arch/msg/oauth/YIntaKQYgRvQvSyuNGdGhUyXv9I>
Subject: Re: [OAUTH-WG] Recommendations for browser-based apps
X-BeenThere: oauth@ietf.org
X-Mailman-Version: 2.1.22
Precedence: list
List-Id: OAUTH WG <oauth.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/oauth>, <mailto:oauth-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/oauth/>
List-Post: <mailto:oauth@ietf.org>
List-Help: <mailto:oauth-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/oauth>, <mailto:oauth-request@ietf.org?subject=subscribe>
X-List-Received-Date: Wed, 20 Sep 2017 05:21:46 -0000

Is this growing in support? It seems like a good idea, but when I reviewed it recently the draft had expired almost a year ago and still only Chrome and Opera had implemented it. From the outside it looks as if it has (inexplicably) died. Do you know if there is some activity happening behind the scenes?

-- Neil

> On 20 Sep 2017, at 02:31, Jim Manico <jim@manicode.com> wrote:
> 
> Not always, Bill. There is a new standard called "same site cookies" or "first party cookies" that allows you to programmatically remove this risk in some modern browsers, it's worth reviewing. 
> 
> https://tools.ietf.org/html/draft-west-first-party-cookies-07
> 
> It's live in Chrome and Opera and will only grow in support. http://caniuse.com/#search=samesite
> 
> Jim
> 
> 
>> On Sep 20, 2017, at 8:44 AM, Bill Burke <bburke@redhat.com> wrote:
>> 
>> Cookies are vulnerable to CXRF.
>> 
>>> On Tue, Sep 19, 2017 at 7:48 PM, nov matake <matake@gmail.com> wrote:
>>> Why not using http-only cookies instead of refresh tokens?
>>> If the app can interact with AuthZ server through a hidden iframe with
>>> prompt=none param, you shouldn’t need refresh tokens.
>>> 
>>> If your SAP is running on a different domain with the backend server,
>>> Safari’s Intelligent Tracking Prevention will break the hidden iframe way
>>> though.
>>> 
>>> On Sep 20, 2017, at 7:32, John Bradley <ve7jtb@ve7jtb.com> wrote:
>>> 
>>> Right,  Refresh token is bearer for native apps, that is why we came up with
>>> PKCE to protect code.
>>> 
>>> For Angular the code flow with PKCE is probably better than the token
>>> response type.
>>> 
>>> However with bearer tokens it is still riskier than code with a confidential
>>> client so the AS should take that into account and not allow refresh tokens
>>> to live forever.
>>> 
>>> One future way to protect refresh tokens and perhaps Access tokens is to use
>>> token binding to bind the tokens to the user agent.   You could do that now
>>> for refresh tokens in Edge (Chrome has TB off by default still).
>>> 
>>> I think more work needs to be done to come up with a best practice for SPA.
>>> 
>>> John B.
>>> 
>>> On Sep 19, 2017, at 7:02 PM, Adam Lewis <adam.lewis@motorolasolutions.com>
>>> wrote:
>>> 
>>> Only for confidential clients.  No authentication is required for public
>>> clients.
>>> 
>>> On Tue, Sep 19, 2017 at 4:47 PM, Phil Hunt (IDM) <phil.hunt@oracle.com>
>>> wrote:
>>>> 
>>>> Except a refresh token is not purely bearer. The client is required to
>>>> authenticate to use it.
>>>> 
>>>> Phil
>>>> 
>>>>> On Sep 19, 2017, at 2:33 PM, Bill Burke <bburke@redhat.com> wrote:
>>>>> 
>>>>> I'd be curious to the response to this too.
>>>>> 
>>>>> Seems to me that refresh token has the same possible security risks in
>>>>> an Angular app as an access token, except the refresh token is valid
>>>>> longer....Still, if you did the implicit flow, you'd have to have
>>>>> longer access token timeouts as it would be really annoying for the
>>>>> user to have to login again and again in a long session with your
>>>>> Angular app.
>>>>> 
>>>>> We have a javascript adapter that does Authz Code Flow with PKCE for
>>>>> our Angular app.  It also does CORS checks on the code to token XHR
>>>>> request just in case on the IDP side.
>>>>> 
>>>>>> On Tue, Sep 19, 2017 at 9:27 AM, Stefan Büringer <sbueringer@gmail.com>
>>>>>> wrote:
>>>>>> Hi,
>>>>>> 
>>>>>> there were some discussions in January regarding recommendations for
>>>>>> browser-based apps
>>>>>> (https://www.ietf.org/mail-archive/web/oauth/current/msg16874.html).
>>>>>> 
>>>>>> I'd just like to ask if the Authorization Code Flow with PKCE is a
>>>>>> valid
>>>>>> option for Single-Page-Applications (in our case Angular), because
>>>>>> Implicit
>>>>>> Flow cannot be used in our scenario.
>>>>>> 
>>>>>> Authorization Code Flow with PKCE eliminates the necessity for client
>>>>>> secrets, but our concern is that exposing the refresh token to the SPA
>>>>>> might
>>>>>> be a security risk, compared to the Implicit Flow were no refresh token
>>>>>> is
>>>>>> exposed.
>>>>>> 
>>>>>> What's your take on this?
>>>>>> 
>>>>>> Kind regards,
>>>>>> Stefan Büringer
>>>>>> 
>>>>>> P.S. I couldn't find that much on the internet regarding Authorization
>>>>>> Code
>>>>>> Flow with PKCE in SPAs, if you have some recommendations for good blog
>>>>>> posts
>>>>>> I would be grateful.
>>>>>> 
>>>>>> _______________________________________________
>>>>>> OAuth mailing list
>>>>>> OAuth@ietf.org
>>>>>> https://www.ietf.org/mailman/listinfo/oauth
>>>>>> 
>>>>> 
>>>>> 
>>>>> 
>>>>> --
>>>>> Bill Burke
>>>>> Red Hat
>>>>> 
>>>>> _______________________________________________
>>>>> OAuth mailing list
>>>>> OAuth@ietf.org
>>>>> https://www.ietf.org/mailman/listinfo/oauth
>>>> 
>>>> _______________________________________________
>>>> OAuth mailing list
>>>> OAuth@ietf.org
>>>> https://www.ietf.org/mailman/listinfo/oauth
>>> 
>>> 
>>> _______________________________________________
>>> OAuth mailing list
>>> OAuth@ietf.org
>>> https://www.ietf.org/mailman/listinfo/oauth
>>> 
>>> 
>>> _______________________________________________
>>> OAuth mailing list
>>> OAuth@ietf.org
>>> https://www.ietf.org/mailman/listinfo/oauth
>>> 
>>> 
>>> 
>>> _______________________________________________
>>> OAuth mailing list
>>> OAuth@ietf.org
>>> https://www.ietf.org/mailman/listinfo/oauth
>>> 
>> 
>> 
>> 
>> -- 
>> Bill Burke
>> Red Hat
>> 
>> _______________________________________________
>> OAuth mailing list
>> OAuth@ietf.org
>> https://www.ietf.org/mailman/listinfo/oauth
> _______________________________________________
> OAuth mailing list
> OAuth@ietf.org
> https://www.ietf.org/mailman/listinfo/oauth