CAT
/MCP
SkillsMCPMarketplacesDigestToolsAdvertise

This week in Claude

Every Monday: Claude Code, Agent SDK, MCP, and the Anthropic platform moves worth your time.

Skills by Category
Frontend DevelopmentBackend & APIsTesting & QASecurityDevOps & CI/CDGit & Pull RequestsDocumentationCode Review & QualityAI & Agent BuildingSkill Development
MCP Servers by Category
Sales & MarketingWeb & Browser AutomationDatabasesAI & LLM ToolsCloud & InfrastructureCommunication & MessagingDeveloper ToolsDesign & CreativeDocuments & KnowledgeSearch & Web Crawling
Marketplaces by Category
AI Agents & OrchestrationLLM IntegrationDevelopment ToolsFrontend & UIBackend & APIsDatabasesTesting & Code QualityDevOps & CloudSecurity & ComplianceGit & Version Control

Cross AI Tools

Discover Claude Code plugins, extensions, and tools. Automatically updated directory of Anthropic Claude AI marketplaces with development tools, productivity plugins, and integrations.

Resources

  • Browse Skills
  • Browse MCP Servers
  • Browse Marketplaces
  • Plugins Reference

Community

  • About
  • Tools
  • Feedback
  • Privacy Policy
  • Advertise

Built for the Claude Code community with Claude Code by @mertduzgun

Independent project, not affiliated with Anthropic

Mcp Server

kontent-ai/mcp-server
authSTDIO, HTTPregistry active
Summary

This server connects Claude to Kontent.ai's Management API, letting you build and modify content models through conversation instead of clicking through the web UI. You can create content types, manage taxonomies, update workflows, and handle multilingual content variants. The standout use case is rapid prototyping: sketch a content model in a diagram, describe it to Claude, and watch it materialize in your Kontent.ai project. It also handles the full content lifecycle, from creating items and variants to managing assets and folders. You'll need a Management API key and environment ID. Best for content architects who want to iterate on structure quickly or automate repetitive content operations across languages and collections.

CodeRabbit
CodeRabbit
AI writes the code. CodeRabbit catches the slop.
Try For Free →
Keep your Mac awake
Keep your Mac awake
Keep your Mac awake while Claude Code and 40+ AI agents run. Sleeps when they're idle.
One time payment $9 →
Context.devContext.dev
Context.dev
Integrate web data into your AI product. One API to scrape website & brand data.
Get API Key Now →
Make your agent a DeFi expert
Make your agent a DeFi expert
Agent, run crypto. Access onchain data & trade routes via 1inch.
Install now →
Make money from your Skills
Make money from your Skills
On Capafy, your Skill runs online 24/7 as an agent product, and you get paid every time someone uses it.
Start earning →
AppSignal
AppSignal
Monitor with ease. Code with confidence.
Start Free Trial →
CodeRabbit
CodeRabbit
AI writes the code. CodeRabbit catches the slop.
Try For Free →
Keep your Mac awake
Keep your Mac awake
Keep your Mac awake while Claude Code and 40+ AI agents run. Sleeps when they're idle.
One time payment $9 →
Context.devContext.dev
Context.dev
Integrate web data into your AI product. One API to scrape website & brand data.
Get API Key Now →
Make your agent a DeFi expert
Make your agent a DeFi expert
Agent, run crypto. Access onchain data & trade routes via 1inch.
Install now →
Make money from your Skills
Make money from your Skills
On Capafy, your Skill runs online 24/7 as an agent product, and you get paid every time someone uses it.
Start earning →
AppSignal
AppSignal
Monitor with ease. Code with confidence.
Start Free Trial →

Kontent.ai MCP Server

NPM Version Contributors Forks Stargazers Issues MIT License Discord

Transform your content operations with AI-powered tools for Kontent.ai. Create, manage, and explore your structured content through natural language conversations in your favorite AI-enabled editor.

Kontent.ai MCP Server implements the Model Context Protocol to connect your Kontent.ai projects with AI tools like Claude, Cursor, and VS Code. It enables AI models to understand your content structure and perform operations through natural language instructions.

✨ Key Features

  • 🚀 Rapid prototyping: Transform your diagrams into live content models in seconds
  • 📈 Data Visualisation: Visualise your content model in any format you want

Table of Contents

  • ✨ Key Features
  • 🔌 Quickstart
  • 🛠️ Available Tools
  • ⚙️ Configuration
  • 🔒 Security
  • 🚀 Transport Options
  • 💻 Development
    • 🛠 Local Installation
    • 📂 Project Structure
    • 🔍 Debugging
    • 📦 Release Process
  • License

🔌 Quickstart

🔑 Prerequisites

