MCP Strapi Server

MCP Strapi Server

Enables CRUD operations, content management, and media handling for any Strapi content type through standardized tools. Supports internationalization, schema management, and works with Strapi v5's API.

Category
访问服务器

README

MCP Strapi Server

Un servidor Model Context Protocol (MCP) para operaciones CRUD en Strapi, permitiendo interactuar con cualquier content type de Strapi a través de herramientas estandarizadas.

Características

  • 13 Herramientas para operaciones CRUD, gestión de contenidos y medios
  • Sistema genérico - funciona con cualquier content type
  • Fetch nativo - sin dependencias adicionales (Node.js 22+)
  • Stdio transport - integración local con Claude Desktop
  • TypeScript moderno - tipado completo y seguro
  • Gestión de medios - búsqueda, obtención y carga de archivos
  • i18n support - soporte completo para internacionalización

Requisitos

  • Node.js 22+ (para soporte nativo de fetch)
  • Strapi corriendo en localhost:1337 (o configurado en STRAPI_URL)

Instalación

Opción 1: Desarrollo Local

# Instalar dependencias
npm install

# Copiar variables de entorno
cp .env.example .env

# Editar .env con tu configuración de Strapi
nano .env

# Compilar TypeScript
npm run build

# Ejecutar servidor
npm start

Opción 2: Desarrollo con Watch Mode

# Ejecutar con hot-reload (usando tsx)
npm run dev

Configuración en Claude Desktop

Añade el servidor MCP a tu configuración de Claude Desktop:

{
  "mcpServers": {
    "strapi": {
      "command": "node",
      "args": ["/ruta/absoluta/a/mcp-strapi/dist/index.js"],
      "env": {
        "STRAPI_URL": "http://localhost:1337",
        "STRAPI_API_TOKEN": "tu-token-opcional"
      }
    }
  }
}

⚠️ Notas Importantes sobre Content Types

Uso del parámetro contentType

Para las operaciones CRUD (create, read, list, update, delete), SIEMPRE debes usar el nombre PLURAL del content type:

CORRECTO:

  • "products"
  • "articles"
  • "categories"
  • "profiles"

INCORRECTO:

  • "api::product.product" (UID completo)
  • "product" (singular)
  • "Product" (capitalizado)

Cómo obtener el nombre correcto

  1. Usa la herramienta strapi-list-content-types para ver todos los content types disponibles
  2. En la respuesta, busca el campo pluralName - ese es el valor que debes usar
  3. Ejemplo de respuesta:
{
  "uid": "api::product.product",
  "apiID": "product",
  "pluralName": "products"  // ← Usa este valor
}

Excepciones

La herramienta strapi-add-field es la ÚNICA que requiere el UID completo:

  • "api::product.product" para strapi-add-field
  • "products" NO funciona con strapi-add-field

Herramientas Disponibles (13 total)

CRUD Operations (6 tools)

1. strapi-create

Crea una nueva entrada en un content type.

Parámetros:

  • contentType (string): Nombre PLURAL del content type (ej: "articles", "products")
  • data (object): Datos de la entrada
  • populate (string[], opcional): Relaciones a poblar

Ejemplo:

{
  "contentType": "articles",
  "data": {
    "title": "Mi Artículo",
    "content": "Contenido del artículo",
    "publishedAt": null
  },
  "populate": ["author", "category"]
}

⚠️ IMPORTANTE: Usa el nombre plural del content type ("articles"), NO el UID completo ("api::article.article").

2. strapi-read

Lee una entrada específica por ID o documentId.

Parámetros:

  • contentType (string): Nombre PLURAL del content type (ej: "articles")
  • id (string | number): ID numérico o documentId (string) de la entrada
  • fields (string[], opcional): Campos a retornar
  • populate (string[], opcional): Relaciones a poblar

Ejemplo:

{
  "contentType": "articles",
  "id": "abc123xyz",
  "fields": ["title", "content"],
  "populate": ["author"]
}

💡 Nota: En Strapi v5, el parámetro id acepta tanto IDs numéricos como documentIds (strings).

3. strapi-list

Lista entradas con filtrado, paginación y ordenamiento.

Parámetros:

  • contentType (string): Nombre PLURAL del content type (ej: "articles")
  • filters (object, opcional): Filtros de búsqueda
  • sort (string[], opcional): Campos de ordenamiento
  • pagination (object, opcional): Configuración de paginación
  • fields (string[], opcional): Campos a retornar
  • populate (string[], opcional): Relaciones a poblar

Ejemplo:

{
  "contentType": "articles",
  "filters": {
    "publishedAt": { "$notNull": true }
  },
  "sort": ["createdAt:desc"],
  "pagination": {
    "page": 1,
    "pageSize": 10
  },
  "populate": ["author", "category"]
}

4. strapi-update

Actualiza una entrada existente (actualización parcial).

Parámetros:

  • contentType (string): Nombre PLURAL del content type (ej: "articles")
  • id (string | number): ID numérico o documentId (string) de la entrada
  • data (object): Datos a actualizar (solo los campos que quieres cambiar)
  • populate (string[], opcional): Relaciones a poblar

Ejemplo:

