BookStack MCP Server

BookStack MCP Server

Enables AI models to interact with BookStack wiki instances through a comprehensive API interface. Supports content management (books, chapters, pages), user administration, search functionality, and content export in multiple formats.

Category
访问服务器

README

BookStack MCP Server

Un servidor del MCP que proporciona una interfaz completa para la API de BookStack, permitiendo que modelos de IA generen y editen contenido de la wiki.

Características

Este servidor MCP proporciona herramientas para:

📚 Gestión de Contenido

  • Libros: Crear, leer, actualizar, eliminar y exportar libros
  • Capítulos: Gestionar capítulos dentro de libros
  • Páginas: Crear y editar páginas con contenido HTML o Markdown
  • Estanterías: Organizar libros en colecciones

🔍 Búsqueda y Descubrimiento

  • Búsqueda Global: Buscar en todo el contenido de BookStack
  • Navegación: Explorar la estructura del contenido

👥 Gestión de Usuarios y Permisos

  • Usuarios: Crear, actualizar y gestionar cuentas de usuario
  • Roles: Configurar roles y permisos
  • Autenticación: Soporte para autenticación externa

📎 Recursos Multimedia

  • Adjuntos: Gestionar archivos adjuntos
  • Imágenes: Administrar la galería de imágenes

📤 Exportación

  • Múltiples Formatos: Exportar contenido en HTML, PDF, texto plano y Markdown

Instalación

Prerrequisitos

  • Node.js 18 o superior
  • Una instancia de BookStack en funcionamiento
  • Token de API de BookStack

Configuración

  1. Instalar dependencias:
npm install
  1. Configurar variables de entorno:
export BOOKSTACK_BASE_URL="https://tu-bookstack.example.com"
export BOOKSTACK_TOKEN_ID="tu_token_id"
export BOOKSTACK_TOKEN="tu_token_secreto"
  1. Compilar el proyecto:
npm run build

Obtener Tokens de API de BookStack

  1. Inicia sesión en tu instancia de BookStack
  2. Ve a tu perfil de usuario (esquina superior derecha)
  3. Selecciona "Preferencias" → "API Tokens"
  4. Crea un nuevo token con los permisos necesarios
  5. Guarda el Token ID y el Token Secret

Uso

Ejecutar el Servidor

npm start

O ejecutar directamente:

node build/index.js

Integración con Cliente MCP

El servidor se comunica a través de stdio y está diseñado para ser usado con clientes MCP como Claude Desktop.

Configuración de Claude Desktop

Agrega esta configuración a tu archivo de configuración de Claude Desktop:

{
  "mcpServers": {
    "bookstack": {
      "type": "stdio",
      "command": "npx",
      "args": ["@lautarobarba/bookstack-mcp-server"],
      "env": {
        "BOOKSTACK_BASE_URL": "${BOOKSTACK_BASE_URL}",
        "BOOKSTACK_TOKEN_ID": "${BOOKSTACK_TOKEN_ID}",
        "BOOKSTACK_TOKEN": "${BOOKSTACK_TOKEN}"
      }
    }
  }
}

Configuración de VS Code

Agrega esta configuración a tu archivo .vscode/mcp.json:

{
  "servers": {
    "bookstack": {
      "type": "stdio",
      "command": "npx",
      "args": ["@lautarobarba/bookstack-mcp-server"],
      "env": {
        "BOOKSTACK_BASE_URL": "${BOOKSTACK_BASE_URL}",
        "BOOKSTACK_TOKEN_ID": "${BOOKSTACK_TOKEN_ID}",
        "BOOKSTACK_TOKEN": "${BOOKSTACK_TOKEN}"
      }
    }
  }
}

Herramientas Disponibles

Gestión de Libros

  • list_books - Listar todos los libros
  • get_book - Obtener detalles de un libro específico
  • create_book - Crear un nuevo libro
  • update_book - Actualizar un libro existente
  • delete_book - Eliminar un libro
  • export_book - Exportar libro en varios formatos

Gestión de Capítulos

  • list_chapters - Listar capítulos
  • get_chapter - Obtener detalles de un capítulo
  • create_chapter - Crear un nuevo capítulo
  • update_chapter - Actualizar un capítulo
  • delete_chapter - Eliminar un capítulo
  • export_chapter - Exportar capítulo

