Skip to main content
Version: v1.2.0-m.1 (pre-release)

MCP Servers

OpenChoreo provides Model Context Protocol (MCP) servers that enable AI assistants to interact with your OpenChoreo platform.

Overview​

OpenChoreo provides two MCP servers:

  1. Control Plane MCP Server - Provides tools for managing OpenChoreo resources (namespaces, projects, components, builds, deployments, infrastructure)
  2. Observability Plane MCP Server - Provides tools for accessing observability data (logs, metrics, traces, alerts, incidents)

Each MCP server is independently accessible and requires separate configuration.

Using Both MCP Servers Together​

Recommended Configuration

For the best experience, configure both the Control Plane and Observability Plane MCP servers together. Observability tools accept resource names (namespace, project, component, environment) as parameters β€” use the Control Plane MCP server to list and discover these names, then pass them directly to Observability tools.

Example workflow:

  1. Use Control Plane MCP (list_namespaces, list_projects, list_components, list_environments) to discover resource names
  2. Use those names with Observability Plane MCP tools (query_component_logs, query_traces, query_http_metrics, query_alerts) to fetch observability data

Available Tools​

Control Plane MCP Server​

The Control Plane MCP server is organized into seven toolsets.

Note: The cluster-prefixed tools have been deprecated since v1.1 and, as of v1.2.0, are hidden from tools/list by default (see Deprecated cluster-prefixed tools).

Tools in multiple toolsets

Some read-only tools (marked with †) appear in both the default developer toolsets and the PE toolset. This allows platform engineers to use the PE toolset alongside Namespace and Project toolsets without needing to enable all developer toolsets.

Deprecated cluster-prefixed tools​

Deprecation notice

The *_cluster_* tools (cluster-scoped component types, traits, workflows, and planes) are deprecated. Each one has been collapsed into its namespace-scoped counterpart, which now accepts a scope: "namespace" | "cluster" argument (defaults to "namespace"). For example, get_cluster_component_type is replaced by get_component_type called with scope: "cluster".

Rollout timeline:

Releasetools/list behaviorCallable?
v1.1.xAliases listed by default, each marked deprecated in its description.Yes
current (v1.2.0)Aliases hidden by default; set ?includeDeprecatedTools=true to opt back in.Yes
v1.3.0Aliases removed; the includeDeprecatedTools flag is also removed.No

Every invocation of a deprecated alias returns a deprecation warning pointing to the replacement, so clients that ignore tools/list metadata still get a migration signal at call time.

If your integration depends on the legacy *_cluster_* names, migrate to the canonical tool with scope: "cluster" β€” as of v1.2.0, discovery-driven clients that read tools/list no longer see the aliases unless you append ?includeDeprecatedTools=true to the MCP server URL (see Per-Session Tool Filtering).

Namespace Toolset
  • list_namespaces β€” List all namespaces (top-level containers for organizing projects, components, and resources)
  • create_namespace β€” Create a new namespace
  • list_secret_references ‑ β€” List all secret references (credentials and sensitive configuration) for a namespace
  • get_secret_reference ‑ β€” Get a single secret reference's full spec (template, data sources, refresh interval, target plane). For sync status, query get_resource_events against the rendered ExternalSecret on the data plane

‑ Also registered on the PE toolset. Authoring secret references (create_, update_, delete_secret_reference) is PE-only β€” see the PE toolset below.

Project Toolset
  • list_projects β€” List all projects in a namespace (logical groupings of related components sharing deployment pipelines)
  • create_project β€” Create a new project in a namespace
  • update_project β€” Partially update a project (display_name, description, deployment_pipeline); only provided fields change
  • delete_project β€” Delete a project; cascades via finalizer to remove all components, workloads, releases, and bindings owned by the project
Component Toolset