Before you can use the MCP server, you need:

  1. A Kontent.ai account - Sign up if you don't have an account.
  2. A project - Create a project to work with.
  3. Management API key - Create a key with appropriate permissions.
  4. Environment ID - Get your environment ID.

🛠 Setup Options

You can run the Kontent.ai MCP Server with npx:

STDIO Transport

npx @kontent-ai/mcp-server@latest stdio

Streamable HTTP Transport

npx @kontent-ai/mcp-server@latest shttp

🛠️ Available Tools

Patch Operations Guide

  • get-patch-guide – 🚨 REQUIRED before any patch operation. Get patch operations guide for Kontent.ai by entity type

Content Type Management

  • get-content-type – Get Kontent.ai content type by ID
  • list-content-types – Get all Kontent.ai content types
  • create-content-type – Create new Kontent.ai content type
  • patch-content-type – Update an existing Kontent.ai content type by codename using patch operations (move, addInto, remove, replace)
  • delete-content-type – Delete a Kontent.ai content type by ID

Content Type Snippet Management

  • get-content-type-snippet – Get Kontent.ai content type snippet by ID
  • list-content-type-snippets – Get all Kontent.ai content type snippets
  • create-content-type-snippet – Create new Kontent.ai content type snippet
  • patch-content-type-snippet – Update an existing Kontent.ai content type snippet by ID using patch operations (move, addInto, remove, replace)
  • delete-content-type-snippet – Delete a Kontent.ai content type snippet by ID

Taxonomy Management

  • get-taxonomy-group – Get Kontent.ai taxonomy group by ID
  • list-taxonomy-groups – Get all Kontent.ai taxonomy groups
  • create-taxonomy-group – Create new Kontent.ai taxonomy group
  • patch-taxonomy-group – Update Kontent.ai taxonomy group using patch operations (addInto, move, remove, replace)
  • delete-taxonomy-group – Delete Kontent.ai taxonomy group by ID

Content Item Management

  • get-content-item – Get Kontent.ai content item by ID
  • get-content-item-variant – Retrieve Kontent.ai content item variant (language version/translation). Returns the current version — draft if one exists, otherwise published
  • get-published-content-item-variant-version – Retrieve the published version of a Kontent.ai content item variant. Use when a newer draft version exists but you need the currently published (live) content
  • get-content-item-translations – Get all Kontent.ai content item translations — every language version (variant) of a specific content item
  • list-content-item-variants – List, filter, search Kontent.ai content items with content item variants (language versions/translations)
  • create-content-item – Create new Kontent.ai content item (creates the container only, use create-content-item-variant to add language versions/translations)
  • update-content-item – Update existing Kontent.ai content item by ID. The content item must already exist - this tool will not create new items
  • delete-content-item – Delete Kontent.ai content item by ID
  • create-content-item-variant – Create Kontent.ai content item variant assigning current user as contributor. Element values must fulfill limitations and guidelines defined in content type. Send only the elements you want to set; omitted ones initialize empty
  • update-content-item-variant – Update Kontent.ai content item variant of a content item. Element values must fulfill limitations and guidelines defined in content type. Send only the elements you want to change — omitted elements are left untouched. For rich-text elements with components, submit the full element (value plus the complete components array, including components that are left untouched)
  • create-new-content-item-variant-version – Create new version of Kontent.ai content item variant. This operation creates a new version of an existing content item variant, useful for content versioning and creating new drafts from published content
  • delete-content-item-variant – Delete Kontent.ai content item variant
  • bulk-get-content-item-variants – Bulk get Kontent.ai content items with their content item variants by item and language reference pairs. Use after list-content-item-variants to retrieve full content data for specific item+language pairs. Items without a variant in the requested language return the item without the variant property. Returns paginated results with continuation token
  • search-content-item-variants – AI-powered semantic search for finding content by meaning and concepts in a specific content item variant. Use for: conceptual searches when you don't know exact keywords. Limited filtering options (variant ID only)

Asset Management

  • get-asset – Get a specific Kontent.ai asset by ID
  • list-assets – Get all Kontent.ai assets
  • update-asset – Update Kontent.ai asset by ID

Asset Folder Management

  • list-asset-folders – List all Kontent.ai asset folders
  • patch-asset-folders – Modify Kontent.ai asset folders using patch operations (addInto to add new folders, rename to change names, remove to delete folders)

Language Management

  • list-languages – Get all Kontent.ai languages (includes both active and inactive - check is_active property)
  • create-language – Create new Kontent.ai language (languages are always created as active)
  • patch-language – Update Kontent.ai language using replace operations (only active languages can be modified - to activate/deactivate, use the Kontent.ai web UI)

Collection Management

  • list-collections – Get all Kontent.ai collections. Collections set boundaries for content items in your environment and help organize content by team, brand, or project
  • patch-collections – Update Kontent.ai collections using patch operations (addInto to add new collections, move to reorder, remove to delete empty collections, replace to rename)

