decocms

studio

Built by decocms โ€ข 354 stars

What is studio?

Open-source control plane for your AI agents. Connect tools, hire agents, track every token and dollar

How to use studio?

1. Install a compatible MCP client (like Claude Desktop). 2. Open your configuration settings. 3. Add studio using the following command: npx @modelcontextprotocol/studio 4. Restart the client and verify the new tools are active.
๐Ÿ›ก๏ธ Scoped (Restricted)
npx @modelcontextprotocol/studio --scope restricted
๐Ÿ”“ Unrestricted Access
npx @modelcontextprotocol/studio

Key Features

Native MCP Protocol Support
Real-time Tool Activation & Execution
Verified High-performance Implementation
Secure Resource & Context Handling

Optimized Use Cases

Extending AI models with custom local capabilities
Automating system workflows via natural language
Connecting external data sources to LLM context windows

studio FAQ

Q

Is studio safe?

Yes, studio follows the standardized Model Context Protocol security patterns and only executes tools with explicit user-granted permissions.

Q

Is studio up to date?

studio is currently active in the registry with 354 stars on GitHub, indicating its reliability and community support.

Q

Are there any limits for studio?

Usage limits depend on the specific implementation of the MCP server and your system resources. Refer to the official documentation below for technical details.

Official Documentation

View on GitHub
<h1 align="center">Deco CMS</h1> <p align="center"> <em>Open-source ยท TypeScript-first ยท Deploy anywhere</em><br/><br/> <b>Open-source control plane for your AI agents.</b> </p> <p align="center"> <a href="https://docs.decocms.com/">Docs</a> ยท <a href="https://decocms.com/discord">Discord</a> ยท <a href="https://decocms.com/studio">decocms.com/studio</a> </p>

TL;DR: Hire agents. Connect tools. Organize them into projects with a UI that fits the job. Track every token and dollar. Self-host or use the cloud.


What is Deco CMS?

Studio is where you hire agents, connect tools, and organize them into projects that actually do things.

Agents come with real skills and battle-tested prompts. Connections give them access to your tools โ€” GitHub, Slack, Postgres, OpenRouter, anything that speaks MCP โ€” set up through a web UI with one-click OAuth. Projects bring agents and connections together around a goal: each project gets its own sidebar and UI, shaped by what's inside it.

Everything is tracked โ€” tokens, costs, errors, latency โ€” per connection, per agent. Install locally and it stays private. Sync to the cloud for remote access, team roles, and shared billing.

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚                           Clients                               โ”‚
โ”‚         Cursor ยท Claude ยท VS Code ยท Custom Agents               โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
                            โ”‚
                            โ–ผ
โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚                         DECO CMS                              โ”‚
โ”‚  Agents ยท Connections ยท Projects ยท Observability ยท Token Vault  โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
                            โ”‚
                            โ–ผ
โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚                     Tools & MCP Servers                          โ”‚
โ”‚      GitHub ยท Slack ยท Postgres ยท OpenRouter ยท Your APIs         โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

Quick Start

bunx decocms

Or clone and run from source:

git clone https://github.com/decocms/studio.git
bun install
bun run dev

runs at http://localhost:3000 (client) + API server


What you get

Agents

Browse and hire specialized AI agents from the built-in store. Each agent knows how to use specific tools and comes with battle-tested prompts. Agents compose โ€” they can call each other โ€” and every action is tracked with cost attribution.

Connections

Set up MCP connections through a web UI with one-click OAuth. No JSON configs. Monitor latency, errors, and costs per connection. Share tools across your team without sharing credentials.

As tool surfaces grow, Studio exposes Virtual MCPs โ€” one endpoint, different strategies for which tools to surface:

  • Full-context: expose everything (simple, deterministic, good for small toolsets)
  • Smart selection: narrow the toolset before execution
  • Code execution: load tools on demand in a sandbox

Projects

Projects bring agents and connections together around a goal. The project's UI adapts to what's inside โ€” add a content agent and a CMS connection, the sidebar shows content management; add an analytics agent and a database, it shows dashboards and queries. The UI you see is the UI that's relevant for operating that project.

You can also define outcomes declaratively and let Studio work backward to derive milestones, assign agents, and verify results.

Observability

Token spend per connection โ€” OpenRouter, Perplexity, Firecrawl, all of it. Latency, errors, bottlenecks. One dashboard.

From your laptop to your org

Localbunx decocms on your laptop. Embedded PostgreSQL. Private.
CloudLog in to studio.decocms.com. Control local projects from any browser.
TeamInvite people. Roles. Shared connections. Cost attribution.
EnterpriseSelf-hosted. Your infra. Your rules.

Core Capabilities

CapabilityWhat it does
AgentsBrowse, hire, and compose AI agents with tracked skills and cost attribution
ConnectionsRoute MCP traffic through one governed endpoint with auth, proxy, and token vault
ProjectsOrganize agents and connections around goals with an adaptive UI
Virtual MCPsCompose and expose governed toolsets as new MCP endpoints
ObservabilityTraces, costs, errors, and latency per connection โ€” one dashboard
Access ControlRBAC via Better Auth โ€” OAuth 2.1 + API keys per workspace/project
Multi-tenancyWorkspace/project isolation for config, credentials, policies, and audit logs
Event BusPub/sub between connections with scheduled/cron delivery and at-least-once guarantees
BindingsCapability contracts so tools target interfaces, not specific implementations
StoreDiscover and install agents, tools, and templates

Define Tools

Type-safe, audited, observable, callable via MCP.

import { z } from "zod";
import { defineTool } from "~/core/define-tool";

