Skip to content
Get started

Results

Apply a declarative bundle of workspace resources — tool sets, memory layers, agents, variations, assignments, and schedules — in a single asynchronous operation.

List per-resource results for a bulk workspace apply
client.BulkWorkspaceResources.Results.List(ctx, workspaceID, bulkWorkspaceApplyID, query) (*CursorPagination[BulkWorkspaceApplyResult], error)
GET/v1/workspaces/{workspaceId}/bulk_workspace_applies/{bulkWorkspaceApplyId}/results
ModelsExpand Collapse
type BulkWorkspaceApplyResult struct{…}

One row of the per-resource result list for a BulkWorkspaceApply. Each row is itself an operation that can be paginated, sorted by created_at, and addressed individually.

Outcome for a single resource within a bulk apply. The type field is the discriminator string naming the populated outcome oneof variant (e.g., “toolSet”, “memoryEntry”). Every outcome shell carries an action enum and either a resulting resource snapshot (for ACTION_CREATED, ACTION_UPDATED, ACTION_UNCHANGED, ACTION_DELETED) or a google.rpc.Status (for ACTION_FAILED).

Action BulkWorkspaceApplyResultDataAgentOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionCreated BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionUpdated BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionDeleted BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionFailed BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataAgentOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataAgentOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource AgentOptional

Agent resource

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Agent specification (user-provided configuration)

Status AgentSpecStatus

Status of the agent

formatenum
One of the following:
const AgentSpecStatusAgentStatusUnspecified AgentSpecStatus = "AGENT_STATUS_UNSPECIFIED"
const AgentSpecStatusAgentStatusDraft AgentSpecStatus = "AGENT_STATUS_DRAFT"
const AgentSpecStatusAgentStatusPublished AgentSpecStatus = "AGENT_STATUS_PUBLISHED"
const AgentSpecStatusAgentStatusArchived AgentSpecStatus = "AGENT_STATUS_ARCHIVED"
VariationSelectionMode AgentSpecVariationSelectionMode

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

formatenum
One of the following:
const AgentSpecVariationSelectionModeVariationSelectionModeUnspecified AgentSpecVariationSelectionMode = "VARIATION_SELECTION_MODE_UNSPECIFIED"
const AgentSpecVariationSelectionModeVariationSelectionModeRandom AgentSpecVariationSelectionMode = "VARIATION_SELECTION_MODE_RANDOM"
const AgentSpecVariationSelectionModeVariationSelectionModeWeighted AgentSpecVariationSelectionMode = "VARIATION_SELECTION_MODE_WEIGHTED"
Description stringOptional

Description of the agent’s purpose

InputDataSchema map[string, unknown]Optional

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.

OutputDefinition map[string, unknown]Optional

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.

WebhookEventsURL stringOptional

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

Info AgentInfoOptional

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

CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

VariationCount int64Optional
Action BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionCreated BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionUpdated BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionDeleted BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionFailed BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataAgentScheduleOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataAgentScheduleOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource AgentScheduleOptional

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

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

AgentScheduleSpec is the user-provided configuration for a schedule.

InitialMessage string

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

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 []ScheduleCalendarOptional

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

Comment stringOptional
DayOfMonth []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
DayOfWeek []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
Hour []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
Minute []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
Month []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
Second []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
Intervals []ScheduleIntervalOptional

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

Every stringOptional
Offset stringOptional

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

Timezone stringOptional

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

Data unknownOptional

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

OverlapPolicy AgentScheduleSpecOverlapPolicyOptional

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

formatenum
One of the following:
const AgentScheduleSpecOverlapPolicyOverlapPolicyUnspecified AgentScheduleSpecOverlapPolicy = "OVERLAP_POLICY_UNSPECIFIED"
const AgentScheduleSpecOverlapPolicyOverlapPolicyAllow AgentScheduleSpecOverlapPolicy = "OVERLAP_POLICY_ALLOW"
const AgentScheduleSpecOverlapPolicyOverlapPolicySkip AgentScheduleSpecOverlapPolicy = "OVERLAP_POLICY_SKIP"
Status AgentScheduleSpecStatusOptional

Lifecycle. Defaults to ACTIVE on create when unspecified.

formatenum
One of the following:
const AgentScheduleSpecStatusAgentScheduleStatusUnspecified AgentScheduleSpecStatus = "AGENT_SCHEDULE_STATUS_UNSPECIFIED"
const AgentScheduleSpecStatusAgentScheduleStatusActive AgentScheduleSpecStatus = "AGENT_SCHEDULE_STATUS_ACTIVE"
const AgentScheduleSpecStatusAgentScheduleStatusPaused AgentScheduleSpecStatus = "AGENT_SCHEDULE_STATUS_PAUSED"
const AgentScheduleSpecStatusAgentScheduleStatusArchived AgentScheduleSpecStatus = "AGENT_SCHEDULE_STATUS_ARCHIVED"
VariationID stringOptional

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

Info AgentScheduleInfoOptional

AgentScheduleInfo provides read-only runtime data about a schedule.

CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

LastFireAt TimeOptional

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

formatdate-time
LastObjectiveID stringOptional

ID of the most recent objective the schedule created.

LastSkippedAt TimeOptional

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

formatdate-time
LastSkipReason stringOptional

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

NextFireAt TimeOptional

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
TotalFires int64Optional

Lifetime count of objectives created by this schedule.

formatint32
Action BulkWorkspaceApplyResultDataAgentVariationOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionCreated BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionUpdated BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionDeleted BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionFailed BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataAgentVariationOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataAgentVariationOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource AgentVariationOptional

AgentVariation resource

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

AgentVariationSpec defines the operational configuration for a variation

CompactionConfig AgentVariationSpecCompactionConfigOptional

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

SummarizationStrategy configures LLM-powered summarization of older conversation turns.

Instructions stringOptional

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

ToolResultClearingStrategy configures clearing of older tool result content.

PreserveRecentResults int64Optional

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
TriggerThreshold float64Optional

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 AgentVariationSpecConstraintsOptional

Execution constraints

MaxSubObjectives int64Optional

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

formatint32
MaxToolCalls int64Optional

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

formatint32
Description stringOptional

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

EnableEpisodicMemory boolOptional

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.

EpisodicMemoryTtl int64Optional

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.

ModelConfig AgentVariationSpecModelConfigOptional

ModelConfig defines the model configuration for a variation

ModelID stringOptional

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

Temperature float64Optional

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

