CVE-2025-56005CRITICAL 9.8EPSS p96.9%

CVE-2025-56005CVE-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.

Scoring

CVSS 3.19.8 (CRITICAL)
VectorCVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
EPSS18.65% probability of exploitation · percentile 96.9% · 2026-06-19T12:03:05Z
Published2026-01-20
Last modified2026-02-06

Underlying weaknesses· 1

CWE-502

References

  1. https://github.com/bohmiiidd/Undocumented-RCE-in-PLY
  2. https://github.com/bohmiiidd/Undocumument_RCE_PLY-yacc-CVE-2025-56005
  3. https://github.com/tom025/ply_exploit_rejection
  4. https://github.com/tom025/ply_exploit_rejection/issues/1
  5. http://www.openwall.com/lists/oss-security/2026/01/23/4
  6. http://www.openwall.com/lists/oss-security/2026/01/23/5
  7. http://www.openwall.com/lists/oss-security/2026/01/28/5
  8. http://www.openwall.com/lists/oss-security/2026/01/29/1

1

TypeTargetConfidenceTier
WeaknessDeserialization of Untrusted Datacwe-5020%live

Related by meaning· 6

Nearest entities by semantic similarity across the cs-graph corpus.

CVE
CVE-2025-1889
CVE
CVE-2026-31048
CVE
CVE-2025-1945
CVE
CVE-2025-61622
CVE
CVE-2025-50460
CVE
CVE-2025-69872
Sourced from NVD + FIRST.org EPSS. Curated for EU compliance use cases by Adam Lundqvist, Founder at SQUR.