When zx is invoked with --prefer-local=<path>, the CLI creates a symlink named ./nodemodules pointing to <path>/nodemodules. 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.
{
"github_reviewed": true,
"github_reviewed_at": "2025-11-21T18:01:32Z",
"nvd_published_at": "2025-11-20T17:15:49Z",
"severity": "MODERATE",
"cwe_ids": [
"CWE-706"
]
}