Skip to content
Get started

Agents

Manage AI agents within a workspace. Agents define AI behavior and tool access.

List agents
agents.list(workspace_id, **kwargs) -> CursorPagination<Agent { metadata, spec, info } >
GET/v1/workspaces/{workspaceId}/agents
Create a new agent
agents.create(workspace_id, **kwargs) -> Agent { metadata, spec, info }
POST/v1/workspaces/{workspaceId}/agents
Get an agent by ID
agents.retrieve(id, **kwargs) -> Agent { metadata, spec, info }
GET/v1/workspaces/{workspaceId}/agents/{id}
Delete an agent
agents.delete(id, **kwargs) -> void
DELETE/v1/workspaces/{workspaceId}/agents/{id}
Update an agent
agents.update(id, **kwargs) -> Agent { metadata, spec, info }
PATCH/v1/workspaces/{workspaceId}/agents/{id}
ModelsExpand Collapse
class Agent { metadata, spec, info }

Agent resource

metadata: ResourceMetadata { id, account_id, created_at, 6 more }

Standard metadata for persistent, named resources (e.g., agents, tools, prompts)

id: String

Unique identifier for the resource (prefixed ULID, e.g., “agent_01HXK…”)

account_id: String

Account this resource belongs to for multi-tenant isolation (prefixed ULID)

created_at: Time

Timestamp when this resource was created

formatdate-time
name: String

Human-readable name for the resource (e.g., “Customer Support Agent”, “Email Tool”) Required for resources that users interact with directly

profile_id: String

ID of the actor (user or service account) that created this resource

workspace_id: String

Workspace this resource belongs to for organizational grouping (prefixed ULID)

bundle_key: String

Optional bundle ownership key. When set, indicates the resource is managed by a configuration bundle identified by this key. Used by BulkWorkspaceResources.Apply to track which resources belong to which bundle for reconciliation / soft-delete on re-apply.

external_id: String

External ID for the resource (e.g., a workflow ID from an external system)

labels: Hash[Symbol, String]

Arbitrary key-value pairs for categorization and filtering Examples: {“environment”: “production”, “team”: “platform”, “version”: “v2”}

spec: AgentSpec { status, variation_selection_mode, description, 3 more }

Agent specification (user-provided configuration)

status: :AGENT_STATUS_UNSPECIFIED | :AGENT_STATUS_DRAFT | :AGENT_STATUS_PUBLISHED | :AGENT_STATUS_ARCHIVED

Status of the agent

formatenum
One of the following:
:AGENT_STATUS_UNSPECIFIED
:AGENT_STATUS_DRAFT
:AGENT_STATUS_PUBLISHED
:AGENT_STATUS_ARCHIVED
variation_selection_mode: :VARIATION_SELECTION_MODE_UNSPECIFIED | :VARIATION_SELECTION_MODE_RANDOM | :VARIATION_SELECTION_MODE_WEIGHTED

Controls how variations are automatically selected when creating objectives Defaults to RANDOM when unspecified

formatenum
One of the following:
:VARIATION_SELECTION_MODE_UNSPECIFIED
:VARIATION_SELECTION_MODE_RANDOM
:VARIATION_SELECTION_MODE_WEIGHTED
description: String

Description of the agent’s purpose

input_data_schema: Hash[Symbol, untyped]

InputDataSchema is used for enforcing a data input when objectives are created. This is valuable when using liquid formatting in agent variation prompts. Input data schema is also valuable when using an agent as a sub-agent, as the schema is used as the tool’s input parameter schema. If omitted, the sub-agent schema will be loaded with a simple “prompt” free text string as its schema.

output_definition: Hash[Symbol, untyped]

Optional output definition for objectives created for this agent. When provided, Cadenya will append a tool to that will be called by the LLM in use by the variant to extract information in the format provided here. Use this option when you want structured data to be created by your objectives.

webhook_events_url: String

The URL that Cadenya will send events for any objective assigned to the agent.

info: AgentInfo { created_by, variation_count }

AgentInfo contains simple information about an agent for display or quick reference

created_by: Profile { metadata, spec }

A profile identifies a user or non-human principal (such as an API key) at the account level. Profiles are account-scoped and can be granted access to multiple workspaces.

metadata: AccountResourceMetadata { id, account_id, name, 3 more }

AccountResourceMetadata is used to represent a resource that is associated to an account but not to a workspace.

id: String

Unique identifier for the resource (prefixed ULID, e.g., “apikey_01HXK…”)

account_id: String

Account this resource belongs to for multi-tenant isolation (prefixed ULID)

name: String

Human-readable name for the resource (e.g., “Customer Support Agent”, “Email Tool”) Required for resources that users interact with directly

profile_id: String
external_id: String

External ID for the resource (e.g., a workflow ID from an external system)

labels: Hash[Symbol, String]

Arbitrary key-value pairs for categorization and filtering Examples: {“environment”: “production”, “team”: “platform”, “version”: “v2”}

spec: ProfileSpec { type, email, name }

Configuration for a profile.

type: :PROFILE_TYPE_UNSPECIFIED | :PROFILE_TYPE_USER | :PROFILE_TYPE_API_KEY | :PROFILE_TYPE_SYSTEM

Whether this profile represents a human user, an API key, or a system principal.

formatenum
One of the following:
:PROFILE_TYPE_UNSPECIFIED
:PROFILE_TYPE_USER
:PROFILE_TYPE_API_KEY
:PROFILE_TYPE_SYSTEM
email: String

Email address of the profile. Required and unique within an account for user profiles.

name: String

Display name (e.g., “Bobby Tables”).

variation_count: Integer
class AgentInfo { created_by, variation_count }

AgentInfo contains simple information about an agent for display or quick reference

created_by: Profile { metadata, spec }

A profile identifies a user or non-human principal (such as an API key) at the account level. Profiles are account-scoped and can be granted access to multiple workspaces.

metadata: AccountResourceMetadata { id, account_id, name, 3 more }

AccountResourceMetadata is used to represent a resource that is associated to an account but not to a workspace.

id: String

Unique identifier for the resource (prefixed ULID, e.g., “apikey_01HXK…”)

account_id: String

Account this resource belongs to for multi-tenant isolation (prefixed ULID)

name: String

Human-readable name for the resource (e.g., “Customer Support Agent”, “Email Tool”) Required for resources that users interact with directly

profile_id: String
external_id: String

External ID for the resource (e.g., a workflow ID from an external system)

labels: Hash[Symbol, String]

Arbitrary key-value pairs for categorization and filtering Examples: {“environment”: “production”, “team”: “platform”, “version”: “v2”}

spec: ProfileSpec { type, email, name }

Configuration for a profile.

type: :PROFILE_TYPE_UNSPECIFIED | :PROFILE_TYPE_USER | :PROFILE_TYPE_API_KEY | :PROFILE_TYPE_SYSTEM

Whether this profile represents a human user, an API key, or a system principal.

formatenum
One of the following:
:PROFILE_TYPE_UNSPECIFIED
:PROFILE_TYPE_USER
:PROFILE_TYPE_API_KEY
:PROFILE_TYPE_SYSTEM
email: String

Email address of the profile. Required and unique within an account for user profiles.

name: String

Display name (e.g., “Bobby Tables”).

variation_count: Integer
class AgentSpec { status, variation_selection_mode, description, 3 more }

Agent specification (user-provided configuration)

