Skip to content

langchain-ai/agent-protocol

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Agent Protocol

Agent Protocol is our attempt at codifying the framework-agnostic APIs that are needed to serve LLM agents in production. This document explains the purpose of the protocol and makes the case for each of the endpoints in the spec. We finish by listing some roadmap items for the future.

See the full OpenAPI docs here and the JSON spec here.

LangGraph Platform implements a superset of this protocol, but we very much welcome other implementations from the community.

Why Agent Protocol

What is the right API to serve an LLM application in production? We believe it’s centered around 3 important concepts:

  • Runs: APIs for executing an agent
  • Threads: APIs to organize multi-turn executions of agents
  • Store: APIs to work with long-term memory

Let’s dive deeper into each one, starting with the requirements, and then presenting the Protocol endpoints that meet these requirements.

Runs: Atomic agent executions

What do we need out of an API to execute an agent?

  • Support the two paradigms for launching a run
    • Fire and forget, ie. launch a run in the background, but don’t wait for it to finish
    • Waiting on a reply (blocking or polling), ie. launch a run and wait/stream its output
  • Support CRUD for agent executions
    • List and get runs
    • Cancel and delete runs
  • Flexible ways to consume output
    • Get the final state
    • Multiple types of streaming output, eg. token-by-token, intermediate steps, etc.
    • Able to reconnect to output stream if disconnected
  • Handling edge cases
    • Failures should be handled gracefully, and retried if desired
    • Bursty traffic should be queued up

Base Endpoints:

Convenience Endpoints:

Threads: multi-turn interactions

What APIs do you need to enable multi-turn interactions?

  • Persistent state
    • Get and update state
    • Track history of past states of a thread, modelled as an append-only log of states
    • Optimize storage by storing only diffs between states
  • Concurrency controls
    • Ensure that only one run per thread is active at a time
    • Customizable handling of concurrent runs (interrupt, enqueue, interrupt or rollback)
  • CRUD endpoints for threads
    • List threads by user, or other metadata
    • List threads by status (idle, interrupted, errored, finished)
    • Copy or delete threads

Endpoints:

Store: Long-term memory

What do you need out of a memory API for agents?

  • Customizable memory scopes
    • Storing memory against the user, thread, assistant, company, etc
    • Accessing memory from different scopes in the same run
  • Flexible storage
    • Support simple text memories, as well as structured data
    • CRUD operations for memories (create, read, update, delete)
  • Search and retrieval
    • Get a single memory by namespace and key
    • List memories filtered by namespace, contents, sorted by time, etc

Endpoints:

Roadmap

  • Add Store endpoint to perform a vector search over memory entries
  • Add param for POST /threads/{thread_id}/runs/{run_id}/stream to replay events since event-id before streaming new events
  • Add param to POST /threads/{thread_id}/runs  to optionally allow concurrent runs on the same thread (current spec makes this forbidden)
  • (Open an issue and let us know what else should be here!)