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.
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
- Instalar dependencias:
npm install
- 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"
- Compilar el proyecto:
npm run build
Obtener Tokens de API de BookStack
- Inicia sesión en tu instancia de BookStack
- Ve a tu perfil de usuario (esquina superior derecha)
- Selecciona "Preferencias" → "API Tokens"
- Crea un nuevo token con los permisos necesarios
- 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 librosget_book- Obtener detalles de un libro específicocreate_book- Crear un nuevo libroupdate_book- Actualizar un libro existentedelete_book- Eliminar un libroexport_book- Exportar libro en varios formatos
Gestión de Capítulos
list_chapters- Listar capítulosget_chapter- Obtener detalles de un capítulocreate_chapter- Crear un nuevo capítuloupdate_chapter- Actualizar un capítulodelete_chapter- Eliminar un capítuloexport_chapter- Exportar capítulo
Gestión de Páginas
list_pages- Listar páginasget_page- Obtener contenido de una páginacreate_page- Crear una nueva páginaupdate_page- Actualizar contenido de páginadelete_page- Eliminar una páginaexport_page- Exportar página
Gestión de Estanterías
list_shelves- Listar estanteríasget_shelf- Obtener detalles de una estanteríacreate_shelf- Crear una nueva estanteríaupdate_shelf- Actualizar una estanteríadelete_shelf- Eliminar una estantería
Búsqueda
search_all- Buscar en todo el contenido
Gestión de Usuarios
list_users- Listar usuariosget_user- Obtener detalles de usuariocreate_user- Crear nuevo usuarioupdate_user- Actualizar usuariodelete_user- Eliminar usuario
Gestión de Roles
list_roles- Listar rolesget_role- Obtener detalles de rolcreate_role- Crear nuevo rolupdate_role- Actualizar roldelete_role- Eliminar rol
Gestión de Recursos
list_attachments- Listar adjuntosget_attachment- Obtener detalles de adjuntodelete_attachment- Eliminar adjuntolist_images- Listar imágenesget_image- Obtener detalles de imagenupdate_image- Actualizar imagendelete_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 JavaScriptnpm run dev- Ejecutar en modo desarrollo con watchnpm start- Ejecutar el servidor compiladonpm test- Ejecutar tests (si están configurados)
Contribuir
- Fork el proyecto
- Crea una rama para tu feature (
git checkout -b feature/nueva-funcionalidad) - Commit tus cambios (
git commit -am 'Agregar nueva funcionalidad') - Push a la rama (
git push origin feature/nueva-funcionalidad) - 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:
- Verifica la documentación de la API de BookStack
- Revisa los logs de error del servidor MCP
- 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
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.