formatfloat
ProgressiveDiscovery AgentVariationSpecProgressiveDiscoveryOptional

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 []stringOptional
MaxTools int64Optional
RerankThreshold float64Optional

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 stringOptional

The system prompt for this variation

Weight int64Optional

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 AgentVariationInfoOptional

AgentVariationInfo provides read-only summary information about a variation

Assignments []VariationAssignmentOptional

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 stringOptional
Agent BareMetadataOptional

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 stringOptional
Name stringOptional

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 BareMetadataOptional

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 stringOptional
Name stringOptional

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).

ToolSet BareMetadataOptional

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 stringOptional
Name stringOptional

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).

CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

FeedbackCount int64Optional

Total number of objective feedbacks received for this variation

formatint32
MemoryLayerAssignments []VariationMemoryLayerAssignmentOptional

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

ID stringOptional

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

MemoryLayer BareMetadataOptional

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 stringOptional
Name stringOptional

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 int64Optional

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
MemoryLayerCount int64Optional

Count of memory layer assignments.

formatint32
Model ResourceMetadataOptional

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Score float64Optional

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
SubAgentCount int64Optional

Number of sub-agents assigned to this variation

formatint32
ToolCount int64Optional

Number of individual tools assigned to this variation

formatint32
ToolSetCount int64Optional

Number of tool sets assigned to this variation

formatint32
Action BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionCreated BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionUpdated BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionDeleted BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionFailed BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataMemoryEntryOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataMemoryEntryOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource MemoryEntryOptional

MemoryEntry is a single keyed value within a MemoryLayer. Entries are addressed by their key, which follows the S3 object key safe-character convention (see MemoryEntrySpec.key for the full rule). Keys are unique within a single layer; the same key may appear in multiple layers, in which case the LIFO stack-walk determines which one wins for a given objective.

MemoryEntry is the summary shape, returned by ListMemoryEntries. It does not carry the entry body — callers that need the body must fetch the entry individually via GetMemoryEntry, which returns a MemoryEntryDetail.

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

MemoryEntrySpec is the metadata portion of an entry — the fields that identify and describe it, without the body. It appears on both the summary (MemoryEntry) and detail (MemoryEntryDetail) views.

Key string

The lookup key for this entry within its layer. Must conform to the S3 object key safe-characters spec: ASCII alphanumerics and the special characters !, -, _, ., *, ’, (, ), and /. Forward slashes may be used to suggest hierarchy (e.g., “skills/postmortem/write”), but lookups are flat — the key is a single opaque string, not a path.

Additional rules enforced by the service:

  • May not begin or end with /
  • May not contain consecutive slashes (//)
  • May not begin with reserved prefixes (cadenya/, system/)
  • Case-sensitive
  • Unique within the parent layer

For skills entries, this key is also the id the model passes to memory_load_skill when it decides to load the entry’s content.

Description stringOptional

One-line “when to use this” hint shown in the frontmatter manifest for skills entries. The model uses this to decide whether to load the body, so it should be written for the model as the audience. Ignored for layer types that do not advertise frontmatter.

Info MemoryEntryInfoOptional
CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

MemoryLayer ResourceMetadataOptional

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Action BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionCreated BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionUpdated BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionDeleted BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionFailed BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataMemoryLayerOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataMemoryLayerOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource MemoryLayerOptional

MemoryLayer is a named container of memory entries that can be composed into an objective’s memory stack. Layers are workspace-scoped resources. The layer type controls how its entries participate in the agent loop — see MemoryLayerType for details.

See “Memory stack composition” above for how layers compose at lookup time.

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Type MemoryLayerSpecType
formatenum
One of the following:
const MemoryLayerSpecTypeMemoryLayerTypeUnspecified MemoryLayerSpecType = "MEMORY_LAYER_TYPE_UNSPECIFIED"
const MemoryLayerSpecTypeMemoryLayerTypeEpisodic MemoryLayerSpecType = "MEMORY_LAYER_TYPE_EPISODIC"
const MemoryLayerSpecTypeMemoryLayerTypeSkills MemoryLayerSpecType = "MEMORY_LAYER_TYPE_SKILLS"
Description stringOptional

Human-readable description of the layer’s purpose. Encouraged for user-created layers; system-managed layers may have a generated description.

ExpiresAt TimeOptional

For layers with a finite lifetime (e.g., episodic), the time at which the layer becomes eligible for cleanup. Set by the system; unset for persistent layers.

formatdate-time
SystemManaged boolOptional

Server-set. True for layers managed by the system (e.g., episodic layers created automatically when an objective uses an episodic_key). System-managed layers cannot be assigned to objective stacks via the API and cannot be mutated by clients — their lifecycle is controlled entirely by the runtime.

Info MemoryLayerInfoOptional
CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

EntryCount int64Optional

Number of entries currently in this layer.

formatint32
LastUsedAt TimeOptional

Timestamp of the most recent objective that resolved against this layer. Useful for surfacing unused layers in the dashboard.

formatdate-time
Action BulkWorkspaceApplyResultDataToolOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataToolOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataToolOutcomeActionActionCreated BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataToolOutcomeActionActionUpdated BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataToolOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataToolOutcomeActionActionDeleted BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataToolOutcomeActionActionFailed BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataToolOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataToolOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource ToolOptional

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Config defines the adapter to use for the tool. This is used to determine how the tool is called. For example, if the tool is an HTTP tool, the adapter will be Http. If the tool is an inline tool, the adapter will be Inline.

HTTP ConfigHTTPOptional
RequestMethod ConfigHTTPRequestMethod
formatenum
One of the following:
const ConfigHTTPRequestMethodHTTPMethodUnspecified ConfigHTTPRequestMethod = "HTTP_METHOD_UNSPECIFIED"
const ConfigHTTPRequestMethodGet ConfigHTTPRequestMethod = "GET"
const ConfigHTTPRequestMethodPost ConfigHTTPRequestMethod = "POST"
const ConfigHTTPRequestMethodPut ConfigHTTPRequestMethod = "PUT"
const ConfigHTTPRequestMethodPatch ConfigHTTPRequestMethod = "PATCH"
const ConfigHTTPRequestMethodDelete ConfigHTTPRequestMethod = "DELETE"
Headers map[string, string]Optional
Path stringOptional
Query stringOptional
RequestBodyContentType stringOptional
RequestBodyTemplate stringOptional

These are only used when the request method is a POST, PUT, or PATCH

ToolName stringOptional

The tool name (commonly an “operation id” in OpenAPI specs) to call on the HTTP adapter. This is used to match the tool spec to the correct endpoint on the HTTP adapter. it will be derived from the name of the tool if not provided.

Mcp ConfigMcpOptional
ToolDescription stringOptional
ToolName stringOptional
ToolTitle stringOptional
OpenAPI ConfigOpenAPIOptional
Method stringOptional
OperationID stringOptional
Path stringOptional
Description string
Parameters map[string, unknown]
Status ToolSpecStatus
formatenum
One of the following:
const ToolSpecStatusToolStatusUnspecified ToolSpecStatus = "TOOL_STATUS_UNSPECIFIED"
const ToolSpecStatusToolStatusAvailable ToolSpecStatus = "TOOL_STATUS_AVAILABLE"
const ToolSpecStatusToolStatusOmitted ToolSpecStatus = "TOOL_STATUS_OMITTED"
const ToolSpecStatusToolStatusArchived ToolSpecStatus = "TOOL_STATUS_ARCHIVED"
RequiresApproval boolOptional
Info ToolInfoOptional
CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

ToolSet ResourceMetadataOptional

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Action BulkWorkspaceApplyResultDataToolSetOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionCreated BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionUpdated BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionDeleted BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionFailed BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataToolSetOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataToolSetOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource ToolSetOptional

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Adapter ToolSetAdapterOptional
HTTP ToolSetAdapterHTTPOptional
BaseURL stringOptional
Headers map[string, string]Optional
Mcp ToolSetAdapterMcpOptional
ExcludeTools ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
Headers map[string, string]Optional
IncludeTools ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
ToolApprovals ApprovalRequirementFilterOptional

Approval filters that will automatically set the approval requirement on tools synced from an external source

Always boolOptional
Only ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
URL stringOptional
OpenAPI ToolSetAdapterOpenAPIOptional
BaseURL stringOptional

Base URL for dispatching tool calls. If set, overrides the server resolved from the spec’s servers array.

ExcludeTools ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
Headers map[string, string]Optional

Headers sent when fetching the spec from a URL and when dispatching tool calls.

IncludeTools ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
ServerName stringOptional

Name of the server entry in the spec’s servers array (OpenAPI 3.2 server.name field). Used to select which server URL to dispatch to when base_url is not set. If unset, the first server is used. Ignored when base_url is set.

ToolApprovals ApprovalRequirementFilterOptional

Approval filters that will automatically set the approval requirement on tools synced from an external source

Always boolOptional
Only ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
UploadID stringOptional

ID of a COMPLETE Upload containing the OpenAPI spec document.

URL stringOptional

URL to fetch the OpenAPI spec from. Synced automatically every hour.

Description stringOptional
Info ToolSetInfoOptional

Tool set information

AgentCount int64Optional
CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

LastSync TimeOptional
ToolCount int64Optional
Type stringOptional
Action BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionCreated BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionUpdated BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionDeleted BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionFailed BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataVariationAssignmentOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataVariationAssignmentOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

Resource VariationAssignmentOptional

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 stringOptional
Agent BareMetadataOptional

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 stringOptional
Name stringOptional

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 BareMetadataOptional

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 stringOptional
Name stringOptional

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).