Component Management

  • create_component β€” Create a new component in a project
  • list_components β€” List all components in a project (deployable units with independent build and deployment lifecycles)
  • get_component β€” Get detailed component info including configuration, deployment status, and builds
  • patch_component β€” Partially update a component's configuration (display_name, description, autoDeploy, parameters, traits, workflow); pass an empty array for traits to clear all traits
  • delete_component β€” Delete a component; cascades via finalizer to its workloads, releases, and release bindings
  • get_component_schema β€” Get the JSON schema for a component's configuration options

Workload Management

  • list_workloads β€” List workloads for a component (names, images, endpoint names)
  • get_workload β€” Get detailed workload info; returns the full Spec (round-trip-safe with update_workload)
  • create_workload β€” Create a new workload for a component (runtime spec: containers, resources, env vars)
  • update_workload β€” Update an existing workload's specification (container config, env vars, port mappings, resource limits)
  • delete_workload β€” Delete a workload; for reversible removal of just the deployment, use update_release_binding with release_state: Undeploy
  • get_workload_schema β€” Get the JSON schema for the workload specification

Platform Standards β€” Read-Only, Namespace-Scoped

  • list_component_types † β€” List available component types in a namespace (WebApplication, Service, ScheduledTask, etc.)
  • get_component_type † β€” Get the full definition of a component type including its complete spec
  • get_component_type_schema † β€” Get the parameter schema for a component type
  • list_traits † β€” List available traits in a namespace (autoscaling, ingress, service mesh, etc.)
  • get_trait † β€” Get the full definition of a trait including its complete spec
  • get_trait_schema † β€” Get the parameter schema for a trait

Platform Standards β€” Read-Only, Cluster-Scoped (deprecated β€” use the namespace-scoped tool with scope: "cluster"; see Deprecated cluster-prefixed tools)

  • list_cluster_component_types † β€” List cluster-scoped component types shared across namespaces
  • get_cluster_component_type † β€” Get the full definition of a cluster-scoped component type
  • get_cluster_component_type_schema † β€” Get the schema for a cluster-scoped component type
  • list_cluster_traits † β€” List cluster-scoped traits shared across namespaces
  • get_cluster_trait † β€” Get the full definition of a cluster-scoped trait
  • get_cluster_trait_schema † β€” Get the schema for a cluster-scoped trait
Resource Toolset

The Resource toolset mirrors the Component toolset for managed infrastructure: developers create Resources that reference platform-engineer-published ResourceTypes, and workloads consume the declared outputs via dependencies.resources[]. ResourceType writes, ResourceRelease management, and ResourceReleaseBinding CRUD live in the PE and Deployment toolsets respectively.

Resource Management

  • list_resources β€” List all Resources in a project (managed-infrastructure dependencies like databases, queues, caches, object stores)
  • get_resource β€” Get a Resource's full spec including parameters, referenced (Cluster)ResourceType, latest cut release, and conditions
  • create_resource β€” Create a new Resource referencing a ResourceType or ClusterResourceType; the controller cuts the first ResourceRelease automatically
  • update_resource β€” Update a Resource's parameters (full replacement). spec.owner and spec.type are immutable
  • delete_resource β€” Delete a Resource; the two-phase finalizer blocks until all ResourceReleaseBindings are removed, then GCs owned ResourceReleases

Platform Standards β€” Read-Only, Namespace-Scoped

  • list_resource_types † β€” List available ResourceTypes in a namespace (Postgres, Valkey, NATS, S3 buckets, Crossplane claims, etc.). Pass scope: "cluster" for ClusterResourceTypes
  • get_resource_type † β€” Get the full definition of a ResourceType including parameter schema, environmentConfigs schema, outputs, and rendered resources. Pass scope: "cluster" for a ClusterResourceType
  • get_resource_type_schema † β€” Get the parameter schema for a ResourceType. Pass scope: "cluster" for a ClusterResourceType
Deployment Toolset

