CVE-2026-33994

CRITICAL

Locutus Prototype Pollution due to incomplete fix for CVE-2026-25521

Title source: cna
STIX 2.1

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.

Scores

CVSS v3 9.8
EPSS 0.0014
EPSS Percentile 33.7%
Attack Vector NETWORK
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H

CISA SSVC

Vulnrichment
Exploitation poc
Automatable yes
Technical Impact total

Details

CWE
CWE-1321
Status published
Products (3)
locutus/locutus 2.0.39 - 3.0.25
locutusjs/locutus >= 2.0.39, < 3.0.25
npm/locutus 2.0.39 - 3.0.25npm
Published Mar 27, 2026
Tracked Since Mar 29, 2026