Communication Model
The protocol follows the JSON-RPC 2.0 specification with two types of messages:- Methods: Request-response pairs that expect a result or error
- Notifications: One-way messages that don’t expect a response
Message Flow
A typical flow follows this pattern:Initialization Phase
- Client → Agent:
initializeto establish connection - Client → Agent:
authenticateif required by the Agent
Session Setup - either:
- Client → Agent:
session/newto create a new session - Client → Agent:
session/loadto resume an existing session if supported
Prompt Turn
- Client → Agent:
session/promptto send user message - Agent → Client:
session/updatenotifications for progress updates - Agent → Client: File operations or permission requests as needed
- Client → Agent:
session/cancelto interrupt processing if needed - Turn ends and the Agent sends the
session/promptresponse with a stop reason
Agent
Agents are programs that use generative AI to autonomously modify code. They typically run as subprocesses of the Client.Baseline Methods
authenticate
Authenticate with the Agent (if required).
session/new
session/prompt
Send user prompts to the Agent.
Optional Methods
session/load
Load an existing session
(requires
session.load capability).logout
End the current authenticated state
(requires
capabilities.auth.logout capability).Notifications
session/cancel
Cancel ongoing operations (no
response expected).
Client
Clients provide the interface between users and agents. They are typically code editors (IDEs, text editors) but can also be other UIs for interacting with agents. Clients manage the environment, handle user interactions, and control access to resources.Baseline Methods
session/request_permission
Request user authorization
for tool calls.
Notifications
session/update
Send session updates to
inform the Client of changes (no response expected). This includes message
updates and chunks, tool calls, updates, and content
chunks, plans, available
commands updates, and
config option updates.
Argument requirements
- All file paths in the protocol MUST be absolute.
- Line numbers are 1-based
Error Handling
All methods follow standard JSON-RPC 2.0 error handling:- Successful responses include a
resultfield - Errors include an
errorobject withcodeandmessage - Notifications never receive responses (success or error)
Conventions
Unless explicitly defined otherwise in the schema, ACP-defined JSON object property keys usecamelCase. String values carried by discriminator fields use snake_case. The JSON-RPC envelope fields (jsonrpc, id, method, params, result, and error) follow the JSON-RPC 2.0 specification.
In v2, selected enum-like fields and tagged unions can define custom or future fallbacks. For those fields, _-prefixed values are reserved for implementation-specific extensions, while unknown non-underscore values are reserved for future ACP variants.
Extensibility
The protocol provides built-in mechanisms for adding custom functionality while maintaining compatibility:- Add custom data using
_metafields - Create custom methods by prefixing their name with underscore (
_) - Advertise custom capabilities during initialization
Next Steps
- Learn about Initialization to understand version and capability negotiation
- Understand Session Setup for creating and loading sessions
- Review the Prompt Turn lifecycle
- Explore Extensibility to add custom features