Description
ajv has ReDoS when using $data option
ajv (Another JSON Schema Validator) through version 8.17.1 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.
Mitigation
Minimal update. May introduce new vulnerabilities or breaking changes.
|
 debian 11 | | =6.12.6-2 || =6.12.6-3 || =8.11.2~ds+~2.1.1-1 || =8.12.0~ds+~2.1.1-1 || =8.12.0~ds+~2.1.1-2 || =8.12.0~ds+~2.1.1-3 || =8.12.0~ds+~2.1.1-4 || =8.12.0~ds+~2.1.1-5 || =8.17.1~ds+~3.0.1+~3.1.0-1 || =8.17.1~ds+~3.0.1+~3.1.0-2 || =8.17.1~ds+~3.0.1+~3.1.0-3 || =8.17.1~ds+~3.0.1+~3.1.0-4 || =8.18.0~ds+~cs6.1.1-1 || =8.18.0~ds+~cs6.1.1-2 || =8.8.2~ds+~2.1.1-1 | - |
 debian 12 | | =6.12.6-3 || =8.11.2~ds+~2.1.1-1 || =8.12.0~ds+~2.1.1-1 || =8.12.0~ds+~2.1.1-2 || =8.12.0~ds+~2.1.1-3 || =8.12.0~ds+~2.1.1-4 || =8.12.0~ds+~2.1.1-5 || =8.17.1~ds+~3.0.1+~3.1.0-1 || =8.17.1~ds+~3.0.1+~3.1.0-2 || =8.17.1~ds+~3.0.1+~3.1.0-3 || =8.17.1~ds+~3.0.1+~3.1.0-4 || =8.18.0~ds+~cs6.1.1-1 || =8.18.0~ds+~cs6.1.1-2 || =8.8.2~ds+~2.1.1-1 | - |
 npm | | >=7.0.0-alpha.0 <8.18.0 || >=0 <6.14.0 | 8.18.0, 6.14.0 |
 debian 14 | | =8.12.0~ds+~2.1.1-5 || =8.17.1~ds+~3.0.1+~3.1.0-1 || =8.17.1~ds+~3.0.1+~3.1.0-2 || =8.17.1~ds+~3.0.1+~3.1.0-3 || =8.17.1~ds+~3.0.1+~3.1.0-4 || >=0 <8.18.0~ds+~cs6.1.1-1 | 8.18.0~ds+~cs6.1.1-1 |
 debian 13 | | =8.12.0~ds+~2.1.1-5 || =8.17.1~ds+~3.0.1+~3.1.0-1 || =8.17.1~ds+~3.0.1+~3.1.0-2 || =8.17.1~ds+~3.0.1+~3.1.0-3 || =8.17.1~ds+~3.0.1+~3.1.0-4 || =8.18.0~ds+~cs6.1.1-1 || =8.18.0~ds+~cs6.1.1-2 | - |