ToolSet BareMetadataOptional

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 stringOptional
Name stringOptional

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).

Action BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionCreated BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionUpdated BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionDeleted BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionFailed BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

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 stringOptional

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

MemoryLayer BareMetadataOptional

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 stringOptional
Name stringOptional

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 int64Optional

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

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

ID string

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

AccountID string

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

CreatedAt Time

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

formatdate-time
ProfileID string

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

WorkspaceID string

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

ExternalID stringOptional

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

Labels map[string, string]Optional

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

type BulkWorkspaceApplyResultData struct{…}

Outcome for a single resource within a bulk apply. The type field is the discriminator string naming the populated outcome oneof variant (e.g., “toolSet”, “memoryEntry”). Every outcome shell carries an action enum and either a resulting resource snapshot (for ACTION_CREATED, ACTION_UPDATED, ACTION_UNCHANGED, ACTION_DELETED) or a google.rpc.Status (for ACTION_FAILED).

Action BulkWorkspaceApplyResultDataAgentOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionCreated BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionUpdated BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionDeleted BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionFailed BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataAgentOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataAgentOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource AgentOptional

Agent resource

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Agent specification (user-provided configuration)

Status AgentSpecStatus

Status of the agent

formatenum
One of the following:
const AgentSpecStatusAgentStatusUnspecified AgentSpecStatus = "AGENT_STATUS_UNSPECIFIED"
const AgentSpecStatusAgentStatusDraft AgentSpecStatus = "AGENT_STATUS_DRAFT"
const AgentSpecStatusAgentStatusPublished AgentSpecStatus = "AGENT_STATUS_PUBLISHED"
const AgentSpecStatusAgentStatusArchived AgentSpecStatus = "AGENT_STATUS_ARCHIVED"
VariationSelectionMode AgentSpecVariationSelectionMode

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

formatenum
One of the following:
const AgentSpecVariationSelectionModeVariationSelectionModeUnspecified AgentSpecVariationSelectionMode = "VARIATION_SELECTION_MODE_UNSPECIFIED"
const AgentSpecVariationSelectionModeVariationSelectionModeRandom AgentSpecVariationSelectionMode = "VARIATION_SELECTION_MODE_RANDOM"
const AgentSpecVariationSelectionModeVariationSelectionModeWeighted AgentSpecVariationSelectionMode = "VARIATION_SELECTION_MODE_WEIGHTED"
Description stringOptional

Description of the agent’s purpose

InputDataSchema map[string, unknown]Optional

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.

OutputDefinition map[string, unknown]Optional

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.

WebhookEventsURL stringOptional

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

Info AgentInfoOptional

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

CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

VariationCount int64Optional
Action BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionCreated BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionUpdated BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionDeleted BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionFailed BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataAgentScheduleOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataAgentScheduleOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource AgentScheduleOptional

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

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

AgentScheduleSpec is the user-provided configuration for a schedule.

InitialMessage string

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

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 []ScheduleCalendarOptional

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

Comment stringOptional
DayOfMonth []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
DayOfWeek []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
Hour []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
Minute []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
Month []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
Second []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
Intervals []ScheduleIntervalOptional

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

Every stringOptional
Offset stringOptional

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

Timezone stringOptional

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

Data unknownOptional

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

OverlapPolicy AgentScheduleSpecOverlapPolicyOptional

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

