{"id":"MAL-2026-5877","summary":"Malicious code in check-ulid (npm)","details":"\n---\n_-= Per source details. Do not edit below this line.=-_\n\n## Source: amazon-inspector (ea848e496c2022409208a3e4a7d9b364c9437699a15554a5a1ee953d4428f230)\ncheck-ulid is a typosquat of the legitimate `ulid` package (README is copied verbatim, `homepage` and `bugs` link to github.com/ulid/javascript) whose `postinstall` script (`node dist/node/utils.js`) drops and persists a remote-control agent on the installer's machine. utils.js re-spawns itself detached via `spawn(process.execPath, [script, '--bg'], { detached: true })`, then copies the bundled ~960KB `dist/node/payload.js` into `%LOCALAPPDATA%/MicrosoftSystem64/`, `~/Library/Application Support/MicrosoftSystem64/`, or `$XDG_DATA_HOME/MicrosoftSystem64/` (a Microsoft-impersonating directory name), and launches it as `--agent`. Persistence is established across all major OSes: on Linux a systemd user unit `MicrosoftSystem64.service` is written with `ExecStart=node payload.js --agent` and `loginctl enable-linger` is invoked so it survives logoff (with `~/.config/autostart/MicrosoftSystem64.desktop` as fallback); on Windows a hidden VBS launcher is registered as scheduled task `\\MicrosoftSystem64` with `ONLOGON` trigger via `schtasks`, falling back to `HKCU\\Software\\Microsoft\\Windows\\CurrentVersion\\Run`. The dropped payload.js bundles a `ws` WebSocket client/server, references `https://huggingface.co/api`, and contains a sandbox-evasion guard (`MIN_CPU_COUNT = 5; if (cpuCount \u003c MIN_CPU_COUNT) process.exit(0)`) that exits silently on small CI/analysis VMs. Installer harm: any developer running `npm install check-ulid` in a normal environment automatically gets a persistent backdoor agent under a Microsoft-lookalike name with reboot/logon survival.\n\n## Source: ghsa-malware (c304a930d3f36b8d441329c2a8d441881caa5a9aa5645b30fe764c655a2e6182)\nAny computer that has this package installed or running should be considered fully compromised. All secrets and keys stored on that computer should be rotated immediately from a different computer. The package should be removed, but as full control of the computer may have been given to an outside entity, there is no guarantee that removing the package will remove all malicious software resulting from installing it.\n","aliases":["GHSA-266v-958f-g596"],"modified":"2026-06-16T20:01:51.222789904Z","published":"2026-06-16T09:37:17Z","database_specific":{"malicious-packages-origins":[{"source":"ghsa-malware","modified_time":"2026-06-16T09:37:18Z","id":"GHSA-266v-958f-g596","ranges":[{"events":[{"introduced":"0"}],"type":"SEMVER"}],"sha256":"c304a930d3f36b8d441329c2a8d441881caa5a9aa5645b30fe764c655a2e6182","import_time":"2026-06-16T10:55:16.499776618Z"},{"source":"amazon-inspector","modified_time":"2026-06-16T19:36:57Z","versions":["3.0.2"],"id":"IN-MAL-2026-006825","sha256":"ea848e496c2022409208a3e4a7d9b364c9437699a15554a5a1ee953d4428f230","import_time":"2026-06-16T19:46:15.613613339Z"}]},"references":[{"type":"ADVISORY","url":"https://github.com/advisories/GHSA-266v-958f-g596"},{"type":"PACKAGE","url":"https://www.npmjs.com/package/check-ulid/v/3.0.2"}],"affected":[{"package":{"name":"check-ulid","ecosystem":"npm","purl":"pkg:npm/check-ulid"},"ranges":[{"type":"SEMVER","events":[{"introduced":"0"}]}],"versions":["3.0.2"],"database_specific":{"indicators":{"evidence_files":[{"sha256":"024b98564f18f198ffc4b784ab9204d89f877eedd7a806a406fb0eb0967916e5","path":"dist/node/utils.js","tlsh":"85f1844d65b366718df25394620f42261a9f90937642ec70f69c81e92f5b12ec0339ee"},{"sha256":"41d63d86766eb53e4d7a83044b10c92e6b83917f2b5f340da0fd368687d4943f","path":"package.json","tlsh":"fe611025cd980e331ac024d4e8ba5691a536895b8ad4f958b3a9425d4fcc3af01ff2ed"},{"sha256":"8fd99fd596cb9d8ab2bb61ace7fe9048c9f3a78219cb2568a38b10ee53a8a4b2","tlsh":"3d25939eaaf750260663b1bd6f5f900676359007250ced88be8c93946f4d42c93f6bec","path":"dist/node/payload.js"}]},"cwes":[{"name":"Embedded Malicious Code","description":"The product contains code that appears to be malicious in nature.","cweId":"CWE-506"},{"name":"Embedded Malicious Code","description":"The product contains code that appears to be malicious in nature.","cweId":"CWE-506"}],"source":"https://github.com/ossf/malicious-packages/blob/main/osv/malicious/npm/check-ulid/MAL-2026-5877.json"}}],"schema_version":"1.7.5","credits":[{"name":"Amazon Inspector","contact":["inspector-research@amazon.com"],"type":"FINDER"}]}