Components

  • create_release_binding β€” Create a new release binding to deploy a component to a specific environment
  • list_release_bindings β€” List release bindings associating releases with environments for a component
  • get_release_binding β€” Get detailed info for a specific release binding including state, overrides, and endpoints
  • update_release_binding β€” Update a release binding's configuration (release, release_state, overrides, traits, workload settings); set release_state: Active to deploy or Undeploy to remove from the data plane while keeping the binding
  • delete_release_binding β€” Delete a release binding entirely; for reversible removal that keeps the binding, use update_release_binding with release_state: Undeploy instead
  • delete_component_release β€” Delete a component release (immutable; useful for pruning old releases)

Resources

  • create_resource_release_binding β€” Create a new ResourceReleaseBinding to deploy a Resource to a specific environment
  • list_resource_release_bindings β€” List ResourceReleaseBindings in a namespace; optionally filter by project, resource, or environment
  • get_resource_release_binding β€” Get detailed info for a ResourceReleaseBinding including the pinned ResourceRelease, retention policy, environment overrides, and resolved outputs
  • update_resource_release_binding β€” Update a ResourceReleaseBinding's configuration (resource_release, retain_policy, resource_type_environment_configs); promotion is performed by setting resource_release to a new ResourceRelease name
  • delete_resource_release_binding β€” Delete a ResourceReleaseBinding; if effective retainPolicy is Retain, the finalizer holds and the data-plane state persists until the policy is flipped to Delete
  • delete_resource_release β€” Delete a ResourceRelease snapshot (immutable; useful for pruning old releases)

Pipelines & Environments

  • list_deployment_pipelines β€” List all deployment pipelines defining environment promotion order in a namespace
  • get_deployment_pipeline β€” Get detailed deployment pipeline info including stages, promotion order, and environments
  • list_environments † β€” List all environments (deployment targets like dev, staging, production) in a namespace
Build Toolset
  • trigger_workflow_run β€” Trigger a workflow run for a component using the component's configured workflow and parameters
  • create_workflow_run β€” Create a new workflow run by specifying a workflow name and optional parameters
  • list_workflow_runs β€” List workflow run executions in a namespace; optionally filter by project and component
  • get_workflow_run β€” Get detailed info for a workflow run including status, tasks, and timestamps
  • get_workflow_run_status β€” Get the live status of a workflow run (phase, task progress)
  • get_workflow_run_logs β€” Stream live logs for a workflow run (live-only β€” does not return archived logs for completed runs); optional task filter
  • get_workflow_run_events β€” Get Kubernetes events for a workflow run (scheduling, pod-startup failures); optional task filter
  • list_workflows † β€” List all workflow templates in a namespace (CI/CD pipelines executed on the workflow plane)
  • get_workflow † β€” Get the full definition of a workflow including its complete spec
  • get_workflow_schema † β€” Get the parameter schema for a workflow template

Deprecated β€” use the namespace-scoped tool with scope: "cluster" instead; see Deprecated cluster-prefixed tools:

  • list_cluster_workflows β€” List cluster-scoped workflow definitions shared across namespaces
  • get_cluster_workflow β€” Get the full definition of a cluster-scoped workflow
  • get_cluster_workflow_schema β€” Get the schema for a cluster-scoped workflow
Platform Engineering (PE) Toolset
note

The PE toolset is enabled by default. These tools are intended for platform administrators who manage infrastructure, environments, platform standards, and deployment pipelines. If you need to disable the PE toolset, see Configuring MCP Toolsets.

Environment Management

  • list_environments † β€” List all environments in a namespace
  • create_environment β€” Create a new environment in a namespace
  • update_environment β€” Update an existing environment (display name, description, production flag)
  • delete_environment β€” Delete an environment from a namespace

Deployment Pipeline Management

  • create_deployment_pipeline β€” Create a new deployment pipeline defining environment promotion order
  • update_deployment_pipeline β€” Update promotion paths and approval requirements
  • delete_deployment_pipeline β€” Delete a deployment pipeline from a namespace

