Description
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.
Remediation
References
https://snyk.io/vuln/SNYK-JAVA-ORGWEBJARSNPM-1579266
https://snyk.io/vuln/SNYK-JS-IMMER-1540542
https://github.com/immerjs/immer/commit/fa671e55ee9bd42ae08cc239102b665a23958237
Related Vulnerabilities
CVE-2023-1454 Vulnerability in maven package org.jeecgframework.boot:jeecg-boot-common
CVE-2023-34614 Vulnerability in maven package cc.plural:jsonij
CVE-2022-45143 Vulnerability in maven package org.apache.tomcat:tomcat-util
CVE-2020-6422 Vulnerability in maven package org.webjars.npm:electron
CVE-2021-42697 Vulnerability in maven package com.typesafe.akka:akka-http