QID 984026
QID 984026: Nodejs (npm) Security Update for shell-quote (GHSA-qg8p-v9q4-gh34)
Affected versions of `shell-quote` do not properly escape command line arguments, which may result in command injection if the library is used to escape user input destined for use as command line arguments. ## Proof of Concept: The following characters are not escaped properly: `>`,`;`,`{`,`}` Bash has a neat but not well known feature known as "Bash Brace Expansion", wherein a sub-command can be executed without spaces by running it between a set of `{}` and using the `,` instead of ` ` to seperate arguments. Because of this, full command injection is possible even though it was initially thought to be impossible. ``` const quote = require('shell-quote').quote; console.log(quote(['a;{echo,test,123,234}'])); // Actual "a;{echo,test,123,234}" // Expected "a\;\{echo,test,123,234\}" // Functional Equivalent "a; echo 'test' '123' '1234'" ``` ## Recommendation Update to version 1.6.1 or later.
Successful exploitation of this vulnerability may affect the confidentiality, integrity, and availability of the targeted user.
- GHSA-qg8p-v9q4-gh34 -
github.com/advisories/GHSA-qg8p-v9q4-gh34
CVEs related to QID 984026
| Advisory ID | Software | Component | Link |
|---|---|---|---|
| GHSA-qg8p-v9q4-gh34 | shell-quote |
|