Re: [OAUTH-WG] [EXTERNAL] Rotating RTs and grace periods

Pieter Kasselman <pieter.kasselman@microsoft.com> Tue, 02 November 2021 14:09 UTC

Return-Path: <pieter.kasselman@microsoft.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 0E7833A11DC for <oauth@ietfa.amsl.com>; Tue, 2 Nov 2021 07:09:35 -0700 (PDT)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -2.001
X-Spam-Level:
X-Spam-Status: No, score=-2.001 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, DKIMWL_WL_HIGH=-0.001, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, HTML_MESSAGE=0.001, HTTPS_HTTP_MISMATCH=0.1, RCVD_IN_MSPIKE_H2=-0.001, SPF_PASS=-0.001, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Authentication-Results: ietfa.amsl.com (amavisd-new); dkim=pass (1024-bit key) header.d=microsoft.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 SLNxF4bFrX3T for <oauth@ietfa.amsl.com>; Tue, 2 Nov 2021 07:09:30 -0700 (PDT)
Received: from EUR04-DB3-obe.outbound.protection.outlook.com (mail-eopbgr60100.outbound.protection.outlook.com [40.107.6.100]) (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 483843A11D5 for <oauth@ietf.org>; Tue, 2 Nov 2021 07:09:30 -0700 (PDT)
ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=PH8nw0zdamKlgm/Omy7zpgWIKzJM6NvDKAicbawCySLD4Z241u0ttelt10x5YonH5HeEENC6dxHAM9oPximAsQqgiVBXdAWxBWoouEuwF1nWefrsdzzpk2ouh7bqHKTXrextKYA7Hl/BQWhosnVoT0Old0TlIyai8sn+y9g2SUOdY6E9eumjpz1egVfCiR4B8v5MhXd+jiSG3Xv6wEdIVTrlDVipa8YNvfJaKGxRiNxiTVxv0ysQqzLQHHmmlQWj8SPCXpNxq3MZVF7f7Nar46v1mH0dGHLhd5R3wYCSXm4A9ECO73Ly9AFkti/iLeMePyE5zHEwHCc7wCXue4ClmA==
ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=6acJAR3P0PGGGh6g0PAP94e71YVBT/sStcnMsx0q4EM=; b=NRbn+GwHY3I7z5ebKD0NftYvYJhBrYu9apSX6Yis16YBPXnwCOz1YE1CcT6wfPgFMu3h+jWjaFceYAEBn7wpqV7jpa+S1HLEQm8qxbFZSy9EnT7zd4zrnrID53zQg9KrSKPL9EG1KkZXf6xBeK1ae43w3gpWAOe2BrjTpRhIvhpkpMdgYb1dYSjpxrBfyTR92lIzqcxk6ydNNJTEccu6X9smUoioaF69Pzbveopx3z9HaYrDlcnOqLP6Pvo6/lpiVDmItGS+5YvKJ/LeiUpt0oUmq48bSypmfWT1lLwY+ylIQKx5IL4tHHUo28G0veoj8q5fhdV5mGPSd7IWlP5bQA==
ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=microsoft.com; dmarc=pass action=none header.from=microsoft.com; dkim=pass header.d=microsoft.com; arc=none
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=selector2; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=6acJAR3P0PGGGh6g0PAP94e71YVBT/sStcnMsx0q4EM=; b=JD4Y4AbSa8NDLk7LLiULxKi6FJLGcGKysLQVLcEs+P2Zst0gBljTtJTOVfW2gwYJtEake7djZ9nGeMkjMS64lvy6YG+E1AC28YKcEE0WkN9QvnxGkOB0KHRib+5ktBCTNMm1BUa3Y+cISOoGVTDBwFaKdqU3ffxYprlemBXKR+U=
Received: from AM7PR83MB0452.EURPRD83.prod.outlook.com (2603:10a6:20b:1b6::10) by AM6PR83MB0295.EURPRD83.prod.outlook.com (2603:10a6:209:6f::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4649.1; Tue, 2 Nov 2021 14:09:26 +0000
Received: from AM7PR83MB0452.EURPRD83.prod.outlook.com ([fe80::356e:b2f3:749c:cf57]) by AM7PR83MB0452.EURPRD83.prod.outlook.com ([fe80::356e:b2f3:749c:cf57%5]) with mapi id 15.20.4690.004; Tue, 2 Nov 2021 14:09:26 +0000
From: Pieter Kasselman <pieter.kasselman@microsoft.com>
To: Neil Madden <neil.madden@forgerock.com>, oauth <oauth@ietf.org>
Thread-Topic: [EXTERNAL] [OAUTH-WG] Rotating RTs and grace periods
Thread-Index: AQHXz9SCB+Ioats7QUu4cZbe5YUg8avwQt8Q
Date: Tue, 02 Nov 2021 14:09:26 +0000
Message-ID: <AM7PR83MB0452C77D32B98A7409681699918B9@AM7PR83MB0452.EURPRD83.prod.outlook.com>
References: <76A1A85D-2DDC-4544-92B0-1723D3303408@forgerock.com>
In-Reply-To: <76A1A85D-2DDC-4544-92B0-1723D3303408@forgerock.com>
Accept-Language: en-IE, en-US
Content-Language: en-US
X-MS-Has-Attach:
X-MS-TNEF-Correlator:
msip_labels: MSIP_Label_f42aa342-8706-4288-bd11-ebb85995028c_Enabled=true; MSIP_Label_f42aa342-8706-4288-bd11-ebb85995028c_SetDate=2021-11-02T14:09:18Z; MSIP_Label_f42aa342-8706-4288-bd11-ebb85995028c_Method=Standard; MSIP_Label_f42aa342-8706-4288-bd11-ebb85995028c_Name=Internal; MSIP_Label_f42aa342-8706-4288-bd11-ebb85995028c_SiteId=72f988bf-86f1-41af-91ab-2d7cd011db47; MSIP_Label_f42aa342-8706-4288-bd11-ebb85995028c_ActionId=de313723-dd8e-4d72-9210-9691b515be22; MSIP_Label_f42aa342-8706-4288-bd11-ebb85995028c_ContentBits=0
authentication-results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=microsoft.com;
x-ms-publictraffictype: Email
x-ms-office365-filtering-correlation-id: e2438293-c001-4402-0546-08d99e0a6109
x-ms-traffictypediagnostic: AM6PR83MB0295:
x-microsoft-antispam-prvs: <AM6PR83MB02951786552226CEDF9F2EEB918B9@AM6PR83MB0295.EURPRD83.prod.outlook.com>
x-ms-oob-tlc-oobclassifiers: OLM:10000;
x-ms-exchange-senderadcheck: 1
x-ms-exchange-antispam-relay: 0
x-microsoft-antispam: BCL:0;
x-microsoft-antispam-message-info: wqXsDaEpI27169VOquGd1v1Rj2018d3pc0H2ESyYYjJfpzDdUPe3Y4rtEsD0oeDfIbPkp+ySzjC+hhLNlpD08WseLBh4CF7gTRW4zAe726gTt1YHZXKslh9aKhw3l7ZNNIl6LqYHsx6WsaLMd/1/8UFD8dWGL2IbDIhf4/sj4SlsnUzk7oCGpRoKmJNhwlpoPblFVnOzmwEvRsueKBzeAZ2yK1AjCpQ4ymii4GAmvESe2JRJ1GDZMeSIjg7mKGpuNcLNyQ/7V3w26tQh6Zf9lEqviYgTfUP/nygUUUhdsRkOXLzCGIsATQ2mkV5J0/BV0cPNK3I530so09oglnoYT/bHPcNIjNoaLf31Z/g0WVp+Ei9AniIGoytRWFc/lrBnPE68m8bkjYd6G9XNaD62LfagzIf9Xuo9uo/MK9UAYa/7nvpitbtFJJNO0pZlZ4teMHxmkCJNFvKqGIm+wT9VWD3Z5H7l3E803PuS49DbXqNcj0xJ+IgKq9So+P49ZupfQ7cAaY/naW1i7tACiWWAd3hbPmAuW6uGwRfATCxKEdjiHzACuFCe49JaGkEgw6vb+hf/z3zcPvZ5ALxHuVHLMixxpMkF7l9+kwtPsUvMJpCwDXBSbVzH0rj3inKiCYz/TG+8jY/S1htChQt1ZsuijPn2frsWQQwRkRLrTsV3Gw6SqJo74co3uU+o2YIwF4baX6P3x+SrdS9kyF4W5vtB5zQ9RyEt2HjwPbClWeLtuVftVhuNu2TmEl34a1fcMyVxATKcvB8QJVojlBN2fq8cqAAzJ5QscBJKN5b71xVG+5k=
x-forefront-antispam-report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:AM7PR83MB0452.EURPRD83.prod.outlook.com; PTR:; CAT:NONE; SFS:(4636009)(366004)(166002)(83380400001)(66946007)(82950400001)(38100700002)(76116006)(7696005)(33656002)(71200400001)(9686003)(6506007)(66556008)(66476007)(53546011)(8676002)(55016002)(8936002)(10290500003)(52536014)(38070700005)(966005)(2906002)(64756008)(66446008)(82960400001)(122000001)(316002)(5660300002)(110136005)(26005)(8990500004)(508600001)(66574015)(44832011)(86362001)(186003); DIR:OUT; SFP:1102;
x-ms-exchange-antispam-messagedata-chunkcount: 1
x-ms-exchange-antispam-messagedata-0: 0wryamfNYZgGKOa1vHfnl1LaFgHfO7fP+dtLYlf/H+cMCBOGoF5bMPCpK6hhujqwOILISREELqWY3M0bXhrv4g8DanTM4bwY/WylautF+XTf3TbxwJGKJSaxepzLdZZMjmI5bOcayuFxfhe8pbnF798gWZ5YccQtPsbDWkpB6sK7+0Vy9f2vC1a65YJQNWKisw0tPn3h+vI8KIsSeFYL3Dy71jfvwp1hiCdZ4FVCmNpYHVSTkYYSLgUB7/z7ZAN0TqLn5Um/3cFk2AicgHSDW6DuDGCkJ6M6+ugcKm0MM9bwdB4DZe4ihH57kO2vEX/CKKxKtULc2iQpCXsZl8s6jbMIlkNrC/9VhWeYoxTrknEVdShpfY3fiqDjz204pftMlk6xZNxcy6x41PRKNOUrtntJnylJolgqCqABgSBe6qS9b2gTnMOsjAuFxDrsYz1Pv8Y1M5lW0pDE/QRpNpwOdXPDy6BlT/VDhQ1wMLYzdxL3oTjwFEY4F/Ye3cKXlv+vS0cKntW5zi3LUsMO8fDlaNuYg6BXda9b/nSJIjiMaRszOzCQMryoTSJQEVZNycW11mrEYYljfs0FGHOYV3ET3IDT9Z3moU8ZSD5MGUJgco7igxRWir42ee1oREPZV5OnZjOBDWV3YrNOL8In3d3taR5mxiM12ubNsyBVJ48aK2awPKDTLUv+lrAkOU3OkYsi9c7yMRqN8ccepJ2Xq8uWlR0k/Z8lipsi3pLWmagpn2EhLN41nMEJgNtdmHngreXAd7fVMnmEuFnp6CYWl56Xqd5raAaHWSEgHrLLp5luXzWSLHq6kodBYuGtom92ZYnqSM1NfpKOKQeORGfp15zeZOeUuAE7tlWzijA0qcDIm68uCVlUmsk5BoXn7k4CRMqwriTliF7kSskht/GokuIsIfshs3cqe8aDA80cjCnLO6kt9fkpDMfoTi6kdN8z0jNLK1JHHVC8VNiwlDUww66n6ADFTl9RQinsCCKr6CgrWaD16gDggZvKOE/kqmrJIDBeQ1CZTETBiVrb74/he5aHtrI6RULhf1+Ibl07Mn8aRtNeXHhWMpQ7iUw+YFaZUBT/o9HDP1B/BbYdKIXbpZGguzwP7E5g9j7J1NjurlfSiA5sOc67AXvsKwvd/M7GyRsZeYEeK3T+r38uX8DkFJyNdUdRBLHx9cSLGm+gI9F7UGdmErKatCLpYIb8oPe1TcHmayLqktc0OzFRVVLFDmw3RIRHgSLsCVWvtir+28tx1Jy5h8TwYQ7w9BZRyUq6BK2VjsNWRmQb8l5OyjZfGwFoaqx6FjGrbweKSJFNIq5YFtSu40+Z6Of/Yj+Eomiw1atOMB6wGD3KMwYw0JkLgk/+SRJr4++gCgQuSRv4OzopnAUFQmLab+a6k9DeKw64VEG52zvOX45rnsqOHQqhRpy6ERYFrQLbHDHYlC2RmtnUDSqqWr3137wRBESlUfsah7U4P4mngLDKE6/NvNv40k4NsGs1jUBn9jNmyPElID8NtMimSR6BXYXg44+p95ha98yydCNt53CpsmLpo7/misqgbVDJ+JuYDoQcpLOE0sKEAOqgS2qji30uB3ZAu+tgDnSxLDebUoLgD5YxPO2jRiZLdQ==
Content-Type: multipart/alternative; boundary="_000_AM7PR83MB0452C77D32B98A7409681699918B9AM7PR83MB0452EURP_"
MIME-Version: 1.0
X-OriginatorOrg: microsoft.com
X-MS-Exchange-CrossTenant-AuthAs: Internal
X-MS-Exchange-CrossTenant-AuthSource: AM7PR83MB0452.EURPRD83.prod.outlook.com
X-MS-Exchange-CrossTenant-Network-Message-Id: e2438293-c001-4402-0546-08d99e0a6109
X-MS-Exchange-CrossTenant-originalarrivaltime: 02 Nov 2021 14:09:26.2417 (UTC)
X-MS-Exchange-CrossTenant-fromentityheader: Hosted
X-MS-Exchange-CrossTenant-id: 72f988bf-86f1-41af-91ab-2d7cd011db47
X-MS-Exchange-CrossTenant-mailboxtype: HOSTED
X-MS-Exchange-CrossTenant-userprincipalname: 1cN5nfwx5B1ym90lTH3K6OB55TyrcLxFHfMCDUN8ToPfgAb6MBaXaLzk4nGirLqh4XwbmgIyAe02O8BTC1P9733YfUbvrfRceBrVp6UwDuc=
X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM6PR83MB0295
Archived-At: <https://mailarchive.ietf.org/arch/msg/oauth/92Z4GBhHSw0lY6bM8ly8A1z3ctw>
Subject: Re: [OAUTH-WG] [EXTERNAL] Rotating RTs and grace periods
X-BeenThere: oauth@ietf.org
X-Mailman-Version: 2.1.29
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: Tue, 02 Nov 2021 14:09:35 -0000

Neil

Is the goal to accommodate network latency or clock drift? It would be helpful to include reasons for why a grace period should be considered if it is allowed.

Without knowing the reasons for the grace period it is not clear why a grace period is a better solution than just extending the expiry time by a set time (60 seconds in your example) and having the client present the token a little earlier.

If grace periods are allowed, it may be worth considering adding additional mitigations against replay. For example, a grace period may be allowed if the refresh token is sender constrained with DPoP so there is at least some assurances that the request is originating from the sender (especially if the nonce option is used with DPoP).

I would worry about adding more complexity and less predictability by adding grace periods though (e.g. by looking at a refresh token, will you be able to tell if it can still be used or not), but your point that implementors may solve for it in other less predictable ways raises a valid point.

Cheers

Pieter

From: OAuth <oauth-bounces@ietf.org> On Behalf Of Neil Madden
Sent: Tuesday 2 November 2021 10:29
To: oauth <oauth@ietf.org>
Subject: [EXTERNAL] [OAUTH-WG] Rotating RTs and grace periods

Hi all,

There was a previous discussion on whether to allow a grace period during refresh token rotation, allowing the client to retry a refresh if the response fails to be received due to some transient network issue/timeout [1]. Vittorio mentioned that Auth0 already implement such a grace period. We (ForgeRock) currently do not, but we do periodically receive requests to support this. The current security BCP draft is silent on whether implementing such a grace period is a good idea, but I think we should add some guidance here one way or another.

My own opinion is that a grace period is not a good idea, and if it is to be supported as an option then it should be kept as short as possible. The reason (as I mentioned in the previous thread) is that it is quite easy for an attacker to observe when a legitimate client performs a refresh flow and so can easily sneak in their own request afterwards within the grace period. There are several reasons why it is easy for an attacker to observe this:

- RT rotation is primarily intended for public clients, such as mobile apps and SPAs. These clients are geographically distributed across the internet, and so there is a good chance that the attacker is able to observe the network traffic of at least some of these client instances.
- The refresh flow is typically the only request that the client makes directly to the AS after initial authorization, so despite the traffic being encrypted it is very easy for an observer to determine that the client is performing a refresh whenever it makes any connection to the AS.
- As well as observing the request itself, an attacker may be able to observe the DNS lookup for the AS hostname instead, which is even more likely to be observable and also in plaintext most of the time.
- An attacker in a position to steal RTs from e.g. localStorage, is probably also in a good position to either observe when the legitimate client refreshes or to actually force it to refresh early (e.g., by deleting the corresponding AT from the same storage).

I know some people argue that a grace period is a reasonable trade-off between security and usability. But I think that this kind of attack would be quite easy to carry out in practice for the reasons I suggest above, so I think the security actually degrades extremely quickly if you allow a grace period of any reasonable length.

On the other hand, if we discourage this entirely then people may use dubious workarounds instead (e.g., one proposal I've seen was to use an ID token with the JWT Bearer grant, effectively turning the ID Token into an ad-hoc RT with much fewer protections).

As a strawman, what would people think of wording like the following:

---
The AS MAY allow the original RT to be replayed for a short grace period to allow the client to recover if the response is not received due to a network problem or other transient issue. However, implementors should be aware that an attacker may be able to easily observe when the legitimate client makes a refresh request to the AS and so time their use of a stolen RT to occur within the grace period. Any grace period MUST be kept as short as possible, and MUST NOT exceed 60 seconds. Clients should prefer sender-constrained refresh tokens if recovery from network issues is a priority.
-

(The 60 seconds limit here is based on Auth0's grace period).

[1]: https://mailarchive.ietf.org/arch/msg/oauth/WXwKxQM2poW7bqOOGGp4POYolFk/<https://nam06.safelinks.protection.outlook.com/?url=https%3A%2F%2Fmailarchive.ietf.org%2Farch%2Fmsg%2Foauth%2FWXwKxQM2poW7bqOOGGp4POYolFk%2F&data=04%7C01%7Cpieter.kasselman%40microsoft.com%7Cbdb0969234774ba6f87608d99deba06c%7C72f988bf86f141af91ab2d7cd011db47%7C1%7C0%7C637714457664531224%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C1000&sdata=CDskCHwXxJxGdmudTW33gUT5f3%2B835uZDxyNEmKkiFc%3D&reserved=0>

Kind regards,

Neil