-= Per source details. Do not edit below this line.=-
check-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 < 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.
Any 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.
{
"malicious-packages-origins": [
{
"id": "GHSA-266v-958f-g596",
"import_time": "2026-06-16T10:55:16.499776618Z",
"source": "ghsa-malware",
"ranges": [
{
"type": "SEMVER",
"events": [
{
"introduced": "0"
}
]
}
],
"modified_time": "2026-06-16T09:37:18Z",
"sha256": "c304a930d3f36b8d441329c2a8d441881caa5a9aa5645b30fe764c655a2e6182"
},
{
"id": "IN-MAL-2026-006825",
"import_time": "2026-06-16T19:46:15.613613339Z",
"versions": [
"3.0.2"
],
"source": "amazon-inspector",
"modified_time": "2026-06-16T19:36:57Z",
"sha256": "ea848e496c2022409208a3e4a7d9b364c9437699a15554a5a1ee953d4428f230"
}
]
}[
{
"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"
}
]
"https://github.com/ossf/malicious-packages/blob/main/osv/malicious/npm/check-ulid/MAL-2026-5877.json"
{
"evidence_files": [
{
"path": "dist/node/utils.js",
"sha256": "024b98564f18f198ffc4b784ab9204d89f877eedd7a806a406fb0eb0967916e5",
"tlsh": "85f1844d65b366718df25394620f42261a9f90937642ec70f69c81e92f5b12ec0339ee"
},
{
"path": "package.json",
"sha256": "41d63d86766eb53e4d7a83044b10c92e6b83917f2b5f340da0fd368687d4943f",
"tlsh": "fe611025cd980e331ac024d4e8ba5691a536895b8ad4f958b3a9425d4fcc3af01ff2ed"
},
{
"path": "dist/node/payload.js",
"sha256": "8fd99fd596cb9d8ab2bb61ace7fe9048c9f3a78219cb2568a38b10ee53a8a4b2",
"tlsh": "3d25939eaaf750260663b1bd6f5f900676359007250ced88be8c93946f4d42c93f6bec"
}
]
}