Vulnerability Description
The snorkel library thru v0.10.0 contains a critical insecure deserialization vulnerability (CWE-502) in the BaseLabeler.load() method of the BaseLabeler class. The method loads serialized labeler models using the unsafe pickle.load() function on user-supplied file paths without any validation or security controls. Python's pickle module is inherently dangerous for deserializing untrusted data, as it can execute arbitrary code during the deserialization process. A remote attacker can exploit this by providing a maliciously crafted pickle file, leading to arbitrary code execution on the victim's system when the file is loaded via the vulnerable method.
CVSS Score
HIGH
Affected Products
| Vendor | Product | Versions |
|---|---|---|
| Snorkel | Snorkel | <= 0.10.0 |
Related Weaknesses (CWE)
References
- https://github.com/snorkel-team/snorkelProduct
- https://www.notion.so/CVE-2026-31223-35d1e1393188811ab1d0e4a8a2e67992Third Party Advisory
FAQ
What is CVE-2026-31223?
CVE-2026-31223 is a vulnerability with a CVSS score of 8.8 (HIGH). The snorkel library thru v0.10.0 contains a critical insecure deserialization vulnerability (CWE-502) in the BaseLabeler.load() method of the BaseLabeler class. The method loads serialized labeler mod...
How severe is CVE-2026-31223?
CVE-2026-31223 has been rated HIGH with a CVSS base score of 8.8/10. Review the CVSS metrics above for detailed severity breakdown.
Is there a patch for CVE-2026-31223?
Check the references section above for vendor advisories and patch information. Affected products include: Snorkel Snorkel.