status: :AGENT_STATUS_UNSPECIFIED | :AGENT_STATUS_DRAFT | :AGENT_STATUS_PUBLISHED | :AGENT_STATUS_ARCHIVED

Status of the agent

formatenum
One of the following:
:AGENT_STATUS_UNSPECIFIED
:AGENT_STATUS_DRAFT
:AGENT_STATUS_PUBLISHED
:AGENT_STATUS_ARCHIVED
variation_selection_mode: :VARIATION_SELECTION_MODE_UNSPECIFIED | :VARIATION_SELECTION_MODE_RANDOM | :VARIATION_SELECTION_MODE_WEIGHTED

Controls how variations are automatically selected when creating objectives Defaults to RANDOM when unspecified

formatenum
One of the following:
:VARIATION_SELECTION_MODE_UNSPECIFIED
:VARIATION_SELECTION_MODE_RANDOM
:VARIATION_SELECTION_MODE_WEIGHTED
description: String

Description of the agent’s purpose

input_data_schema: Hash[Symbol, untyped]

InputDataSchema is used for enforcing a data input when objectives are created. This is valuable when using liquid formatting in agent variation prompts. Input data schema is also valuable when using an agent as a sub-agent, as the schema is used as the tool’s input parameter schema. If omitted, the sub-agent schema will be loaded with a simple “prompt” free text string as its schema.

output_definition: Hash[Symbol, untyped]

Optional output definition for objectives created for this agent. When provided, Cadenya will append a tool to that will be called by the LLM in use by the variant to extract information in the format provided here. Use this option when you want structured data to be created by your objectives.

webhook_events_url: String

The URL that Cadenya will send events for any objective assigned to the agent.

class Page { next_cursor, total }
next_cursor: String
total: Integer

AgentsFeedback

Manage AI agents within a workspace. Agents define AI behavior and tool access.

List feedback for an agent
agents.feedback.list(agent_id, **kwargs) -> CursorPagination<ObjectiveFeedback { data, metadata, info } >
GET/v1/workspaces/{workspaceId}/agents/{agentId}/feedback

AgentsWebhook Deliveries

Manage AI agents within a workspace. Agents define AI behavior and tool access.

List webhook deliveries
agents.webhook_deliveries.list(agent_id, **kwargs) -> CursorPagination<WebhookDelivery { data, metadata } >
GET/v1/workspaces/{workspaceId}/agents/{agentId}/webhook_deliveries
ModelsExpand Collapse
class WebhookDelivery { data, metadata }
data: WebhookDeliveryData { agent_id, attempt_count, event_type, 11 more }

Webhook delivery details.

agent_id: String

Related resources

attempt_count: Integer
event_type: :OBJECTIVE_EVENT_TYPE_UNSPECIFIED | :OBJECTIVE_EVENT_TYPE_USER_MESSAGE | :OBJECTIVE_EVENT_TYPE_TOOL_APPROVAL_REQUESTED | 13 more

The type of objective event that triggered this webhook delivery

formatenum
One of the following:
:OBJECTIVE_EVENT_TYPE_UNSPECIFIED
:OBJECTIVE_EVENT_TYPE_USER_MESSAGE
:OBJECTIVE_EVENT_TYPE_TOOL_APPROVAL_REQUESTED
:OBJECTIVE_EVENT_TYPE_TOOL_APPROVED
:OBJECTIVE_EVENT_TYPE_TOOL_DENIED
:OBJECTIVE_EVENT_TYPE_TOOL_CALLED
:OBJECTIVE_EVENT_TYPE_ERROR
:OBJECTIVE_EVENT_TYPE_ASSISTANT_MESSAGE
:OBJECTIVE_EVENT_TYPE_TOOL_RESULT
:OBJECTIVE_EVENT_TYPE_TOOL_ERROR
:OBJECTIVE_EVENT_TYPE_CONTEXT_WINDOW_COMPACTED
:OBJECTIVE_EVENT_TYPE_MEMORY_READ
:OBJECTIVE_EVENT_TYPE_CANCELLED
:OBJECTIVE_EVENT_TYPE_SUB_AGENT_SPAWNED
:OBJECTIVE_EVENT_TYPE_SUB_AGENT_UPDATED
:OBJECTIVE_EVENT_TYPE_FINALIZED
http_status_code: Integer

Response details. The response body is not retained.

formatint32
last_attempt_at: Time
latency_ms: Integer
objective_event_id: String
objective_id: String
response_content_length: String

Content length of the response body in bytes

status: :WEBHOOK_DELIVERY_STATUS_UNSPECIFIED | :WEBHOOK_DELIVERY_STATUS_PENDING | :WEBHOOK_DELIVERY_STATUS_COMPLETED | 2 more
formatenum
One of the following:
:WEBHOOK_DELIVERY_STATUS_UNSPECIFIED
:WEBHOOK_DELIVERY_STATUS_PENDING
:WEBHOOK_DELIVERY_STATUS_COMPLETED
:WEBHOOK_DELIVERY_STATUS_FAILED
:WEBHOOK_DELIVERY_STATUS_DISABLED
webhook_id: String
webhook_url: String

Webhook delivery details

error_message: String
response_headers: Hash[Symbol, String]

Response headers received from the webhook endpoint

metadata: OperationMetadata { id, account_id, created_at, 4 more }

Metadata for ephemeral operations and activities (e.g., objectives, executions, runs)

id: String

Unique identifier for the operation (prefixed ULID, e.g., “obj_01HXK…”)

account_id: String

Account this operation belongs to for multi-tenant isolation (prefixed ULID)

created_at: Time

Timestamp when this operation was created ULID includes timestamp information, but this explicit field enables easier querying

formatdate-time
profile_id: String

ID of the actor (user or service account) that created this operation

workspace_id: String

Workspace this operation belongs to for organizational grouping (prefixed ULID)

external_id: String

External ID for the operation (e.g., a workflow ID from an external system)

labels: Hash[Symbol, String]

Arbitrary key-value pairs for categorization and filtering Examples: {“priority”: “high”, “source”: “api”, “workflow”: “onboarding”}

class WebhookDeliveryData { agent_id, attempt_count, event_type, 11 more }
agent_id: String

Related resources

attempt_count: Integer
event_type: :OBJECTIVE_EVENT_TYPE_UNSPECIFIED | :OBJECTIVE_EVENT_TYPE_USER_MESSAGE | :OBJECTIVE_EVENT_TYPE_TOOL_APPROVAL_REQUESTED | 13 more

The type of objective event that triggered this webhook delivery

formatenum
One of the following:
:OBJECTIVE_EVENT_TYPE_UNSPECIFIED
:OBJECTIVE_EVENT_TYPE_USER_MESSAGE
:OBJECTIVE_EVENT_TYPE_TOOL_APPROVAL_REQUESTED
:OBJECTIVE_EVENT_TYPE_TOOL_APPROVED
:OBJECTIVE_EVENT_TYPE_TOOL_DENIED
:OBJECTIVE_EVENT_TYPE_TOOL_CALLED
:OBJECTIVE_EVENT_TYPE_ERROR
:OBJECTIVE_EVENT_TYPE_ASSISTANT_MESSAGE
:OBJECTIVE_EVENT_TYPE_TOOL_RESULT
:OBJECTIVE_EVENT_TYPE_TOOL_ERROR
:OBJECTIVE_EVENT_TYPE_CONTEXT_WINDOW_COMPACTED
:OBJECTIVE_EVENT_TYPE_MEMORY_READ
:OBJECTIVE_EVENT_TYPE_CANCELLED
:OBJECTIVE_EVENT_TYPE_SUB_AGENT_SPAWNED
:OBJECTIVE_EVENT_TYPE_SUB_AGENT_UPDATED
:OBJECTIVE_EVENT_TYPE_FINALIZED
http_status_code: Integer

