{"api_version":"1","generated_at":"2026-06-23T06:30:12+00:00","cve":"CVE-2026-55388","urls":{"html":"https://cve.report/CVE-2026-55388","api":"https://cve.report/api/cve/CVE-2026-55388.json","docs":"https://cve.report/api","cve_org":"https://www.cve.org/CVERecord?id=CVE-2026-55388","nvd":"https://nvd.nist.gov/vuln/detail/CVE-2026-55388"},"summary":{"title":"piscina: Prototype Pollution Gadget → RCE via inherited options.filename","description":"piscina is a node.js worker pool implementation. Prior to 6.0.0-rc.2, 5.2.0, and 4.9.3, piscina's constructor and run() paths read the filename option via plain member access. Both reads fall through the prototype chain when the caller's options object doesn't have filename as an own property. When Object.prototype.filename is polluted upstream the inherited value flows to worker_threads.Worker import and the attacker's .mjs runs in the worker. This vulnerability is fixed in 6.0.0-rc.2, 5.2.0, and 4.9.3.","state":"PUBLISHED","assigner":"GitHub_M","published_at":"2026-06-22 18:16:47","updated_at":"2026-06-22 18:16:47"},"problem_types":["CWE-94","CWE-1321","CWE-94 CWE-94: Improper Control of Generation of Code ('Code Injection')","CWE-1321 CWE-1321: Improperly Controlled Modification of Object Prototype Attributes ('Prototype Pollution')"],"metrics":[{"version":"3.1","source":"security-advisories@github.com","type":"Secondary","score":"8.1","severity":"HIGH","vector":"CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H","data":{"version":"3.1","vectorString":"CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H","baseScore":8.1,"baseSeverity":"HIGH","attackVector":"NETWORK","attackComplexity":"HIGH","privilegesRequired":"NONE","userInteraction":"NONE","scope":"UNCHANGED","confidentialityImpact":"HIGH","integrityImpact":"HIGH","availabilityImpact":"HIGH"}},{"version":"3.1","source":"CNA","type":"DECLARED","score":"8.1","severity":"HIGH","vector":"CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H","data":{"attackComplexity":"HIGH","attackVector":"NETWORK","availabilityImpact":"HIGH","baseScore":8.1,"baseSeverity":"HIGH","confidentialityImpact":"HIGH","integrityImpact":"HIGH","privilegesRequired":"NONE","scope":"UNCHANGED","userInteraction":"NONE","vectorString":"CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H","version":"3.1"}}],"references":[{"url":"https://github.com/piscinajs/piscina/security/advisories/GHSA-x9g3-xrwr-cwfg","name":"https://github.com/piscinajs/piscina/security/advisories/GHSA-x9g3-xrwr-cwfg","refsource":"security-advisories@github.com","tags":[],"title":"","mime":"","httpstatus":"","archivestatus":"0"},{"url":"https://www.cve.org/CVERecord?id=CVE-2026-55388","name":"CVE Program record","refsource":"CVE.ORG","tags":["canonical"]},{"url":"https://nvd.nist.gov/vuln/detail/CVE-2026-55388","name":"NVD vulnerability detail","refsource":"NVD","tags":["canonical","analysis"]}],"affected":[{"source":"CNA","vendor":"piscinajs","product":"piscina","version":"affected < 4.9.3","platforms":[]},{"source":"CNA","vendor":"piscinajs","product":"piscina","version":"affected >= 5.0.0-alpha.0, < 5.2.0","platforms":[]},{"source":"CNA","vendor":"piscinajs","product":"piscina","version":"affected >= 6.0.0-rc.1, < 6.0.0-rc.2","platforms":[]}],"timeline":[],"solutions":[],"workarounds":[],"exploits":[],"credits":[],"nvd_cpes":[],"vendor_comments":[],"enrichments":{"kev":null,"epss":null,"legacy_qids":[]},"source_records":{"cve_program":{"containers":{"cna":{"affected":[{"product":"piscina","vendor":"piscinajs","versions":[{"status":"affected","version":"< 4.9.3"},{"status":"affected","version":">= 5.0.0-alpha.0, < 5.2.0"},{"status":"affected","version":">= 6.0.0-rc.1, < 6.0.0-rc.2"}]}],"descriptions":[{"lang":"en","value":"piscina is a node.js worker pool implementation. Prior to 6.0.0-rc.2, 5.2.0, and 4.9.3, piscina's constructor and run() paths read the filename option via plain member access. Both reads fall through the prototype chain when the caller's options object doesn't have filename as an own property. When Object.prototype.filename is polluted upstream the inherited value flows to worker_threads.Worker import and the attacker's .mjs runs in the worker. This vulnerability is fixed in 6.0.0-rc.2, 5.2.0, and 4.9.3."}],"metrics":[{"cvssV3_1":{"attackComplexity":"HIGH","attackVector":"NETWORK","availabilityImpact":"HIGH","baseScore":8.1,"baseSeverity":"HIGH","confidentialityImpact":"HIGH","integrityImpact":"HIGH","privilegesRequired":"NONE","scope":"UNCHANGED","userInteraction":"NONE","vectorString":"CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H","version":"3.1"}}],"problemTypes":[{"descriptions":[{"cweId":"CWE-94","description":"CWE-94: Improper Control of Generation of Code ('Code Injection')","lang":"en","type":"CWE"}]},{"descriptions":[{"cweId":"CWE-1321","description":"CWE-1321: Improperly Controlled Modification of Object Prototype Attributes ('Prototype Pollution')","lang":"en","type":"CWE"}]}],"providerMetadata":{"dateUpdated":"2026-06-22T16:50:40.867Z","orgId":"a0819718-46f1-4df5-94e2-005712e83aaa","shortName":"GitHub_M"},"references":[{"name":"https://github.com/piscinajs/piscina/security/advisories/GHSA-x9g3-xrwr-cwfg","tags":["x_refsource_CONFIRM"],"url":"https://github.com/piscinajs/piscina/security/advisories/GHSA-x9g3-xrwr-cwfg"}],"source":{"advisory":"GHSA-x9g3-xrwr-cwfg","discovery":"UNKNOWN"},"title":"piscina: Prototype Pollution Gadget → RCE via inherited options.filename"}},"cveMetadata":{"assignerOrgId":"a0819718-46f1-4df5-94e2-005712e83aaa","assignerShortName":"GitHub_M","cveId":"CVE-2026-55388","datePublished":"2026-06-22T16:50:40.867Z","dateReserved":"2026-06-16T18:57:40.183Z","dateUpdated":"2026-06-22T16:50:40.867Z","state":"PUBLISHED"},"dataType":"CVE_RECORD","dataVersion":"5.2"},"nvd":{"publishedDate":"2026-06-22 18:16:47","lastModifiedDate":"2026-06-22 18:16:47","problem_types":["CWE-94","CWE-1321","CWE-94 CWE-94: Improper Control of Generation of Code ('Code Injection')","CWE-1321 CWE-1321: Improperly Controlled Modification of Object Prototype Attributes ('Prototype Pollution')"],"metrics":{"cvssMetricV31":[{"source":"security-advisories@github.com","type":"Secondary","cvssData":{"version":"3.1","vectorString":"CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H","baseScore":8.1,"baseSeverity":"HIGH","attackVector":"NETWORK","attackComplexity":"HIGH","privilegesRequired":"NONE","userInteraction":"NONE","scope":"UNCHANGED","confidentialityImpact":"HIGH","integrityImpact":"HIGH","availabilityImpact":"HIGH"},"exploitabilityScore":2.2,"impactScore":5.9}]},"configurations":[]},"legacy_mitre":{"record":{"CveYear":"2026","CveId":"55388","Ordinal":"1","Title":"piscina: Prototype Pollution Gadget → RCE via inherited options.","CVE":"CVE-2026-55388","Year":"2026"},"notes":[{"CveYear":"2026","CveId":"55388","Ordinal":"1","NoteData":"piscina is a node.js worker pool implementation. Prior to 6.0.0-rc.2, 5.2.0, and 4.9.3, piscina's constructor and run() paths read the filename option via plain member access. Both reads fall through the prototype chain when the caller's options object doesn't have filename as an own property. When Object.prototype.filename is polluted upstream the inherited value flows to worker_threads.Worker import and the attacker's .mjs runs in the worker. This vulnerability is fixed in 6.0.0-rc.2, 5.2.0, and 4.9.3.","Type":"Description","Title":"piscina: Prototype Pollution Gadget → RCE via inherited options."}]}}}