CVEReports
CVEReports

Automated vulnerability intelligence platform. Comprehensive reports for high-severity CVEs generated by AI.

Product

  • Home
  • Sitemap
  • RSS Feed

Company

  • About
  • Contact
  • Privacy Policy
  • Terms of Service

© 2026 CVEReports. All rights reserved.

Made with love by Amit Schendel & Alon Barad



GHSA-MVM6-F9R3-FGFX

GHSA-mvm6-f9r3-fgfx: JSON Policy Injection in AWS SDK for .NET CloudFront Signers

Amit Schendel
Amit Schendel
Senior Security Researcher

Mar 28, 2026·6 min read·40 visits

Executive Summary (TL;DR)

Unescaped quotes and backslashes in AWS SDK for .NET CloudFront utilities allow attackers to inject malicious JSON into custom policies, bypassing intended access controls for private CloudFront content.

The AWS SDK for .NET contains a vulnerability in its CloudFront signing utilities where improper escaping of special characters permits JSON policy injection. Attackers who can control input passed to the signing methods can alter the generated CloudFront custom policy, allowing them to bypass access restrictions and access private resources.

Vulnerability Overview

The AWS SDK for .NET provides utilities to programmatically generate Amazon CloudFront signed URLs and signed cookies. These mechanisms are used to restrict access to private content served through CloudFront, ensuring that only authenticated or authorized clients can retrieve specific resources. The signing process relies on constructing a JSON-formatted Custom Policy document that defines the exact access parameters, such as the allowed resource path, expiration time, and permitted IP ranges.

A vulnerability exists within the AWSSDK.CloudFront and AWSSDK.Extensions.CloudFront.Signers packages where the SDK fails to properly neutralize special characters when constructing these JSON policy documents. Specifically, the SDK does not adequately escape double quotes (") and backslashes (\) present in the input variables before concatenating them into the final JSON string.

This flaw is classified as Improper Encoding or Escaping of Output (CWE-116). By exploiting this vulnerability, an attacker who controls the input parameters can break out of the intended JSON value context. The attacker can then inject arbitrary JSON key-value pairs into the policy document, fundamentally altering the access control rules enforced by CloudFront.

Root Cause Analysis

CloudFront Custom Policies are structured as JSON documents containing a Statement array. Each statement specifies a Resource and various Condition blocks that dictate access rules. When developers use the SDK's signing methods, they provide parameters such as the target URL or client IP addresses. The SDK dynamically constructs the JSON policy using these provided parameters.

Prior to the patched versions, the SDK assembled this JSON document using string formatting or concatenation rather than a safe JSON serialization library, or it failed to apply a proper escaping routine to the input strings. Because double quotes and backslashes were not sanitized, any input containing these characters was inserted verbatim into the JSON structure.

When a developer passes user-controlled data to a vulnerable signing method, the untrusted data is directly embedded into a JSON string value. If the input contains a double quote, the JSON parser reading the generated policy will interpret that quote as the termination of the string literal. Any subsequent characters in the input are then parsed as structural JSON elements rather than data, enabling JSON injection.

Code Analysis

The vulnerability manifests when developers use methods like AmazonCloudFrontUrlSigner.SignUrl. The method accepts parameters like the resource URL and constructs a policy internally if a custom policy is not explicitly provided by the developer.

// Conceptual representation of the vulnerable code pattern
string resourceUrl = userInput;
string policy = @"{""Statement"":[{
    ""Resource"":""" + resourceUrl + @""",
    ""Condition"":{
        ""DateLessThan"":{""AWS:EpochTime"":1672531200}
    }
}]}";

In the vulnerable pattern above, resourceUrl is concatenated directly into the policy string. If userInput contains a double quote, it closes the "Resource" value. The patch addresses this by implementing strict escaping for user-controlled variables before they are incorporated into the JSON document.

// Conceptual representation of the patched code pattern
string escapedResourceUrl = resourceUrl.Replace("\\", "\\\\").Replace("\"", "\\\"");
string policy = @"{""Statement"":[{
    ""Resource"":""" + escapedResourceUrl + @""",
    ""Condition"":{
        ""DateLessThan"":{""AWS:EpochTime"":1672531200}
    }
}]}";