Component Releases

  • list_component_releases β€” List all releases (immutable snapshots at a specific build) for a component
  • create_component_release β€” Create a new release from the latest build of a component
  • get_component_release β€” Get detailed release info including build information, image tags, and deployment status
  • get_component_release_schema β€” Get the JSON schema for a component release's configuration options

Resource Releases

  • list_resource_releases β€” List all ResourceReleases (immutable snapshots of Resource.spec + (Cluster)ResourceType.spec) for a Resource
  • create_resource_release β€” Manually cut a ResourceRelease from the current Resource and ResourceType state. Typically not needed in steady stateβ€”the Resource controller cuts releases automatically on hash change
  • get_resource_release β€” Get the full snapshot including the frozen (Cluster)ResourceType spec and the Resource parameters captured at release time

Infrastructure β€” Namespace-Scoped Planes

  • list_dataplanes β€” List all data planes (clusters where workloads execute) in a namespace
  • get_dataplane β€” Get detailed data plane info including cluster details, capacity, and health
  • list_workflowplanes β€” List all workflow planes (dedicated build infrastructure) in a namespace
  • get_workflowplane β€” Get detailed workflow plane info including cluster details and health status
  • list_observability_planes β€” List all observability planes providing monitoring, logging, and tracing in a namespace
  • get_observability_plane β€” Get detailed observability plane info including observer URL and health status

Infrastructure β€” Cluster-Scoped Planes (deprecated β€” use the namespace-scoped tool with scope: "cluster"; see Deprecated cluster-prefixed tools)

  • list_cluster_dataplanes β€” List all cluster-scoped data planes
  • get_cluster_dataplane β€” Get detailed info for a cluster-scoped data plane
  • list_cluster_workflowplanes β€” List all cluster-scoped workflow planes
  • get_cluster_workflowplane β€” Get detailed info for a cluster-scoped workflow plane
  • list_cluster_observability_planes β€” List all cluster-scoped observability planes
  • get_cluster_observability_plane β€” Get detailed info for a cluster-scoped observability plane

Platform Standards β€” Read, Namespace-Scoped

  • list_component_types † β€” List available component types in a namespace
  • get_component_type β€” Get the full definition of a component type including its complete spec
  • get_component_type_schema † β€” Get the parameter schema for a component type
  • list_traits † β€” List available traits in a namespace
  • get_trait β€” Get the full definition of a trait including its complete spec
  • get_trait_schema † β€” Get the parameter schema for a trait
  • list_resource_types † β€” List available ResourceTypes in a namespace. Pass scope: "cluster" for ClusterResourceTypes
  • get_resource_type † β€” Get the full definition of a ResourceType including outputs and resource manifests. Pass scope: "cluster" for a ClusterResourceType
  • get_resource_type_schema † β€” Get the parameter schema for a ResourceType. Pass scope: "cluster" for a ClusterResourceType
  • list_workflows † β€” List all workflow templates in a namespace
  • get_workflow β€” Get the full definition of a workflow including its complete spec
  • get_workflow_schema † β€” Get the parameter schema for a workflow template

Platform Standards β€” Creation Schemas

  • get_component_type_creation_schema β€” Get the spec schema for creating a component type
  • get_cluster_component_type_creation_schema (deprecated β€” use get_component_type_creation_schema with scope: "cluster") β€” Get the spec schema for creating a cluster-scoped component type
  • get_trait_creation_schema β€” Get the spec schema for creating a trait
  • get_cluster_trait_creation_schema (deprecated β€” use get_trait_creation_schema with scope: "cluster") β€” Get the spec schema for creating a cluster-scoped trait
  • get_resource_type_creation_schema β€” Get the spec schema for creating a ResourceType. Pass scope: "cluster" for a ClusterResourceType
  • get_workflow_creation_schema β€” Get the spec schema for creating a workflow
  • get_cluster_workflow_creation_schema (deprecated β€” use get_workflow_creation_schema with scope: "cluster") β€” Get the spec schema for creating a cluster-scoped workflow