Response details. The response body is not retained.

formatint32
last_attempt_at: Time
latency_ms: Integer
objective_event_id: String
objective_id: String
response_content_length: String

Content length of the response body in bytes

status: :WEBHOOK_DELIVERY_STATUS_UNSPECIFIED | :WEBHOOK_DELIVERY_STATUS_PENDING | :WEBHOOK_DELIVERY_STATUS_COMPLETED | 2 more
formatenum
One of the following:
:WEBHOOK_DELIVERY_STATUS_UNSPECIFIED
:WEBHOOK_DELIVERY_STATUS_PENDING
:WEBHOOK_DELIVERY_STATUS_COMPLETED
:WEBHOOK_DELIVERY_STATUS_FAILED
:WEBHOOK_DELIVERY_STATUS_DISABLED
webhook_id: String
webhook_url: String

Webhook delivery details

error_message: String
response_headers: Hash[Symbol, String]

Response headers received from the webhook endpoint

AgentsVariations

Manage variations of an agent and their tool, sub-agent, and memory layer assignments.

List variations
agents.variations.list(agent_id, **kwargs) -> CursorPagination<AgentVariation { metadata, spec, info } >
GET/v1/workspaces/{workspaceId}/agents/{agentId}/variations
Create a new variation
agents.variations.create(agent_id, **kwargs) -> AgentVariation { metadata, spec, info }
POST/v1/workspaces/{workspaceId}/agents/{agentId}/variations
Get a variation by ID
agents.variations.retrieve(id, **kwargs) -> AgentVariation { metadata, spec, info }
GET/v1/workspaces/{workspaceId}/agents/{agentId}/variations/{id}
Delete a variation
agents.variations.delete(id, **kwargs) -> void
DELETE/v1/workspaces/{workspaceId}/agents/{agentId}/variations/{id}
Update a variation
agents.variations.update(id, **kwargs) -> AgentVariation { metadata, spec, info }
PATCH/v1/workspaces/{workspaceId}/agents/{agentId}/variations/{id}
Add an assignment to a variation
agents.variations.add_assignment(variation_id, **kwargs) -> VariationAssignment { id, agent, tool, tool_set }
POST/v1/workspaces/{workspaceId}/agents/{agentId}/variations/{variationId}/assignments
Remove an assignment from a variation
agents.variations.remove_assignment(id, **kwargs) -> void
DELETE/v1/workspaces/{workspaceId}/agents/{agentId}/variations/{variationId}/assignments/{id}
Attach a memory layer to a variation
agents.variations.add_memory_layer(variation_id, **kwargs) -> VariationMemoryLayerAssignment { id, memory_layer, position }
POST/v1/workspaces/{workspaceId}/agents/{agentId}/variations/{variationId}/memory_layer_assignments
Update a variation's memory layer assignment
agents.variations.update_memory_layer(id, **kwargs) -> VariationMemoryLayerAssignment { id, memory_layer, position }
PATCH/v1/workspaces/{workspaceId}/agents/{agentId}/variations/{variationId}/memory_layer_assignments/{id}
Remove a memory layer assignment from a variation
agents.variations.remove_memory_layer(id, **kwargs) -> void
DELETE/v1/workspaces/{workspaceId}/agents/{agentId}/variations/{variationId}/memory_layer_assignments/{id}
ModelsExpand Collapse
class AgentVariation { metadata, spec, info }

AgentVariation resource

metadata: ResourceMetadata { id, account_id, created_at, 6 more }

Standard metadata for persistent, named resources (e.g., agents, tools, prompts)

id: String

Unique identifier for the resource (prefixed ULID, e.g., “agent_01HXK…”)

account_id: String

Account this resource belongs to for multi-tenant isolation (prefixed ULID)

created_at: Time

Timestamp when this resource was created

formatdate-time
name: String

Human-readable name for the resource (e.g., “Customer Support Agent”, “Email Tool”) Required for resources that users interact with directly

profile_id: String

ID of the actor (user or service account) that created this resource

workspace_id: String

Workspace this resource belongs to for organizational grouping (prefixed ULID)

bundle_key: String

Optional bundle ownership key. When set, indicates the resource is managed by a configuration bundle identified by this key. Used by BulkWorkspaceResources.Apply to track which resources belong to which bundle for reconciliation / soft-delete on re-apply.

external_id: String

External ID for the resource (e.g., a workflow ID from an external system)

labels: Hash[Symbol, String]

Arbitrary key-value pairs for categorization and filtering Examples: {“environment”: “production”, “team”: “platform”, “version”: “v2”}

spec: AgentVariationSpec { compaction_config, constraints, description, 6 more }

AgentVariationSpec defines the operational configuration for a variation

compaction_config: AgentVariationSpecCompactionConfig { summarization, tool_result_clearing, trigger_threshold }

CompactionConfig defines how context window compaction behaves for objectives using this variation.

summarization: CompactionConfigSummarizationStrategy { instructions }

SummarizationStrategy configures LLM-powered summarization of older conversation turns.

instructions: String

Custom instructions that guide what the summarizer preserves. Replaces the default summarization prompt entirely. Example: “Preserve all code snippets, variable names, and technical decisions.”

tool_result_clearing: CompactionConfigToolResultClearingStrategy { preserve_recent_results }

ToolResultClearingStrategy configures clearing of older tool result content.

preserve_recent_results: Integer

Number of most recent tool call results to keep intact. Older tool results have their content replaced with “[result cleared]” while preserving the assistant tool call message (function name, arguments). Default: 2

formatint32
trigger_threshold: Float

Trigger threshold as a percentage of the model’s context window (0.0 to 1.0). When input tokens reach this percentage of the model’s limit, compaction triggers. Default: 0.75 (75%)

formatfloat
constraints: AgentVariationSpecConstraints { max_sub_objectives, max_tool_calls }

Execution constraints

max_sub_objectives: Integer

The maximum number of sub-objectives that can be created. 0 means no limit.

formatint32
max_tool_calls: Integer

The maximum number of tool calls that can be made. 0 means no limit.

formatint32
description: String

Human-readable description of what this variation does or when it should be used

enable_episodic_memory: bool

Enable episodic memory for objectives using this variation. When true, the system automatically creates a document namespace for each objective using the objective’s episodic_key as the external_id, allowing the agent to store and retrieve documents specific to that episode.

episodic_memory_ttl: Integer

How long episodic memories should be retained. After this duration, episodic document namespaces can be automatically cleaned up. If not set, episodic memories are retained indefinitely.

model_config: AgentVariationSpecModelConfig { model_id, temperature }

ModelConfig defines the model configuration for a variation

model_id: String

The model identifier in family/model format (e.g., “claude/opus-4.6”, “claude/sonnet-4.5”)

temperature: Float

Sampling temperature for model inference (0.0 to 1.0) Lower values produce more deterministic outputs, higher values increase randomness

formatfloat
progressive_discovery: AgentVariationSpecProgressiveDiscovery { hints, max_tools, rerank_threshold }