export const CONNECTION_CREATE = defineTool({
  name: "CONNECTION_CREATE",
  description: "Create a new MCP connection",
  inputSchema: z.object({
    name: z.string(),
    connection: z.object({
      type: z.enum(["HTTP", "SSE", "WebSocket"]),
      url: z.string().url(),
      token: z.string().optional(),
    }),
  }),
  outputSchema: z.object({
    id: z.string(),
    scope: z.enum(["workspace", "project"]),
  }),
  handler: async (input, ctx) => {
    await ctx.access.check();
    const conn = await ctx.storage.connections.create({
      projectId: ctx.project?.id ?? null,
      ...input,
      createdById: ctx.auth.user!.id,
    });
    return { id: conn.id, scope: conn.projectId ? "project" : "workspace" };
  },
});

Every tool call gets input/output validation, access control, audit logging, and OpenTelemetry traces automatically.


Project Structure

โ”œโ”€โ”€ apps/
โ”‚   โ”œโ”€โ”€ mesh/                # Full-stack Deco CMS (Hono API + Vite/React)
โ”‚   โ”‚   โ”œโ”€โ”€ src/
โ”‚   โ”‚   โ”‚   โ”œโ”€โ”€ api/         # Hono HTTP + MCP proxy routes
โ”‚   โ”‚   โ”‚   โ”œโ”€โ”€ auth/        # Better Auth (OAuth + API keys)
โ”‚   โ”‚   โ”‚   โ”œโ”€โ”€ core/        # MeshContext, AccessControl, defineTool
โ”‚   โ”‚   โ”‚   โ”œโ”€โ”€ tools/       # Built-in MCP management tools
โ”‚   โ”‚   โ”‚   โ”œโ”€โ”€ storage/     # Kysely DB adapters
โ”‚   โ”‚   โ”‚   โ”œโ”€โ”€ event-bus/   # Pub/sub event delivery system
โ”‚   โ”‚   โ”‚   โ”œโ”€โ”€ encryption/  # Token vault & credential management
โ”‚   โ”‚   โ”‚   โ”œโ”€โ”€ observability/  # OpenTelemetry tracing & metrics
โ”‚   โ”‚   โ”‚   โ””โ”€โ”€ web/         # React 19 admin UI
โ”‚   โ”‚   โ””โ”€โ”€ migrations/      # Kysely database migrations
โ”‚   โ””โ”€โ”€ docs/                # Astro documentation site
โ”‚
โ””โ”€โ”€ packages/
    โ”œโ”€โ”€ bindings/            # Core MCP bindings and connection abstractions
    โ”œโ”€โ”€ runtime/             # MCP proxy, OAuth, and runtime utilities
    โ”œโ”€โ”€ ui/                  # Shared React components (shadcn-based)
    โ”œโ”€โ”€ cli/                 # CLI tooling (deco commands)
    โ”œโ”€โ”€ create-deco/         # Project scaffolding (npm create deco)
    โ””โ”€โ”€ vite-plugin-deco/    # Vite plugin for Deco projects

Development

bun install          # Install dependencies
bun run dev          # Run dev server (client + API)
bun test             # Run tests
bun run check        # Type check
bun run lint         # Lint
bun run fmt          # Format

Studio commands (from apps/mesh/)

bun run dev:client     # Vite dev server (port 4000)
bun run dev:server     # Hono server with hot reload
bun run migrate        # Run database migrations

Worktrees

dev:worktree routes http://<WORKTREE_SLUG>.localhost via Caddy โ€” useful for running multiple workspaces without port conflicts.

# One-time setup
brew install caddy && caddy start

# Start
WORKTREE_SLUG=my-feature bun run dev:worktree

# Conductor adapter (sets WORKTREE_SLUG from CONDUCTOR_WORKSPACE_NAME)
bun run dev:conductor

Deploy Anywhere

# Docker (embedded PostgreSQL)
docker compose -f deploy/docker-compose.yml up

# Docker (PostgreSQL)
docker compose -f deploy/docker-compose.postgres.yml up

# Bun
bun run build:client && bun run build:server && bun run start

# Kubernetes (Helm)
helm install deco-studio oci://ghcr.io/decocms/chart-deco-studio --version <version> -n deco-studio --create-namespace

No vendor lock-in. Runs on Docker, Kubernetes, AWS, GCP, or local runtimes.


Tech Stack

LayerTech
RuntimeBun / Node
LanguageTypeScript + Zod
FrameworkHono (API) + Vite + React 19
DatabaseKysely โ†’ embedded PostgreSQL / PostgreSQL
AuthBetter Auth (OAuth 2.1 + API keys)
ObservabilityOpenTelemetry
UIReact 19 + Tailwind v4 + shadcn
ProtocolModel Context Protocol (MCP)

Roadmap

  • Agent marketplace โ€” discover, hire, and compose agents
  • Declarative planning engine
  • Cost analytics and spend caps
  • Remote access from any browser
  • Live tracing debugger
  • Workflow orchestration with guardrails

License

Sustainable Use License (SUL) โ€” see LICENSE.md.

  • Free to self-host for internal use
  • Free for client projects (agencies, SIs)
  • Commercial license required for SaaS or revenue-generating production systems

Questions? builders@decocms.com


Contributing

bun run fmt      # Format
bun run lint     # Lint
bun test         # Test

See AGENTS.md for coding guidelines.


<div align="center"> <sub>Made with care by the <a href="https://decocms.com">deco</a> community</sub> </div>

Global Ranking

-
Trust ScoreMCPHub Index

Based on codebase health & activity.

Manual Config

{ "mcpServers": { "studio": { "command": "npx", "args": ["studio"] } } }