A vulnerability has been identified in the Node.js (.msi version) installation process, specifically affecting Windows users who install Node.js using the .msi installer. This vulnerability emerges during the repair operation, where the msiexec.exe process, running under the NT AUTHORITYSYSTEM context, attempts to read the %USERPROFILE% environment variable from the current users registry.
The issue arises when the path referenced by the %USERPROFILE% environment variable does not exist. In such cases, the msiexec.exe process attempts to create the specified path in an unsafe manner, potentially leading to the creation of arbitrary folders in arbitrary locations.
The severity of this vulnerability is heightened by the fact that the %USERPROFILE% environment variable in the Windows registry can be modified by standard (or non-privileged) users. Consequently, unprivileged actors, including malicious entities or trojans, can manipulate the environment variable key to deceive the privileged msiexec.exe process. This manipulation can result in the creation of folders in unintended and potentially malicious locations.
It is important to note that this vulnerability is specific to Windows users who install Node.js using the .msi installer. Users who opt for other installation methods are not affected by this particular issue.
Name | Vendor | Start Version | End Version |
---|---|---|---|
Node.js | Nodejs | 16.0.0 (including) | 16.20.1 (excluding) |
Node.js | Nodejs | 18.0.0 (including) | 18.16.1 (excluding) |
Node.js | Nodejs | 20.0.0 (including) | 20.3.1 (excluding) |
Nodejs | Ubuntu | bionic | * |
Nodejs | Ubuntu | kinetic | * |
Nodejs | Ubuntu | lunar | * |
Nodejs | Ubuntu | trusty | * |
Nodejs | Ubuntu | xenial | * |