If your organization runs LangGraph with explicit cache backends (Redis, SQLite, or InMemoryCache) and any node uses CachePolicy, you have a live RCE risk — upgrade langgraph-checkpoint to 4.0.0 now. Caching is off by default, so most deployments are unaffected, but any multi-tenant or shared-cache AI platform scenario is high priority. Audit all LangGraph deployments for cache configuration before end of day.
Affected Systems
| Package | Ecosystem | Vulnerable Range | Patched |
|---|---|---|---|
| langgraph-checkpoint | pip | < 4.0.0 | 4.0.0 |
Do you use langgraph-checkpoint? You're affected.
Severity & Risk
Recommended Action
- 1) PATCH: Upgrade langgraph-checkpoint to >=4.0.0 — this sets pickle_fallback=False by default, eliminating the deserialization sink. 2) INVENTORY: Audit all LangGraph deployments for explicit cache= arguments in StateGraph.compile() and CachePolicy usage on nodes; if caching is not required, confirm it is absent from config. 3) HARDEN CACHE BACKENDS: Enforce authentication (requirepass) on Redis; restrict SQLite cache file permissions to the LangGraph service account only; place Redis behind network ACLs or VPC-internal-only routing. 4) ISOLATE: Ensure cache backends are not shared across tenant or service trust boundaries. 5) DETECT: Alert on unexpected WRITE operations to LangGraph cache namespaces from non-LangGraph processes; consider scanning cache contents for pickle magic bytes (\x80\x04 or \x80\x05 prefix) as an IOC. 6) VERIFY: Confirm no Redis cache instances are publicly network-accessible without authentication using a port scan of AI infrastructure.
Classification
Compliance Impact
This CVE is relevant to:
Technical Details
NVD Description
## Context A Remote Code Execution vulnerability exists in LangGraph's caching layer when applications enable cache backends that inherit from `BaseCache` and opt nodes into caching via `CachePolicy`. Prior to `langgraph-checkpoint` 4.0.0, `BaseCache` defaults to `JsonPlusSerializer(pickle_fallback=True)`. When msgpack serialization fails, cached values can be deserialized via `pickle.loads(...)`. ### Who is affected? Caching is not enabled by default. Applications are affected only when: - The application explicitly enables a cache backend (for example by passing `cache=...` to `StateGraph.compile(...)` or otherwise configuring a `BaseCache` implementation) - One or more nodes opt into caching via `CachePolicy` - The attacker can write to the cache backend (for example a network-accessible Redis instance with weak/no auth, shared cache infrastructure reachable by other tenants/services, or a writable SQLite cache file) Example (enabling a cache backend and opting a node into caching): ```py from langgraph.cache.memory import InMemoryCache from langgraph.graph import StateGraph from langgraph.types import CachePolicy def my_node(state: dict) -> dict: return {"value": state.get("value", 0) + 1} builder = StateGraph(dict) builder.add_node("my_node", my_node, cache_policy=CachePolicy(ttl=120)) builder.set_entry_point("my_node") graph = builder.compile(cache=InMemoryCache()) result = graph.invoke({"value": 1}) ``` With `pickle_fallback=True`, when msgpack serialization fails, `JsonPlusSerializer` can fall back to storing values as a `("pickle", <bytes>)` tuple and later deserialize them via `pickle.loads(...)`. If an attacker can place a malicious pickle payload into the cache backend such that the LangGraph process reads and deserializes it, this can lead to arbitrary code execution. Exploitation requires attacker write access to the cache backend. The serializer is not exposed as a network-facing API. This is fixed in `langgraph-checkpoint>=4.0.0` by disabling pickle fallback by default (`pickle_fallback=False`). ## Impact Arbitrary code execution in the LangGraph process when attacker-controlled cache entries are deserialized. ## Root Cause - `BaseCache` default serializer configuration inherited by cache implementations (`InMemoryCache`, `RedisCache`, `SqliteCache`): - `libs/checkpoint/langgraph/cache/base/__init__.py` (pre-fix default: `JsonPlusSerializer(pickle_fallback=True)`) - `JsonPlusSerializer` deserialization sink: - `libs/checkpoint/langgraph/checkpoint/serde/jsonplus.py` - `loads_typed(...)` calls `pickle.loads(data_)` when `type_ == "pickle"` and pickle fallback is enabled ## Attack preconditions An attacker must be able to write attacker-controlled bytes into the cache backend such that the LangGraph process later reads and deserializes them. This typically requires write access to a networked cache (for example a network-accessible Redis instance with weak/no auth or shared cache infrastructure reachable by other tenants/services) or write access to local cache storage (for example a writable SQLite cache file via permissive file permissions or a shared writable volume). Because exploitation requires write access to the cache storage layer, this is a post-compromise / post-access escalation vector. ## Remediation - Upgrade to `langgraph-checkpoint>=4.0.0`. ## Resources - ZDI-CAN-28385 - Patch: https://github.com/langchain-ai/langgraph/pull/6677 - Patch diff: https://patch-diff.githubusercontent.com/raw/langchain-ai/langgraph/pull/6677.patch - Credit: Peter Girnus (@gothburz), Demeng Chen, and Brandon Niemczyk (Trend Micro Zero Day Initiative)
Exploitation Scenario
An attacker targeting a multi-tenant AI platform discovers that a shared Redis instance backs LangGraph agent caching across multiple tenant workloads. Using weak or reused Redis credentials discovered through credential stuffing or lateral movement from a lower-privilege tenant, the attacker uses redis-cli to SET a cache key matching the LangGraph node cache namespace with a crafted pickle payload that spawns a reverse shell. When the LangGraph process executes the next graph run for that node, JsonPlusSerializer reads the ('pickle', <malicious_bytes>) tuple from Redis and calls pickle.loads() on attacker-controlled data — achieving RCE in the LangGraph process, full access to in-memory API keys, model configs, and inference data, and a foothold for lateral movement into connected infrastructure.
Weaknesses (CWE)
CVSS Vector
CVSS:3.1/AV:N/AC:H/PR:H/UI:N/S:U/C:H/I:H/A:H References
- github.com/advisories/GHSA-mhr3-j7m5-c7c9
- github.com/langchain-ai/langgraph/commit/f91d79d0c86932ded6e3b9f195d5a0bbd5aef99c
- github.com/langchain-ai/langgraph/pull/6677
- github.com/langchain-ai/langgraph/releases/tag/checkpoint%3D%3D4.0.0
- github.com/langchain-ai/langgraph/security/advisories/GHSA-mhr3-j7m5-c7c9
- nvd.nist.gov/vuln/detail/CVE-2026-27794