CVE-2025-56005
Description
An undocumented and unsafe feature in the PLY (Python Lex-Yacc) library 3.11 allows Remote Code Execution (RCE) via the `picklefile` parameter in the `yacc()` function. This parameter accepts a `.pkl` file that is deserialized with `pickle.load()` without validation. Because `pickle` allows execution of embedded code via `__reduce__()`, an attacker can achieve code execution by passing a malicious pickle file. The parameter is not mentioned in official documentation or the GitHub repository, yet it is active in the PyPI version. This introduces a stealthy backdoor and persistence risk. NOTE: A third-party states that this vulnerability should be rejected because the proof of concept does not demonstrate arbitrary code execution and fails to complete successfully.
CVSS Details
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H Threat Intelligence
Weaknesses 1
Affected Products 1
| Vendor | Product | Version | Range |
|---|---|---|---|
| dabeaz | ply | 3.11 | any |
References 10
- openwall.com http://www.openwall.com/lists/oss-security/2026/01/23/4
- openwall.com http://www.openwall.com/lists/oss-security/2026/01/23/5
- openwall.com http://www.openwall.com/lists/oss-security/2026/01/28/5
- openwall.com http://www.openwall.com/lists/oss-security/2026/01/29/1
- openwall.com http://www.openwall.com/lists/oss-security/2026/01/29/2
- openwall.com http://www.openwall.com/lists/oss-security/2026/01/30/1
- github.com https://github.com/bohmiiidd/Undocumented-RCE-in-PLY
- github.com https://github.com/bohmiiidd/Undocumument_RCE_PLY-yacc-CVE-2025-56005
- github.com https://github.com/tom025/ply_exploit_rejection
- github.com https://github.com/tom025/ply_exploit_rejection/issues/1
Remediation
No remediation data recorded yet
Check vendor advisories and the NVD entry for patch availability.