Space Management

  • list-spaces – Get all Kontent.ai spaces
  • create-space – Create new Kontent.ai space for managing a website or channel
  • patch-space – Patch Kontent.ai space using replace operations
  • delete-space – Delete Kontent.ai space

Role Management

  • list-roles – Get all Kontent.ai roles. Requires Enterprise or Flex plan with "Manage custom roles" permission

Workflow Management

  • list-workflows – Get all Kontent.ai workflows. Workflows define the content lifecycle stages and transitions between them
  • create-workflow – Create new Kontent.ai workflow with custom steps, transitions, scopes, and role permissions
  • update-workflow – Update an existing Kontent.ai workflow by ID. Modify steps, transitions, scopes, and role permissions. Cannot remove steps that are in use
  • delete-workflow – Delete a Kontent.ai workflow by ID. The workflow must not be in use by any content items
  • change-content-item-variant-workflow-step – Change the workflow step of a content item variant in Kontent.ai. This operation moves a content item variant to a different step in the workflow, enabling content lifecycle management such as moving content from draft to review, review to published, etc.
  • publish-content-item-variant – Publish or schedule a content item variant of a content item in Kontent.ai. This operation can either immediately publish the variant or schedule it for publication at a specific future date and time with optional timezone specification
  • unpublish-content-item-variant – Unpublish or schedule unpublishing of a content item variant of a content item in Kontent.ai. This operation can either immediately unpublish the variant (making it unavailable through the Delivery API) or schedule it for unpublishing at a specific future date and time with optional timezone specification

⚙️ Configuration

The server supports two modes, each tied to its transport:

TransportModeAuthenticationUse Case
STDIOSingle-tenantEnvironment variablesLocal communication with a single Kontent.ai environment
Streamable HTTPMulti-tenantBearer token per requestRemote/shared server handling multiple environments

Single-Tenant Mode (STDIO)

Configure credentials via environment variables:

VariableDescriptionRequired
KONTENT_API_KEYYour Kontent.ai key✅
KONTENT_ENVIRONMENT_IDYour environment ID✅
appInsightsConnectionStringApplication Insights connection string for telemetry❌
projectLocationProject location identifier for telemetry tracking❌
manageApiUrlCustom base URL (for preview environments)❌

Multi-Tenant Mode (Streamable HTTP)

For the Streamable HTTP transport, credentials are provided per request:

  • Environment ID as a URL path parameter: /{environmentId}/mcp
  • API Key via Bearer token in the Authorization header: Authorization: Bearer <api-key>

This allows a single server instance to handle requests for multiple Kontent.ai environments without requiring credential environment variables.

VariableDescriptionRequired
PORTPort for HTTP transport (defaults to 3001)❌
appInsightsConnectionStringApplication Insights connection string for telemetry❌
projectLocationProject location identifier for telemetry tracking❌
manageApiUrlCustom base URL (for preview environments)❌

🔒 Security

Indirect prompt injection

Content returned by this server (for example, an element written by an editor) can contain text that a connected LLM interprets as instructions — indirect prompt injection. A hijacked agent could be steered into destructive tool calls (delete / unpublish / overwrite) or into leaking unpublished drafts. This is an industry-wide, unsolved problem that the server cannot reliably fix by transforming the content it returns, so defense is layered:

  • Use a least-privilege Management API key. The server acts with whatever key it is given. With a read-only key, a hijacked agent's destructive call simply fails at the API boundary — the strongest control, since it holds regardless of model behaviour.
  • Keep a human in the loop. Every tool carries MCP annotations — reads are readOnlyHint, create-only tools are additive, and tools that overwrite or remove data are destructiveHint — which compliant clients use to auto-approve reads and prompt before destructive calls. Run the server with such a client and avoid headless auto-approve setups against a write-capable key.
  • Add a client-side gate if your client supports one. Some clients (for example, Claude Code hooks) let you deterministically prompt before a destructive tool runs, independent of the model. This is configured locally; a server cannot enforce it.

These are hints, not guarantees. Report security issues privately to security@kontent.ai.

🚀 Transport Options

📟 STDIO Transport

To run the server with STDIO transport, configure your MCP client with:

{
  "kontent-ai-stdio": {
      "command": "npx",
      "args": ["@kontent-ai/mcp-server@latest", "stdio"],
      "env": {
        "KONTENT_API_KEY": "<management-api-key>",
        "KONTENT_ENVIRONMENT_ID": "<environment-id>"
      }
    }
}

🌊 Streamable HTTP Transport (Multi-Tenant)

Streamable HTTP transport serves multiple Kontent.ai environments from a single server instance. Each request provides credentials via URL path parameters and Bearer authentication.

