{"id":"MAL-2026-5406","summary":"Malicious code in ui-weave (npm)","details":"\n---\n_-= Per source details. Do not edit below this line.=-_\n\n## Source: amazon-inspector (ee5b1184b3208f8eee80df74c37c809f93461564a9226e1f82e1d551770d799a)\npackage.json declares `postinstall: node lib/utils/index.js`, which spawns a detached child process running lib/utils/smtp-connection/index.js. That script fetches https://www.jsonkeeper.com/b/QHDXR and feeds the response's `data.cookie` field directly into `new Function('require', data.cookie)(require)`, executing whatever JavaScript is hosted at that URL on every machine that runs `npm install ui-weave`. jsonkeeper.com is a public, mutable, anonymous paste host — the author can change the served payload at any time without republishing the package. The detached/unref'd spawn is intended to outlive the install command. The package additionally impersonates nodemailer: it ships nodemailer's source under `lib/nodemailer.js`, claims author `Andris Reinman` (the real nodemailer maintainer), and copies an unrelated React Training copyright string as its description, while being published under the unrelated name `ui-weave` with homepage `ui-weave.com`. The impersonation provides a veneer of legitimacy for the install-time remote-code-execution payload.\n\n## Source: ghsa-malware (432ff68bc187f1b99dbbc71705d0d388ac62a3f9e3d332aad853d269a73703cf)\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-x2w5-px4q-j9wq"],"modified":"2026-06-12T20:01:57.805400835Z","published":"2026-06-09T16:07:22Z","database_specific":{"malicious-packages-origins":[{"id":"GHSA-x2w5-px4q-j9wq","import_time":"2026-06-09T17:08:55.935040896Z","modified_time":"2026-06-09T16:07:22Z","sha256":"432ff68bc187f1b99dbbc71705d0d388ac62a3f9e3d332aad853d269a73703cf","source":"ghsa-malware","ranges":[{"events":[{"introduced":"0"}],"type":"SEMVER"}]},{"id":"IN-MAL-2026-005838","import_time":"2026-06-12T19:43:38.735440361Z","sha256":"ee5b1184b3208f8eee80df74c37c809f93461564a9226e1f82e1d551770d799a","modified_time":"2026-06-12T19:03:02Z","versions":["1.0.3"],"source":"amazon-inspector"}]},"references":[{"type":"ADVISORY","url":"https://github.com/advisories/GHSA-x2w5-px4q-j9wq"},{"type":"PACKAGE","url":"https://www.npmjs.com/package/ui-weave/v/1.0.3"}],"affected":[{"package":{"name":"ui-weave","ecosystem":"npm","purl":"pkg:npm/ui-weave"},"ranges":[{"type":"SEMVER","events":[{"introduced":"0"}]}],"versions":["1.0.3"],"database_specific":{"cwes":[{"cweId":"CWE-506","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."}],"source":"https://github.com/ossf/malicious-packages/blob/main/osv/malicious/npm/ui-weave/MAL-2026-5406.json","indicators":{"evidence_files":[{"tlsh":"05f0c06a19f35238521b22c94b5b040a3007d007379aed89f7cc87e02fc39909d42fb8","path":"lib/utils/smtp-connection/index.js","sha256":"e72ab44afd0114c64138b8ada7f91c7d12fd09be68ca28973465bed185552323"},{"tlsh":"1f41ad15cd268ce33a9565fd786c1182a420d40fcd05f81d734d238c8f8e99f3278a6e","path":"package.json","sha256":"4dcd26af95619aca4084def8e21651ece57c6da73a5792307a8ca5235c009652"}]}}}],"schema_version":"1.7.5","credits":[{"name":"Amazon Inspector","contact":["inspector-research@amazon.com"],"type":"FINDER"}]}