ProgressiveDiscovery is used to indicate that the agent should automatically discover tools that are not explicitly assigned to it. Max tools is the maximum number of tools that can be discovered per search. Hints are optional hints for tool search. These are used in conjunction with the context-aware tool search and can help select the best tools for the task.

hints: Array[String]
max_tools: Integer
rerank_threshold: Float

Rerank Threshold is an optional value that instructs whether or not to run a search result through a embedding/reranker process which can improve performance and reduce context bloat when tools reach the configured threshold. If a tool match must exceed 0.8, for example, the tool very closely match the query the tool search performed.

formatfloat
prompt: String

The system prompt for this variation

weight: Integer

Weight for weighted random selection (>= 0). P(v) = v.weight / sum(all_weights). Only used when the agent’s variation_selection_mode is WEIGHTED. A weight of 0 means never auto-selected, but can still be chosen explicitly via variation_id on CreateObjectiveRequest.

formatint32
info: AgentVariationInfo { assignments, created_by, feedback_count, 7 more }

AgentVariationInfo provides read-only summary information about a variation

assignments: Array[VariationAssignment { id, agent, tool, tool_set } ]

All tools, tool sets, and sub-agents assigned to this variation. Populated on reads so clients can render a variation’s full assignment list without calling the add/remove endpoints just to enumerate.

id: String
agent: BareMetadata { id, name }

BareMetadata contains the minimal metadata for a resource: the ID and an optional human-readable name. These are used for reference fields where the full metadata (account scoping, timestamps, labels, external IDs) is not needed — e.g., the tool references inside an agent variation spec or the tools assigned to an objective. Both fields are server-populated; clients provide IDs through sibling fields rather than by constructing a BareMetadata themselves.

id: String
name: String

Human-readable name of the referenced resource, populated by the server on reads for convenience. Absent on references to resources that do not have a name (e.g., objective tasks).

tool: BareMetadata { id, name }

BareMetadata contains the minimal metadata for a resource: the ID and an optional human-readable name. These are used for reference fields where the full metadata (account scoping, timestamps, labels, external IDs) is not needed — e.g., the tool references inside an agent variation spec or the tools assigned to an objective. Both fields are server-populated; clients provide IDs through sibling fields rather than by constructing a BareMetadata themselves.

id: String
name: String

Human-readable name of the referenced resource, populated by the server on reads for convenience. Absent on references to resources that do not have a name (e.g., objective tasks).

tool_set: BareMetadata { id, name }

BareMetadata contains the minimal metadata for a resource: the ID and an optional human-readable name. These are used for reference fields where the full metadata (account scoping, timestamps, labels, external IDs) is not needed — e.g., the tool references inside an agent variation spec or the tools assigned to an objective. Both fields are server-populated; clients provide IDs through sibling fields rather than by constructing a BareMetadata themselves.

id: String
name: String

Human-readable name of the referenced resource, populated by the server on reads for convenience. Absent on references to resources that do not have a name (e.g., objective tasks).

created_by: Profile { metadata, spec }

A profile identifies a user or non-human principal (such as an API key) at the account level. Profiles are account-scoped and can be granted access to multiple workspaces.

metadata: AccountResourceMetadata { id, account_id, name, 3 more }

AccountResourceMetadata is used to represent a resource that is associated to an account but not to a workspace.

id: String

Unique identifier for the resource (prefixed ULID, e.g., “apikey_01HXK…”)

account_id: String

Account this resource belongs to for multi-tenant isolation (prefixed ULID)

name: String

Human-readable name for the resource (e.g., “Customer Support Agent”, “Email Tool”) Required for resources that users interact with directly

profile_id: String
external_id: String

External ID for the resource (e.g., a workflow ID from an external system)

labels: Hash[Symbol, String]

Arbitrary key-value pairs for categorization and filtering Examples: {“environment”: “production”, “team”: “platform”, “version”: “v2”}

spec: ProfileSpec { type, email, name }

Configuration for a profile.

type: :PROFILE_TYPE_UNSPECIFIED | :PROFILE_TYPE_USER | :PROFILE_TYPE_API_KEY | :PROFILE_TYPE_SYSTEM

Whether this profile represents a human user, an API key, or a system principal.

formatenum
One of the following:
:PROFILE_TYPE_UNSPECIFIED
:PROFILE_TYPE_USER
:PROFILE_TYPE_API_KEY
:PROFILE_TYPE_SYSTEM
email: String

Email address of the profile. Required and unique within an account for user profiles.

name: String

Display name (e.g., “Bobby Tables”).

feedback_count: Integer

Total number of objective feedbacks received for this variation

formatint32
memory_layer_assignments: Array[VariationMemoryLayerAssignment { id, memory_layer, position } ]

Read-only list of memory layer assignments for this variation, returned in ascending position (bottom → top). Capped at 10 entries.

id: String

Assignment row id — handle for removing the assignment. Distinct from the referenced memory layer’s id.

memory_layer: BareMetadata { id, name }

BareMetadata contains the minimal metadata for a resource: the ID and an optional human-readable name. These are used for reference fields where the full metadata (account scoping, timestamps, labels, external IDs) is not needed — e.g., the tool references inside an agent variation spec or the tools assigned to an objective. Both fields are server-populated; clients provide IDs through sibling fields rather than by constructing a BareMetadata themselves.

id: String
name: String

Human-readable name of the referenced resource, populated by the server on reads for convenience. Absent on references to resources that do not have a name (e.g., objective tasks).

position: Integer

Position in the variation’s baseline stack. Lower values sit lower; the highest-position assignment is on top of the variation’s baseline. Gaps are fine — only relative position matters. Positions must be unique within a variation; a request that would collide with an existing assignment’s position is rejected with InvalidArgument.

formatint32
memory_layer_count: Integer

Count of memory layer assignments.

formatint32
model: ResourceMetadata { id, account_id, created_at, 6 more }

Standard metadata for persistent, named resources (e.g., agents, tools, prompts)

id: String

Unique identifier for the resource (prefixed ULID, e.g., “agent_01HXK…”)

account_id: String

Account this resource belongs to for multi-tenant isolation (prefixed ULID)

created_at: Time

Timestamp when this resource was created

formatdate-time
name: String

Human-readable name for the resource (e.g., “Customer Support Agent”, “Email Tool”) Required for resources that users interact with directly

profile_id: String

ID of the actor (user or service account) that created this resource

workspace_id: String

Workspace this resource belongs to for organizational grouping (prefixed ULID)

bundle_key: String

Optional bundle ownership key. When set, indicates the resource is managed by a configuration bundle identified by this key. Used by BulkWorkspaceResources.Apply to track which resources belong to which bundle for reconciliation / soft-delete on re-apply.

external_id: String

External ID for the resource (e.g., a workflow ID from an external system)

labels: Hash[Symbol, String]

Arbitrary key-value pairs for categorization and filtering Examples: {“environment”: “production”, “team”: “platform”, “version”: “v2”}

score: Float

Thompson Sampling score: posterior mean of Beta(ts_alpha, ts_beta). Range [0, 1] where 0.5 = neutral, >0.5 = positive, <0.5 = negative.

formatfloat
sub_agent_count: Integer

Number of sub-agents assigned to this variation

formatint32
tool_count: Integer

Number of individual tools assigned to this variation

formatint32
tool_set_count: Integer

Number of tool sets assigned to this variation

formatint32
class AgentVariationInfo { assignments, created_by, feedback_count, 7 more }

AgentVariationInfo provides read-only summary information about a variation

