CVE-2026-33228

CRITICAL

flatted: Prototype Pollution via parse()

Title source: cna
STIX 2.1

Description

flatted is a circular JSON parser. Prior to version 3.4.2, the parse() function in flatted can use attacker-controlled string values from the parsed JSON as direct array index keys, without validating that they are numeric. Since the internal input buffer is a JavaScript Array, accessing it with the key "__proto__" returns Array.prototype via the inherited getter. This object is then treated as a legitimate parsed value and assigned as a property of the output object, effectively leaking a live reference to Array.prototype to the consumer. Any code that subsequently writes to that property will pollute the global prototype. This issue has been patched in version 3.4.2.

Scores

CVSS v3 9.8
EPSS 0.0005
EPSS Percentile 15.1%
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)
npm/flatted 0 - 3.4.2npm
webreflection/flatted < 3.4.2
WebReflection/flatted < 3.4.2
Published Mar 20, 2026
Tracked Since Mar 21, 2026