CVE-2026-44843 PUBLISHED

LangChain: Unsafe deserialization of attacker-controlled LangChain objects through overly broad `load()` allowlists

Assigner: GitHub_M
Reserved: 07.05.2026 Published: 26.05.2026 Updated: 27.05.2026

LangChain is a framework for building agents and LLM-powered applications. Prior to 0.3.85 and 1.3.3, LangChain contains older runtime code paths that deserialize run inputs, run outputs, or other application-controlled payloads using overly broad object allowlists. These paths may call load() with allowed_objects="all". This does not enable arbitrary Python object deserialization, but it does allow any trusted LangChain-serializable object to be revived, which is broader than these runtime paths require. As a result, attacker-supplied LangChain serialized constructor dictionaries may cause trusted runtime paths to instantiate classes with untrusted constructor arguments. This vulnerability is fixed in 0.3.85 and 1.3.3.

Metrics

CVSS Vector: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:L/A:N
CVSS Score: 8.2

Product Status

Vendor langchain-ai
Product langchain
Versions
  • Version < 0.3.85 is affected
  • Version >= 1.0.0a1, < 1.3.3 is affected

References

Problem Types

  • CWE-502: Deserialization of Untrusted Data CWE