assignments: Array[VariationAssignment { id, agent, tool, tool_set } ]

All tools, tool sets, and sub-agents assigned to this variation. Populated on reads so clients can render a variation’s full assignment list without calling the add/remove endpoints just to enumerate.

id: String
agent: BareMetadata { id, name }

BareMetadata contains the minimal metadata for a resource: the ID and an optional human-readable name. These are used for reference fields where the full metadata (account scoping, timestamps, labels, external IDs) is not needed — e.g., the tool references inside an agent variation spec or the tools assigned to an objective. Both fields are server-populated; clients provide IDs through sibling fields rather than by constructing a BareMetadata themselves.

id: String
name: String

Human-readable name of the referenced resource, populated by the server on reads for convenience. Absent on references to resources that do not have a name (e.g., objective tasks).

tool: BareMetadata { id, name }

BareMetadata contains the minimal metadata for a resource: the ID and an optional human-readable name. These are used for reference fields where the full metadata (account scoping, timestamps, labels, external IDs) is not needed — e.g., the tool references inside an agent variation spec or the tools assigned to an objective. Both fields are server-populated; clients provide IDs through sibling fields rather than by constructing a BareMetadata themselves.

id: String
name: String

Human-readable name of the referenced resource, populated by the server on reads for convenience. Absent on references to resources that do not have a name (e.g., objective tasks).

tool_set: BareMetadata { id, name }

BareMetadata contains the minimal metadata for a resource: the ID and an optional human-readable name. These are used for reference fields where the full metadata (account scoping, timestamps, labels, external IDs) is not needed — e.g., the tool references inside an agent variation spec or the tools assigned to an objective. Both fields are server-populated; clients provide IDs through sibling fields rather than by constructing a BareMetadata themselves.

id: String
name: String

Human-readable name of the referenced resource, populated by the server on reads for convenience. Absent on references to resources that do not have a name (e.g., objective tasks).

created_by: Profile { metadata, spec }

A profile identifies a user or non-human principal (such as an API key) at the account level. Profiles are account-scoped and can be granted access to multiple workspaces.

metadata: AccountResourceMetadata { id, account_id, name, 3 more }

AccountResourceMetadata is used to represent a resource that is associated to an account but not to a workspace.

id: String

Unique identifier for the resource (prefixed ULID, e.g., “apikey_01HXK…”)

account_id: String

Account this resource belongs to for multi-tenant isolation (prefixed ULID)

name: String

Human-readable name for the resource (e.g., “Customer Support Agent”, “Email Tool”) Required for resources that users interact with directly

profile_id: String
external_id: String

External ID for the resource (e.g., a workflow ID from an external system)

labels: Hash[Symbol, String]

Arbitrary key-value pairs for categorization and filtering Examples: {“environment”: “production”, “team”: “platform”, “version”: “v2”}

spec: ProfileSpec { type, email, name }

Configuration for a profile.

type: :PROFILE_TYPE_UNSPECIFIED | :PROFILE_TYPE_USER | :PROFILE_TYPE_API_KEY | :PROFILE_TYPE_SYSTEM

Whether this profile represents a human user, an API key, or a system principal.

formatenum
One of the following:
:PROFILE_TYPE_UNSPECIFIED
:PROFILE_TYPE_USER
:PROFILE_TYPE_API_KEY
:PROFILE_TYPE_SYSTEM
email: String

Email address of the profile. Required and unique within an account for user profiles.

name: String

Display name (e.g., “Bobby Tables”).

feedback_count: Integer

Total number of objective feedbacks received for this variation

formatint32
memory_layer_assignments: Array[VariationMemoryLayerAssignment { id, memory_layer, position } ]

Read-only list of memory layer assignments for this variation, returned in ascending position (bottom → top). Capped at 10 entries.

id: String

Assignment row id — handle for removing the assignment. Distinct from the referenced memory layer’s id.

memory_layer: BareMetadata { id, name }

BareMetadata contains the minimal metadata for a resource: the ID and an optional human-readable name. These are used for reference fields where the full metadata (account scoping, timestamps, labels, external IDs) is not needed — e.g., the tool references inside an agent variation spec or the tools assigned to an objective. Both fields are server-populated; clients provide IDs through sibling fields rather than by constructing a BareMetadata themselves.

id: String
name: String

Human-readable name of the referenced resource, populated by the server on reads for convenience. Absent on references to resources that do not have a name (e.g., objective tasks).

position: Integer

Position in the variation’s baseline stack. Lower values sit lower; the highest-position assignment is on top of the variation’s baseline. Gaps are fine — only relative position matters. Positions must be unique within a variation; a request that would collide with an existing assignment’s position is rejected with InvalidArgument.

formatint32
memory_layer_count: Integer

Count of memory layer assignments.

formatint32
model: ResourceMetadata { id, account_id, created_at, 6 more }

Standard metadata for persistent, named resources (e.g., agents, tools, prompts)

id: String

Unique identifier for the resource (prefixed ULID, e.g., “agent_01HXK…”)

account_id: String

Account this resource belongs to for multi-tenant isolation (prefixed ULID)

created_at: Time

Timestamp when this resource was created

formatdate-time
name: String

Human-readable name for the resource (e.g., “Customer Support Agent”, “Email Tool”) Required for resources that users interact with directly

profile_id: String

ID of the actor (user or service account) that created this resource

workspace_id: String

Workspace this resource belongs to for organizational grouping (prefixed ULID)

bundle_key: String

Optional bundle ownership key. When set, indicates the resource is managed by a configuration bundle identified by this key. Used by BulkWorkspaceResources.Apply to track which resources belong to which bundle for reconciliation / soft-delete on re-apply.

external_id: String

External ID for the resource (e.g., a workflow ID from an external system)

labels: Hash[Symbol, String]

Arbitrary key-value pairs for categorization and filtering Examples: {“environment”: “production”, “team”: “platform”, “version”: “v2”}

score: Float

Thompson Sampling score: posterior mean of Beta(ts_alpha, ts_beta). Range [0, 1] where 0.5 = neutral, >0.5 = positive, <0.5 = negative.

formatfloat
sub_agent_count: Integer

Number of sub-agents assigned to this variation

formatint32
tool_count: Integer

Number of individual tools assigned to this variation

formatint32
tool_set_count: Integer

Number of tool sets assigned to this variation

formatint32
class AgentVariationSpec { compaction_config, constraints, description, 6 more }

AgentVariationSpec defines the operational configuration for a variation

compaction_config: AgentVariationSpecCompactionConfig { summarization, tool_result_clearing, trigger_threshold }

CompactionConfig defines how context window compaction behaves for objectives using this variation.

summarization: CompactionConfigSummarizationStrategy { instructions }

SummarizationStrategy configures LLM-powered summarization of older conversation turns.

instructions: String

Custom instructions that guide what the summarizer preserves. Replaces the default summarization prompt entirely. Example: “Preserve all code snippets, variable names, and technical decisions.”

tool_result_clearing: CompactionConfigToolResultClearingStrategy { preserve_recent_results }

ToolResultClearingStrategy configures clearing of older tool result content.

preserve_recent_results: Integer

Number of most recent tool call results to keep intact. Older tool results have their content replaced with “[result cleared]” while preserving the assistant tool call message (function name, arguments). Default: 2

formatint32
trigger_threshold: Float

Trigger threshold as a percentage of the model’s context window (0.0 to 1.0). When input tokens reach this percentage of the model’s limit, compaction triggers. Default: 0.75 (75%)

