Docs
Docs MCP Server
This project provides a flexible Model Context Protocol (MCP) server, powered by Probe, designed to make documentation or codebases searchable by AI assistants.
You can chat with code or your docs, simply by pointing to git repo or a folder.
npx -y @buger/docs-mcp@latest --gitUrl https://github.com/buger/probe
Use Cases:
- Chat with any GitHub Repository: Point the server to a public or private Git repository to enable natural language queries about its contents.
- Search Your Documentation: Integrate your project's documentation (from a local directory or Git) for easy searching.
- Build Custom MCP Servers: Use this project as a template to create your own official MCP servers tailored to specific documentation sets or even codebases.
The content source (documentation or code) can be pre-built into the package during the npm run build
step, or configured dynamically at runtime using local directories or Git repositories. By default, when using a gitUrl
without enabling auto-updates, the server downloads a .tar.gz
archive for faster startup. Full Git cloning is used only when autoUpdateInterval
is greater than 0.
Features
- Powered by Probe: Leverages the Probe search engine for efficient and relevant results.
- Flexible Content Sources: Include a specific local directory or clone a Git repository.
- Pre-build Content: Optionally bundle documentation/code content directly into the package.
- Dynamic Configuration: Configure content sources, Git settings, and MCP tool details via config file, CLI arguments, or environment variables.
- Automatic Git Updates: Keep content fresh by automatically pulling changes from a Git repository at a configurable interval.
- Customizable MCP Tool: Define the name and description of the search tool exposed to AI assistants.
- AI Integration: Seamlessly integrates with AI assistants supporting the Model Context Protocol (MCP).
Usage
The primary way to use this server is via npx
, which downloads and runs the package without needing a local installation. This makes it easy to integrate with AI assistants and MCP clients (like IDE extensions).
Installing via Smithery
To install Docs MCP Server for Claude Desktop automatically via Smithery:
npx -y @smithery/cli install @buger/docs-mcp --client claude
Integrating with MCP Clients (e.g., IDEs)
You can configure your MCP client to launch this server using npx
. Here are examples of how you might configure a client (syntax may vary based on the specific client):
Example 1: Dynamically Searching a Git Repository (Tyk Docs)
This configuration tells the client to run the latest @buger/docs-mcp
package using npx
, pointing it dynamically to the Tyk documentation repository. The -y
argument automatically confirms the npx
installation prompt. The --toolName
and --toolDescription
arguments customize how the search tool appears to the AI assistant.
{
"mcpServers": {
"tyk-docs-search": {
"command": "npx",
"args": [
"-y",
"@buger/docs-mcp@latest",
"--gitUrl",
"https://github.com/TykTechnologies/tyk-docs",
"--toolName",
"search_tyk_docs",
"--toolDescription",
"Search Tyk API Management Documentation"
],
"enabled": true
}
}
}
Alternatively, some clients might allow specifying the full command directly. You could achieve the same as Example 1 using:
npx -y @buger/docs-mcp@latest --gitUrl https://github.com/TykTechnologies/tyk-docs --toolName search_tyk_docs --toolDescription "Search Tyk API Management Documentation"
Example 2: Using a Pre-built, Branded MCP Server (e.g., Tyk Package)
If a team publishes a pre-built package containing specific documentation (like @tyk-technologies/docs-mcp
), the configuration becomes simpler as the content source and tool details are baked into that package. The -y
argument is still recommended for npx
.
{
"mcpServers": {
"tyk-official-docs": {
"command": "npx",
"args": [
"-y",
"@tyk-technologies/docs-mcp@latest"
],
"enabled": true
}
}
}
This approach is ideal for distributing standardized search experiences for official documentation or codebases. See the "Creating Your Own Pre-built MCP Server" section below.
Here is example on how Tyk team have build own documentation MCP server https://github.com/TykTechnologies/docs-mcp.
Configuration
Create a docs-mcp.config.json
file in the root directory to define the default content source and MCP tool details used during the build and at runtime (unless overridden by CLI arguments or environment variables).
Example 1: Using a Local Directory
{
"includeDir": "/Users/username/projects/my-project/docs",
"toolName": "search_my_project_docs",
"toolDescription": "Search the documentation for My Project.",
"ignorePatterns": [
"node_modules",
".git",
"build",
"*.log"
]
}
Example 2: Using a Git Repository
{
"gitUrl": "https://github.com/your-org/your-codebase.git",
"gitRef": "develop",
"autoUpdateInterval": 15,
"toolName": "search_codebase",
"toolDescription": "Search the main company codebase.",
"ignorePatterns": [
"*.test.js",
"dist/",
"__snapshots__"
]
}
Configuration Options
includeDir
: (Build/Runtime) Absolute path to a local directory whose contents will be copied to thedata
directory during build, or used directly at runtime ifdataDir
is not specified. Use this ORgitUrl
.gitUrl
: (Build/Runtime) URL of the Git repository. Use this ORincludeDir
.- If
autoUpdateInterval
is 0 (default), the server attempts to download a.tar.gz
archive directly (currently assumes GitHub URL structure:https://github.com/{owner}/{repo}/archive/{ref}.tar.gz
). This is faster but doesn't support updates. - If
autoUpdateInterval
> 0, the server performs agit clone
and enables periodic updates.
- If
gitRef
: (Build/Runtime) The branch, tag, or commit hash to use from thegitUrl
(default:main
). Used for both tarball download and Git clone/pull.autoUpdateInterval
: (Runtime) Interval in minutes to automatically check for Git updates (default: 0, meaning disabled). Setting this to a value > 0 enables Git cloning and periodicgit pull
operations. Requires thegit
command to be available in the system path.dataDir
: (Runtime) Path to the directory containing the content to be searched at runtime. Overrides content sourced fromincludeDir
orgitUrl
defined in the config file or built into the package. Useful for pointing the server to live data without rebuilding.toolName
: (Build/Runtime) The name of the MCP tool exposed by the server (default:search_docs
). Choose a descriptive name relevant to the content.toolDescription
: (Build/Runtime) The description of the MCP tool shown to AI assistants (default: "Search documentation using the probe search engine.").ignorePatterns
: (Build/Runtime) An array of glob patterns.enableBuildCleanup
: (Build) Iftrue
(default), removes common binary/media files (images, videos, archives, etc.) and files larger than 100KB from thedata
directory after the build step. Set tofalse
to disable this cleanup.- If using
includeDir
during build: Files matching these patterns are excluded when copying todata
..gitignore
rules are also respected. - If using
gitUrl
ordataDir
at runtime: Files matching these patterns within thedata
directory are ignored by the search indexer.
- If using
Precedence:
- Runtime Configuration (Highest): CLI arguments (
--dataDir
,--gitUrl
, etc.) and Environment Variables (DATA_DIR
,GIT_URL
, etc.) override all other settings. CLI arguments take precedence over Environment Variables. - Build-time Configuration: Settings in
docs-mcp.config.json
(includeDir
,gitUrl
,toolName
, etc.) define defaults used duringnpm run build
and also serve as runtime defaults if not overridden. - Default Values (Lowest): Internal defaults are used if no configuration is provided (e.g.,
toolName: 'search_docs'
,autoUpdateInterval: 5
).
Note: If both includeDir
and gitUrl
are provided in the same configuration source (e.g., both in the config file, or both as CLI args), gitUrl
takes precedence.
Creating Your Own Pre-built MCP Server
You can use this project as a template to create and publish your own npm package with documentation or code pre-built into it. This provides a zero-configuration experience for users (like Example 2 above).
- Fork/Clone this Repository: Start with this project's code.
- Configure
docs-mcp.config.json
: Define theincludeDir
orgitUrl
pointing to your content source. Set the defaulttoolName
andtoolDescription
. - Update
package.json
: Change thename
(e.g.,@my-org/my-docs-mcp
),version
,description
, etc. - Build: Run
npm run build
. This clones/copies your content into thedata
directory and makes the package ready. - Publish: Run
npm publish
(you'll need npm authentication configured).
Now, users can run your specific documentation server easily: npx @my-org/my-docs-mcp@latest
.
(The previous "Running", "Dynamic Configuration at Runtime", and "Environment Variables" sections have been removed as npx
usage with arguments within client configurations is now the primary documented method.)
Using with AI Assistants
This MCP server exposes a search tool to connected AI assistants via the Model Context Protocol. The tool's name and description are configurable (see Configuration section). It searches the content within the currently active data
directory (determined by build settings, config file, CLI args, or environment variables).
Tool Parameters:
query
: A natural language query or keywords describing what to search for (e.g., "how to configure the gateway", "database connection example", "user authentication"). The server uses Probe's search capabilities to find relevant content. (Required)page
: The page number for results when dealing with many matches. Defaults to 1 if omitted. (Optional)
Example Tool Call (using search_tyk_docs
from Usage Example 1):
{
"tool_name": "search_tyk_docs",
"arguments": {
"query": "gateway rate limiting",
"page": 1 // Requesting the first page
}
}
Example Tool Call (using the tool from the @tyk/docs-mcp
package):
Assuming the pre-built package @tyk/docs-mcp
defined its tool name as search_tyk_official_docs
:
{
"tool_name": "search_tyk_official_docs",
"arguments": {
"query": "dashboard api access",
"page": 2 // Requesting the second page
}
}
(The previous "Publishing as an npm Package" section has been replaced by the "Creating Your Own Pre-built MCP Server" section above.)
License
MIT