Guides architectural decisions for LangGraph applications. Use when deciding between LangGraph vs alternatives, choosing state management strategies, designi...
Best for remote or guided setup. Copy the exact prompt, then paste it into OpenClaw for anderskev/langgraph-architecture.
Previewing Install & Setup.
Prompt PreviewInstall & Setup
Install the skill "Langgraph Architecture" (anderskev/langgraph-architecture) from ClawHub.
Skill page: https://clawhub.ai/anderskev/langgraph-architecture
Keep the work scoped to this skill only.
After install, inspect the skill metadata and help me finish setup.
Use only the metadata you can verify from ClawHub; do not invent missing requirements.
Ask before making any broader environment changes.
Command Line
CLI Commands
Use the direct CLI path if you want to install manually and keep every step visible.
The skill's name and description match the SKILL.md content: architectural guidance for LangGraph (state, routing, persistence, multi-agent patterns). Nothing requested (no env vars, no binaries, no config paths) is disproportionate to that purpose.
✓
Instruction Scope
SKILL.md contains recommendations and example code snippets (Python types, reducers, checkpointer choices, streaming modes). The instructions do not direct the agent to read local files, access secrets, call external endpoints, or perform actions beyond giving guidance and sample code.
✓
Install Mechanism
No install spec and no code files — the skill is instruction-only, so nothing will be written to disk or fetched during install.
✓
Credentials
The skill declares no required environment variables, no primary credential, and no config paths. This is proportionate for a documentation/architecture guidance skill.
✓
Persistence & Privilege
always is false and there are no signs the skill modifies agent configs or requests persistent presence. The default ability for the agent to invoke the skill autonomously is normal and not a concern here given the skill's benign footprint.
Assessment
This skill appears to be pure guidance and low-risk: it asks for no credentials and installs nothing. You can safely use it for design advice, but treat the code examples as templates — review and test them before copying into production. Also prefer skills from known sources if you need long-term maintenance or security guarantees.
Like a lobster shell, security has layers — review code before you run it.
latestvk97ekgqm627wjwh13pr908amhd85b92f
179downloads
0stars
2versions
Updated 6d ago
v1.0.1
MIT-0
LangGraph Architecture Decisions
When to Use LangGraph
Use LangGraph When You Need:
Stateful conversations - Multi-turn interactions with memory
Recommendation: Use TypedDict for most cases. Use Pydantic when you need validation or complex nested structures.
Reducer Selection
Use Case
Reducer
Example
Chat messages
add_messages
Handles IDs, RemoveMessage
Simple append
operator.add
Annotated[list, operator.add]
Keep latest
None (LastValue)
field: str
Custom merge
Lambda
Annotated[list, lambda a, b: ...]
Overwrite list
Overwrite
Bypass reducer
State Size Considerations
# SMALL STATE (< 1MB) - Put in state
class State(TypedDict):
messages: Annotated[list, add_messages]
context: str
# LARGE DATA - Use Store
class State(TypedDict):
messages: Annotated[list, add_messages]
document_ref: str # Reference to store
def node(state, *, store: BaseStore):
doc = store.get(namespace, state["document_ref"])
# Process without bloating checkpoints
Graph Structure Decisions
Single Graph vs Subgraphs
Single Graph when:
All nodes share the same state schema
Simple linear or branching flow
< 10 nodes
Subgraphs when:
Different state schemas needed
Reusable components across graphs
Team separation of concerns
Complex hierarchical workflows
Conditional Edges vs Command
Conditional Edges
Command
Routing based on state
Routing + state update
Separate router function
Decision in node
Clearer visualization
More flexible
Standard patterns
Dynamic destinations
# Conditional Edge - when routing is the focus
def router(state) -> Literal["a", "b"]:
return "a" if condition else "b"
builder.add_conditional_edges("node", router)
# Command - when combining routing with updates
def node(state) -> Command:
return Command(goto="next", update={"step": state["step"] + 1})
# Stream from subgraphs
async for chunk in graph.astream(
input,
stream_mode="updates",
subgraphs=True # Include subgraph events
):
namespace, data = chunk # namespace indicates depth
Human-in-the-Loop Design
Interrupt Placement
Strategy
Use Case
interrupt_before
Approval before action
interrupt_after
Review after completion
interrupt() in node
Dynamic, contextual pauses
Resume Patterns
# Simple resume (same thread)
graph.invoke(None, config)
# Resume with value
graph.invoke(Command(resume="approved"), config)
# Resume specific interrupt
graph.invoke(Command(resume={interrupt_id: value}), config)
# Modify state and resume
graph.update_state(config, {"field": "new_value"})
graph.invoke(None, config)
Gates (sequenced)
Complete in order before treating a LangGraph design as locked in. Each step has an objective pass condition (artifact or explicit “none”), not an honor-system “we considered it.”
Alternatives — Pass: For the workload, either (a) at least one row from Consider Alternatives When was evaluated and rejected with a one-line reason, or (b) the use case clearly matches Use LangGraph When You Need and does not fit a “consider alternative” row.
State contract — Pass: Every state field has an assigned reducer (or default/LastValue) documented in the same place as the schema; large payloads are references or Store-backed, not inlined blobs (see State Size Considerations).
Checkpointer — Pass: The saver type is chosen for the target environment per Checkpointer Selection (e.g. production is not InMemorySaver unless explicitly test-only).
Loops and flaky nodes — Pass:recursion_limit (or equivalent) is set for any graph that can cycle; per-node RetryPolicy or a documented “no retries” choice exists for external calls (see Retry Configuration).