formatenum
One of the following:
const AgentScheduleSpecOverlapPolicyOverlapPolicyUnspecified AgentScheduleSpecOverlapPolicy = "OVERLAP_POLICY_UNSPECIFIED"
const AgentScheduleSpecOverlapPolicyOverlapPolicyAllow AgentScheduleSpecOverlapPolicy = "OVERLAP_POLICY_ALLOW"
const AgentScheduleSpecOverlapPolicyOverlapPolicySkip AgentScheduleSpecOverlapPolicy = "OVERLAP_POLICY_SKIP"
Status AgentScheduleSpecStatusOptional

Lifecycle. Defaults to ACTIVE on create when unspecified.

formatenum
One of the following:
const AgentScheduleSpecStatusAgentScheduleStatusUnspecified AgentScheduleSpecStatus = "AGENT_SCHEDULE_STATUS_UNSPECIFIED"
const AgentScheduleSpecStatusAgentScheduleStatusActive AgentScheduleSpecStatus = "AGENT_SCHEDULE_STATUS_ACTIVE"
const AgentScheduleSpecStatusAgentScheduleStatusPaused AgentScheduleSpecStatus = "AGENT_SCHEDULE_STATUS_PAUSED"
const AgentScheduleSpecStatusAgentScheduleStatusArchived AgentScheduleSpecStatus = "AGENT_SCHEDULE_STATUS_ARCHIVED"
VariationID stringOptional

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

Info AgentScheduleInfoOptional

AgentScheduleInfo provides read-only runtime data about a schedule.

CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

LastFireAt TimeOptional

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

formatdate-time
LastObjectiveID stringOptional

ID of the most recent objective the schedule created.

LastSkippedAt TimeOptional

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

formatdate-time
LastSkipReason stringOptional

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

NextFireAt TimeOptional

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
TotalFires int64Optional

Lifetime count of objectives created by this schedule.

formatint32
Action BulkWorkspaceApplyResultDataAgentVariationOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionCreated BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionUpdated BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionDeleted BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionFailed BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataAgentVariationOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataAgentVariationOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource AgentVariationOptional

AgentVariation resource

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

AgentVariationSpec defines the operational configuration for a variation

CompactionConfig AgentVariationSpecCompactionConfigOptional

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

SummarizationStrategy configures LLM-powered summarization of older conversation turns.

Instructions stringOptional

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

ToolResultClearingStrategy configures clearing of older tool result content.

PreserveRecentResults int64Optional

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
TriggerThreshold float64Optional

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 AgentVariationSpecConstraintsOptional

Execution constraints

MaxSubObjectives int64Optional

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

formatint32
MaxToolCalls int64Optional

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

formatint32
Description stringOptional

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

EnableEpisodicMemory boolOptional

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.

EpisodicMemoryTtl int64Optional

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.

ModelConfig AgentVariationSpecModelConfigOptional

ModelConfig defines the model configuration for a variation

ModelID stringOptional

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

Temperature float64Optional

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

formatfloat
ProgressiveDiscovery AgentVariationSpecProgressiveDiscoveryOptional

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 []stringOptional
MaxTools int64Optional
RerankThreshold float64Optional

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 stringOptional

The system prompt for this variation

Weight int64Optional

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 AgentVariationInfoOptional

AgentVariationInfo provides read-only summary information about a variation

Assignments []VariationAssignmentOptional

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 stringOptional
Agent BareMetadataOptional

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 stringOptional
Name stringOptional

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 BareMetadataOptional

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 stringOptional
Name stringOptional

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).

ToolSet BareMetadataOptional

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 stringOptional
Name stringOptional

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).

CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

FeedbackCount int64Optional

Total number of objective feedbacks received for this variation

formatint32
MemoryLayerAssignments []VariationMemoryLayerAssignmentOptional

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

ID stringOptional

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

MemoryLayer BareMetadataOptional

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 stringOptional
Name stringOptional

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 int64Optional

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
MemoryLayerCount int64Optional

Count of memory layer assignments.

formatint32
Model ResourceMetadataOptional

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Score float64Optional

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
SubAgentCount int64Optional

Number of sub-agents assigned to this variation

formatint32
ToolCount int64Optional

Number of individual tools assigned to this variation

formatint32
ToolSetCount int64Optional

Number of tool sets assigned to this variation

formatint32
Action BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionCreated BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionUpdated BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionDeleted BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionFailed BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataMemoryEntryOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataMemoryEntryOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource MemoryEntryOptional

MemoryEntry is a single keyed value within a MemoryLayer. Entries are addressed by their key, which follows the S3 object key safe-character convention (see MemoryEntrySpec.key for the full rule). Keys are unique within a single layer; the same key may appear in multiple layers, in which case the LIFO stack-walk determines which one wins for a given objective.

MemoryEntry is the summary shape, returned by ListMemoryEntries. It does not carry the entry body — callers that need the body must fetch the entry individually via GetMemoryEntry, which returns a MemoryEntryDetail.

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

MemoryEntrySpec is the metadata portion of an entry — the fields that identify and describe it, without the body. It appears on both the summary (MemoryEntry) and detail (MemoryEntryDetail) views.

Key string

The lookup key for this entry within its layer. Must conform to the S3 object key safe-characters spec: ASCII alphanumerics and the special characters !, -, _, ., *, ’, (, ), and /. Forward slashes may be used to suggest hierarchy (e.g., “skills/postmortem/write”), but lookups are flat — the key is a single opaque string, not a path.

