Severity
2.9
Low severity
Details
- CVSS score
- 2.9
- CVSS vector
- CVSS:3.1/AV:L/AC:H/PR:N/UI:N/S:U/C:N/I:N/A:L
Overview
About vulnerability
ajv (Another JSON Schema Validator) before 8.18.0 is vulnerable to Regular Expression Denial of Service (ReDoS) when the $data option is enabled. The pattern keyword accepts runtime data via JSON Pointer syntax ($data reference), which is passed directly to the JavaScript RegExp() constructor without validation. An attacker can inject a malicious regex pattern (e.g., “^(a|a)*$”) combined with crafted input to cause catastrophic backtracking. A 31-character payload causes approximately 44 seconds of CPU blocking, with each additional character doubling execution time. This enables complete denial of service with a single HTTP request against any API using ajv with $data: true for dynamic schema validation. This issue is also fixed in version 6.14.0.Details
- Affected product:
- @microsoft/api-extractor , Acorn , AlmaLinux 9.2 ESU , Next.js , Node.js , TuxCare 9.6 ESU , ajv , ajv-keywords , babel-loader , extract-text-webpack-plugin , nuxt , protractor , request , rushstack , schema-utils , tsdoc , url-loader , webpack , webpack-dev-middleware , webpack-dev-server
- Affected packages:
- ajv (+55 more)