Description
When zx is invoked with --prefer-local=<path>, the CLI creates a symlink named ./node_modules pointing to <path>/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 <path>/node_modules outside the current working directory.
Problem types
CWE-706 Use of Incorrectly-Resolved Name or Reference
Product status
8.8.4 (semver)
Credits
Ali Firas
References
github.com/google/zx/issues/1348