Home

Description

Keras versions prior to 3.14.0 are vulnerable to a path traversal issue in the archive extraction utilities located in `keras/src/utils/file_utils.py`. The functions `filter_safe_tarinfos()` and `filter_safe_zipinfos()` validate archive member paths against the process current working directory (CWD) instead of the actual extraction destination. When the process runs with CWD set to `/`, which is common in Docker containers, CI/CD runners, and Jupyter environments, the validation boundary becomes the filesystem root, allowing traversal paths to bypass the security check. Additionally, the zip filter contains a bug that causes an `AttributeError` when a blocked entry is encountered, leading to incomplete extraction. Furthermore, Python 3.11 installations lack the `filter="data"` safety net, leaving them entirely reliant on the flawed CWD-based filter. Exploitation of this vulnerability can result in arbitrary file writes outside the intended extraction directory, enabling attackers to overwrite configuration files, inject malicious code, or corrupt machine learning datasets and pipelines.

PUBLISHED Reserved 2026-06-09 | Published 2026-06-11 | Updated 2026-06-11 | Assigner @huntr_ai




HIGH: 8.1CVSS:3.0/AV:N/AC:L/PR:N/UI:R/S:U/C:H/I:H/A:N

Problem types

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

Product status

Any version before 3.14.0
affected

References

huntr.com/bounties/a07e3983-7158-4419-af2b-38f1dea01a4f exploit

huntr.com/bounties/a07e3983-7158-4419-af2b-38f1dea01a4f

github.com/...ommit/2465b6657b02c8eed308759b7e800e295ae01888

cve.org (CVE-2026-11816)

nvd.nist.gov (CVE-2026-11816)

Download JSON