CVE-2026-54297
Received
Received - Intake
Faraday Nested Query Parameter Stack Overflow
Publication date: 2026-06-24
Last updated on: 2026-06-24
Assigner: GitHub, Inc.
Description
Description
Faraday is an HTTP client library abstraction layer that provides a common interface over many adapters. From 1.0.0 until 1.10.6 and 2.14.3, Faraday::NestedParamsEncoder, the default nested query parameter encoder/decoder in Faraday, decodes nested query strings without enforcing a maximum nesting depth. A crafted query string causes Faraday to build a deeply nested Ruby Hash structure. The internal dehash routine then recursively walks this attacker-controlled structure without a depth limit. At sufficient depth, Ruby raises an uncaught SystemStackError (stack level too deep), crashing the calling thread or worker. This can lead to denial of service in applications that pass attacker-controlled query strings to Faraday's nested query parsing or URL-building paths. This vulnerability is fixed in 1.10.6 and 2.14.3.
CVSS Scores
EPSS Scores
| Probability: | |
| Percentile: |
Meta Information
Affected Vendors & Products
| Vendor | Product | Version / Range |
|---|---|---|
| lostisland | faraday | 1.0.0 |
| lostisland | faraday | 1.10.6 |
| lostisland | faraday | 2.14.3 |
| lostisland | faraday | From 1.0.0 (inc) to 1.10.6 (exc) |
| lostisland | faraday | From 1.10.6 (inc) to 2.14.3 (inc) |
| lostisland | faraday | From 1.0.0 (inc) to 2.14.2 (inc) |
| lostisland | faraday | to 1.10.5 (inc) |
Helpful Resources
Exploitability
| CWE ID | Description |
|---|---|
| CWE-674 | The product does not properly control the amount of recursion that takes place, consuming excessive resources, such as allocated memory or the program stack. |