Platform Standards β€” Write, Namespace-Scoped

  • create_component_type β€” Create a new component type in a namespace
  • update_component_type β€” Update an existing component type (full replacement)
  • delete_component_type β€” Delete a component type from a namespace
  • create_trait β€” Create a new trait in a namespace
  • update_trait β€” Update an existing trait (full replacement)
  • delete_trait β€” Delete a trait from a namespace
  • create_resource_type β€” Create a new ResourceType. Pass scope: "cluster" to create a ClusterResourceType
  • update_resource_type β€” Update an existing ResourceType (full replacement). Pass scope: "cluster" for a ClusterResourceType
  • delete_resource_type β€” Delete a ResourceType. Pass scope: "cluster" to delete a ClusterResourceType
  • create_workflow β€” Create a new workflow in a namespace
  • update_workflow β€” Update an existing workflow (full replacement)
  • delete_workflow β€” Delete a workflow from a namespace

Platform Standards β€” Read, Cluster-Scoped (deprecated β€” use the namespace-scoped tool with scope: "cluster"; see Deprecated cluster-prefixed tools)

  • list_cluster_component_types † β€” List cluster-scoped component types
  • get_cluster_component_type † β€” Get the full definition of a cluster-scoped component type
  • get_cluster_component_type_schema † β€” Get the schema for a cluster-scoped component type
  • list_cluster_traits † β€” List cluster-scoped traits
  • get_cluster_trait † β€” Get the full definition of a cluster-scoped trait
  • get_cluster_trait_schema † β€” Get the schema for a cluster-scoped trait
  • list_cluster_workflows † β€” List cluster-scoped workflow definitions
  • get_cluster_workflow † β€” Get the full definition of a cluster-scoped workflow
  • get_cluster_workflow_schema † β€” Get the schema for a cluster-scoped workflow

Platform Standards β€” Write, Cluster-Scoped (deprecated β€” use the namespace-scoped tool with scope: "cluster"; see Deprecated cluster-prefixed tools)

  • create_cluster_component_type β€” Create a new cluster-scoped component type
  • update_cluster_component_type β€” Update an existing cluster-scoped component type (full replacement)
  • delete_cluster_component_type β€” Delete a cluster-scoped component type
  • create_cluster_trait β€” Create a new cluster-scoped trait
  • update_cluster_trait β€” Update an existing cluster-scoped trait (full replacement)
  • delete_cluster_trait β€” Delete a cluster-scoped trait
  • create_cluster_workflow β€” Create a new cluster-scoped workflow
  • update_cluster_workflow β€” Update an existing cluster-scoped workflow (full replacement)
  • delete_cluster_workflow β€” Delete a cluster-scoped workflow

Authorization β€” Roles

  • list_authz_roles β€” List authz roles in a namespace
  • get_authz_role β€” Get the full definition of an authz role
  • get_authz_role_creation_schema β€” Get the spec schema for creating an authz role
  • create_authz_role β€” Create a new authz role
  • update_authz_role β€” Update an existing authz role (full replacement)
  • delete_authz_role β€” Delete an authz role

Authorization β€” Role Bindings

  • list_authz_role_bindings β€” List authz role bindings in a namespace
  • get_authz_role_binding β€” Get the full definition of an authz role binding
  • get_authz_role_binding_creation_schema β€” Get the spec schema for creating an authz role binding
  • create_authz_role_binding β€” Create a new authz role binding
  • update_authz_role_binding β€” Update an existing authz role binding (full replacement)
  • delete_authz_role_binding β€” Delete an authz role binding