{
  "contentType": "articles",
  "id": "abc123xyz",
  "data": {
    "title": "Título Actualizado",
    "publishedAt": "2024-01-15T10:00:00.000Z"
  }
}

5. strapi-delete

Elimina una entrada.

Parámetros:

  • contentType (string): Nombre PLURAL del content type (ej: "articles")
  • id (string | number): ID numérico o documentId (string) de la entrada a eliminar

Ejemplo:

{
  "contentType": "articles",
  "id": "abc123xyz"
}

⚠️ Nota: Puede aparecer un error de "JSON input" después de eliminar, pero la entrada SÍ se elimina correctamente. Esto ocurre porque Strapi retorna una respuesta vacía.

Content Type Management (3 tools)

  • strapi-list-content-types - Listar todos los content types disponibles
  • strapi-get-schema - Obtener schema detallado de un content type
  • strapi-add-field - Añadir campo a un content type

Internationalization (1 tool)

  • strapi-get-i18n-locales - Obtener locales disponibles

Media Management (3 tools)

  • strapi-search-media - Buscar archivos en la biblioteca de medios
  • strapi-get-media - Obtener archivo específico por ID
  • strapi-upload-media - Subir archivo a la biblioteca de medios

Ejemplos de Uso con Content Types Personalizados

Productos

{
  "contentType": "products",
  "data": {
    "name": "Producto Ejemplo",
    "price": 99.99,
    "stock": 100,
    "category": 1
  }
}

Perfiles de Usuario

{
  "contentType": "profiles",
  "data": {
    "displayName": "Juan Pérez",
    "bio": "Desarrollador",
    "avatar": "https://example.com/avatar.jpg"
  }
}

Estructura del Proyecto

mcp-strapi/
├── docs/                        # Documentación
├── src/
│   ├── index.ts                 # Entry point
│   ├── server.ts                # Configuración MCP server
│   ├── tools/                   # Herramientas (13 total)
│   │   ├── create.ts
│   │   ├── create-with-locales.ts
│   │   ├── read.ts
│   │   ├── list.ts
│   │   ├── update.ts
│   │   ├── delete.ts
│   │   ├── list-content-types.ts
│   │   ├── get-schema.ts
│   │   ├── add-field.ts
│   │   ├── get-i18n-locales.ts
│   │   ├── search-media.ts
│   │   ├── get-media.ts
│   │   └── upload-media.ts
│   ├── services/
│   │   ├── strapi-client.ts    # Cliente HTTP (fetch nativo)
│   │   └── i18n-validator.ts   # Validador de internacionalización
│   ├── types/
│   │   └── index.ts            # Tipos TypeScript
│   └── config/
│       └── environment.ts      # Variables de entorno
├── package.json
├── tsconfig.json
├── CLAUDE.md
└── README.md

Variables de Entorno

Variable Descripción Valor por defecto
STRAPI_URL URL base de la API de Strapi http://localhost:1337
NODE_ENV Entorno de ejecución production

Debugging

Los logs se escriben a stderr para no interferir con el protocolo MCP (que usa stdout):

# Ver logs en desarrollo
npm run dev 2>&1 | grep "ERROR\|CONFIG\|TOOL"

Características implementadas

  • ✅ Autenticación con API Tokens de Strapi
  • ✅ Validación de i18n con detección de idiomas heredados
  • ✅ 13 herramientas completas (CRUD, Content Types, Medios, i18n)
  • ✅ Soporte para localizaciones múltiples
  • ✅ Gestión completa de medios (búsqueda, descarga, carga)
  • ✅ Documentación exhaustiva en CLAUDE.md
  • ✅ Strict mode para validaciones de contenido

Solución de Problemas

Error: "Node.js 22+ required"

Asegúrate de tener Node.js 22 o superior instalado:

node --version  # Debe mostrar v22.x.x o superior

Error de conexión a Strapi

Verifica que Strapi esté corriendo y accesible:

curl http://localhost:1337/api

Licencia

MIT

Contribuciones

Las contribuciones son bienvenidas. Por favor:

  1. Fork el repositorio
  2. Crea una rama para tu feature (git checkout -b feature/amazing-feature)
  3. Commit tus cambios (git commit -m 'Add amazing feature')
  4. Push a la rama (git push origin feature/amazing-feature)
  5. Abre un Pull Request

Autor

Creado con las mejores prácticas de MCP TypeScript SDK y Strapi Entity Service API.

推荐服务器

Baidu Map

Baidu Map

百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。

官方
精选
JavaScript
Playwright MCP Server

Playwright MCP Server

一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。

官方
精选
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。

官方
精选
本地
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

官方
精选
本地
TypeScript
VeyraX

VeyraX

一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。

官方
精选
本地
graphlit-mcp-server

graphlit-mcp-server

模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。

官方
精选
TypeScript
Kagi MCP Server

Kagi MCP Server

一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

官方
精选
Python
e2b-mcp-server

e2b-mcp-server

使用 MCP 通过 e2b 运行代码。

官方
精选
Neon MCP Server

Neon MCP Server

用于与 Neon 管理 API 和数据库交互的 MCP 服务器

官方
精选
Exa MCP Server

Exa MCP Server

模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。

官方
精选