zx Uses Incorrectly-Resolved Name or Reference
Moderate severity
GitHub Reviewed
Published
Nov 20, 2025
to the GitHub Advisory Database
•
Updated Nov 21, 2025
Description
Published by the National Vulnerability Database
Nov 20, 2025
Published to the GitHub Advisory Database
Nov 20, 2025
Reviewed
Nov 21, 2025
Last updated
Nov 21, 2025
When zx is invoked with --prefer-local=, the CLI creates a symlink named ./node_modules pointing to /node_modules. Due to a logic error in src/cli.ts (linkNodeModules / cleanup), the function returns the target path instead of the alias (symlink path). The later cleanup routine removes what it received, which deletes the target directory itself. Result: zx can delete an external /node_modules outside the current working directory.
References