CVE-2025-8869
Description
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.
AI Insight
LLM-synthesized narrative grounded in this CVE's description and references.
Affected packages
Versions sourced from the GitHub Security Advisory.
| Package | Affected versions | Patched versions |
|---|---|---|
pipPyPI | < 25.3 | 25.3 |
Affected products
59- osv-coords58 versionspkg:apk/chainguard/airflow-2pkg:apk/chainguard/airflow-2-bitnami-compatpkg:apk/chainguard/airflow-2-compatpkg:apk/chainguard/airflow-2-iamguarded-compatpkg:apk/chainguard/graalvm-25-graalpy-venvpkg:apk/chainguard/localstackpkg:apk/chainguard/mlflowpkg:apk/chainguard/mlflow-bitnamipkg:apk/chainguard/mlflow-iamguarded-compatpkg:apk/chainguard/nvidia-nsight-compute-13.1pkg:apk/chainguard/py3.10-pippkg:apk/chainguard/py3.10-pip-basepkg:apk/chainguard/py3.10-pytorch-cuda-11.8pkg:apk/chainguard/py3.10-virtualenvpkg:apk/chainguard/py3.10-wheels-torch-cuda-11.8pkg:apk/chainguard/py3.11-pippkg:apk/chainguard/py3.11-pip-basepkg:apk/chainguard/py3.11-virtualenvpkg:apk/chainguard/py3.12-pippkg:apk/chainguard/py3.12-pip-basepkg:apk/chainguard/py3.12-pytorch-cuda-11.8pkg:apk/chainguard/py3.12-virtualenvpkg:apk/chainguard/py3.12-wheels-torch-cuda-11.8pkg:apk/chainguard/py3.13-pippkg:apk/chainguard/py3.13-pip-basepkg:apk/chainguard/py3.13-virtualenvpkg:apk/chainguard/py3.14-pippkg:apk/chainguard/py3.14-pip-basepkg:apk/chainguard/py3.9-pippkg:apk/chainguard/py3-pippkg:apk/chainguard/py3-pip-wheelpkg:apk/chainguard/py3-pip-wheel-bootstrappkg:apk/chainguard/py3-supported-pippkg:apk/chainguard/reflexpkg:apk/chainguard/request-1276pkg:apk/wolfi/mlflowpkg:apk/wolfi/mlflow-bitnamipkg:apk/wolfi/mlflow-iamguarded-compatpkg:apk/wolfi/py3.10-pippkg:apk/wolfi/py3.10-pip-basepkg:apk/wolfi/py3.10-virtualenvpkg:apk/wolfi/py3.11-pippkg:apk/wolfi/py3.11-pip-basepkg:apk/wolfi/py3.11-virtualenvpkg:apk/wolfi/py3.12-pippkg:apk/wolfi/py3.12-pip-basepkg:apk/wolfi/py3.12-virtualenvpkg:apk/wolfi/py3.13-pippkg:apk/wolfi/py3.13-pip-basepkg:apk/wolfi/py3.13-virtualenvpkg:apk/wolfi/py3.14-pippkg:apk/wolfi/py3.14-pip-basepkg:apk/wolfi/py3-pippkg:apk/wolfi/py3-pip-wheelpkg:apk/wolfi/py3-pip-wheel-bootstrappkg:apk/wolfi/py3-supported-pippkg:apk/wolfi/reflexpkg:pypi/pip
< 2.11.2-r5+ 57 more
- (no CPE)range: < 2.11.2-r5
- (no CPE)range: < 2.11.0-r14
- (no CPE)range: < 2.11.0-r14
- (no CPE)range: < 2.11.0-r14
- (no CPE)range: < 25.0.2-r10
- (no CPE)range: < 4.14.0-r11
- (no CPE)range: < 3.6.0-r0
- (no CPE)range: < 3.6.0-r0
- (no CPE)range: < 3.6.0-r0
- (no CPE)range: < 2025.4.1.2-r1
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 2.3.1-r12
- (no CPE)range: < 21.5.0-r0
- (no CPE)range: < 2.3.1-r12
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 21.5.0-r0
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 2.3.1-r10
- (no CPE)range: < 21.5.0-r0
- (no CPE)range: < 2.3.1-r10
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 21.5.0-r0
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 25.2-r1
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 25.3-r0
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 0.8.14-r0
- (no CPE)range: < 0.27.1-r1
- (no CPE)range: < 3.6.0-r0
- (no CPE)range: < 3.6.0-r0
- (no CPE)range: < 3.6.0-r0
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 21.5.0-r0
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 21.5.0-r0
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 21.5.0-r0
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 21.5.0-r0
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 25.3-r0
- (no CPE)range: < 25.2-r2
- (no CPE)range: < 0.8.14-r0
- (no CPE)range: < 25.3
Patches
Vulnerability mechanics
References
8- github.com/advisories/GHSA-4xh5-x5gv-qwphghsaADVISORY
- nvd.nist.gov/vuln/detail/CVE-2025-8869ghsaADVISORY
- github.com/pypa/pip/commit/f2b92314da012b9fffa36b3f3e67748a37ef464aghsaWEB
- github.com/pypa/pip/pull/13550nvdWEB
- lists.debian.org/debian-lts-announce/2025/10/msg00028.htmlnvdWEB
- mail.python.org/archives/list/security-announce@python.org/thread/IF5A3GCJY3VH7BVHJKOWOJFKTW7VFQENghsaWEB
- pip.pypa.io/en/stable/news/ghsaWEB
- mail.python.org/archives/list/security-announce@python.org/thread/IF5A3GCJY3VH7BVHJKOWOJFKTW7VFQEN/nvd
News mentions
0No linked articles in our index yet.