Home

Description

Locutus brings stdlibs of other programming languages to JavaScript for educational purposes. Starting in version 2.0.39 and prior to version 3.0.25, a prototype pollution vulnerability exists in the `parse_str` function of the npm package locutus. An attacker can pollute `Object.prototype` by overriding `RegExp.prototype.test` and then passing a crafted query string to `parse_str`, bypassing the prototype pollution guard. This vulnerability stems from an incomplete fix for CVE-2026-25521. The CVE-2026-25521 patch replaced the `String.prototype.includes()`-based guard with a `RegExp.prototype.test()`-based guard. However, `RegExp.prototype.test` is itself a writable prototype method that can be overridden, making the new guard bypassable in the same way as the original — trading one hijackable built-in for another. Version 3.0.25 contains an updated fix.

PUBLISHED Reserved 2026-03-24 | Published 2026-03-27 | Updated 2026-04-01 | Assigner GitHub_M




MEDIUM: 6.3CVSS:4.0/AV:N/AC:L/AT:P/PR:N/UI:N/VC:N/VI:L/VA:N/SC:N/SI:L/SA:N

Problem types

CWE-1321: Improperly Controlled Modification of Object Prototype Attributes ('Prototype Pollution')

Product status

>= 2.0.39, < 3.0.25
affected

References

github.com/...ocutus/security/advisories/GHSA-vc8f-x9pp-wf5p

github.com/...ocutus/security/advisories/GHSA-vc8f-x9pp-wf5p

github.com/locutusjs/locutus/pull/597

github.com/...ommit/345a6211e1e6f939f96a7090bfeff642c9fcf9e4

github.com/locutusjs/locutus/releases/tag/v3.0.25

cve.org (CVE-2026-33994)

nvd.nist.gov (CVE-2026-33994)

Download JSON