Secret References

  • list_secret_references ‑ β€” List all secret references (credentials and sensitive configuration) for a namespace
  • get_secret_reference ‑ β€” Get a single secret reference's full spec (template, data sources, refresh interval, target plane). For sync status, query get_resource_events against the rendered ExternalSecret on the data plane
  • create_secret_reference β€” Create a new secret reference; spec must include template (Kubernetes Secret type) and data[] (mapping of secret keys to external store references)
  • update_secret_reference β€” Update an existing secret reference; annotations are merged, spec is replaced wholesale when provided
  • delete_secret_reference β€” Delete a secret reference (the underlying Kubernetes Secret is removed by the controller)

‑ Also registered on the Namespace toolset so developers can list and inspect secret references without enabling PE.

Diagnostics

  • get_resource_tree β€” Get the rendered resource tree for a release binding
  • get_resource_events β€” Get Kubernetes events for a specific resource in a deployment (scheduling, startup issues)
  • get_resource_logs β€” Get container logs from a specific pod in a deployment (application errors, runtime issues)
  • evaluate_authz β€” Evaluate one or more authz requests and return allow/deny plus the matching binding chain on a deny
  • list_authz_actions β€” List the catalog of authz action names and the lowest applicable scope for each

Observability Plane MCP Server​

The Observability Plane MCP server provides tools covering logs, traces, metrics, alerts, and incidents:

  • query_component_logs β€” Query runtime application logs for components (services, APIs, workers, scheduled tasks); filter by project, component, environment, time range, log levels, and search phrases
  • query_workflow_logs β€” Query CI/CD workflow run logs capturing build, test, and deployment pipeline execution details; filter by workflow run name and task name
  • query_http_metrics β€” Query HTTP request and latency metrics; returns time-series data for request counts (total, successful, unsuccessful) and latency percentiles (p50, p90, p99)
  • query_resource_metrics β€” Query CPU and memory resource usage metrics; returns time-series data for usage, requests, and limits β€” useful for capacity planning and detecting memory leaks
  • query_traces β€” Query distributed traces; returns a list of traces with summary information including trace ID, span count, root span details, and duration
  • query_trace_spans β€” Query all spans within a specific distributed trace by trace ID; returns span details with timing, parent span, and service information
  • get_span_details β€” Get full details for a specific span including attributes, resource attributes, parent span ID, and timing details
  • query_alerts β€” Query fired alerts in OpenChoreo; supports filtering by project, component, environment, and time range β€” useful for investigating recent alerts and their details
  • query_incidents β€” Query incidents in OpenChoreo; supports filtering by project, component, environment, and time range β€” useful for tracking incident lifecycle and response status; all incidents have an accompanying alert but not the other way around

Configuring MCP Toolsets​

The Control Plane MCP server exposes seven toolsets: namespace, project, component, resource, deployment, build, and pe. All seven are enabled by default. You can control which toolsets are active by passing a JSON array to openchoreoApi.config.mcp.toolsets via helm upgrade.

Syntax:

helm upgrade openchoreo-control-plane oci://ghcr.io/openchoreo/helm-charts/openchoreo-control-plane \
--version 1.2.0-m.1 \
--namespace openchoreo-control-plane \
--reuse-values \
--set-json 'openchoreoApi.config.mcp.toolsets=["<toolset1>","<toolset2>",...]'

Common Configurations​

Developer toolsets:

helm upgrade openchoreo-control-plane oci://ghcr.io/openchoreo/helm-charts/openchoreo-control-plane \
--version 1.2.0-m.1 \
--namespace openchoreo-control-plane \
--reuse-values \
--set-json 'openchoreoApi.config.mcp.toolsets=["namespace","project","component","resource","deployment","build"]'

Platform Engineer toolset:

helm upgrade openchoreo-control-plane oci://ghcr.io/openchoreo/helm-charts/openchoreo-control-plane \
--version 1.2.0-m.1 \
--namespace openchoreo-control-plane \
--reuse-values \
--set-json 'openchoreoApi.config.mcp.toolsets=["namespace","project","pe"]'
tip

