GHSA-5hvv-m4w4-gf6v

Suggest an improvement
Source
https://github.com/advisories/GHSA-5hvv-m4w4-gf6v
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-5hvv-m4w4-gf6v/GHSA-5hvv-m4w4-gf6v.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-5hvv-m4w4-gf6v
Aliases
Downstream
Published
2026-04-14T22:31:19Z
Modified
2026-04-17T04:57:11.352797722Z
Severity
  • 9.1 (Critical) CVSS_V3 - CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:N CVSS Calculator
Summary
OAuth2 Proxy's Health Check User-Agent Matching Bypasses Authentication in auth_request Mode
Details

Impact

A configuration-dependent authentication bypass exists in OAuth2 Proxy.

Deployments are affected when all of the following are true:

  • OAuth2 Proxy is used with an auth_request-style integration (for example, nginx auth_request)
  • --ping-user-agent is set or --gcp-healthchecks is enabled

In affected configurations, OAuth2 Proxy will treat a request with the configured health check User-Agent value as a successful health check regardless of the requested path. This allows an unauthenticated remote attacker to bypass authentication and access protected upstream resources without completing the normal login flow.

This issue does not affect deployments that do not use auth_request-style subrequests, or that do not enable --ping-user-agent/--gcp-healthchecks.

Patches

Users should upgrade to v7.15.2 or later once available. Deployments running versions prior to v7.15.2 should be considered affected if they use auth_request-style authentication together with --ping-user-agent or --gcp-healthchecks.

Workarounds

Users can mitigate this issue by:

  • disabling --gcp-healthchecks
  • removing any configured --ping-user-agent
  • ensuring the reverse proxy does not forward client-controlled User-Agent headers to the OAuth2 Proxy auth subrequest
  • using path-based health checks only, on dedicated health check endpoints

Example nginx mitigation for the auth subrequest:

location = /oauth2/auth {
    internal;
    proxy_pass http://127.0.0.1:4180;
    proxy_pass_request_body off;
    proxy_set_header Content-Length "";
    proxy_set_header Host $host;
    # set to value that isn't the same as your configured PingUserAgent or GCPs "GoogleHC/1.0"
    proxy_set_header User-Agent "oauth2-proxy-auth-request";
}
Database specific
{
    "github_reviewed": true,
    "severity": "CRITICAL",
    "nvd_published_at": "2026-04-14T23:16:28Z",
    "cwe_ids": [
        "CWE-290"
    ],
    "github_reviewed_at": "2026-04-14T22:31:19Z"
}
References

Affected packages

Go / github.com/oauth2-proxy/oauth2-proxy/v7

Package

Name
github.com/oauth2-proxy/oauth2-proxy/v7
View open source insights on deps.dev
Purl
pkg:golang/github.com/oauth2-proxy/oauth2-proxy/v7

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
7.15.2

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-5hvv-m4w4-gf6v/GHSA-5hvv-m4w4-gf6v.json"

Go / github.com/oauth2-proxy/oauth2-proxy

Package

Name
github.com/oauth2-proxy/oauth2-proxy
View open source insights on deps.dev
Purl
pkg:golang/github.com/oauth2-proxy/oauth2-proxy

Affected ranges

Type
SEMVER
Events
Introduced
0Unknown introduced version / All previous versions are affected
Last affected
3.2.0

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-5hvv-m4w4-gf6v/GHSA-5hvv-m4w4-gf6v.json"