@cloudflare/workers-oauth-provider PKCE bypass via downgrade attack
Moderate severity
GitHub Reviewed
Published
May 1, 2025
in
cloudflare/workers-oauth-provider
•
Updated May 1, 2025
Description
Published to the GitHub Advisory Database
May 1, 2025
Reviewed
May 1, 2025
Last updated
May 1, 2025
Summary
PKCE was implemented in the OAuth implementation in workers-oauth-provider that is part of MCP framework. However, it was found that an attacker could cause the check to be skipped.
Impact
PKCE is a defense-in-depth mechanism against certain kinds of attacks and was an optional extension in OAuth 2.0 which became required in the OAuth 2.1 draft. (Note that the MCP specification requires OAuth 2.1.)
This bug completely bypasses PKCE protection.
Patches
Fixed in: cloudflare/workers-oauth-provider#27
We patched up the vulnerabilities in the latest version, v 0.0.5 of the Workers OAuth provider (https://www.npmjs.com/package/@cloudflare/workers-oauth-provider). You'll need to update your MCP servers to use that version to resolve the vulnerability.
Workarounds
None
References