The namespace and project toolsets are useful companions for the PE toolset β€” they let platform engineers discover resources without enabling all developer toolsets.

Per-Session Tool Filtering​

By default, the Control Plane MCP server filters tools/list and tools/call results by the authenticated user's permissions. Tools the user lacks permission for are hidden, and unauthorized calls are rejected. MCP clients can additionally narrow what a session sees, opt out of authorization-based filtering, or opt back into the deprecated cluster-prefixed aliases, by passing optional query parameters when establishing the session.

Query ParameterRequiredDefaultDescription
toolsetsfalseAll configured toolsetsComma-separated list of toolsets to expose via tools/list for the session (e.g. namespace,component,pe). Unknown toolset names are silently ignored.
filterByAuthzfalsetrueWhen true, hides tools the user cannot call and rejects unauthorized invocations. Set to false to disable MCP-layer authorization filtering.
includeDeprecatedToolsfalsefalse (was true before v1.2.0)Controls whether tools/list includes the deprecated cluster-prefixed aliases. The aliases remain callable regardless of this flag β€” it only controls listing. The flag and aliases are both removed in v1.3.0.

Example (as of v1.2.0 the deprecated aliases are hidden by default; append includeDeprecatedTools=true to opt back in):

http://api.openchoreo.localhost:8080/mcp?toolsets=namespace,component,pe&filterByAuthz=false&includeDeprecatedTools=true
note

These query parameters are HTTP-only and read once when the session is established. The toolsets parameter only filters tools/list results; it does not gate tools/call. The control plane API enforces authorization independently of filterByAuthz, so disabling MCP-layer filtering does not grant additional access. It just exposes tools the user cannot successfully invoke.

Authorization of scope-collapsed tools

A scope-collapsed tool (one that accepts a scope argument) requires a distinct permission per scope β€” one for scope: "namespace" and one for scope: "cluster". It appears in tools/list as long as the user holds the permission for at least one scope; a tools/call invocation is then authorized against the permission for the scope actually requested. So a user with only namespace-level permissions still sees the tool, but a call with scope: "cluster" is rejected unless they also hold the cluster-level permission.

Finding MCP Server URLs​

MCP server URLs follow a simple pattern based on the respective service's hostname:

  • Control Plane MCP Server: <control-plane-api-hostname>/mcp
  • Observability Plane MCP Server: <observer-service-hostname>/mcp

Example: Local k3d Setup​

If you followed the local setup guide, your MCP server URLs will be:

Single Cluster Installation:

  • Control Plane MCP Server: http://api.openchoreo.localhost:8080/mcp
  • Observability Plane MCP Server: http://observer.openchoreo.localhost:11080/mcp

Multi-Cluster Installation:

  • Control Plane MCP Server: http://api.openchoreo.localhost:8080/mcp
  • Observability Plane MCP Server: http://observer.observability.openchoreo.localhost:11087/mcp
note

The k3d local setup examples show different ports and hostnames:

  • Control plane services use port 8080
  • Observability plane uses port 11080 (single cluster) or 11087 (multi-cluster)
  • Multi-cluster deployments use distinct subdomain patterns for namespace isolation

Default OAuth Applications​

OpenChoreo ships with pre-created OAuth applications in the default ThunderID identity provider for quick-start configuration:

ApplicationClient IDGrant TypeUse Case
Browser-Based (Public)user_mcp_clientAuthorization Code + PKCEInteractive use with AI agents that support browser-based OAuth (Claude Code, Cursor)
Service (Confidential)service_mcp_clientClient CredentialsProgrammatic access, any AI agent via bearer token

These default applications eliminate the need to manually create OAuth apps for common setups.

Next Steps​

To configure your AI assistant to connect to OpenChoreo MCP servers, follow the AI Configuration Guide to set up authentication and connect your AI agent.