CVE-2025-8869: pip's fallback tar extraction doesn't check symbolic links point to extraction directory
(updated )
When extracting a tar archive pip may not check symbolic links point into the extraction directory if the tarfile module doesn’t implement PEP 706. Note that upgrading pip to a “fixed” version for this vulnerability doesn’t fix all known vulnerabilities that are remediated by using a Python version that implements PEP 706. Note that this is a vulnerability in pip’s fallback implementation of tar extraction for Python versions that don’t implement PEP 706 and therefore are not secure to all vulnerabilities in the Python ’tarfile’ module. If you’re using a Python version that implements PEP 706 then pip doesn’t use the “vulnerable” fallback code. Mitigations include upgrading to a version of pip that includes the fix, upgrading to a Python version that implements PEP 706 (Python >=3.9.17, >=3.10.12, >=3.11.4, or >=3.12), applying the linked patch, or inspecting source distributions (sdists) before installation as is already a best-practice.
References
- github.com/advisories/GHSA-4xh5-x5gv-qwph
- github.com/pypa/pip
- github.com/pypa/pip/commit/f2b92314da012b9fffa36b3f3e67748a37ef464a
- github.com/pypa/pip/pull/13550
- lists.debian.org/debian-lts-announce/2025/10/msg00028.html
- mail.python.org/archives/list/security-announce@python.org/thread/IF5A3GCJY3VH7BVHJKOWOJFKTW7VFQEN
- nvd.nist.gov/vuln/detail/CVE-2025-8869
- pip.pypa.io/en/stable/news/
Code Behaviors & Features
Detect and mitigate CVE-2025-8869 with GitLab Dependency Scanning
Secure your software supply chain by verifying that all open source dependencies used in your projects contain no disclosed vulnerabilities. Learn more about Dependency Scanning →