formatfloat
constraints: AgentVariationSpecConstraints { max_sub_objectives, max_tool_calls }

Execution constraints

max_sub_objectives: Integer

The maximum number of sub-objectives that can be created. 0 means no limit.

formatint32
max_tool_calls: Integer

The maximum number of tool calls that can be made. 0 means no limit.

formatint32
description: String

Human-readable description of what this variation does or when it should be used

enable_episodic_memory: bool

Enable episodic memory for objectives using this variation. When true, the system automatically creates a document namespace for each objective using the objective’s episodic_key as the external_id, allowing the agent to store and retrieve documents specific to that episode.

episodic_memory_ttl: Integer

How long episodic memories should be retained. After this duration, episodic document namespaces can be automatically cleaned up. If not set, episodic memories are retained indefinitely.

model_config: AgentVariationSpecModelConfig { model_id, temperature }

ModelConfig defines the model configuration for a variation

model_id: String

The model identifier in family/model format (e.g., “claude/opus-4.6”, “claude/sonnet-4.5”)

temperature: Float

Sampling temperature for model inference (0.0 to 1.0) Lower values produce more deterministic outputs, higher values increase randomness

formatfloat
progressive_discovery: AgentVariationSpecProgressiveDiscovery { hints, max_tools, rerank_threshold }

ProgressiveDiscovery is used to indicate that the agent should automatically discover tools that are not explicitly assigned to it. Max tools is the maximum number of tools that can be discovered per search. Hints are optional hints for tool search. These are used in conjunction with the context-aware tool search and can help select the best tools for the task.

hints: Array[String]
max_tools: Integer
rerank_threshold: Float

Rerank Threshold is an optional value that instructs whether or not to run a search result through a embedding/reranker process which can improve performance and reduce context bloat when tools reach the configured threshold. If a tool match must exceed 0.8, for example, the tool very closely match the query the tool search performed.

formatfloat
prompt: String

The system prompt for this variation

weight: Integer

Weight for weighted random selection (>= 0). P(v) = v.weight / sum(all_weights). Only used when the agent’s variation_selection_mode is WEIGHTED. A weight of 0 means never auto-selected, but can still be chosen explicitly via variation_id on CreateObjectiveRequest.

formatint32
class AgentVariationSpecCompactionConfig { summarization, tool_result_clearing, trigger_threshold }

CompactionConfig defines how context window compaction behaves for objectives using this variation.

summarization: CompactionConfigSummarizationStrategy { instructions }

SummarizationStrategy configures LLM-powered summarization of older conversation turns.

instructions: String

Custom instructions that guide what the summarizer preserves. Replaces the default summarization prompt entirely. Example: “Preserve all code snippets, variable names, and technical decisions.”

tool_result_clearing: CompactionConfigToolResultClearingStrategy { preserve_recent_results }

ToolResultClearingStrategy configures clearing of older tool result content.

preserve_recent_results: Integer

Number of most recent tool call results to keep intact. Older tool results have their content replaced with “[result cleared]” while preserving the assistant tool call message (function name, arguments). Default: 2

formatint32
trigger_threshold: Float

Trigger threshold as a percentage of the model’s context window (0.0 to 1.0). When input tokens reach this percentage of the model’s limit, compaction triggers. Default: 0.75 (75%)

formatfloat
class AgentVariationSpecConstraints { max_sub_objectives, max_tool_calls }
max_sub_objectives: Integer

The maximum number of sub-objectives that can be created. 0 means no limit.

formatint32
max_tool_calls: Integer

The maximum number of tool calls that can be made. 0 means no limit.

formatint32
class AgentVariationSpecModelConfig { model_id, temperature }

ModelConfig defines the model configuration for a variation

model_id: String

The model identifier in family/model format (e.g., “claude/opus-4.6”, “claude/sonnet-4.5”)

temperature: Float

Sampling temperature for model inference (0.0 to 1.0) Lower values produce more deterministic outputs, higher values increase randomness

formatfloat
class AgentVariationSpecProgressiveDiscovery { hints, max_tools, rerank_threshold }

ProgressiveDiscovery is used to indicate that the agent should automatically discover tools that are not explicitly assigned to it. Max tools is the maximum number of tools that can be discovered per search. Hints are optional hints for tool search. These are used in conjunction with the context-aware tool search and can help select the best tools for the task.

hints: Array[String]
max_tools: Integer
rerank_threshold: Float

Rerank Threshold is an optional value that instructs whether or not to run a search result through a embedding/reranker process which can improve performance and reduce context bloat when tools reach the configured threshold. If a tool match must exceed 0.8, for example, the tool very closely match the query the tool search performed.

formatfloat
class CompactionConfigSummarizationStrategy { instructions }

SummarizationStrategy configures LLM-powered summarization of older conversation turns.

instructions: String

Custom instructions that guide what the summarizer preserves. Replaces the default summarization prompt entirely. Example: “Preserve all code snippets, variable names, and technical decisions.”

class CompactionConfigToolResultClearingStrategy { preserve_recent_results }

ToolResultClearingStrategy configures clearing of older tool result content.

preserve_recent_results: Integer

Number of most recent tool call results to keep intact. Older tool results have their content replaced with “[result cleared]” while preserving the assistant tool call message (function name, arguments). Default: 2

formatint32
class VariationAssignment { id, agent, tool, tool_set }

A read-only reference to a single tool, tool set, or sub-agent attached to a variation. Read the full set of assignments via AgentVariationInfo.assignments; mutations go through the dedicated add/remove assignment endpoints.

The id identifies the assignment itself (not the referenced resource) and is the handle used to remove the assignment. It is returned by the add endpoint and present on every entry in AgentVariationInfo.assignments.

id: String
agent: BareMetadata { id, name }

BareMetadata contains the minimal metadata for a resource: the ID and an optional human-readable name. These are used for reference fields where the full metadata (account scoping, timestamps, labels, external IDs) is not needed — e.g., the tool references inside an agent variation spec or the tools assigned to an objective. Both fields are server-populated; clients provide IDs through sibling fields rather than by constructing a BareMetadata themselves.

id: String
name: String

Human-readable name of the referenced resource, populated by the server on reads for convenience. Absent on references to resources that do not have a name (e.g., objective tasks).

tool: BareMetadata { id, name }

BareMetadata contains the minimal metadata for a resource: the ID and an optional human-readable name. These are used for reference fields where the full metadata (account scoping, timestamps, labels, external IDs) is not needed — e.g., the tool references inside an agent variation spec or the tools assigned to an objective. Both fields are server-populated; clients provide IDs through sibling fields rather than by constructing a BareMetadata themselves.

id: String
name: String

Human-readable name of the referenced resource, populated by the server on reads for convenience. Absent on references to resources that do not have a name (e.g., objective tasks).

tool_set: BareMetadata { id, name }

BareMetadata contains the minimal metadata for a resource: the ID and an optional human-readable name. These are used for reference fields where the full metadata (account scoping, timestamps, labels, external IDs) is not needed — e.g., the tool references inside an agent variation spec or the tools assigned to an objective. Both fields are server-populated; clients provide IDs through sibling fields rather than by constructing a BareMetadata themselves.

id: String
name: String

Human-readable name of the referenced resource, populated by the server on reads for convenience. Absent on references to resources that do not have a name (e.g., objective tasks).

class VariationMemoryLayerAssignment { id, memory_layer, position }