Gestión de Páginas

  • list_pages - Listar páginas
  • get_page - Obtener contenido de una página
  • create_page - Crear una nueva página
  • update_page - Actualizar contenido de página
  • delete_page - Eliminar una página
  • export_page - Exportar página

Gestión de Estanterías

  • list_shelves - Listar estanterías
  • get_shelf - Obtener detalles de una estantería
  • create_shelf - Crear una nueva estantería
  • update_shelf - Actualizar una estantería
  • delete_shelf - Eliminar una estantería

Búsqueda

  • search_all - Buscar en todo el contenido

Gestión de Usuarios

  • list_users - Listar usuarios
  • get_user - Obtener detalles de usuario
  • create_user - Crear nuevo usuario
  • update_user - Actualizar usuario
  • delete_user - Eliminar usuario

Gestión de Roles

  • list_roles - Listar roles
  • get_role - Obtener detalles de rol
  • create_role - Crear nuevo rol
  • update_role - Actualizar rol
  • delete_role - Eliminar rol

Gestión de Recursos

  • list_attachments - Listar adjuntos
  • get_attachment - Obtener detalles de adjunto
  • delete_attachment - Eliminar adjunto
  • list_images - Listar imágenes
  • get_image - Obtener detalles de imagen
  • update_image - Actualizar imagen
  • delete_image - Eliminar imagen

Ejemplos de Uso

Crear un Nuevo Libro

// A través del cliente MCP
await mcpClient.callTool("create_book", {
  name: "Guía de Desarrollo",
  description: "Una guía completa para el desarrollo de software",
  tags: [
    { name: "categoria", value: "desarrollo" },
    { name: "nivel", value: "intermedio" },
  ],
});

Crear una Página con Contenido

await mcpClient.callTool("create_page", {
  book_id: 1,
  name: "Introducción a TypeScript",
  markdown: `# Introducción a TypeScript

TypeScript es un lenguaje de programación desarrollado por Microsoft...

## Características principales

- Tipado estático
- Compatibilidad con JavaScript
- Herramientas de desarrollo avanzadas
`,
  tags: [
    { name: "lenguaje", value: "typescript" },
    { name: "tema", value: "introduccion" },
  ],
});

Buscar Contenido

await mcpClient.callTool("search_all", {
  query: "typescript desarrollo",
  count: 10,
});

Seguridad

  • Todas las operaciones requieren un token de API válido de BookStack
  • Los permisos se manejan a través del sistema de roles de BookStack
  • Las validaciones de entrada utilizan schemas Zod para mayor seguridad
  • Manejo robusto de errores para evitar exposición de información sensible

Desarrollo

Estructura del Proyecto

src/
├── index.ts              # Punto de entrada del servidor MCP
├── types/                # Definiciones de tipos TypeScript
│   └── index.ts
├── lib/                  # Utilidades y cliente API
│   ├── bookstack-client.ts
│   └── validation.ts
└── tools/                # Implementación de herramientas MCP
    ├── content-tools.ts
    └── search-user-tools.ts

Scripts Disponibles

  • npm run build - Compilar TypeScript a JavaScript
  • npm run dev - Ejecutar en modo desarrollo con watch
  • npm start - Ejecutar el servidor compilado
  • npm test - Ejecutar tests (si están configurados)

Contribuir

  1. Fork el proyecto
  2. Crea una rama para tu feature (git checkout -b feature/nueva-funcionalidad)
  3. Commit tus cambios (git commit -am 'Agregar nueva funcionalidad')
  4. Push a la rama (git push origin feature/nueva-funcionalidad)
  5. Crea un Pull Request

Licencia

Este proyecto está bajo la Licencia MIT. Ver el archivo LICENSE para más detalles.

Soporte

Para problemas y preguntas:

  1. Verifica la documentación de la API de BookStack
  2. Revisa los logs de error del servidor MCP
  3. Crea un issue en el repositorio del proyecto

Changelog

v1.0.0

  • Implementación inicial del servidor MCP
  • Soporte completo para la API de BookStack
  • Herramientas para gestión de contenido, usuarios y búsqueda
  • Validación robusta con Zod
  • Exportación en múltiples formatos

推荐服务器

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 模型以安全和受控的方式获取实时的网络信息。

官方
精选