{"id":"MAL-2026-5847","summary":"Malicious code in reading-cookies (npm)","details":"\n---\n_-= Per source details. Do not edit below this line.=-_\n\n## Source: amazon-inspector (d137cd4e8e7fc6d323c33ed04a87a97b152b217f948d01fae3172900751bf121)\nOn import, the package's middleware spawns a detached `node lib/caller.js` child process. `caller.js` decodes a base64-obfuscated URL (https://api.jsonstorage.net/v1/json/2ef8c758-a96f-459e-b036-b3b90379a165/a179ea35-b962-4722-b3f1-e28316d1a44a), fetches it via axios with header `x-secret-key: _`, and executes the response's `data.cookie` string by passing it to `new Function.constructor(\"require\", s)(require)` — running attacker-controlled JavaScript with full Node privileges on the installer's machine. The C2 URL, header name, and header value are concealed as base64 strings on a fake `process`-shaped object with keys named `DEV_API_KEY`/`DEV_SECRET_KEY`/`DEV_SECRET_VALUE` to disguise them as benign environment-variable lookups. The README, npm badges, and exports (`module.exports.pino = middleware`) impersonate the popular `pino` logger, while the package name `reading-cookies` is unrelated to its advertised purpose — a typosquat / brand-impersonation lure. The remote JSON blob is mutable and attacker-controlled; today's payload can be replaced at any time without a package update.\n\n## Source: ghsa-malware (f4a194e55ab8a2e54ad6d9ce957abd157196a174cba472fdb8c3d54235b5920c)\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-mf62-v96j-mg7g"],"modified":"2026-06-18T19:31:45.601157953Z","published":"2026-06-15T23:47:28Z","database_specific":{"malicious-packages-origins":[{"modified_time":"2026-06-15T23:47:35Z","source":"ghsa-malware","id":"GHSA-mf62-v96j-mg7g","sha256":"f4a194e55ab8a2e54ad6d9ce957abd157196a174cba472fdb8c3d54235b5920c","ranges":[{"events":[{"introduced":"0"}],"type":"SEMVER"}],"import_time":"2026-06-15T23:52:17.802279754Z"},{"modified_time":"2026-06-18T19:08:37Z","source":"amazon-inspector","id":"IN-MAL-2026-007022","versions":["6.13.2"],"sha256":"d137cd4e8e7fc6d323c33ed04a87a97b152b217f948d01fae3172900751bf121","import_time":"2026-06-18T19:20:02.688203745Z"}]},"references":[{"type":"ADVISORY","url":"https://github.com/advisories/GHSA-mf62-v96j-mg7g"},{"type":"PACKAGE","url":"https://www.npmjs.com/package/reading-cookies/v/6.13.2"}],"affected":[{"package":{"name":"reading-cookies","ecosystem":"npm","purl":"pkg:npm/reading-cookies"},"ranges":[{"type":"SEMVER","events":[{"introduced":"0"}]}],"versions":["6.13.2"],"database_specific":{"indicators":{"evidence_files":[{"tlsh":"1b01af9934fe541c015112e9171fa1326050e4673d86e6c83b4c87129fa667e6e93adf","path":"lib/caller.js","sha256":"37e9dde0f35864e2ea8dcd4c8b5324ef50e3798195d04c30ba6938352af702db"},{"tlsh":"075175a782e87b6e4b6300b1a1c279a6ff2f931c7b69606ddc98d139131d5d7813114a","path":"README.md","sha256":"554635e2ca7137794ba2f94624161b74fc77c87c2f7eff97a5c830810bf194d3"}]},"source":"https://github.com/ossf/malicious-packages/blob/main/osv/malicious/npm/reading-cookies/MAL-2026-5847.json","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"}]}}],"schema_version":"1.7.5","credits":[{"name":"Amazon Inspector","contact":["inspector-research@amazon.com"],"type":"FINDER"}]}