Additional rules enforced by the service:

  • May not begin or end with /
  • May not contain consecutive slashes (//)
  • May not begin with reserved prefixes (cadenya/, system/)
  • Case-sensitive
  • Unique within the parent layer

For skills entries, this key is also the id the model passes to memory_load_skill when it decides to load the entry’s content.

Description stringOptional

One-line “when to use this” hint shown in the frontmatter manifest for skills entries. The model uses this to decide whether to load the body, so it should be written for the model as the audience. Ignored for layer types that do not advertise frontmatter.

Info MemoryEntryInfoOptional
CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

MemoryLayer ResourceMetadataOptional

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Action BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionCreated BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionUpdated BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionDeleted BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionFailed BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataMemoryLayerOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataMemoryLayerOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource MemoryLayerOptional

MemoryLayer is a named container of memory entries that can be composed into an objective’s memory stack. Layers are workspace-scoped resources. The layer type controls how its entries participate in the agent loop — see MemoryLayerType for details.

See “Memory stack composition” above for how layers compose at lookup time.

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Type MemoryLayerSpecType
formatenum
One of the following:
const MemoryLayerSpecTypeMemoryLayerTypeUnspecified MemoryLayerSpecType = "MEMORY_LAYER_TYPE_UNSPECIFIED"
const MemoryLayerSpecTypeMemoryLayerTypeEpisodic MemoryLayerSpecType = "MEMORY_LAYER_TYPE_EPISODIC"
const MemoryLayerSpecTypeMemoryLayerTypeSkills MemoryLayerSpecType = "MEMORY_LAYER_TYPE_SKILLS"
Description stringOptional

Human-readable description of the layer’s purpose. Encouraged for user-created layers; system-managed layers may have a generated description.

ExpiresAt TimeOptional

For layers with a finite lifetime (e.g., episodic), the time at which the layer becomes eligible for cleanup. Set by the system; unset for persistent layers.

formatdate-time
SystemManaged boolOptional

Server-set. True for layers managed by the system (e.g., episodic layers created automatically when an objective uses an episodic_key). System-managed layers cannot be assigned to objective stacks via the API and cannot be mutated by clients — their lifecycle is controlled entirely by the runtime.

Info MemoryLayerInfoOptional
CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

EntryCount int64Optional

Number of entries currently in this layer.

formatint32
LastUsedAt TimeOptional

Timestamp of the most recent objective that resolved against this layer. Useful for surfacing unused layers in the dashboard.

formatdate-time
Action BulkWorkspaceApplyResultDataToolOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataToolOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataToolOutcomeActionActionCreated BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataToolOutcomeActionActionUpdated BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataToolOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataToolOutcomeActionActionDeleted BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataToolOutcomeActionActionFailed BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataToolOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataToolOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource ToolOptional

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Config defines the adapter to use for the tool. This is used to determine how the tool is called. For example, if the tool is an HTTP tool, the adapter will be Http. If the tool is an inline tool, the adapter will be Inline.

HTTP ConfigHTTPOptional
RequestMethod ConfigHTTPRequestMethod
formatenum
One of the following:
const ConfigHTTPRequestMethodHTTPMethodUnspecified ConfigHTTPRequestMethod = "HTTP_METHOD_UNSPECIFIED"
const ConfigHTTPRequestMethodGet ConfigHTTPRequestMethod = "GET"
const ConfigHTTPRequestMethodPost ConfigHTTPRequestMethod = "POST"
const ConfigHTTPRequestMethodPut ConfigHTTPRequestMethod = "PUT"
const ConfigHTTPRequestMethodPatch ConfigHTTPRequestMethod = "PATCH"
const ConfigHTTPRequestMethodDelete ConfigHTTPRequestMethod = "DELETE"
Headers map[string, string]Optional
Path stringOptional
Query stringOptional
RequestBodyContentType stringOptional
RequestBodyTemplate stringOptional

These are only used when the request method is a POST, PUT, or PATCH

ToolName stringOptional

The tool name (commonly an “operation id” in OpenAPI specs) to call on the HTTP adapter. This is used to match the tool spec to the correct endpoint on the HTTP adapter. it will be derived from the name of the tool if not provided.

Mcp ConfigMcpOptional
ToolDescription stringOptional
ToolName stringOptional
ToolTitle stringOptional
OpenAPI ConfigOpenAPIOptional
Method stringOptional
OperationID stringOptional
Path stringOptional
Description string
Parameters map[string, unknown]
Status ToolSpecStatus
formatenum
One of the following:
const ToolSpecStatusToolStatusUnspecified ToolSpecStatus = "TOOL_STATUS_UNSPECIFIED"
const ToolSpecStatusToolStatusAvailable ToolSpecStatus = "TOOL_STATUS_AVAILABLE"
const ToolSpecStatusToolStatusOmitted ToolSpecStatus = "TOOL_STATUS_OMITTED"
const ToolSpecStatusToolStatusArchived ToolSpecStatus = "TOOL_STATUS_ARCHIVED"
RequiresApproval boolOptional
Info ToolInfoOptional
CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

ToolSet ResourceMetadataOptional

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Action BulkWorkspaceApplyResultDataToolSetOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionCreated BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionUpdated BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionDeleted BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionFailed BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataToolSetOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataToolSetOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource ToolSetOptional

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Adapter ToolSetAdapterOptional
HTTP ToolSetAdapterHTTPOptional
BaseURL stringOptional
Headers map[string, string]Optional
Mcp ToolSetAdapterMcpOptional
ExcludeTools ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
Headers map[string, string]Optional
IncludeTools ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
ToolApprovals ApprovalRequirementFilterOptional

Approval filters that will automatically set the approval requirement on tools synced from an external source

Always boolOptional
Only ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
URL stringOptional
OpenAPI ToolSetAdapterOpenAPIOptional
BaseURL stringOptional

Base URL for dispatching tool calls. If set, overrides the server resolved from the spec’s servers array.

ExcludeTools ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
Headers map[string, string]Optional

Headers sent when fetching the spec from a URL and when dispatching tool calls.

IncludeTools ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
ServerName stringOptional

Name of the server entry in the spec’s servers array (OpenAPI 3.2 server.name field). Used to select which server URL to dispatch to when base_url is not set. If unset, the first server is used. Ignored when base_url is set.

ToolApprovals ApprovalRequirementFilterOptional

Approval filters that will automatically set the approval requirement on tools synced from an external source

Always boolOptional
Only ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
UploadID stringOptional

ID of a COMPLETE Upload containing the OpenAPI spec document.

URL stringOptional

URL to fetch the OpenAPI spec from. Synced automatically every hour.

Description stringOptional
Info ToolSetInfoOptional

Tool set information

AgentCount int64Optional
CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

LastSync TimeOptional
ToolCount int64Optional
Type stringOptional
Action BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionCreated BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionUpdated BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionDeleted BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionFailed BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataVariationAssignmentOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataVariationAssignmentOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

Resource VariationAssignmentOptional

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 stringOptional
Agent BareMetadataOptional

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 stringOptional
Name stringOptional

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 BareMetadataOptional

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 stringOptional
Name stringOptional

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).

ToolSet BareMetadataOptional

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 stringOptional
Name stringOptional

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).

Action BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionCreated BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionUpdated BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionDeleted BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionFailed BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

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 stringOptional

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

MemoryLayer BareMetadataOptional

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 stringOptional
Name stringOptional

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 int64Optional

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
type BulkWorkspaceApplyResultDataAgentOutcome struct{…}
Action BulkWorkspaceApplyResultDataAgentOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionCreated BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionUpdated BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionDeleted BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataAgentOutcomeActionActionFailed BulkWorkspaceApplyResultDataAgentOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataAgentOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataAgentOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource AgentOptional

