GHSA-48pq-2xq3-c2m4

Suggest an improvement
Source
https://github.com/advisories/GHSA-48pq-2xq3-c2m4
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/06/GHSA-48pq-2xq3-c2m4/GHSA-48pq-2xq3-c2m4.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-48pq-2xq3-c2m4
Aliases
  • CVE-2026-54781
Published
2026-06-19T20:47:08Z
Modified
2026-06-19T21:00:18.135208094Z
Severity
  • 7.4 (High) CVSS_V3 - CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:N CVSS Calculator
Summary
CoreWCF: SAML SubjectConfirmation methods and holder-of-key proof keys are not enforced
Details

Impact

The relying application is given a ClaimsPrincipal for a subject whose authority over the assertion the sender never proved. There are two distinct exploit shapes: - Holder-of-key downgrade. An attacker who obtains a holder-of-key SAML assertion that was issued without KeyInfo (issuer bug, custom STS shape, or assertion captured from an interaction where KeyInfo was elided) can present it to the service and be authenticated as the assertion’s subject without producing the proof key the assertion’s confirmation method would normally require. The service’s reliance on holder-of-key for sensitive actions is bypassed. - Custom-method bypass. An attacker who can obtain or arrange the issuance of a SAML assertion bearing a non-standard confirmation method URI (a permissive STS that accepts arbitrary method strings, an experimental custom IDP, or an attacker-side construction that the issuer signs without validating the method field) can present the assertion and be authenticated. Per-method policies that an application or a binding-level policy expects the framework to enforce are silently bypassed.

Preconditions

The service is configured to accept SAML 1.1 tokens via federation. Typical bindings are WS2007FederationHttpBinding and WSFederationHttpBinding, or any custom binding using IssuedSecurityTokenParameters with a SAML 1.1 token type.
The attacker has obtained at least one signed SAML 1.1 assertion of a shape that triggers the bypass.

Patches

Fixed in CoreWCF v1.8.1 and v1.9.1

Workarounds

To exploit this issue, it's required that a trusted STS issues SAML assertions whose SubjectConfirmationMethod is not one of the SAML 1.1 trio, or is willing to issue holder-of-key assertions without KeyInfo. If no trusted STS is willing to issue SAML assertions meeting either of these criteria, then a service isn't vulnerable.

Database specific
{
    "github_reviewed": true,
    "github_reviewed_at": "2026-06-19T20:47:08Z",
    "nvd_published_at": null,
    "severity": "HIGH",
    "cwe_ids": [
        "CWE-287",
        "CWE-345"
    ]
}
References

Affected packages

NuGet / CoreWCF.Primitives

Package

Name
CoreWCF.Primitives
View open source insights on deps.dev
Purl
pkg:nuget/CoreWCF.Primitives

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
1.8.1

Affected versions

0.*
0.1.0-preview
0.1.0-preview-2
0.1.0
0.2.0
0.2.1
0.3.0
0.3.1
0.3.2
0.4.0
1.*
1.0.0-preview1
1.0.0-preview2
1.0.0
1.0.1
1.0.2
1.1.0
1.1.1
1.2.0
1.2.1
1.3.0
1.3.1
1.3.2
1.4.0-preview1
1.4.0
1.4.1
1.4.2
1.5.0-preview1
1.5.0
1.5.1
1.5.2
1.6.0
1.7.0
1.8.0

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/06/GHSA-48pq-2xq3-c2m4/GHSA-48pq-2xq3-c2m4.json"

NuGet / CoreWCF.Primitives

Package

Name
CoreWCF.Primitives
View open source insights on deps.dev
Purl
pkg:nuget/CoreWCF.Primitives

Affected ranges

Type
ECOSYSTEM
Events
Introduced
1.9.0
Fixed
1.9.1

Affected versions

1.*
1.9.0

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/06/GHSA-48pq-2xq3-c2m4/GHSA-48pq-2xq3-c2m4.json"