Home

Description

The keras.utils.get_file API in Keras, when used with the extract=True option for tar archives, is vulnerable to a path traversal attack. The utility uses Python's tarfile.extractall function without the filter="data" feature. A remote attacker can craft a malicious tar archive containing special symlinks, which, when extracted, allows them to write arbitrary files to any location on the filesystem outside of the intended destination folder. This vulnerability is linked to the underlying Python tarfile weakness, identified as CVE-2025-4517. Note that upgrading Python to one of the versions that fix CVE-2025-4517 (e.g. Python 3.13.4) is not enough. One additionally needs to upgrade Keras to a version with the fix (Keras 3.12).

PUBLISHED Reserved 2025-10-22 | Published 2025-10-30 | Updated 2025-11-01 | Assigner Google




HIGH: 8.9CVSS:4.0/AV:N/AC:L/AT:P/PR:L/UI:P/VC:H/VI:H/VA:H/SC:H/SI:H/SA:H

Problem types

CWE-22 Improper Limitation of a Pathname to a Restricted Directory ('Path Traversal')

Product status

Default status
unaffected

3.0.0 (semver)
affected

Credits

Krishna Gudimetla finder

References

github.com/keras-team/keras/pull/21760

github.com/.../keras/security/advisories/GHSA-hjqc-jx6g-rwp9

cve.org (CVE-2025-12060)

nvd.nist.gov (CVE-2025-12060)

Download JSON