## List per-resource results for a bulk workspace apply **get** `/v1/workspaces/{workspaceId}/bulk_workspace_applies/{bulkWorkspaceApplyId}/results` Lists each resource action recorded by a bulk workspace apply operation. ### Path Parameters - `workspaceId: string` - `bulkWorkspaceApplyId: string` ### Query Parameters - `action: optional "ACTION_UNSPECIFIED" or "ACTION_CREATED" or "ACTION_UPDATED" or 3 more` Filter by action. - `"ACTION_UNSPECIFIED"` - `"ACTION_CREATED"` - `"ACTION_UPDATED"` - `"ACTION_UNCHANGED"` - `"ACTION_DELETED"` - `"ACTION_FAILED"` - `cursor: optional string` Pagination cursor from previous response - `limit: optional number` Maximum number of results to return - `sortOrder: optional string` Sort order for results (asc or desc by creation time) - `type: optional string` Filter by data.type discriminator (e.g., "toolSet", "memoryEntry"). ### Returns - `items: optional array of BulkWorkspaceApplyResult` - `data: BulkWorkspaceApplyResultData` 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). - `agent: optional BulkWorkspaceApplyResultDataAgentOutcome` - `action: optional "ACTION_UNSPECIFIED" or "ACTION_CREATED" or "ACTION_UPDATED" or 3 more` - `"ACTION_UNSPECIFIED"` - `"ACTION_CREATED"` - `"ACTION_UPDATED"` - `"ACTION_UNCHANGED"` - `"ACTION_DELETED"` - `"ACTION_FAILED"` - `error: optional object { code, details, message }` 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](https://github.com/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](https://cloud.google.com/apis/design/errors). - `code: optional number` The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code]. - `details: optional array of object { "@type" }` A list of messages that carry the error details. There is a common set of message types for APIs to use. - `"@type": optional string` The type of the serialized message. - `message: optional string` 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: optional string` - `resource: optional Agent` Agent resource - `metadata: ResourceMetadata` 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: string` Timestamp when this resource was created - `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: optional string` Optional bundle ownership key. When set, indicates the resource is managed by a configuration bundle identified by this key. Used by BulkWorkspaceResources.Apply to track which resources belong to which bundle for reconciliation / soft-delete on re-apply. - `externalId: optional string` External ID for the resource (e.g., a workflow ID from an external system) - `labels: optional map[string]` Arbitrary key-value pairs for categorization and filtering Examples: {"environment": "production", "team": "platform", "version": "v2"} - `spec: AgentSpec` Agent specification (user-provided configuration) - `status: "AGENT_STATUS_UNSPECIFIED" or "AGENT_STATUS_DRAFT" or "AGENT_STATUS_PUBLISHED" or "AGENT_STATUS_ARCHIVED"` Status of the agent - `"AGENT_STATUS_UNSPECIFIED"` - `"AGENT_STATUS_DRAFT"` - `"AGENT_STATUS_PUBLISHED"` - `"AGENT_STATUS_ARCHIVED"` - `variationSelectionMode: "VARIATION_SELECTION_MODE_UNSPECIFIED" or "VARIATION_SELECTION_MODE_RANDOM" or "VARIATION_SELECTION_MODE_WEIGHTED"` Controls how variations are automatically selected when creating objectives Defaults to RANDOM when unspecified - `"VARIATION_SELECTION_MODE_UNSPECIFIED"` - `"VARIATION_SELECTION_MODE_RANDOM"` - `"VARIATION_SELECTION_MODE_WEIGHTED"` - `description: optional string` Description of the agent's purpose - `inputDataSchema: optional map[unknown]` 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: optional map[unknown]` 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: optional string` The URL that Cadenya will send events for any objective assigned to the agent. - `info: optional AgentInfo` AgentInfo contains simple information about an agent for display or quick reference - `createdBy: optional Profile` A profile identifies a user or non-human principal (such as an API key) at the account level. Profiles are account-scoped and can be granted access to multiple workspaces. - `metadata: AccountResourceMetadata` 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: optional string` External ID for the resource (e.g., a workflow ID from an external system) - `labels: optional map[string]` Arbitrary key-value pairs for categorization and filtering Examples: {"environment": "production", "team": "platform", "version": "v2"} - `spec: ProfileSpec` Configuration for a profile. - `type: "PROFILE_TYPE_UNSPECIFIED" or "PROFILE_TYPE_USER" or "PROFILE_TYPE_API_KEY" or "PROFILE_TYPE_SYSTEM"` Whether this profile represents a human user, an API key, or a system principal. - `"PROFILE_TYPE_UNSPECIFIED"` - `"PROFILE_TYPE_USER"` - `"PROFILE_TYPE_API_KEY"` - `"PROFILE_TYPE_SYSTEM"` - `email: optional string` Email address of the profile. Required and unique within an account for user profiles. - `name: optional string` Display name (e.g., "Bobby Tables"). - `variationCount: optional number` - `agentSchedule: optional BulkWorkspaceApplyResultDataAgentScheduleOutcome` - `action: optional "ACTION_UNSPECIFIED" or "ACTION_CREATED" or "ACTION_UPDATED" or 3 more` - `"ACTION_UNSPECIFIED"` - `"ACTION_CREATED"` - `"ACTION_UPDATED"` - `"ACTION_UNCHANGED"` - `"ACTION_DELETED"` - `"ACTION_FAILED"` - `error: optional object { code, details, message }` 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](https://github.com/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](https://cloud.google.com/apis/design/errors). - `code: optional number` The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code]. - `details: optional array of object { "@type" }` A list of messages that carry the error details. There is a common set of message types for APIs to use. - `"@type": optional string` The type of the serialized message. - `message: optional string` 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: optional string` - `resource: optional AgentSchedule` AgentSchedule resource — a recurring trigger attached to an agent that creates objectives on its cadence. - `metadata: ResourceMetadata` Standard metadata for persistent, named resources (e.g., agents, tools, prompts) - `spec: AgentScheduleSpec` 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: AgentScheduleSpecSchedule` 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: optional array of ScheduleCalendar` Wall-clock rules. May be empty if `intervals` is non-empty. - `comment: optional string` - `dayOfMonth: optional array of ScheduleRange` - `end: optional number` - `start: optional number` - `step: optional number` - `dayOfWeek: optional array of ScheduleRange` - `end: optional number` - `start: optional number` - `step: optional number` - `hour: optional array of ScheduleRange` - `end: optional number` - `start: optional number` - `step: optional number` - `minute: optional array of ScheduleRange` - `end: optional number` - `start: optional number` - `step: optional number` - `month: optional array of ScheduleRange` - `end: optional number` - `start: optional number` - `step: optional number` - `second: optional array of ScheduleRange` - `end: optional number` - `start: optional number` - `step: optional number` - `intervals: optional array of ScheduleInterval` Duration-based rules. May be empty if `calendars` is non-empty. - `every: optional string` - `offset: optional string` Phase shift within `every`. Must be < `every` (enforced at runtime). - `timezone: optional string` IANA tz name (e.g. "America/New_York"). Required. Applies to calendars; intervals fire on wall-clock cadence anchored in this zone. - `data: optional unknown` Optional input data passed to the objective. If the agent has an input_data_schema, this must satisfy it. - `overlapPolicy: optional "OVERLAP_POLICY_UNSPECIFIED" or "OVERLAP_POLICY_ALLOW" or "OVERLAP_POLICY_SKIP"` What to do when the previous run is still in flight. Defaults to SKIP. - `"OVERLAP_POLICY_UNSPECIFIED"` - `"OVERLAP_POLICY_ALLOW"` - `"OVERLAP_POLICY_SKIP"` - `status: optional "AGENT_SCHEDULE_STATUS_UNSPECIFIED" or "AGENT_SCHEDULE_STATUS_ACTIVE" or "AGENT_SCHEDULE_STATUS_PAUSED" or "AGENT_SCHEDULE_STATUS_ARCHIVED"` Lifecycle. Defaults to ACTIVE on create when unspecified. - `"AGENT_SCHEDULE_STATUS_UNSPECIFIED"` - `"AGENT_SCHEDULE_STATUS_ACTIVE"` - `"AGENT_SCHEDULE_STATUS_PAUSED"` - `"AGENT_SCHEDULE_STATUS_ARCHIVED"` - `variationId: optional string` Optional explicit variation. When unset, the agent's variation_selection_mode chooses per fire. - `info: optional AgentScheduleInfo` AgentScheduleInfo provides read-only runtime data about a schedule. - `createdBy: optional Profile` 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. - `lastFireAt: optional string` When the schedule last fired (regardless of objective outcome). - `lastObjectiveId: optional string` ID of the most recent objective the schedule created. - `lastSkippedAt: optional string` When the schedule most recently skipped a fire (SKIP policy + prior in flight). - `lastSkipReason: optional string` Reason for the most recent skip (e.g. "previous objective still running"). - `nextFireAt: optional string` When the schedule will next fire. Computed from the spec; absent when the schedule is PAUSED/ARCHIVED or has no future fire times. - `totalFires: optional number` Lifetime count of objectives created by this schedule. - `agentVariation: optional BulkWorkspaceApplyResultDataAgentVariationOutcome` - `action: optional "ACTION_UNSPECIFIED" or "ACTION_CREATED" or "ACTION_UPDATED" or 3 more` - `"ACTION_UNSPECIFIED"` - `"ACTION_CREATED"` - `"ACTION_UPDATED"` - `"ACTION_UNCHANGED"` - `"ACTION_DELETED"` - `"ACTION_FAILED"` - `error: optional object { code, details, message }` 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](https://github.com/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](https://cloud.google.com/apis/design/errors). - `code: optional number` The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code]. - `details: optional array of object { "@type" }` A list of messages that carry the error details. There is a common set of message types for APIs to use. - `"@type": optional string` The type of the serialized message. - `message: optional string` 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: optional string` - `resource: optional AgentVariation` AgentVariation resource - `metadata: ResourceMetadata` Standard metadata for persistent, named resources (e.g., agents, tools, prompts) - `spec: AgentVariationSpec` AgentVariationSpec defines the operational configuration for a variation - `compactionConfig: optional AgentVariationSpecCompactionConfig` CompactionConfig defines how context window compaction behaves for objectives using this variation. - `summarization: optional CompactionConfigSummarizationStrategy` SummarizationStrategy configures LLM-powered summarization of older conversation turns. - `instructions: optional string` Custom instructions that guide what the summarizer preserves. Replaces the default summarization prompt entirely. Example: "Preserve all code snippets, variable names, and technical decisions." - `toolResultClearing: optional CompactionConfigToolResultClearingStrategy` ToolResultClearingStrategy configures clearing of older tool result content. - `preserveRecentResults: optional number` 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 - `triggerThreshold: optional number` 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%) - `constraints: optional AgentVariationSpecConstraints` Execution constraints - `maxSubObjectives: optional number` The maximum number of sub-objectives that can be created. 0 means no limit. - `maxToolCalls: optional number` The maximum number of tool calls that can be made. 0 means no limit. - `description: optional string` Human-readable description of what this variation does or when it should be used - `enableEpisodicMemory: optional boolean` 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: optional number` 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: optional AgentVariationSpecModelConfig` ModelConfig defines the model configuration for a variation - `modelId: optional string` The model identifier in family/model format (e.g., "claude/opus-4.6", "claude/sonnet-4.5") - `temperature: optional number` Sampling temperature for model inference (0.0 to 1.0) Lower values produce more deterministic outputs, higher values increase randomness - `progressiveDiscovery: optional AgentVariationSpecProgressiveDiscovery` 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: optional array of string` - `maxTools: optional number` - `rerankThreshold: optional number` 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. - `prompt: optional string` The system prompt for this variation - `weight: optional number` 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. - `info: optional AgentVariationInfo` AgentVariationInfo provides read-only summary information about a variation - `assignments: optional array of VariationAssignment` 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: optional string` - `agent: optional BareMetadata` 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: optional string` - `name: optional string` Human-readable name of the referenced resource, populated by the server on reads for convenience. Absent on references to resources that do not have a name (e.g., objective tasks). - `tool: optional BareMetadata` 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. - `toolSet: optional BareMetadata` 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. - `createdBy: optional Profile` 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. - `feedbackCount: optional number` Total number of objective feedbacks received for this variation - `memoryLayerAssignments: optional array of VariationMemoryLayerAssignment` Read-only list of memory layer assignments for this variation, returned in ascending `position` (bottom → top). Capped at 10 entries. - `id: optional string` Assignment row id — handle for removing the assignment. Distinct from the referenced memory layer's id. - `memoryLayer: optional BareMetadata` 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. - `position: optional number` 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. - `memoryLayerCount: optional number` Count of memory layer assignments. - `model: optional ResourceMetadata` Standard metadata for persistent, named resources (e.g., agents, tools, prompts) - `score: optional number` Thompson Sampling score: posterior mean of Beta(ts_alpha, ts_beta). Range [0, 1] where 0.5 = neutral, >0.5 = positive, <0.5 = negative. - `subAgentCount: optional number` Number of sub-agents assigned to this variation - `toolCount: optional number` Number of individual tools assigned to this variation - `toolSetCount: optional number` Number of tool sets assigned to this variation - `memoryEntry: optional BulkWorkspaceApplyResultDataMemoryEntryOutcome` - `action: optional "ACTION_UNSPECIFIED" or "ACTION_CREATED" or "ACTION_UPDATED" or 3 more` - `"ACTION_UNSPECIFIED"` - `"ACTION_CREATED"` - `"ACTION_UPDATED"` - `"ACTION_UNCHANGED"` - `"ACTION_DELETED"` - `"ACTION_FAILED"` - `error: optional object { code, details, message }` 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](https://github.com/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](https://cloud.google.com/apis/design/errors). - `code: optional number` The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code]. - `details: optional array of object { "@type" }` A list of messages that carry the error details. There is a common set of message types for APIs to use. - `"@type": optional string` The type of the serialized message. - `message: optional string` 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: optional string` - `resource: optional MemoryEntry` 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. - `metadata: ResourceMetadata` Standard metadata for persistent, named resources (e.g., agents, tools, prompts) - `spec: MemoryEntrySpec` 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: optional string` 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: optional MemoryEntryInfo` - `createdBy: optional Profile` 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. - `memoryLayer: optional ResourceMetadata` Standard metadata for persistent, named resources (e.g., agents, tools, prompts) - `memoryLayer: optional BulkWorkspaceApplyResultDataMemoryLayerOutcome` - `action: optional "ACTION_UNSPECIFIED" or "ACTION_CREATED" or "ACTION_UPDATED" or 3 more` - `"ACTION_UNSPECIFIED"` - `"ACTION_CREATED"` - `"ACTION_UPDATED"` - `"ACTION_UNCHANGED"` - `"ACTION_DELETED"` - `"ACTION_FAILED"` - `error: optional object { code, details, message }` 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](https://github.com/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](https://cloud.google.com/apis/design/errors). - `code: optional number` The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code]. - `details: optional array of object { "@type" }` A list of messages that carry the error details. There is a common set of message types for APIs to use. - `"@type": optional string` The type of the serialized message. - `message: optional string` 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: optional string` - `resource: optional MemoryLayer` 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. - `metadata: ResourceMetadata` Standard metadata for persistent, named resources (e.g., agents, tools, prompts) - `spec: MemoryLayerSpec` - `type: "MEMORY_LAYER_TYPE_UNSPECIFIED" or "MEMORY_LAYER_TYPE_EPISODIC" or "MEMORY_LAYER_TYPE_SKILLS"` - `"MEMORY_LAYER_TYPE_UNSPECIFIED"` - `"MEMORY_LAYER_TYPE_EPISODIC"` - `"MEMORY_LAYER_TYPE_SKILLS"` - `description: optional string` Human-readable description of the layer's purpose. Encouraged for user-created layers; system-managed layers may have a generated description. - `expiresAt: optional string` 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. - `systemManaged: optional boolean` 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: optional MemoryLayerInfo` - `createdBy: optional Profile` 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. - `entryCount: optional number` Number of entries currently in this layer. - `lastUsedAt: optional string` Timestamp of the most recent objective that resolved against this layer. Useful for surfacing unused layers in the dashboard. - `tool: optional BulkWorkspaceApplyResultDataToolOutcome` - `action: optional "ACTION_UNSPECIFIED" or "ACTION_CREATED" or "ACTION_UPDATED" or 3 more` - `"ACTION_UNSPECIFIED"` - `"ACTION_CREATED"` - `"ACTION_UPDATED"` - `"ACTION_UNCHANGED"` - `"ACTION_DELETED"` - `"ACTION_FAILED"` - `error: optional object { code, details, message }` 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](https://github.com/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](https://cloud.google.com/apis/design/errors). - `code: optional number` The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code]. - `details: optional array of object { "@type" }` A list of messages that carry the error details. There is a common set of message types for APIs to use. - `"@type": optional string` The type of the serialized message. - `message: optional string` 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: optional string` - `resource: optional Tool` - `metadata: ResourceMetadata` Standard metadata for persistent, named resources (e.g., agents, tools, prompts) - `spec: ToolSpec` - `config: ToolSpecConfig` 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: optional ConfigHTTP` - `requestMethod: "HTTP_METHOD_UNSPECIFIED" or "GET" or "POST" or 3 more` - `"HTTP_METHOD_UNSPECIFIED"` - `"GET"` - `"POST"` - `"PUT"` - `"PATCH"` - `"DELETE"` - `headers: optional map[string]` - `path: optional string` - `query: optional string` - `requestBodyContentType: optional string` - `requestBodyTemplate: optional string` These are only used when the request method is a POST, PUT, or PATCH - `toolName: optional string` 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: optional ConfigMcp` - `toolDescription: optional string` - `toolName: optional string` - `toolTitle: optional string` - `openapi: optional ConfigOpenAPI` - `method: optional string` - `operationId: optional string` - `path: optional string` - `description: string` - `parameters: map[unknown]` - `status: "TOOL_STATUS_UNSPECIFIED" or "TOOL_STATUS_AVAILABLE" or "TOOL_STATUS_OMITTED" or "TOOL_STATUS_ARCHIVED"` - `"TOOL_STATUS_UNSPECIFIED"` - `"TOOL_STATUS_AVAILABLE"` - `"TOOL_STATUS_OMITTED"` - `"TOOL_STATUS_ARCHIVED"` - `requiresApproval: optional boolean` - `info: optional ToolInfo` - `createdBy: optional Profile` 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. - `toolSet: optional ResourceMetadata` Standard metadata for persistent, named resources (e.g., agents, tools, prompts) - `toolSet: optional BulkWorkspaceApplyResultDataToolSetOutcome` - `action: optional "ACTION_UNSPECIFIED" or "ACTION_CREATED" or "ACTION_UPDATED" or 3 more` - `"ACTION_UNSPECIFIED"` - `"ACTION_CREATED"` - `"ACTION_UPDATED"` - `"ACTION_UNCHANGED"` - `"ACTION_DELETED"` - `"ACTION_FAILED"` - `error: optional object { code, details, message }` 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](https://github.com/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](https://cloud.google.com/apis/design/errors). - `code: optional number` The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code]. - `details: optional array of object { "@type" }` A list of messages that carry the error details. There is a common set of message types for APIs to use. - `"@type": optional string` The type of the serialized message. - `message: optional string` 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: optional string` - `resource: optional ToolSet` - `metadata: ResourceMetadata` Standard metadata for persistent, named resources (e.g., agents, tools, prompts) - `spec: ToolSetSpec` - `adapter: optional ToolSetAdapter` - `http: optional ToolSetAdapterHTTP` - `baseUrl: optional string` - `headers: optional map[string]` - `mcp: optional ToolSetAdapterMcp` - `excludeTools: optional ToolFilter` Top-level filter with simple boolean logic (no nesting) - `operator: "OPERATOR_UNSPECIFIED" or "OPERATOR_AND" or "OPERATOR_OR"` - `"OPERATOR_UNSPECIFIED"` - `"OPERATOR_AND"` - `"OPERATOR_OR"` - `filters: optional array of AttributeFilter` - `attribute: "ATTRIBUTE_UNSPECIFIED" or "ATTRIBUTE_NAME" or "ATTRIBUTE_TITLE" or "ATTRIBUTE_DESCRIPTION"` - `"ATTRIBUTE_UNSPECIFIED"` - `"ATTRIBUTE_NAME"` - `"ATTRIBUTE_TITLE"` - `"ATTRIBUTE_DESCRIPTION"` - `matcher: optional StringMatcher` String matching operations - `caseSensitive: optional boolean` - `contains: optional string` - `endsWith: optional string` - `exact: optional string` - `regex: optional string` - `startsWith: optional string` - `headers: optional map[string]` - `includeTools: optional ToolFilter` Top-level filter with simple boolean logic (no nesting) - `toolApprovals: optional ApprovalRequirementFilter` Approval filters that will automatically set the approval requirement on tools synced from an external source - `always: optional boolean` - `only: optional ToolFilter` Top-level filter with simple boolean logic (no nesting) - `url: optional string` - `openapi: optional ToolSetAdapterOpenAPI` - `baseUrl: optional string` Base URL for dispatching tool calls. If set, overrides the server resolved from the spec's servers array. - `excludeTools: optional ToolFilter` Top-level filter with simple boolean logic (no nesting) - `headers: optional map[string]` Headers sent when fetching the spec from a URL and when dispatching tool calls. - `includeTools: optional ToolFilter` Top-level filter with simple boolean logic (no nesting) - `serverName: optional string` 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: optional ApprovalRequirementFilter` Approval filters that will automatically set the approval requirement on tools synced from an external source - `uploadId: optional string` ID of a COMPLETE Upload containing the OpenAPI spec document. - `url: optional string` URL to fetch the OpenAPI spec from. Synced automatically every hour. - `description: optional string` - `info: optional ToolSetInfo` Tool set information - `agentCount: optional number` - `createdBy: optional Profile` 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. - `lastSync: optional string` - `toolCount: optional number` - `type: optional string` - `variationAssignment: optional BulkWorkspaceApplyResultDataVariationAssignmentOutcome` - `action: optional "ACTION_UNSPECIFIED" or "ACTION_CREATED" or "ACTION_UPDATED" or 3 more` - `"ACTION_UNSPECIFIED"` - `"ACTION_CREATED"` - `"ACTION_UPDATED"` - `"ACTION_UNCHANGED"` - `"ACTION_DELETED"` - `"ACTION_FAILED"` - `error: optional object { code, details, message }` 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](https://github.com/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](https://cloud.google.com/apis/design/errors). - `code: optional number` The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code]. - `details: optional array of object { "@type" }` A list of messages that carry the error details. There is a common set of message types for APIs to use. - `"@type": optional string` The type of the serialized message. - `message: optional string` 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: optional VariationAssignment` 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: optional string` - `agent: optional BareMetadata` 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. - `tool: optional BareMetadata` 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. - `toolSet: optional BareMetadata` 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. - `variationMemoryLayer: optional BulkWorkspaceApplyResultDataVariationMemoryLayerOutcome` - `action: optional "ACTION_UNSPECIFIED" or "ACTION_CREATED" or "ACTION_UPDATED" or 3 more` - `"ACTION_UNSPECIFIED"` - `"ACTION_CREATED"` - `"ACTION_UPDATED"` - `"ACTION_UNCHANGED"` - `"ACTION_DELETED"` - `"ACTION_FAILED"` - `error: optional object { code, details, message }` 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](https://github.com/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](https://cloud.google.com/apis/design/errors). - `code: optional number` The status code, which should be an enum value of [google.rpc.Code][google.rpc.Code]. - `details: optional array of object { "@type" }` A list of messages that carry the error details. There is a common set of message types for APIs to use. - `"@type": optional string` The type of the serialized message. - `message: optional string` 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: optional VariationMemoryLayerAssignment` 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: optional string` Assignment row id — handle for removing the assignment. Distinct from the referenced memory layer's id. - `memoryLayer: optional BareMetadata` 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. - `position: optional number` 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. - `metadata: OperationMetadata` 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: string` Timestamp when this operation was created ULID includes timestamp information, but this explicit field enables easier querying - `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: optional string` External ID for the operation (e.g., a workflow ID from an external system) - `labels: optional map[string]` Arbitrary key-value pairs for categorization and filtering Examples: {"priority": "high", "source": "api", "workflow": "onboarding"} - `pagination: optional Page` - `nextCursor: optional string` - `total: optional number` ### Example ```http curl https://api.cadenya.com/v1/workspaces/$WORKSPACE_ID/bulk_workspace_applies/$BULK_WORKSPACE_APPLY_ID/results \ -H "Authorization: Bearer $CADENYA_API_KEY" ``` #### Response ```json { "items": [ { "data": { "agent": { "action": "ACTION_UNSPECIFIED", "error": { "code": 0, "details": [ { "@type": "@type" } ], "message": "message" }, "externalId": "externalId", "resource": { "metadata": { "id": "id", "accountId": "accountId", "createdAt": "2019-12-27T18:11:19.117Z", "name": "name", "profileId": "profileId", "workspaceId": "workspaceId", "bundleKey": "bundleKey", "externalId": "externalId", "labels": { "foo": "string" } }, "spec": { "status": "AGENT_STATUS_UNSPECIFIED", "variationSelectionMode": "VARIATION_SELECTION_MODE_UNSPECIFIED", "description": "description", "inputDataSchema": { "foo": "bar" }, "outputDefinition": { "foo": "bar" }, "webhookEventsUrl": "webhookEventsUrl" }, "info": { "createdBy": { "metadata": { "id": "id", "accountId": "accountId", "name": "name", "profileId": "profileId", "externalId": "externalId", "labels": { "foo": "string" } }, "spec": { "type": "PROFILE_TYPE_UNSPECIFIED", "email": "email", "name": "name" } }, "variationCount": 0 } } }, "agentSchedule": { "action": "ACTION_UNSPECIFIED", "error": { "code": 0, "details": [ { "@type": "@type" } ], "message": "message" }, "externalId": "externalId", "resource": { "metadata": { "id": "id", "accountId": "accountId", "createdAt": "2019-12-27T18:11:19.117Z", "name": "name", "profileId": "profileId", "workspaceId": "workspaceId", "bundleKey": "bundleKey", "externalId": "externalId", "labels": { "foo": "string" } }, "spec": { "initialMessage": "initialMessage", "schedule": { "calendars": [ { "comment": "comment", "dayOfMonth": [ { "end": 0, "start": 0, "step": 0 } ], "dayOfWeek": [ { "end": 0, "start": 0, "step": 0 } ], "hour": [ { "end": 0, "start": 0, "step": 0 } ], "minute": [ { "end": 0, "start": 0, "step": 0 } ], "month": [ { "end": 0, "start": 0, "step": 0 } ], "second": [ { "end": 0, "start": 0, "step": 0 } ] } ], "intervals": [ { "every": "-160513s", "offset": "-160513s" } ], "timezone": "timezone" }, "data": {}, "overlapPolicy": "OVERLAP_POLICY_UNSPECIFIED", "status": "AGENT_SCHEDULE_STATUS_UNSPECIFIED", "variationId": "variationId" }, "info": { "createdBy": { "metadata": { "id": "id", "accountId": "accountId", "name": "name", "profileId": "profileId", "externalId": "externalId", "labels": { "foo": "string" } }, "spec": { "type": "PROFILE_TYPE_UNSPECIFIED", "email": "email", "name": "name" } }, "lastFireAt": "2019-12-27T18:11:19.117Z", "lastObjectiveId": "lastObjectiveId", "lastSkippedAt": "2019-12-27T18:11:19.117Z", "lastSkipReason": "lastSkipReason", "nextFireAt": "2019-12-27T18:11:19.117Z", "totalFires": 0 } } }, "agentVariation": { "action": "ACTION_UNSPECIFIED", "error": { "code": 0, "details": [ { "@type": "@type" } ], "message": "message" }, "externalId": "externalId", "resource": { "metadata": { "id": "id", "accountId": "accountId", "createdAt": "2019-12-27T18:11:19.117Z", "name": "name", "profileId": "profileId", "workspaceId": "workspaceId", "bundleKey": "bundleKey", "externalId": "externalId", "labels": { "foo": "string" } }, "spec": { "compactionConfig": { "summarization": { "instructions": "instructions" }, "toolResultClearing": { "preserveRecentResults": 0 }, "triggerThreshold": 0 }, "constraints": { "maxSubObjectives": 0, "maxToolCalls": 0 }, "description": "description", "enableEpisodicMemory": true, "episodicMemoryTtl": 0, "modelConfig": { "modelId": "modelId", "temperature": 0 }, "progressiveDiscovery": { "hints": [ "string" ], "maxTools": 0, "rerankThreshold": 0 }, "prompt": "prompt", "weight": 0 }, "info": { "assignments": [ { "id": "id", "agent": { "id": "id", "name": "name" }, "tool": { "id": "id", "name": "name" }, "toolSet": { "id": "id", "name": "name" } } ], "createdBy": { "metadata": { "id": "id", "accountId": "accountId", "name": "name", "profileId": "profileId", "externalId": "externalId", "labels": { "foo": "string" } }, "spec": { "type": "PROFILE_TYPE_UNSPECIFIED", "email": "email", "name": "name" } }, "feedbackCount": 0, "memoryLayerAssignments": [ { "id": "id", "memoryLayer": { "id": "id", "name": "name" }, "position": 0 } ], "memoryLayerCount": 0, "model": { "id": "id", "accountId": "accountId", "createdAt": "2019-12-27T18:11:19.117Z", "name": "name", "profileId": "profileId", "workspaceId": "workspaceId", "bundleKey": "bundleKey", "externalId": "externalId", "labels": { "foo": "string" } }, "score": 0, "subAgentCount": 0, "toolCount": 0, "toolSetCount": 0 } } }, "memoryEntry": { "action": "ACTION_UNSPECIFIED", "error": { "code": 0, "details": [ { "@type": "@type" } ], "message": "message" }, "externalId": "externalId", "resource": { "metadata": { "id": "id", "accountId": "accountId", "createdAt": "2019-12-27T18:11:19.117Z", "name": "name", "profileId": "profileId", "workspaceId": "workspaceId", "bundleKey": "bundleKey", "externalId": "externalId", "labels": { "foo": "string" } }, "spec": { "key": "key", "description": "description" }, "info": { "createdBy": { "metadata": { "id": "id", "accountId": "accountId", "name": "name", "profileId": "profileId", "externalId": "externalId", "labels": { "foo": "string" } }, "spec": { "type": "PROFILE_TYPE_UNSPECIFIED", "email": "email", "name": "name" } }, "memoryLayer": { "id": "id", "accountId": "accountId", "createdAt": "2019-12-27T18:11:19.117Z", "name": "name", "profileId": "profileId", "workspaceId": "workspaceId", "bundleKey": "bundleKey", "externalId": "externalId", "labels": { "foo": "string" } } } } }, "memoryLayer": { "action": "ACTION_UNSPECIFIED", "error": { "code": 0, "details": [ { "@type": "@type" } ], "message": "message" }, "externalId": "externalId", "resource": { "metadata": { "id": "id", "accountId": "accountId", "createdAt": "2019-12-27T18:11:19.117Z", "name": "name", "profileId": "profileId", "workspaceId": "workspaceId", "bundleKey": "bundleKey", "externalId": "externalId", "labels": { "foo": "string" } }, "spec": { "type": "MEMORY_LAYER_TYPE_UNSPECIFIED", "description": "description", "expiresAt": "2019-12-27T18:11:19.117Z", "systemManaged": true }, "info": { "createdBy": { "metadata": { "id": "id", "accountId": "accountId", "name": "name", "profileId": "profileId", "externalId": "externalId", "labels": { "foo": "string" } }, "spec": { "type": "PROFILE_TYPE_UNSPECIFIED", "email": "email", "name": "name" } }, "entryCount": 0, "lastUsedAt": "2019-12-27T18:11:19.117Z" } } }, "tool": { "action": "ACTION_UNSPECIFIED", "error": { "code": 0, "details": [ { "@type": "@type" } ], "message": "message" }, "externalId": "externalId", "resource": { "metadata": { "id": "id", "accountId": "accountId", "createdAt": "2019-12-27T18:11:19.117Z", "name": "name", "profileId": "profileId", "workspaceId": "workspaceId", "bundleKey": "bundleKey", "externalId": "externalId", "labels": { "foo": "string" } }, "spec": { "config": { "http": { "requestMethod": "HTTP_METHOD_UNSPECIFIED", "headers": { "foo": "string" }, "path": "path", "query": "query", "requestBodyContentType": "requestBodyContentType", "requestBodyTemplate": "requestBodyTemplate", "toolName": "toolName" }, "mcp": { "toolDescription": "toolDescription", "toolName": "toolName", "toolTitle": "toolTitle" }, "openapi": { "method": "method", "operationId": "operationId", "path": "path" } }, "description": "description", "parameters": { "foo": "bar" }, "status": "TOOL_STATUS_UNSPECIFIED", "requiresApproval": true }, "info": { "createdBy": { "metadata": { "id": "id", "accountId": "accountId", "name": "name", "profileId": "profileId", "externalId": "externalId", "labels": { "foo": "string" } }, "spec": { "type": "PROFILE_TYPE_UNSPECIFIED", "email": "email", "name": "name" } }, "toolSet": { "id": "id", "accountId": "accountId", "createdAt": "2019-12-27T18:11:19.117Z", "name": "name", "profileId": "profileId", "workspaceId": "workspaceId", "bundleKey": "bundleKey", "externalId": "externalId", "labels": { "foo": "string" } } } } }, "toolSet": { "action": "ACTION_UNSPECIFIED", "error": { "code": 0, "details": [ { "@type": "@type" } ], "message": "message" }, "externalId": "externalId", "resource": { "metadata": { "id": "id", "accountId": "accountId", "createdAt": "2019-12-27T18:11:19.117Z", "name": "name", "profileId": "profileId", "workspaceId": "workspaceId", "bundleKey": "bundleKey", "externalId": "externalId", "labels": { "foo": "string" } }, "spec": { "adapter": { "http": { "baseUrl": "baseUrl", "headers": { "foo": "string" } }, "mcp": { "excludeTools": { "operator": "OPERATOR_UNSPECIFIED", "filters": [ { "attribute": "ATTRIBUTE_UNSPECIFIED", "matcher": { "caseSensitive": true, "contains": "contains", "endsWith": "endsWith", "exact": "exact", "regex": "regex", "startsWith": "startsWith" } } ] }, "headers": { "foo": "string" }, "includeTools": { "operator": "OPERATOR_UNSPECIFIED", "filters": [ { "attribute": "ATTRIBUTE_UNSPECIFIED", "matcher": { "caseSensitive": true, "contains": "contains", "endsWith": "endsWith", "exact": "exact", "regex": "regex", "startsWith": "startsWith" } } ] }, "toolApprovals": { "always": true, "only": { "operator": "OPERATOR_UNSPECIFIED", "filters": [ { "attribute": "ATTRIBUTE_UNSPECIFIED", "matcher": { "caseSensitive": true, "contains": "contains", "endsWith": "endsWith", "exact": "exact", "regex": "regex", "startsWith": "startsWith" } } ] } }, "url": "url" }, "openapi": { "baseUrl": "baseUrl", "excludeTools": { "operator": "OPERATOR_UNSPECIFIED", "filters": [ { "attribute": "ATTRIBUTE_UNSPECIFIED", "matcher": { "caseSensitive": true, "contains": "contains", "endsWith": "endsWith", "exact": "exact", "regex": "regex", "startsWith": "startsWith" } } ] }, "headers": { "foo": "string" }, "includeTools": { "operator": "OPERATOR_UNSPECIFIED", "filters": [ { "attribute": "ATTRIBUTE_UNSPECIFIED", "matcher": { "caseSensitive": true, "contains": "contains", "endsWith": "endsWith", "exact": "exact", "regex": "regex", "startsWith": "startsWith" } } ] }, "serverName": "serverName", "toolApprovals": { "always": true, "only": { "operator": "OPERATOR_UNSPECIFIED", "filters": [ { "attribute": "ATTRIBUTE_UNSPECIFIED", "matcher": { "caseSensitive": true, "contains": "contains", "endsWith": "endsWith", "exact": "exact", "regex": "regex", "startsWith": "startsWith" } } ] } }, "uploadId": "uploadId", "url": "url" } }, "description": "description" }, "info": { "agentCount": 0, "createdBy": { "metadata": { "id": "id", "accountId": "accountId", "name": "name", "profileId": "profileId", "externalId": "externalId", "labels": { "foo": "string" } }, "spec": { "type": "PROFILE_TYPE_UNSPECIFIED", "email": "email", "name": "name" } }, "lastSync": "2019-12-27T18:11:19.117Z", "toolCount": 0 } } }, "type": "type", "variationAssignment": { "action": "ACTION_UNSPECIFIED", "error": { "code": 0, "details": [ { "@type": "@type" } ], "message": "message" }, "resource": { "id": "id", "agent": { "id": "id", "name": "name" }, "tool": { "id": "id", "name": "name" }, "toolSet": { "id": "id", "name": "name" } } }, "variationMemoryLayer": { "action": "ACTION_UNSPECIFIED", "error": { "code": 0, "details": [ { "@type": "@type" } ], "message": "message" }, "resource": { "id": "id", "memoryLayer": { "id": "id", "name": "name" }, "position": 0 } } }, "metadata": { "id": "id", "accountId": "accountId", "createdAt": "2019-12-27T18:11:19.117Z", "profileId": "profileId", "workspaceId": "workspaceId", "externalId": "externalId", "labels": { "foo": "string" } } } ], "pagination": { "nextCursor": "nextCursor", "total": 0 } } ```