VariationMemoryLayerAssignment attaches a single MemoryLayer to a variation at a given position in the variation’s baseline memory stack. A variation has at most one assignment per memory_layer_id.

Variations only support whole-layer attachments — entry pinning is an objective-level capability.

id: String

Assignment row id — handle for removing the assignment. Distinct from the referenced memory layer’s id.

memory_layer: BareMetadata { id, name }

BareMetadata contains the minimal metadata for a resource: the ID and an optional human-readable name. These are used for reference fields where the full metadata (account scoping, timestamps, labels, external IDs) is not needed — e.g., the tool references inside an agent variation spec or the tools assigned to an objective. Both fields are server-populated; clients provide IDs through sibling fields rather than by constructing a BareMetadata themselves.

id: String
name: String

Human-readable name of the referenced resource, populated by the server on reads for convenience. Absent on references to resources that do not have a name (e.g., objective tasks).

position: Integer

Position in the variation’s baseline stack. Lower values sit lower; the highest-position assignment is on top of the variation’s baseline. Gaps are fine — only relative position matters. Positions must be unique within a variation; a request that would collide with an existing assignment’s position is rejected with InvalidArgument.

formatint32

AgentsSchedules

Manage recurring schedules attached to agents. Schedules trigger objectives on a cadence defined by AgentScheduleSpec.Schedule.

List schedules
agents.schedules.list(agent_id, **kwargs) -> CursorPagination<AgentSchedule { metadata, spec, info } >
GET/v1/workspaces/{workspaceId}/agents/{agentId}/schedules
Create a new schedule
agents.schedules.create(agent_id, **kwargs) -> AgentSchedule { metadata, spec, info }
POST/v1/workspaces/{workspaceId}/agents/{agentId}/schedules
Get a schedule by ID
agents.schedules.retrieve(id, **kwargs) -> AgentSchedule { metadata, spec, info }
GET/v1/workspaces/{workspaceId}/agents/{agentId}/schedules/{id}
Delete a schedule
agents.schedules.delete(id, **kwargs) -> void
DELETE/v1/workspaces/{workspaceId}/agents/{agentId}/schedules/{id}
Update a schedule
agents.schedules.update(id, **kwargs) -> AgentSchedule { metadata, spec, info }
PATCH/v1/workspaces/{workspaceId}/agents/{agentId}/schedules/{id}
ModelsExpand Collapse
class AgentSchedule { metadata, spec, info }

AgentSchedule resource — a recurring trigger attached to an agent that creates objectives on its cadence.

metadata: ResourceMetadata { id, account_id, created_at, 6 more }

Standard metadata for persistent, named resources (e.g., agents, tools, prompts)

id: String

Unique identifier for the resource (prefixed ULID, e.g., “agent_01HXK…”)

account_id: String

Account this resource belongs to for multi-tenant isolation (prefixed ULID)

created_at: Time

Timestamp when this resource was created

formatdate-time
name: String

Human-readable name for the resource (e.g., “Customer Support Agent”, “Email Tool”) Required for resources that users interact with directly

profile_id: String

ID of the actor (user or service account) that created this resource

workspace_id: String

Workspace this resource belongs to for organizational grouping (prefixed ULID)

bundle_key: String

Optional bundle ownership key. When set, indicates the resource is managed by a configuration bundle identified by this key. Used by BulkWorkspaceResources.Apply to track which resources belong to which bundle for reconciliation / soft-delete on re-apply.

external_id: String

External ID for the resource (e.g., a workflow ID from an external system)

labels: Hash[Symbol, String]

Arbitrary key-value pairs for categorization and filtering Examples: {“environment”: “production”, “team”: “platform”, “version”: “v2”}

spec: AgentScheduleSpec { initial_message, schedule, data, 3 more }

AgentScheduleSpec is the user-provided configuration for a schedule.

initial_message: String

The initial message passed to CreateObjective on each fire. Becomes the first user message in the objective’s chat history.

schedule: AgentScheduleSpecSchedule { calendars, intervals, timezone }

Schedule defines WHEN the schedule fires. Temporal-style structured form: a list of calendar rules (wall-clock) and/or interval rules (duration), OR’d together. At least one rule is required.

calendars: Array[ScheduleCalendar { comment, day_of_month, day_of_week, 4 more } ]

Wall-clock rules. May be empty if intervals is non-empty.

comment: String
day_of_month: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
day_of_week: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
hour: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
minute: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
month: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
second: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
intervals: Array[ScheduleInterval { every, offset } ]

Duration-based rules. May be empty if calendars is non-empty.

every: String
offset: String

Phase shift within every. Must be < every (enforced at runtime).

timezone: String

IANA tz name (e.g. “America/New_York”). Required. Applies to calendars; intervals fire on wall-clock cadence anchored in this zone.

data: untyped

Optional input data passed to the objective. If the agent has an input_data_schema, this must satisfy it.

overlap_policy: :OVERLAP_POLICY_UNSPECIFIED | :OVERLAP_POLICY_ALLOW | :OVERLAP_POLICY_SKIP

What to do when the previous run is still in flight. Defaults to SKIP.

formatenum
One of the following:
:OVERLAP_POLICY_UNSPECIFIED
:OVERLAP_POLICY_ALLOW
:OVERLAP_POLICY_SKIP
status: :AGENT_SCHEDULE_STATUS_UNSPECIFIED | :AGENT_SCHEDULE_STATUS_ACTIVE | :AGENT_SCHEDULE_STATUS_PAUSED | :AGENT_SCHEDULE_STATUS_ARCHIVED

Lifecycle. Defaults to ACTIVE on create when unspecified.

formatenum
One of the following:
:AGENT_SCHEDULE_STATUS_UNSPECIFIED
:AGENT_SCHEDULE_STATUS_ACTIVE
:AGENT_SCHEDULE_STATUS_PAUSED
:AGENT_SCHEDULE_STATUS_ARCHIVED
variation_id: String

Optional explicit variation. When unset, the agent’s variation_selection_mode chooses per fire.

info: AgentScheduleInfo { created_by, last_fire_at, last_objective_id, 4 more }

AgentScheduleInfo provides read-only runtime data about a schedule.

created_by: Profile { metadata, spec }

A profile identifies a user or non-human principal (such as an API key) at the account level. Profiles are account-scoped and can be granted access to multiple workspaces.

metadata: AccountResourceMetadata { id, account_id, name, 3 more }

AccountResourceMetadata is used to represent a resource that is associated to an account but not to a workspace.

id: String

Unique identifier for the resource (prefixed ULID, e.g., “apikey_01HXK…”)

account_id: String

Account this resource belongs to for multi-tenant isolation (prefixed ULID)

name: String

Human-readable name for the resource (e.g., “Customer Support Agent”, “Email Tool”) Required for resources that users interact with directly

profile_id: String
external_id: String

External ID for the resource (e.g., a workflow ID from an external system)

labels: Hash[Symbol, String]

Arbitrary key-value pairs for categorization and filtering Examples: {“environment”: “production”, “team”: “platform”, “version”: “v2”}

spec: ProfileSpec { type, email, name }

Configuration for a profile.

type: :PROFILE_TYPE_UNSPECIFIED | :PROFILE_TYPE_USER | :PROFILE_TYPE_API_KEY | :PROFILE_TYPE_SYSTEM

Whether this profile represents a human user, an API key, or a system principal.

