StateWeave
Cross-framework cognitive state serializer for AI agents. Export, import, and diff agent state across 10 frameworks.
README
<p align="center"> <h1 align="center">๐งถ StateWeave</h1> <p align="center"><strong><code>git</code> for agent brains.</strong></p> <p align="center"><em>Your agent switches frameworks. Its memories come with it.</em></p> <p align="center"> <a href="https://pypi.org/project/stateweave/"><img src="https://img.shields.io/pypi/v/stateweave?color=%2334D058&label=PyPI" alt="PyPI"></a> <a href="https://github.com/GDWN-BLDR/stateweave/actions"><img src="https://img.shields.io/github/actions/workflow/status/GDWN-BLDR/stateweave/ci.yml?label=CI" alt="CI"></a> <a href="https://github.com/GDWN-BLDR/stateweave/blob/main/LICENSE"><img src="https://img.shields.io/badge/License-Apache%202.0-blue.svg" alt="License"></a> <a href="https://www.python.org/downloads/"><img src="https://img.shields.io/pypi/pyversions/stateweave" alt="Python"></a> </p> </p>
<!-- mcp-name: stateweave -->
StateWeave moves, debugs, and secures AI agent state across 10 frameworks. Export from LangGraph, import into MCP, checkpoint, rollback, diff, encrypt, sign โ all through a single Universal Schema.
When your agent needs to switch frameworks, its memories come with it. When a 20-step autonomous workflow derails at step 15, rewind to step 14, fix the issue, and replay. When your enterprise needs to audit agent behavior, every state transition is versioned, signed, and encrypted.
Why StateWeave?
StateWeave solves three critical problems in the AI agent ecosystem:
๐ Debugging โ Agent workflows are non-deterministic. When they go wrong, you need to pause, rewind, inspect, and replay โ not restart. StateWeave gives you git-like version control for agent cognitive state.
๐ Security โ Agent state contains the agent's entire cognitive history. StateWeave encrypts at rest (AES-256-GCM), signs payloads (Ed25519), strips credentials on export, and enforces compliance policies.
๐ Portability โ Every framework has persistence, none have portability. StateWeave's Universal Schema โ a canonical representation of agent cognitive state โ lets you move state between any of 10 frameworks. One schema, N adapters, zero data loss (with explicit warnings for anything non-portable).
โโโโโโโโโโโโโโโ โโโโโโโโโโโโโโโ โโโโโโโโโโโโโโโ โโโโโโโโโโโโโโโ
โ LangGraph โ โ MCP โ โ CrewAI โ โ AutoGen โ
โ Adapter โ โ Adapter โ โ Adapter โ โ Adapter โ
โโโโโโโโฌโโโโโโโ โโโโโโโโฌโโโโโโโ โโโโโโโโฌโโโโโโโ โโโโโโโโฌโโโโโโโ
โ โ โ โ
โโโโโโโโโโโโโฌโโโโโโโโดโโโโโโโโโโโโฌโโโโโโโโ โ
โ โ โ
โผ โผ โผ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ ๐งถ Universal Schema v1 โ
โ โ
โ conversation_history ยท working_memory ยท goal_tree โ
โ tool_results_cache ยท trust_parameters ยท audit_trail โ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
Star topology, not mesh. N adapters, not Nยฒ translation pairs. Adding a new framework = one adapter, instant compatibility with everything else.
See it working
$ pip install stateweave
$ python examples/quickstart.py
Exported: 2 messages
Framework: langgraph
Imported into MCP โ
MCP has: 2 messages
Diff: 15 changes (framework tag + timestamps)
Done! The agent's memories migrated successfully. ๐งถ
See the full Cloud-to-Local Sandbox Escape demo for a more advanced scenario.
Quick Start
Install
pip install stateweave
Use with Claude Desktop / Cursor
Add to your MCP config (~/.cursor/mcp.json or Claude Desktop settings):
{
"mcpServers": {
"stateweave": {
"command": "python3",
"args": ["-m", "stateweave.mcp_server"]
}
}
}
Claude and Cursor can now export, import, and diff your agent state directly.
Export an Agent's State
from stateweave import LangGraphAdapter, MCPAdapter, diff_payloads
# Set up a LangGraph agent with some state
lg = LangGraphAdapter()
lg._agents["my-agent"] = {
"messages": [
{"type": "human", "content": "What's the weather?"},
{"type": "ai", "content": "It's 72ยฐF and sunny!"},
],
"current_task": "weather_check",
}
# Export from LangGraph
payload = lg.export_state("my-agent")
print(f"Exported: {len(payload.cognitive_state.conversation_history)} messages")
Import into Another Framework
from stateweave import MCPAdapter
# Import into MCP
mcp_adapter = MCPAdapter()
mcp_adapter.import_state(payload)
# The agent resumes with its memories intact
Auto-Checkpoint Middleware
from stateweave.middleware import auto_checkpoint
# Simple: checkpoint every 5 steps
@auto_checkpoint(every_n_steps=5)
def run_agent(payload):
return payload
# Smart: only checkpoint on significant state changes
@auto_checkpoint(strategy="on_significant_delta", delta_threshold=3)
def smart_agent(payload):
return payload
# Manual: zero overhead, checkpoint when you decide
@auto_checkpoint(strategy="manual_only")
def hot_path_agent(payload):
return payload
Migrate with Encryption
from stateweave import EncryptionFacade, MigrationEngine
# Set up encrypted migration
key = EncryptionFacade.generate_key()
engine = MigrationEngine(
encryption=EncryptionFacade(key)
)
# Full pipeline: export โ validate โ encrypt โ transport
result = engine.export_state(
adapter=langgraph_adapter,
agent_id="my-agent",
encrypt=True,
)
# Decrypt โ validate โ import on the other side
engine.import_state(
adapter=mcp_adapter,
encrypted_data=result.encrypted_data,
nonce=result.nonce,
)
Diff Two States
from stateweave import diff_payloads
diff = diff_payloads(state_before, state_after)
print(diff.to_report())
# โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
# ๐ STATEWEAVE DIFF REPORT
# โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
# Changes: 5 (+2 -1 ~2)
# [working_memory]
# + working_memory.new_task: 'research'
# ~ working_memory.confidence: 0.7 โ 0.95
Framework Support
| Framework | Adapter | Export | Import | Tier |
|---|---|---|---|---|
| LangGraph | LangGraphAdapter |
โ | โ | ๐ข Tier 1 |
| MCP | MCPAdapter |
โ | โ | ๐ข Tier 1 |
| CrewAI | CrewAIAdapter |
โ | โ | ๐ข Tier 1 |
| AutoGen | AutoGenAdapter |
โ | โ | ๐ข Tier 1 |
| DSPy | DSPyAdapter |
โ | โ | ๐ก Tier 2 |
| OpenAI Agents | OpenAIAgentsAdapter |
โ | โ | ๐ก Tier 2 |
| LlamaIndex | LlamaIndexAdapter |
โ | โ | ๐ต Community |
| Haystack | HaystackAdapter |
โ | โ | ๐ต Community |
| Letta / MemGPT | LettaAdapter |
โ | โ | ๐ต Community |
| Semantic Kernel | SemanticKernelAdapter |
โ | โ | ๐ต Community |
| Custom | Extend StateWeaveAdapter |
โ | โ | DIY |
Tier definitions: ๐ข Tier 1 = Core team maintained, guaranteed stability. ๐ก Tier 2 = Actively maintained, patches may lag. ๐ต Community = Best-effort, contributed by community.
MCP Server
StateWeave ships as an MCP Server โ any MCP-compatible AI assistant can use it directly.
Tools
| Tool | Description |
|---|---|
export_agent_state |
Export an agent's cognitive state from any supported framework |
import_agent_state |
Import state into a target framework with validation |
diff_agent_states |
Compare two states and return a detailed change report |
Resources
| Resource | URI |
|---|---|
| Universal Schema spec | stateweave://schemas/v1 |
| Migration history log | stateweave://migrations/history |
| Live agent snapshot | stateweave://agents/{id}/snapshot |
Prompts
| Prompt | Use Case |
|---|---|
backup_before_risky_operation |
Agent self-requests state backup before risky ops |
migration_guide |
Step-by-step framework migration template |
The Universal Schema
Every agent's state is represented as a StateWeavePayload:
StateWeavePayload(
stateweave_version="0.3.0",
source_framework="langgraph",
exported_at=datetime,
cognitive_state=CognitiveState(
conversation_history=[...], # Full message history
working_memory={...}, # Current task state
goal_tree={...}, # Active goals
tool_results_cache={...}, # Cached tool outputs
trust_parameters={...}, # Confidence scores
long_term_memory={...}, # Persistent knowledge
episodic_memory=[...], # Past experiences
),
metadata=AgentMetadata(
agent_id="my-agent",
access_policy="private",
),
audit_trail=[...], # Full operation history
non_portable_warnings=[...], # Explicit data loss docs
)
Security
- AES-256-GCM authenticated encryption with unique nonce per operation
- PBKDF2 key derivation (600K iterations, OWASP recommended)
- Ed25519 payload signing โ digital signatures verify sender identity and detect tampering
- Credential stripping โ API keys, tokens, and passwords are flagged as non-portable and stripped during export
- Non-portable warnings โ every piece of state that can't fully transfer is explicitly documented (no silent data loss)
- Associated data โ encrypt with AAD to bind ciphertext to specific agent metadata
Payload Signing
from stateweave import EncryptionFacade
# Generate a signing key pair
private_key, public_key = EncryptionFacade.generate_signing_keypair()
# Sign serialized payload
signature = EncryptionFacade.sign(payload_bytes, private_key)
# Verify on receipt
is_authentic = EncryptionFacade.verify(payload_bytes, signature, public_key)
Delta State Transport
For large state payloads, send only the changes:
from stateweave.core.delta import create_delta, apply_delta
# Create delta: only the differences
delta = create_delta(old_payload, new_payload)
# Apply delta on the receiver side
updated = apply_delta(base_payload, delta)
Agent Time Travel
Version, checkpoint, rollback, and branch agent cognitive state:
from stateweave.core.timetravel import CheckpointStore
store = CheckpointStore()
# Save a checkpoint
store.checkpoint(payload, label="before-experiment")
# View history
print(store.format_history("my-agent"))
# Roll back to a previous version
restored = store.rollback("my-agent", version=3)
# Branch from a checkpoint
store.branch("my-agent", version=3, new_agent_id="my-agent-experiment")
# Diff two versions
diff = store.diff_versions("my-agent", version_a=1, version_b=5)
print(diff.to_report())
Content-addressable storage (SHA-256), parent hash chains, delta compression between versions.
A2A Bridge
Bridge between the Agent2Agent (A2A) protocol and StateWeave. A2A defines how agents communicate โ StateWeave adds what agents know:
from stateweave.a2a import A2ABridge
bridge = A2ABridge()
# Package state for A2A handoff
artifact = bridge.create_transfer_artifact(payload)
# Extract state from received A2A message
extracted = bridge.extract_payload(a2a_message_parts)
# Generate AgentCard skill for capability advertisement
caps = bridge.get_agent_capabilities()
skill = caps.to_agent_card_skill()
State Merge (CRDT Foundation)
Merge state from parallel agents:
from stateweave.core.merge import merge_payloads, ConflictResolutionPolicy
result = merge_payloads(
agent_a_state, agent_b_state,
policy=ConflictResolutionPolicy.LAST_WRITER_WINS,
)
merged_payload = result.payload
Non-Portable State
Not everything can transfer between frameworks. StateWeave handles this honestly:
| Category | Example | Behavior |
|---|---|---|
| DB connections | sqlite3.Cursor |
โ ๏ธ Stripped, warning emitted |
| Credentials | api_key, oauth_token |
๐ด Stripped, CRITICAL warning |
| Framework internals | LangGraph __channel_versions__ |
โ ๏ธ Stripped, warning emitted |
| Thread/async state | threading.Lock, asyncio.Task |
โ ๏ธ Stripped, warning emitted |
| Live connections | Network sockets, file handles | โ ๏ธ Stripped, warning emitted |
All non-portable elements appear in payload.non_portable_warnings[] with severity, reason, and remediation guidance.
Zero-Loss Translations
Framework-specific state that doesn't map to universal fields is not silently dropped โ it's preserved in cognitive_state.framework_specific:
# LangGraph internals survive the round-trip
payload = lg_adapter.export_state("my-thread")
print(payload.cognitive_state.framework_specific)
# {"__channel_versions__": {"messages": 5}, "checkpoint_id": "ckpt-abc"}
# Import back into LangGraph โ internal state is restored
target = LangGraphAdapter()
target.import_state(payload)
Three layers of state handling:
| Layer | Storage | Round-Trip |
|---|---|---|
| Universal | conversation_history, working_memory, etc. |
โ Fully portable |
| Framework-specific | framework_specific dict |
โ Preserved in same-framework |
| Non-portable | non_portable_warnings |
โ ๏ธ Stripped with warnings |
Building a Custom Adapter
Extend StateWeaveAdapter to add support for any framework:
from stateweave.adapters.base import StateWeaveAdapter
from stateweave.schema.v1 import StateWeavePayload, AgentInfo
class MyFrameworkAdapter(StateWeaveAdapter):
@property
def framework_name(self) -> str:
return "my-framework"
def export_state(self, agent_id: str, **kwargs) -> StateWeavePayload:
# Translate your framework's state โ Universal Schema
...
def import_state(self, payload: StateWeavePayload, **kwargs):
# Translate Universal Schema โ your framework's state
...
def list_agents(self) -> list[AgentInfo]:
# Return available agents
...
The UCE adapter_contract scanner automatically validates that all adapters correctly implement the ABC.
CLI
# Show version and available adapters
stateweave version
# Dump the Universal Schema as JSON Schema
stateweave schema -o schema.json
# Validate a payload file
stateweave validate state.json
# Export/import/diff
stateweave export -f langgraph -a my-agent -o state.json
stateweave import -f mcp --payload state.json
stateweave diff before.json after.json
# Auto-detect source framework
stateweave detect state.json
# Scan environment for installed frameworks
stateweave scan
# Time travel โ checkpoint, history, rollback
stateweave checkpoint state.json --label "before-experiment"
stateweave history my-agent
stateweave rollback my-agent 3 -o restored.json
# Run diagnostic health checks
stateweave doctor
# List all available adapters
stateweave adapters
# Scaffold a new adapter
stateweave generate-adapter my-framework --output-dir ./adapters
Compliance (UCE)
StateWeave enforces its own architectural standards via the Universal Compliance Engine โ 10 automated scanners that run on every commit:
| Scanner | What It Checks | Mode |
|---|---|---|
schema_integrity |
Universal Schema models have required fields | BLOCK |
adapter_contract |
All adapters implement the full ABC | BLOCK |
serialization_safety |
No raw pickle/json.dumps outside serializer | BLOCK |
encryption_compliance |
All crypto goes through EncryptionFacade | BLOCK |
mcp_protocol |
MCP server has all required tools | BLOCK |
import_discipline |
No cross-layer imports | BLOCK |
logger_naming |
All loggers use stateweave.* convention |
BLOCK |
test_coverage_gate |
Minimum test file coverage ratio | BLOCK |
file_architecture |
No orphan files outside MANIFEST | WARN |
dependency_cycles |
No circular imports | BLOCK |
# Run UCE locally
python scripts/uce.py
# Run in CI mode (exit 1 on failure)
python scripts/uce.py --mode=CI --json
Why Not Just Serialize to JSON Yourself?
You could โ and it'll work for one framework. Here's what you'd have to build:
| Problem | DIY JSON | StateWeave |
|---|---|---|
Map LangGraph's messages[] to CrewAI's task_output |
Write it yourself for each pair | Handled by adapters |
| Detect credentials in state (API keys, OAuth tokens) | Easy to miss โ leaked secrets | Auto-stripped with warnings |
| Validate state structure after migration | Write your own schema checks | Pydantic models + UCE scanners |
| Track what was lost during migration | Hope you remember | non_portable_warnings[] |
| Encrypt state for transport | DIY crypto (dangerous) | AES-256-GCM + Ed25519 |
| Roll back if migration goes wrong | No undo | CheckpointStore.rollback() |
| Support 10 frameworks | 90 translation pairs (Nยฒ) | 10 adapters (N) |
StateWeave exists because the translation layer between frameworks is boring, error-prone work that every team rebuilds. We built it once.
Contributing
We welcome contributions! The highest-impact way to contribute is building a new framework adapter. See Building a Custom Adapter above.
Development Setup
git clone https://github.com/GDWN-BLDR/stateweave.git
cd stateweave
pip install -e ".[dev]"
# Run tests
pytest tests/ -v
# Run UCE
python scripts/uce.py
Architecture
stateweave/
โโโ schema/ # Universal Schema (Pydantic models)
โโโ core/ # Engine (serializer, encryption, diff, delta, timetravel, environment, doctor)
โโโ adapters/ # Framework adapters (10 frameworks)
โโโ a2a/ # A2A protocol bridge
โโโ middleware/ # Auto-checkpoint middleware
โโโ playground/ # Interactive playground (REST API + UI)
โโโ registry/ # Schema registry (publish, search, discover)
โโโ templates/ # Project scaffolding (create-stateweave-agent)
โโโ mcp_server/ # MCP Server implementation
โโโ compliance/ # UCE scanners
Additional Tools
| Tool | Description |
|---|---|
| VS Code Extension | Payload preview, diff, doctor, adapter scaffold โ vscode-extension/ |
| TypeScript SDK | Universal Schema types, serializer, diff โ sdk/typescript/ |
| GitHub Action | CI validation + PR diffs โ action.yml |
Using StateWeave?
Add the badge to your project's README:
[](https://github.com/GDWN-BLDR/stateweave)
What StateWeave Replaces
Without StateWeave, migrating agent state between frameworks means:
| Task | DIY | StateWeave |
|---|---|---|
| Serialize state between frameworks | Write custom code per pair (Nยฒ effort) | adapter.export_state() / import_state() |
| Strip credentials before export | Manual โ easy to miss, leaks secrets | Auto-stripped with warnings |
| Roll back if migration fails | No undo โ restart from scratch | checkpoint_store.rollback() |
| Track what was lost in translation | Hope you remember | non_portable_warnings[] |
| Encrypt state for transit | DIY crypto (dangerous) | AES-256-GCM + Ed25519 built-in |
| Audit what the agent did | Build your own logging | Versioned, signed audit trail |
License
Apache 2.0 โ use it, modify it, ship it. Patent shield included.
<p align="center"> <strong>๐งถ StateWeave</strong> โ <code>git</code> for agent brains. </p>
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.