This affects the package immer before 9.0.6. A type confusion vulnerability can lead to a bypass of CVE-2020-28477 when the user-provided keys used in the path parameter are arrays. In particular, this bypass is possible because the condition (p === "__proto__" || p === "constructor") in applyPatches_ returns false if p is ['__proto__'] (or ['constructor']). The === operator (strict equality operator) returns false if the operands have different type.
References
Link | Resource |
---|---|
https://snyk.io/vuln/SNYK-JAVA-ORGWEBJARSNPM-1579266 | Exploit Patch Third Party Advisory |
https://snyk.io/vuln/SNYK-JS-IMMER-1540542 | Exploit Patch Third Party Advisory |
https://github.com/immerjs/immer/commit/fa671e55ee9bd42ae08cc239102b665a23958237 | Patch Third Party Advisory |
Configurations
Information
Published : 2021-09-01 11:15
Updated : 2021-09-10 06:33
NVD link : CVE-2021-23436
Mitre link : CVE-2021-23436
JSON object : View
CWE
CWE-843
Access of Resource Using Incompatible Type ('Type Confusion')
Products Affected
immer_project
- immer