Agent resource

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Agent specification (user-provided configuration)

Status AgentSpecStatus

Status of the agent

formatenum
One of the following:
const AgentSpecStatusAgentStatusUnspecified AgentSpecStatus = "AGENT_STATUS_UNSPECIFIED"
const AgentSpecStatusAgentStatusDraft AgentSpecStatus = "AGENT_STATUS_DRAFT"
const AgentSpecStatusAgentStatusPublished AgentSpecStatus = "AGENT_STATUS_PUBLISHED"
const AgentSpecStatusAgentStatusArchived AgentSpecStatus = "AGENT_STATUS_ARCHIVED"
VariationSelectionMode AgentSpecVariationSelectionMode

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

formatenum
One of the following:
const AgentSpecVariationSelectionModeVariationSelectionModeUnspecified AgentSpecVariationSelectionMode = "VARIATION_SELECTION_MODE_UNSPECIFIED"
const AgentSpecVariationSelectionModeVariationSelectionModeRandom AgentSpecVariationSelectionMode = "VARIATION_SELECTION_MODE_RANDOM"
const AgentSpecVariationSelectionModeVariationSelectionModeWeighted AgentSpecVariationSelectionMode = "VARIATION_SELECTION_MODE_WEIGHTED"
Description stringOptional

Description of the agent’s purpose

InputDataSchema map[string, unknown]Optional

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.

OutputDefinition map[string, unknown]Optional

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.

WebhookEventsURL stringOptional

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

Info AgentInfoOptional

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

CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

VariationCount int64Optional
type BulkWorkspaceApplyResultDataAgentScheduleOutcome struct{…}
Action BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionCreated BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionUpdated BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionDeleted BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataAgentScheduleOutcomeActionActionFailed BulkWorkspaceApplyResultDataAgentScheduleOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataAgentScheduleOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataAgentScheduleOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource AgentScheduleOptional

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

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

AgentScheduleSpec is the user-provided configuration for a schedule.

InitialMessage string

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

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 []ScheduleCalendarOptional

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

Comment stringOptional
DayOfMonth []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
DayOfWeek []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
Hour []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
Minute []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
Month []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
Second []ScheduleRangeOptional
End int64Optional
Start int64Optional
Step int64Optional
Intervals []ScheduleIntervalOptional

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

Every stringOptional
Offset stringOptional

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

Timezone stringOptional

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

Data unknownOptional

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

OverlapPolicy AgentScheduleSpecOverlapPolicyOptional

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

formatenum
One of the following:
const AgentScheduleSpecOverlapPolicyOverlapPolicyUnspecified AgentScheduleSpecOverlapPolicy = "OVERLAP_POLICY_UNSPECIFIED"
const AgentScheduleSpecOverlapPolicyOverlapPolicyAllow AgentScheduleSpecOverlapPolicy = "OVERLAP_POLICY_ALLOW"
const AgentScheduleSpecOverlapPolicyOverlapPolicySkip AgentScheduleSpecOverlapPolicy = "OVERLAP_POLICY_SKIP"
Status AgentScheduleSpecStatusOptional

Lifecycle. Defaults to ACTIVE on create when unspecified.

formatenum
One of the following:
const AgentScheduleSpecStatusAgentScheduleStatusUnspecified AgentScheduleSpecStatus = "AGENT_SCHEDULE_STATUS_UNSPECIFIED"
const AgentScheduleSpecStatusAgentScheduleStatusActive AgentScheduleSpecStatus = "AGENT_SCHEDULE_STATUS_ACTIVE"
const AgentScheduleSpecStatusAgentScheduleStatusPaused AgentScheduleSpecStatus = "AGENT_SCHEDULE_STATUS_PAUSED"
const AgentScheduleSpecStatusAgentScheduleStatusArchived AgentScheduleSpecStatus = "AGENT_SCHEDULE_STATUS_ARCHIVED"
VariationID stringOptional

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

Info AgentScheduleInfoOptional

AgentScheduleInfo provides read-only runtime data about a schedule.

CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

LastFireAt TimeOptional

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

formatdate-time
LastObjectiveID stringOptional

ID of the most recent objective the schedule created.

LastSkippedAt TimeOptional

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

formatdate-time
LastSkipReason stringOptional

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

NextFireAt TimeOptional

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
TotalFires int64Optional

Lifetime count of objectives created by this schedule.

formatint32
type BulkWorkspaceApplyResultDataAgentVariationOutcome struct{…}
Action BulkWorkspaceApplyResultDataAgentVariationOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionCreated BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionUpdated BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionDeleted BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataAgentVariationOutcomeActionActionFailed BulkWorkspaceApplyResultDataAgentVariationOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataAgentVariationOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataAgentVariationOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource AgentVariationOptional

AgentVariation resource

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

AgentVariationSpec defines the operational configuration for a variation

CompactionConfig AgentVariationSpecCompactionConfigOptional

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

SummarizationStrategy configures LLM-powered summarization of older conversation turns.

Instructions stringOptional

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

ToolResultClearingStrategy configures clearing of older tool result content.

PreserveRecentResults int64Optional

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
TriggerThreshold float64Optional

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 AgentVariationSpecConstraintsOptional

Execution constraints

MaxSubObjectives int64Optional

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

formatint32
MaxToolCalls int64Optional

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

formatint32
Description stringOptional

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

EnableEpisodicMemory boolOptional

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.

EpisodicMemoryTtl int64Optional

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.

ModelConfig AgentVariationSpecModelConfigOptional

ModelConfig defines the model configuration for a variation

ModelID stringOptional

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

Temperature float64Optional

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

formatfloat
ProgressiveDiscovery AgentVariationSpecProgressiveDiscoveryOptional

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 []stringOptional
MaxTools int64Optional
RerankThreshold float64Optional

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 stringOptional

The system prompt for this variation

Weight int64Optional

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 AgentVariationInfoOptional

AgentVariationInfo provides read-only summary information about a variation

Assignments []VariationAssignmentOptional

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 stringOptional
Agent BareMetadataOptional

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 stringOptional
Name stringOptional

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 BareMetadataOptional

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 stringOptional
Name stringOptional

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).

ToolSet BareMetadataOptional

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 stringOptional
Name stringOptional

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).

CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

FeedbackCount int64Optional

Total number of objective feedbacks received for this variation

formatint32
MemoryLayerAssignments []VariationMemoryLayerAssignmentOptional

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

ID stringOptional

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