First start the server:

npx @kontent-ai/mcp-server@latest shttp
VS Code

Create a .vscode/mcp.json file in your workspace:

{
  "servers": {
    "kontent-ai-multi": {
      "uri": "http://localhost:3001/<environment-id>/mcp",
      "headers": {
        "Authorization": "Bearer <management-api-key>"
      }
    }
  }
}

For secure configuration with input prompts:

{
  "inputs": [
    {
      "id": "apiKey",
      "type": "password",
      "description": "Kontent.ai API Key"
    },
    {
      "id": "environmentId",
      "type": "text",
      "description": "Environment ID"
    }
  ],
  "servers": {
    "kontent-ai-multi": {
      "uri": "http://localhost:3001/${inputs.environmentId}/mcp",
      "headers": {
        "Authorization": "Bearer ${inputs.apiKey}"
      }
    }
  }
}
Claude Desktop

Update your Claude Desktop configuration file:

  • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  • Windows: %APPDATA%\Claude\claude_desktop_config.json
  • Linux: ~/.config/Claude/claude_desktop_config.json

Use mcp-remote as a proxy to add authentication headers:

{
  "mcpServers": {
    "kontent-ai-multi": {
      "command": "npx",
      "args": [
        "mcp-remote",
        "http://localhost:3001/<environment-id>/mcp",
        "--header",
        "Authorization: Bearer <management-api-key>"
      ]
    }
  }
}
Claude Code

Add the server using the CLI:

claude mcp add --transport http kontent-ai-multi \
  "http://localhost:3001/<environment-id>/mcp" \
  --header "Authorization: Bearer <management-api-key>"

Note: You can also configure this in your Claude Code settings JSON with the url and headers properties.

[!IMPORTANT] Replace <environment-id> with your Kontent.ai environment ID (GUID) and <management-api-key> with your key.

💻 Development

🛠 Local Installation

# Clone the repository
git clone https://github.com/kontent-ai/mcp-server.git
cd mcp-server

# Install dependencies
npm ci

# Build the project
npm run build

# Start the server
npm run start:stdio  # For STDIO transport
npm run start:shttp  # For Streamable HTTP transport

# Start the server with automatic reloading (no need to build first)
npm run dev:stdio  # For STDIO transport
npm run dev:shttp  # For Streamable HTTP transport

📂 Project Structure

  • src/ - Source code
    • tools/ - MCP tool implementations
    • clients/ - Kontent.ai API client setup
    • schemas/ - Data validation schemas
    • utils/ - Utility functions
      • errorHandler.ts - Standardized error handling for MCP tools
      • throwError.ts - Generic error throwing utility
    • server.ts - Main server setup and tool registration
    • bin.ts - Single entry point that handles both transport types

🔍 Debugging

For debugging, you can use the MCP inspector:

npx @modelcontextprotocol/inspector -e KONTENT_API_KEY=<key> -e KONTENT_ENVIRONMENT_ID=<env-id> node path/to/build/bin.js

Or use the MCP inspector on a running streamable HTTP server:

npx @modelcontextprotocol/inspector

This provides a web interface for inspecting and testing the available tools.

📦 Release Process

To release a new version:

  1. Bump the version using npm version [patch|minor|major] - this updates package.json, package-lock.json, and syncs to server.json
  2. Push the commit to your branch and create a pull request
  3. Merge the pull request
  4. Create a new GitHub release with the version number as both name and tag, using auto-generated release notes
  5. Publishing the release triggers an automated workflow that publishes to npm and GitHub MCP registry

License

MIT

Featured
CodeRabbit
CodeRabbit
AI writes the code. CodeRabbit catches the slop.
Try For Free →
Keep your Mac awake
Keep your Mac awake
Keep your Mac awake while Claude Code and 40+ AI agents run. Sleeps when they're idle.
One time payment $9 →
Context.devContext.dev
Context.dev
Integrate web data into your AI product. One API to scrape website & brand data.
Get API Key Now →
Make your agent a DeFi expert
Make your agent a DeFi expert
Agent, run crypto. Access onchain data & trade routes via 1inch.
Install now →
Make money from your Skills
Make money from your Skills
On Capafy, your Skill runs online 24/7 as an agent product, and you get paid every time someone uses it.
Start earning →
AppSignal
AppSignal
Monitor with ease. Code with confidence.
Start Free Trial →

Configuration

KONTENT_API_KEY*secret

Kontent.ai Management API key

KONTENT_ENVIRONMENT_ID*

Kontent.ai environment ID

PORT

Server port for HTTP transport (defaults to 3001)

Registryactive
Package@kontent-ai/mcp-server
TransportSTDIO, HTTP
AuthRequired
UpdatedJun 5, 2026
View on GitHub