Initial State
During Session Setup the Agent MAY return a list of configuration options and their current values:The list of configuration options available for this session. The order of
this array represents the Agent’s preferred priority. Clients SHOULD
respect this ordering when displaying options.
ConfigOption
Unique identifier for this configuration option. Used when setting values.
Human-readable label for the option
Optional description providing more details about what this option controls
Optional semantic category to help Clients provide
consistent UX.
The type of input control. Currently only
select is supported.The currently selected value for this option
The available values for this option
ConfigOptionValue
The value identifier used when setting this option
Human-readable name to display
Optional description of what this value does
Option Categories
Each config option MAY include acategory field. Categories are semantic metadata intended to help Clients provide consistent UX, such as attaching keyboard shortcuts, choosing icons, or deciding placement.
Category names beginning with _ are free for custom use (e.g., _my_custom_category). Category names that do not begin with _ are reserved for the ACP spec.
| Category | Description |
|---|---|
mode | Session mode selector |
model | Model selector |
thought_level | Thought/reasoning level selector |
Option Ordering
The order of theconfigOptions array is significant. Agents SHOULD place higher-priority options first in the list.
Clients SHOULD:
- Display options in the order provided by the Agent
- Use ordering to resolve ties when multiple options share the same category
- If displaying a limited number of options, prefer those at the beginning of the list
Default Values and Graceful Degradation
Agents MUST always provide a default value for every configuration option. This ensures the Agent can operate correctly even if:- The Client doesn’t support configuration options
- The Client chooses not to display certain options
- The Client receives an option type it doesn’t recognize
type values can be custom or future variants. Custom option types MUST begin with _; unknown non-underscore option types are reserved for future ACP variants. If a Client receives an option with an unrecognized type, it SHOULD preserve the raw option when storing, replaying, proxying, or forwarding session state, and otherwise ignore that option. The Agent will continue using its default value.
Setting a Config Option
The current value of a config option can be changed at any point during a session, whether the Agent is idle or generating a response.From the Client
Clients can change a config option value by calling thesession/set_config_option method:
The ID of the session
The
id of the configuration option to changeThe new value to set. Must be one of the values listed in the option’s
options array.The response always contains the complete configuration state. This allows
Agents to reflect dependent changes. For example, if changing the model
affects available reasoning options, or if an option’s available values change
based on another selection.
From the Agent
The Agent can also change configuration options and notify the Client by sending aconfig_option_update session notification:
- Switching modes after completing a planning phase
- Falling back to a different model due to rate limits or errors
- Adjusting available options based on context discovered during execution