CWE
601
Advisory Published
Updated

GHSA-4pc9-x2fx-p7vj

First published: Thu May 01 2025(Updated: )

### Summary PKCE was implemented in the OAuth implementation in workers-oauth-provider that is part of[ MCP framework](https://github.com/cloudflare/workers-mcp). However, it was found that an attacker could cause the check to be skipped. ### Impact Under certain circumstances (see below), if a victim had previously authorized with a server built on workers-oath-provider, and an attacker could later trick the victim into visiting a malicious web site, then attacker could potentially steal the victim's credentials to the same OAuth server and subsequently impersonate them. In order for the attack to be possible, the OAuth server's authorized callback must be designed to auto-approve authorizations that appear to come from an OAuth client that the victim has authorized previously. The authorization flow is not implemented by workers-oauth-provider; it is up to the application built on top to decide whether to implement such automatic re-authorization. However, many applications do implement such logic. ### Patches Fixed in: https://github.com/cloudflare/workers-oauth-provider/pull/26 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 ### Note It is a basic, well-known requirement that OAuth servers should verify that the redirect URI is among the allowed list for the client, both during the authorization flow and subsequently when exchanging the authorization code for an access token. workers-oauth-provider implemented only the latter check, not the former. Unfortunately, the former is the much more important check. Readers who are familiar with OAuth may recognize that failing to check redirect URIs against the allowed list is a well-known, basic mistake, covered extensively in the RFC and elsewhere. The author of this library would like everyone to know that he was, in fact, well-aware of this requirement, thought about it a lot while designing the library, and then, somehow, forgot to actually make sure the check was in the code. That is, it's not that he didn't know what he was doing, it's that he knew what he was doing but flubbed it.

Affected SoftwareAffected VersionHow to fix
npm/@cloudflare/workers-oauth-provider<0.0.5
0.0.5

Never miss a vulnerability like this again

Sign up to SecAlerts for real-time vulnerability data matched to your software, aggregated from hundreds of sources.

Frequently Asked Questions

  • What is the severity of GHSA-4pc9-x2fx-p7vj?

    The severity of GHSA-4pc9-x2fx-p7vj is considered high due to the potential skipping of security checks.

  • How do I fix GHSA-4pc9-x2fx-p7vj?

    To fix GHSA-4pc9-x2fx-p7vj, upgrade the @cloudflare/workers-oauth-provider package to version 0.0.5 or higher.

  • What does GHSA-4pc9-x2fx-p7vj affect?

    GHSA-4pc9-x2fx-p7vj affects the OAuth implementation in the @cloudflare/workers-oauth-provider package.

  • What are the risks associated with GHSA-4pc9-x2fx-p7vj?

    The risks associated with GHSA-4pc9-x2fx-p7vj include unauthorized access due to skipped security checks.

  • Is GHSA-4pc9-x2fx-p7vj specific to certain software versions?

    Yes, GHSA-4pc9-x2fx-p7vj is specific to versions of the @cloudflare/workers-oauth-provider package below 0.0.5.

Contact

SecAlerts Pty Ltd.
132 Wickham Terrace
Fortitude Valley,
QLD 4006, Australia
info@secalerts.co
By using SecAlerts services, you agree to our services end-user license agreement. This website is safeguarded by reCAPTCHA and governed by the Google Privacy Policy and Terms of Service. All names, logos, and brands of products are owned by their respective owners, and any usage of these names, logos, and brands for identification purposes only does not imply endorsement. If you possess any content that requires removal, please get in touch with us.
© 2025 SecAlerts Pty Ltd.
ABN: 70 645 966 203, ACN: 645 966 203