CVE-2025-4138

Name
CVE-2025-4138
Description
Allows the extraction filter to be ignored, allowing symlink targets to point outside the destination directory, and the modification of some file metadata. You are affected by this vulnerability if using the tarfile module to extract untrusted tar archives using TarFile.extractall() or TarFile.extract() using the filter= parameter with a value of "data" or "tar". See the tarfile extraction filters documentation https://docs.python.org/3/library/tarfile.html#tarfile-extraction-filter  for more information. Note that for Python 3.14 or later the default value of filter= changed from "no filtering" to `"data", so if you are relying on this new default behavior then your usage is also affected. Note that none of these vulnerabilities significantly affect the installation of source distributions which are tar archives as source distributions already allow arbitrary code execution during the build process. However when evaluating source distributions it's important to avoid installing source distributions with suspicious links.
NVD Severity
medium
Other trackers
Mailing lists
Exploits
Forges
GitHub (code, issues), Aports (code, issues)

References

Type URI
issue-tracking https://github.com/python/cpython/issues/135034
patch https://github.com/python/cpython/pull/135037
mitigation https://gist.github.com/sethmlarson/52398e33eff261329a0180ac1d54f42f
patch https://github.com/python/cpython/commit/3612d8f51741b11f36f8fb0494d79086bac9390a
patch https://github.com/python/cpython/commit/9e0ac76d96cf80b49055f6d6b9a6763fb9215c2a
vendor-advisory https://mail.python.org/archives/list/security-announce@python.org/thread/MAXIJJCUUMCL7ATZNDVEGGHUMQMUUKLG/
patch https://github.com/python/cpython/commit/19de092debb3d7e832e5672cc2f7b788d35951da
patch https://github.com/python/cpython/commit/aa9eb5f757ceff461e6e996f12c89e5d9b583b01
patch https://github.com/python/cpython/commit/28463dba112af719df1e8b0391c46787ad756dd9
patch https://github.com/python/cpython/commit/4633f3f497b1ff70e4a35b6fe2c907cbe2d4cb2e
patch https://github.com/python/cpython/commit/9c1110ef6652687d7c55f590f909720eddde965a
patch https://github.com/python/cpython/commit/dd8f187d0746da151e0025c51680979ac5b4cfb1

Match rules

CPE URI Source package Min version Max version
cpython >= 0 < 3.9.23
cpython >= 3.10.0 < 3.10.18
cpython >= 3.11.0 < 3.11.13
cpython >= 3.12.0 < 3.12.11
cpython >= 3.13.0 < 3.13.4
cpython >= 3.14.0a1 < 3.14.0

Vulnerable and fixed packages

Source package Branch Version Maintainer Status
python3 edge-main 3.12.11-r0 Natanael Copa <ncopa@alpinelinux.org> fixed
python3-tkinter edge-community 3.12.11-r0 Jingyun Hua <huajingyun@loongson.cn> fixed
python3 3.21-main 3.12.11-r0 Natanael Copa <ncopa@alpinelinux.org> fixed
python3-tkinter 3.21-community 3.12.11-r0 None fixed
python3 3.20-main 3.12.11-r0 Natanael Copa <ncopa@alpinelinux.org> fixed
python3 3.19-main 3.11.13-r0 Natanael Copa <ncopa@alpinelinux.org> fixed
python3-tkinter edge-main 3.12.11-r0 Jingyun Hua <huajingyun@loongson.cn> fixed
python3 3.22-main 3.12.11-r0 Natanael Copa <ncopa@alpinelinux.org> fixed
python3-tkinter 3.22-community 3.12.11-r0 None fixed