The fix ensures that any backslashes or double quotes within the input are prefixed with an escape character. This forces the downstream JSON parser to treat these characters as literal string content rather than structural delimiters, neutralizing the injection vector.

Exploitation Methodology

Exploitation requires an application that accepts user input and incorporates it into a CloudFront signed URL or cookie without prior validation. The attacker crafts a payload containing a double quote to close the active JSON field, followed by a comma, and then entirely new JSON keys and values.

Consider an application that generates signed URLs for user-specific directories: https://example.com/files/ + userInput. An attacker provides the following string as their input: ", "Condition": {"DateLessThan": {"AWS:EpochTime": 2147483647}} }.

When the SDK processes this input, the resulting JSON policy document will include the injected condition:

{
  "Statement": [{
    "Resource": "https://example.com/files/", 
    "Condition": {"DateLessThan": {"AWS:EpochTime": 2147483647}} },
    "Condition": {"DateLessThan": {"AWS:EpochTime": 1672531200}}
  }]
}

Depending on the JSON parser's behavior regarding duplicate keys, the injected Condition block may override the original restrictions set by the application. This allows the attacker to unilaterally modify the expiration time or remove IP-based restrictions from the generated signature.

Impact Assessment

The primary impact of this vulnerability is a high loss of confidentiality. By successfully injecting custom conditions into the CloudFront policy, an attacker can generate valid cryptographic signatures that grant broader access than the application intended. This allows the attacker to bypass time-based expirations or IP-based geo-restrictions.