MemoryLayer BareMetadataOptional

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 stringOptional
Name stringOptional

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 int64Optional

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
MemoryLayerCount int64Optional

Count of memory layer assignments.

formatint32
Model ResourceMetadataOptional

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Score float64Optional

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
SubAgentCount int64Optional

Number of sub-agents assigned to this variation

formatint32
ToolCount int64Optional

Number of individual tools assigned to this variation

formatint32
ToolSetCount int64Optional

Number of tool sets assigned to this variation

formatint32
type BulkWorkspaceApplyResultDataMemoryEntryOutcome struct{…}
Action BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionCreated BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionUpdated BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionDeleted BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataMemoryEntryOutcomeActionActionFailed BulkWorkspaceApplyResultDataMemoryEntryOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataMemoryEntryOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataMemoryEntryOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource MemoryEntryOptional

MemoryEntry is a single keyed value within a MemoryLayer. Entries are addressed by their key, which follows the S3 object key safe-character convention (see MemoryEntrySpec.key for the full rule). Keys are unique within a single layer; the same key may appear in multiple layers, in which case the LIFO stack-walk determines which one wins for a given objective.

MemoryEntry is the summary shape, returned by ListMemoryEntries. It does not carry the entry body — callers that need the body must fetch the entry individually via GetMemoryEntry, which returns a MemoryEntryDetail.

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

MemoryEntrySpec is the metadata portion of an entry — the fields that identify and describe it, without the body. It appears on both the summary (MemoryEntry) and detail (MemoryEntryDetail) views.

Key string

The lookup key for this entry within its layer. Must conform to the S3 object key safe-characters spec: ASCII alphanumerics and the special characters !, -, _, ., *, ’, (, ), and /. Forward slashes may be used to suggest hierarchy (e.g., “skills/postmortem/write”), but lookups are flat — the key is a single opaque string, not a path.

Additional rules enforced by the service:

  • May not begin or end with /
  • May not contain consecutive slashes (//)
  • May not begin with reserved prefixes (cadenya/, system/)
  • Case-sensitive
  • Unique within the parent layer

For skills entries, this key is also the id the model passes to memory_load_skill when it decides to load the entry’s content.

Description stringOptional

One-line “when to use this” hint shown in the frontmatter manifest for skills entries. The model uses this to decide whether to load the body, so it should be written for the model as the audience. Ignored for layer types that do not advertise frontmatter.

Info MemoryEntryInfoOptional
CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

MemoryLayer ResourceMetadataOptional

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

type BulkWorkspaceApplyResultDataMemoryLayerOutcome struct{…}
Action BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionCreated BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionUpdated BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionDeleted BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataMemoryLayerOutcomeActionActionFailed BulkWorkspaceApplyResultDataMemoryLayerOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataMemoryLayerOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataMemoryLayerOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource MemoryLayerOptional

MemoryLayer is a named container of memory entries that can be composed into an objective’s memory stack. Layers are workspace-scoped resources. The layer type controls how its entries participate in the agent loop — see MemoryLayerType for details.

See “Memory stack composition” above for how layers compose at lookup time.

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Type MemoryLayerSpecType
formatenum
One of the following:
const MemoryLayerSpecTypeMemoryLayerTypeUnspecified MemoryLayerSpecType = "MEMORY_LAYER_TYPE_UNSPECIFIED"
const MemoryLayerSpecTypeMemoryLayerTypeEpisodic MemoryLayerSpecType = "MEMORY_LAYER_TYPE_EPISODIC"
const MemoryLayerSpecTypeMemoryLayerTypeSkills MemoryLayerSpecType = "MEMORY_LAYER_TYPE_SKILLS"
Description stringOptional

Human-readable description of the layer’s purpose. Encouraged for user-created layers; system-managed layers may have a generated description.

ExpiresAt TimeOptional

For layers with a finite lifetime (e.g., episodic), the time at which the layer becomes eligible for cleanup. Set by the system; unset for persistent layers.

formatdate-time
SystemManaged boolOptional

Server-set. True for layers managed by the system (e.g., episodic layers created automatically when an objective uses an episodic_key). System-managed layers cannot be assigned to objective stacks via the API and cannot be mutated by clients — their lifecycle is controlled entirely by the runtime.

Info MemoryLayerInfoOptional
CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

EntryCount int64Optional

Number of entries currently in this layer.

formatint32
LastUsedAt TimeOptional

Timestamp of the most recent objective that resolved against this layer. Useful for surfacing unused layers in the dashboard.

formatdate-time
type BulkWorkspaceApplyResultDataToolOutcome struct{…}
Action BulkWorkspaceApplyResultDataToolOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataToolOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataToolOutcomeActionActionCreated BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataToolOutcomeActionActionUpdated BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataToolOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataToolOutcomeActionActionDeleted BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataToolOutcomeActionActionFailed BulkWorkspaceApplyResultDataToolOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataToolOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataToolOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource ToolOptional

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Config defines the adapter to use for the tool. This is used to determine how the tool is called. For example, if the tool is an HTTP tool, the adapter will be Http. If the tool is an inline tool, the adapter will be Inline.

HTTP ConfigHTTPOptional
RequestMethod ConfigHTTPRequestMethod
formatenum
One of the following:
const ConfigHTTPRequestMethodHTTPMethodUnspecified ConfigHTTPRequestMethod = "HTTP_METHOD_UNSPECIFIED"
const ConfigHTTPRequestMethodGet ConfigHTTPRequestMethod = "GET"
const ConfigHTTPRequestMethodPost ConfigHTTPRequestMethod = "POST"
const ConfigHTTPRequestMethodPut ConfigHTTPRequestMethod = "PUT"
const ConfigHTTPRequestMethodPatch ConfigHTTPRequestMethod = "PATCH"
const ConfigHTTPRequestMethodDelete ConfigHTTPRequestMethod = "DELETE"
Headers map[string, string]Optional
Path stringOptional
Query stringOptional
RequestBodyContentType stringOptional
RequestBodyTemplate stringOptional

These are only used when the request method is a POST, PUT, or PATCH

ToolName stringOptional

The tool name (commonly an “operation id” in OpenAPI specs) to call on the HTTP adapter. This is used to match the tool spec to the correct endpoint on the HTTP adapter. it will be derived from the name of the tool if not provided.

Mcp ConfigMcpOptional
ToolDescription stringOptional
ToolName stringOptional
ToolTitle stringOptional
OpenAPI ConfigOpenAPIOptional
Method stringOptional
OperationID stringOptional
Path stringOptional
Description string
Parameters map[string, unknown]
Status ToolSpecStatus
formatenum
One of the following:
const ToolSpecStatusToolStatusUnspecified ToolSpecStatus = "TOOL_STATUS_UNSPECIFIED"
const ToolSpecStatusToolStatusAvailable ToolSpecStatus = "TOOL_STATUS_AVAILABLE"
const ToolSpecStatusToolStatusOmitted ToolSpecStatus = "TOOL_STATUS_OMITTED"
const ToolSpecStatusToolStatusArchived ToolSpecStatus = "TOOL_STATUS_ARCHIVED"
RequiresApproval boolOptional
Info ToolInfoOptional
CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

ToolSet ResourceMetadataOptional

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

type BulkWorkspaceApplyResultDataToolSetOutcome struct{…}
Action BulkWorkspaceApplyResultDataToolSetOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionCreated BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionUpdated BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionDeleted BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataToolSetOutcomeActionActionFailed BulkWorkspaceApplyResultDataToolSetOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataToolSetOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataToolSetOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

ExternalID stringOptional
Resource ToolSetOptional

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

ID string

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

AccountID string

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

CreatedAt 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

ProfileID string

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

WorkspaceID string

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

BundleKey stringOptional

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.

ExternalID stringOptional

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

Labels map[string, string]Optional

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

Adapter ToolSetAdapterOptional
HTTP ToolSetAdapterHTTPOptional
BaseURL stringOptional
Headers map[string, string]Optional
Mcp ToolSetAdapterMcpOptional
ExcludeTools ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
Headers map[string, string]Optional
IncludeTools ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
ToolApprovals ApprovalRequirementFilterOptional

Approval filters that will automatically set the approval requirement on tools synced from an external source

Always boolOptional
Only ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
URL stringOptional
OpenAPI ToolSetAdapterOpenAPIOptional
BaseURL stringOptional

Base URL for dispatching tool calls. If set, overrides the server resolved from the spec’s servers array.

ExcludeTools ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
Headers map[string, string]Optional

Headers sent when fetching the spec from a URL and when dispatching tool calls.

IncludeTools ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
ServerName stringOptional

Name of the server entry in the spec’s servers array (OpenAPI 3.2 server.name field). Used to select which server URL to dispatch to when base_url is not set. If unset, the first server is used. Ignored when base_url is set.

ToolApprovals ApprovalRequirementFilterOptional

Approval filters that will automatically set the approval requirement on tools synced from an external source

Always boolOptional
Only ToolFilterOptional

Top-level filter with simple boolean logic (no nesting)

Operator ToolFilterOperator
formatenum
One of the following:
const ToolFilterOperatorOperatorUnspecified ToolFilterOperator = "OPERATOR_UNSPECIFIED"
const ToolFilterOperatorOperatorAnd ToolFilterOperator = "OPERATOR_AND"
const ToolFilterOperatorOperatorOr ToolFilterOperator = "OPERATOR_OR"
Filters []AttributeFilterOptional
Attribute AttributeFilterAttribute
formatenum
One of the following:
const AttributeFilterAttributeAttributeUnspecified AttributeFilterAttribute = "ATTRIBUTE_UNSPECIFIED"
const AttributeFilterAttributeAttributeName AttributeFilterAttribute = "ATTRIBUTE_NAME"
const AttributeFilterAttributeAttributeTitle AttributeFilterAttribute = "ATTRIBUTE_TITLE"
const AttributeFilterAttributeAttributeDescription AttributeFilterAttribute = "ATTRIBUTE_DESCRIPTION"
Matcher StringMatcherOptional

String matching operations

CaseSensitive boolOptional
Contains stringOptional
EndsWith stringOptional
Exact stringOptional
Regex stringOptional
StartsWith stringOptional
UploadID stringOptional

ID of a COMPLETE Upload containing the OpenAPI spec document.

URL stringOptional

URL to fetch the OpenAPI spec from. Synced automatically every hour.

Description stringOptional
Info ToolSetInfoOptional

Tool set information

AgentCount int64Optional
CreatedBy ProfileOptional

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.

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…”)

