session/update notifications, providing real-time visibility into their thinking and progress.
plan_update is the v2 plan format. It carries a plan object with a type discriminator and a required id so Clients can track multiple plans independently.
The stable v2 plan content type is items. Additional plan operations remain unstable while the Plan Operations RFD is in progress.
Creating Plans
When the language model creates an execution plan, the Agent SHOULD report it to the Client withplan_update.
Item-Based Plans
The plan content type.
A unique identifier for this plan within the session.
An array of plan entries representing the tasks to be
accomplished.
Extensibility
plan.type values can be custom or future variants when Clients can preserve or display them generically. Custom plan content types MUST begin with _; unknown non-underscore plan content types are reserved for future ACP variants.
Every plan content variant, including custom or future variants, MUST carry an id.
Plan Entries
Each plan entry represents a specific task or goal within the overall execution strategy:A human-readable description of what this task aims to accomplish
The relative importance of this task.
highmediumlow
_; unknown non-underscore priorities are reserved for future ACP variants.The current execution status of this task
pendingin_progresscompleted
_; unknown non-underscore statuses are reserved for future ACP variants.Updating Plans
As the Agent progresses through the plan, it SHOULD report updates by sending moresession/update notifications with the same sessionUpdate: "plan_update" structure and plan id.
For item-based plans, the Agent MUST send a complete list of all plan entries in each update and their current status. The Client MUST replace the current contents of that plan completely.