Furthermore, if the injected payload alters the Resource field to include wildcards (e.g., https://example.com/*), the attacker could use the resulting signed URL or cookie to access arbitrary private files within the same CloudFront distribution. This effectively defeats the primary access control mechanism for the content delivery network.

> [!NOTE] > The integrity impact is rated as low. While the attacker can modify the logical conditions of the access policy, they cannot alter the actual files stored behind the CloudFront distribution. The vulnerability does not provide write access to the origin servers or Amazon S3 buckets.

Remediation and Mitigation

Organizations utilizing the AWS SDK for .NET to generate CloudFront signed URLs or signed cookies must upgrade their dependencies immediately. The official patches resolve the string escaping flaws within the policy construction logic.

The required minimum versions are AWSSDK.CloudFront version 3.7.510.7 and AWSSDK.Extensions.CloudFront.Signers version 4.0.0.31. Upgrading to these versions or newer ensures that the SDK internally escapes all double quotes and backslashes before integrating parameters into the JSON policy.

As a defense-in-depth measure, development teams should implement strict input validation at the application layer. User-provided data destined for CloudFront signing methods should be sanitized or validated against a strict allowlist. Rejecting inputs containing double quotes or backslashes before they reach the AWS SDK provides an additional layer of security against future injection flaws.

Official Patches

Amazon Web ServicesAWS SDK for .NET Security Advisories

Technical Appendix

CVSS Score
9.3/ 10
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:H/I:L/A:N

Affected Systems

AWS SDK for .NETNuGet Package: AWSSDK.CloudFrontNuGet Package: AWSSDK.Extensions.CloudFront.Signers

Affected Versions Detail

Product
Affected Versions
Fixed Version
AWSSDK.CloudFront
Amazon Web Services
< 3.7.510.73.7.510.7
AWSSDK.Extensions.CloudFront.Signers
Amazon Web Services
< 4.0.0.314.0.0.31
AttributeDetail
CWE IDCWE-116
Attack VectorNetwork
CVSS v3.1 Score9.3 (Critical)
Confidentiality ImpactHigh
Integrity ImpactLow
Exploit StatusNone

MITRE ATT&CK Mapping

T1190Exploit Public-Facing Application
Initial Access
CWE-116
Improper Encoding or Escaping of Output

The software does not properly encode or escape output, which can allow an attacker to alter the structure of the data.

Vulnerability Timeline

Vulnerability patched in AWS SDK for PHP (coordinated fix).
2026-03-03
GHSA-mvm6-f9r3-fgfx published for AWS SDK for .NET.
2026-03-27
Remediation versions released on NuGet.
2026-03-27

References & Sources

  • [1]GitHub Advisory (GHSA-mvm6-f9r3-fgfx)
  • [2]AWS SDK for .NET GitHub Repository
  • [3]AWS SDK for .NET Security Advisories
  • [4]GitLab Advisory Mirror
  • [5]Related PHP Advisory (GHSA-27qh-8cxx-2cr5)
  • [6]Related Java Advisory (GHSA-443W-3RQ3-5M5H)
Related Vulnerabilities
GHSA-27qh-8cxx-2cr5GHSA-443W-3RQ3-5M5H

Attack Flow Diagram

Press enter or space to select a node. You can then use the arrow keys to move the node around. Press delete to remove it and escape to cancel.
Press enter or space to select an edge. You can then press delete to remove it or escape to cancel.

More Reports

•about 1 hour ago•CVE-2026-39829
7.5

CVE-2026-39829: Denial of Service in Go SSH Parser

A high-severity Denial of Service (DoS) vulnerability exists in the golang.org/x/crypto/ssh package prior to version 0.52.0. The vulnerability is caused by a lack of size and range validation on incoming RSA and DSA public key parameters during SSH authentication. An unauthenticated attacker can submit a crafted public key with pathologically large parameters, triggering intensive CPU computation during signature verification and leading to a complete Denial of Service.

Alon Barad
Alon Barad
3 views•5 min read
•about 3 hours ago•CVE-2026-39831
9.1

CVE-2026-39831: Authentication Bypass in golang.org/x/crypto/ssh via FIDO/U2F User Presence Bypass

An authentication bypass vulnerability was identified in the golang.org/x/crypto/ssh package. The library's verification logic for FIDO/U2F security keys failed to check the User Presence (UP) flag. This omission allows an attacker with access to a hardware token interface or an agent-forwarding socket to authenticate without physical user interaction.

Alon Barad
Alon Barad
5 views•5 min read
•about 4 hours ago•CVE-2026-39834
9.1

CVE-2026-39834: Infinite Loop and CPU Exhaustion via Integer Truncation in Go SSH Channel Write

A critical vulnerability exists in the Go SSH sub-repository (golang.org/x/crypto/ssh) before version 0.52.0. When an application writes payloads of 4GB or larger in a single write operation, integer truncation in the remote window calculation causes an infinite loop. This results in complete CPU core exhaustion and a denial-of-service condition.

Amit Schendel
Amit Schendel
6 views•7 min read
•about 6 hours ago•CVE-2026-42508
9.1

CVE-2026-42508: Bypass of SSH Certificate Authority Revocation in golang.org/x/crypto/ssh/knownhosts

An issue was discovered in Go's `golang.org/x/crypto/ssh/knownhosts` package where a revoked Certification Authority (CA) public key was not correctly checked for revocation during SSH host certificate validation. This allowed clients or servers utilizing the library to validate and trust host certificates issued by explicitly revoked CAs.

Alon Barad
Alon Barad
9 views•5 min read
•about 7 hours ago•CVE-2026-46595
10.0

CVE-2026-46595: Critical Authorization Bypass via source-address Validation Failure in golang.org/x/crypto/ssh

An authorization bypass vulnerability exists in the golang.org/x/crypto/ssh package prior to version 0.52.0. When an SSH server is configured with a custom VerifiedPublicKeyCallback that returns a Permissions object containing a source-address critical option, the server fails to validate and enforce the restriction. This allows remote clients with valid public keys to bypass IP-based access restrictions and authenticate from unauthorized network locations.

Alon Barad
Alon Barad
6 views•7 min read
•about 9 hours ago•CVE-2026-48517
7.5

CVE-2026-48517: Remote Code Execution via Typeless Deserialization Blocklist Bypass in MessagePack-CSharp

A critical vulnerability exists in MessagePack-CSharp's typeless deserialization mechanism where configured blocklists fail to recursively inspect nested types. An attacker can bypass security restrictions by wrapping unauthorized types in arrays or generic collections, allowing insecure deserialization and remote code execution.

Alon Barad
Alon Barad
6 views•7 min read