The shell-quote package before 1.7.3 for Node.js allows command injection. An attacker can inject unescaped shell metacharacters through a regex designed to support Windows drive letters. If the output of this package is passed to a real shell as a quoted argument to a command with exec(), an attacker can inject arbitrary commands. This is because the Windows drive letter regex character class is {A-z] instead of the correct {A-Za-z]. Several shell metacharacters exist in the space between capital letter Z and lower case letter a, such as the backtick character.
References
Link | Resource |
---|---|
https://github.com/substack/node-shell-quote/commit/5799416ed454aa4ec9afafc895b4e31760ea1abe | Patch Third Party Advisory |
https://www.npmjs.com/package/shell-quote | Vendor Advisory |
https://github.com/substack/node-shell-quote/blob/master/CHANGELOG.md#173 | Third Party Advisory |
Configurations
Information
Published : 2021-10-21 08:15
Updated : 2021-10-28 06:54
NVD link : CVE-2021-42740
Mitre link : CVE-2021-42740
JSON object : View
CWE
CWE-77
Improper Neutralization of Special Elements used in a Command ('Command Injection')
Products Affected
shell-quote_project
- shell-quote