Description
In TypeStack class-validator 0.10.2, validate() input validation can be bypassed because certain internal attributes can be overwritten via a conflicting name. Even though there is an optional forbidUnknownValues parameter that can be used to reduce the risk of this bypass, this option is not documented and thus most developers configure input validation in the vulnerable default manner. With this vulnerability, attackers can launch SQL Injection or XSS attacks by injecting arbitrary malicious input. NOTE: a software maintainer agrees with the "is not documented" finding but suggests that much of the responsibility for the risk lies in a different product.
Remediation
References
https://github.com/typestack/class-validator#passing-options
https://github.com/typestack/class-validator/issues/1422#issuecomment-1344635415
https://github.com/typestack/class-validator/issues/438
https://github.com/typestack/class-validator/issues/438#issuecomment-964728471
Related Vulnerabilities
CVE-2019-13173 Vulnerability in npm package fstream
CVE-2023-37957 Vulnerability in maven package io.jenkins.plugins:pipeline-restful-api
CVE-2018-1327 Vulnerability in maven package org.apache.struts:struts2-rest-plugin
CVE-2023-24998 Vulnerability in maven package org.apache.tomcat:tomcat-util
CVE-2021-23329 Vulnerability in npm package nested-object-assign