AccountID 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

ProfileID string
ExternalID stringOptional

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

Labels map[string, string]Optional

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

Configuration for a profile.

Type ProfileSpecType

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

formatenum
One of the following:
const ProfileSpecTypeProfileTypeUnspecified ProfileSpecType = "PROFILE_TYPE_UNSPECIFIED"
const ProfileSpecTypeProfileTypeUser ProfileSpecType = "PROFILE_TYPE_USER"
const ProfileSpecTypeProfileTypeAPIKey ProfileSpecType = "PROFILE_TYPE_API_KEY"
const ProfileSpecTypeProfileTypeSystem ProfileSpecType = "PROFILE_TYPE_SYSTEM"
Email stringOptional

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

Name stringOptional

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

LastSync TimeOptional
ToolCount int64Optional
type BulkWorkspaceApplyResultDataVariationAssignmentOutcome struct{…}
Action BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionCreated BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionUpdated BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionDeleted BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataVariationAssignmentOutcomeActionActionFailed BulkWorkspaceApplyResultDataVariationAssignmentOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataVariationAssignmentOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataVariationAssignmentOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

Resource VariationAssignmentOptional

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 stringOptional
Agent BareMetadataOptional

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 stringOptional
Name stringOptional

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 BareMetadataOptional

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 stringOptional
Name stringOptional

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).

ToolSet BareMetadataOptional

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 stringOptional
Name stringOptional

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).

type BulkWorkspaceApplyResultDataVariationMemoryLayerOutcome struct{…}
Action BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionOptional
formatenum
One of the following:
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionUnspecified BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_UNSPECIFIED"
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionCreated BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_CREATED"
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionUpdated BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_UPDATED"
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionUnchanged BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_UNCHANGED"
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionDeleted BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_DELETED"
const BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeActionActionFailed BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeAction = "ACTION_FAILED"
Error BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeErrorOptional

The Status type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by gRPC. Each Status message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the API Design Guide.

Code int64Optional

The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code].

formatint32
Details []BulkWorkspaceApplyResultDataVariationMemoryLayerOutcomeErrorDetailOptional

A list of messages that carry the error details. There is a common set of message types for APIs to use.

Type stringOptional

The type of the serialized message.

Message stringOptional

A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the [google.rpc.Status.details][google.rpc.Status.details] field, or localized by the client.

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 stringOptional

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

MemoryLayer BareMetadataOptional

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 stringOptional
Name stringOptional

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 int64Optional

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