formatenum
One of the following:
:PROFILE_TYPE_UNSPECIFIED
:PROFILE_TYPE_USER
:PROFILE_TYPE_API_KEY
:PROFILE_TYPE_SYSTEM
email: String

Email address of the profile. Required and unique within an account for user profiles.

name: String

Display name (e.g., “Bobby Tables”).

last_fire_at: Time

When the schedule last fired (regardless of objective outcome).

formatdate-time
last_objective_id: String

ID of the most recent objective the schedule created.

last_skipped_at: Time

When the schedule most recently skipped a fire (SKIP policy + prior in flight).

formatdate-time
last_skip_reason: String

Reason for the most recent skip (e.g. “previous objective still running”).

next_fire_at: Time

When the schedule will next fire. Computed from the spec; absent when the schedule is PAUSED/ARCHIVED or has no future fire times.

formatdate-time
total_fires: Integer

Lifetime count of objectives created by this schedule.

formatint32
class AgentScheduleInfo { created_by, last_fire_at, last_objective_id, 4 more }

AgentScheduleInfo provides read-only runtime data about a schedule.

created_by: Profile { metadata, spec }

A profile identifies a user or non-human principal (such as an API key) at the account level. Profiles are account-scoped and can be granted access to multiple workspaces.

metadata: AccountResourceMetadata { id, account_id, name, 3 more }

AccountResourceMetadata is used to represent a resource that is associated to an account but not to a workspace.

id: String

Unique identifier for the resource (prefixed ULID, e.g., “apikey_01HXK…”)

account_id: String

Account this resource belongs to for multi-tenant isolation (prefixed ULID)

name: String

Human-readable name for the resource (e.g., “Customer Support Agent”, “Email Tool”) Required for resources that users interact with directly

profile_id: String
external_id: String

External ID for the resource (e.g., a workflow ID from an external system)

labels: Hash[Symbol, String]

Arbitrary key-value pairs for categorization and filtering Examples: {“environment”: “production”, “team”: “platform”, “version”: “v2”}

spec: ProfileSpec { type, email, name }

Configuration for a profile.

type: :PROFILE_TYPE_UNSPECIFIED | :PROFILE_TYPE_USER | :PROFILE_TYPE_API_KEY | :PROFILE_TYPE_SYSTEM

Whether this profile represents a human user, an API key, or a system principal.

formatenum
One of the following:
:PROFILE_TYPE_UNSPECIFIED
:PROFILE_TYPE_USER
:PROFILE_TYPE_API_KEY
:PROFILE_TYPE_SYSTEM
email: String

Email address of the profile. Required and unique within an account for user profiles.

name: String

Display name (e.g., “Bobby Tables”).

last_fire_at: Time

When the schedule last fired (regardless of objective outcome).

formatdate-time
last_objective_id: String

ID of the most recent objective the schedule created.

last_skipped_at: Time

When the schedule most recently skipped a fire (SKIP policy + prior in flight).

formatdate-time
last_skip_reason: String

Reason for the most recent skip (e.g. “previous objective still running”).

next_fire_at: Time

When the schedule will next fire. Computed from the spec; absent when the schedule is PAUSED/ARCHIVED or has no future fire times.

formatdate-time
total_fires: Integer

Lifetime count of objectives created by this schedule.

formatint32
class AgentScheduleSpec { initial_message, schedule, data, 3 more }

AgentScheduleSpec is the user-provided configuration for a schedule.

initial_message: String

The initial message passed to CreateObjective on each fire. Becomes the first user message in the objective’s chat history.

schedule: AgentScheduleSpecSchedule { calendars, intervals, timezone }

Schedule defines WHEN the schedule fires. Temporal-style structured form: a list of calendar rules (wall-clock) and/or interval rules (duration), OR’d together. At least one rule is required.

calendars: Array[ScheduleCalendar { comment, day_of_month, day_of_week, 4 more } ]

Wall-clock rules. May be empty if intervals is non-empty.

comment: String
day_of_month: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
day_of_week: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
hour: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
minute: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
month: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
second: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
intervals: Array[ScheduleInterval { every, offset } ]

Duration-based rules. May be empty if calendars is non-empty.

every: String
offset: String

Phase shift within every. Must be < every (enforced at runtime).

timezone: String

IANA tz name (e.g. “America/New_York”). Required. Applies to calendars; intervals fire on wall-clock cadence anchored in this zone.

data: untyped

Optional input data passed to the objective. If the agent has an input_data_schema, this must satisfy it.

overlap_policy: :OVERLAP_POLICY_UNSPECIFIED | :OVERLAP_POLICY_ALLOW | :OVERLAP_POLICY_SKIP

What to do when the previous run is still in flight. Defaults to SKIP.

formatenum
One of the following:
:OVERLAP_POLICY_UNSPECIFIED
:OVERLAP_POLICY_ALLOW
:OVERLAP_POLICY_SKIP
status: :AGENT_SCHEDULE_STATUS_UNSPECIFIED | :AGENT_SCHEDULE_STATUS_ACTIVE | :AGENT_SCHEDULE_STATUS_PAUSED | :AGENT_SCHEDULE_STATUS_ARCHIVED

Lifecycle. Defaults to ACTIVE on create when unspecified.

formatenum
One of the following:
:AGENT_SCHEDULE_STATUS_UNSPECIFIED
:AGENT_SCHEDULE_STATUS_ACTIVE
:AGENT_SCHEDULE_STATUS_PAUSED
:AGENT_SCHEDULE_STATUS_ARCHIVED
variation_id: String

Optional explicit variation. When unset, the agent’s variation_selection_mode chooses per fire.

class AgentScheduleSpecSchedule { calendars, intervals, timezone }

Schedule defines WHEN the schedule fires. Temporal-style structured form: a list of calendar rules (wall-clock) and/or interval rules (duration), OR’d together. At least one rule is required.

calendars: Array[ScheduleCalendar { comment, day_of_month, day_of_week, 4 more } ]

Wall-clock rules. May be empty if intervals is non-empty.

comment: String
day_of_month: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
day_of_week: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
hour: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
minute: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
month: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
second: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
intervals: Array[ScheduleInterval { every, offset } ]

Duration-based rules. May be empty if calendars is non-empty.

every: String
offset: String

Phase shift within every. Must be < every (enforced at runtime).

timezone: String

IANA tz name (e.g. “America/New_York”). Required. Applies to calendars; intervals fire on wall-clock cadence anchored in this zone.

class ScheduleCalendar { comment, day_of_month, day_of_week, 4 more }

Calendar is a wall-clock rule. Empty field-list semantics:

  • second/minute/hour: empty means [{start: 0}] (top of the unit)
  • day_of_month/month/day_of_week: empty means “any value” Fire times = cartesian product across all fields.
comment: String
day_of_month: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
day_of_week: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
hour: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
minute: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
month: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
second: Array[ScheduleRange { end_, start, step } ]
end_: Integer
start: Integer
step: Integer
class ScheduleInterval { every, offset }

Interval is a duration-based rule. Fires every every from a stable anchor (workspace epoch), optionally phase-shifted by offset.

every: String
offset: String

Phase shift within every. Must be < every (enforced at runtime).

class ScheduleRange { end_, start, step }

Inclusive numeric range with optional step. {start: 9} → 9 {start: 9, end: 17} → 9..17 {start: 0, end: 59, step: 15} → 0,15,30,45 end defaults to start; step defaults to 1.

end_: Integer
start: Integer
step: Integer