docusaurus-plugin-mcp
Provides AI agents with search and read access to Docusaurus documentation, including categories and OpenAPI specs when configured.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@docusaurus-plugin-mcpsearch docs for getting started guide"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
docusaurus-plugin-mcp
Expose your Docusaurus docs and OpenAPI specs as an MCP server, so AI agents like Claude, Cursor, and VS Code can search your docs and inspect API endpoints from the editor.
Most docs-MCP tools index prose only. This one treats your OpenAPI specs as a first-class source: it resolves $refs and serves full request and response schemas, so an agent gets the real shape of an endpoint instead of guessing field names.
How it works
The plugin runs at build time. It reads your docs and OpenAPI files and writes a single snapshot (build/<outputDir>/snapshot.json) alongside your site. A small, host-agnostic handler then serves MCP over HTTP from that snapshot.
Docusaurus sites usually deploy as static files, which can't serve a live endpoint. So serving is split out: a CLI for local dev, and a tiny serverless function for production. The plugin's only job is producing the snapshot.
Related MCP server: apifable
Install
npm install docusaurus-plugin-mcpConfigure
// docusaurus.config.js
export default {
plugins: [
[
'docusaurus-plugin-mcp',
{
server: { name: 'my-docs', version: '1.0.0' },
// OpenAPI specs to index, paths relative to the site dir. Optional.
openapi: [
{ name: 'api', spec: 'openapi/api.json' },
{ name: 'admin', spec: 'openapi/admin.yaml' },
],
},
],
],
};Run docusaurus build and you'll get build/mcp/snapshot.json.
Options
Option | Default | Description |
| site title / | Identity reported to MCP clients. |
| — | One-line steer shown to the model on connect. |
|
| Docs source dir, relative to the site. |
|
| Route base path your docs are served under. Used to build real page URLs. |
|
|
|
|
| Substrings; any source-relative doc path containing one is skipped. |
|
| Snapshot location, relative to the build |
|
| Default endpoint path for the CLI server. |
Tools
Tool | Description |
| Full-text search the docs. Returns URL, title, category, snippet. |
| Full markdown of a page by URL. |
| Categories with page counts. |
| The indexed OpenAPI specs with versions and counts. |
| Search operations and webhook events by path, name, summary, or tag. |
| Full detail of one operation: params, request body, responses, |
The three *_api tools only appear when you configure openapi. Everything is read-only.
Serve it
Local dev
After a build, serve the snapshot:
npx docusaurus-plugin-mcp serve # reads build/mcp/snapshot.json on :3100Or build and serve in one step, without a full Docusaurus build:
npx docusaurus-plugin-mcp serve --site . --openapi api=openapi/api.jsonThen point a client at http://localhost:3100/mcp, or inspect it:
npx @modelcontextprotocol/inspector # connect via Streamable HTTPProduction
Static hosting can't serve a live endpoint, so add one serverless function that imports the snapshot. The handler is a standard Node (req, res). Vercel example:
// api/mcp.ts
import { createNodeHandler } from 'docusaurus-plugin-mcp/server';
import snapshot from '../build/mcp/snapshot.json' assert { type: 'json' };
export default createNodeHandler(snapshot, { name: 'my-docs', version: '1.0.0' });It's stateless: a fresh server is created per request, so it scales horizontally with no session store. The same handler works in any Node serverless runtime or an Express route. See examples/vercel.
Connect a client
# Claude Code
claude mcp add --transport http my-docs https://docs.example.com/mcp// Cursor / VS Code: .cursor/mcp.json or .vscode/mcp.json
{ "mcpServers": { "my-docs": { "url": "https://docs.example.com/mcp" } } }Programmatic use
import { buildSnapshot, resolveOptions } from 'docusaurus-plugin-mcp';
import { createMcpServer, createNodeHandler, loadSnapshot } from 'docusaurus-plugin-mcp/server';buildSnapshot({ siteDir, baseUrl, options })— build a snapshot in memory.createMcpServer(snapshot, opts)— a configuredMcpServerfrom the SDK.createNodeHandler(snapshot, opts)— a stateless Node request handler.loadSnapshot(file)— read a snapshot from disk.
Limitations
Doc URLs are derived from
routeBasePathplus the file path orslugfrontmatter. That covers the common cases; exotic routing or path aliases may not match exactly.Refreshing happens at build. Rebuild to pick up doc changes. The CLI's build-on-the-fly mode is for dev.
Runtime targets Node. Web-standard/edge runtimes aren't supported yet.
License
MIT
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/mcclowes/docusaurus-plugin-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server