{"dataType":"CVE_RECORD","dataVersion":"5.2","cveMetadata":{"cveId":"CVE-2026-3479","assignerOrgId":"28c92f92-d60d-412d-b760-e73465c3df22","state":"PUBLISHED","assignerShortName":"PSF","dateReserved":"2026-03-03T14:18:35.394Z","datePublished":"2026-03-18T18:13:42.288Z","dateUpdated":"2026-04-07T22:01:35.724Z"},"containers":{"cna":{"affected":[{"defaultStatus":"unaffected","modules":["pkgutil"],"product":"CPython","vendor":"Python Software Foundation","versions":[{"version":"0","lessThan":"3.13.13","status":"affected","versionType":"python"},{"version":"3.14.0","lessThan":"3.14.4","status":"affected","versionType":"python"},{"version":"3.15.0a1","lessThan":"3.15.0a8","status":"affected","versionType":"python"}]}],"descriptions":[{"lang":"en","supportingMedia":[{"base64":false,"type":"text/html","value":"<p>DISPUTED: The project has clarified that the documentation was incorrect, and that pkgutil.get_data() has the same security model as open(). The documentation has been updated to clarify this point. There is no vulnerability in the function if following the intended security model.</p><p>pkgutil.get_data() did not validate the resource argument as documented, allowing path traversals.</p>"}],"value":"DISPUTED: The project has clarified that the documentation was incorrect, and that pkgutil.get_data() has the same security model as open(). The documentation has been updated to clarify this point. There is no vulnerability in the function if following the intended security model.\n\npkgutil.get_data() did not validate the resource argument as documented, allowing path traversals."}],"metrics":[{"cvssV4_0":{"Automatable":"NOT_DEFINED","Recovery":"NOT_DEFINED","Safety":"NOT_DEFINED","attackComplexity":"LOW","attackRequirements":"NONE","attackVector":"PHYSICAL","baseScore":0,"baseSeverity":"NONE","exploitMaturity":"NOT_DEFINED","privilegesRequired":"NONE","providerUrgency":"NOT_DEFINED","subAvailabilityImpact":"NONE","subConfidentialityImpact":"NONE","subIntegrityImpact":"NONE","userInteraction":"NONE","valueDensity":"NOT_DEFINED","vectorString":"CVSS:4.0/AV:P/AC:L/AT:N/PR:N/UI:N/VC:N/VI:N/VA:N/SC:N/SI:N/SA:N","version":"4.0","vulnAvailabilityImpact":"NONE","vulnConfidentialityImpact":"NONE","vulnIntegrityImpact":"NONE","vulnerabilityResponseEffort":"NOT_DEFINED"},"format":"CVSS","scenarios":[{"lang":"en","value":"GENERAL"}]}],"providerMetadata":{"orgId":"28c92f92-d60d-412d-b760-e73465c3df22","shortName":"PSF","dateUpdated":"2026-04-07T22:01:35.724Z"},"references":[{"tags":["patch"],"url":"https://github.com/python/cpython/pull/146122"},{"tags":["vendor-advisory"],"url":"https://mail.python.org/archives/list/security-announce@python.org/thread/WYLLVQOOCKGK73JM7Z7ZSNOJC4N7BAWY/"},{"tags":["issue-tracking"],"url":"https://github.com/python/cpython/issues/146121"},{"tags":["patch"],"url":"https://github.com/python/cpython/commit/bcdf231946b1da8bdfbab4c05539bb0cc964a1c7"},{"tags":["patch"],"url":"https://github.com/python/cpython/commit/5af6ce3e7b643a30a02d22245c1e3f4a8bc0a1fe"},{"tags":["patch"],"url":"https://github.com/python/cpython/commit/cf59bf76470f3d75ad47d80ffb8ce76b64b5e943"},{"tags":["patch"],"url":"https://github.com/python/cpython/commit/d786d59a8f7196bb630100a869f28ad13436b59c"}],"source":{"discovery":"UNKNOWN"},"tags":["disputed"],"title":"pkgutil.get_data() does not enforce documented restrictions","x_generator":{"engine":"Vulnogram 0.6.0"}},"adp":[{"problemTypes":[{"descriptions":[{"type":"CWE","cweId":"CWE-22","lang":"en","description":"CWE-22 Improper Limitation of a Pathname to a Restricted Directory ('Path Traversal')"}]}],"metrics":[{"other":{"type":"ssvc","content":{"timestamp":"2026-03-18T18:50:20.603616Z","id":"CVE-2026-3479","options":[{"Exploitation":"none"},{"Automatable":"no"},{"Technical Impact":"partial"}],"role":"CISA Coordinator","version":"2.0.3"}}}],"title":"CISA ADP Vulnrichment","providerMetadata":{"orgId":"134c704f-9b21-4f2e-91b3-4a467353bcc0","shortName":"CISA-ADP","dateUpdated":"2026-03-18T18:50:41.609Z"}}]}}