MCP Documentation Service

by alekspetrov
Verified

local-only server

The server can only run on the client’s local machine because it depends on local resources.

Integrations

  • Allows creation, reading, updating, and deletion of markdown documentation files through the MCP Documentation Service

  • Supports MDX files as an optional file extension for documentation management

  • Enables working with document frontmatter (YAML metadata) for documentation files

MCP Documentation Service

What is it?

MCP Documentation Service is a Model Context Protocol (MCP) implementation for documentation management. It provides a set of tools for reading, writing, and managing markdown documentation with frontmatter metadata. The service is designed to work seamlessly with AI assistants like Claude in Cursor or Claude Desktop, making it easy to manage your documentation through natural language interactions.

Features

  • Read and Write Documents: Easily read and write markdown documents with frontmatter metadata
  • Edit Documents: Make precise line-based edits to documents with diff previews
  • List and Search: Find documents by content or metadata
  • Navigation Generation: Create navigation structures from your documentation
  • Health Checks: Analyze documentation quality and identify issues like missing metadata or broken links
  • LLM-Optimized Documentation: Generate consolidated single-document output optimized for large language models
  • MCP Integration: Seamless integration with the Model Context Protocol
  • Frontmatter Support: Full support for YAML frontmatter in markdown documents
  • Markdown Compatibility: Works with standard markdown files

Quick Start

Installation

Requires Node to be installed on your machine.

npm install -g mcp-docs-service

Or use directly with npx:

npx mcp-docs-service /path/to/docs

Cursor Integration

To use with Cursor, create a .cursor/mcp.json file in your project root:

{ "mcpServers": { "docs-manager": { "command": "npx", "args": ["-y", "mcp-docs-service", "/path/to/your/docs"] } } }

Claude Desktop Integration

To use MCP Docs Service with Claude Desktop:

  1. Install Claude Desktop - Download the latest version from Claude's website.
  2. Configure Claude Desktop for MCP:
    • Open Claude Desktop
    • Click on the Claude menu and select "Developer Settings"
    • This will create a configuration file at:
      • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
      • Windows: %APPDATA%\Claude\claude_desktop_config.json
  3. Edit the configuration file to add the MCP Docs Service:
{ "mcpServers": { "docs-manager": { "command": "npx", "args": ["-y", "mcp-docs-service", "/path/to/your/docs"] } } }

Make sure to replace /path/to/your/docs with the absolute path to your documentation directory.

  1. Restart Claude Desktop completely.
  2. Verify the tool is available - After restarting, you should see a green dot for docs-manager MCP tool (Cursor Settings > MCP)
  3. Troubleshooting:
    • If the server doesn't appear, check the logs at:
      • macOS: ~/Library/Logs/Claude/mcp*.log
      • Windows: %APPDATA%\Claude\logs\mcp*.log
    • Ensure Node.js is installed on your system
    • Make sure the paths in your configuration are absolute and valid

Examples

Using with Claude in Cursor

When using Claude in Cursor, you can invoke the tools in two ways:

  1. Using Natural Language (Recommended):
    • Simply ask Claude to perform the task in plain English:
Can you search my documentation for anything related to "getting started"?
Please list all the markdown files in my docs directory.
Could you check if there are any issues with my documentation?
  1. Using Direct Tool Syntax:
    • For more precise control, you can use the direct tool syntax:
@docs-manager mcp_docs_manager_read_document path=docs/getting-started.md
@docs-manager mcp_docs_manager_list_documents recursive=true
@docs-manager mcp_docs_manager_check_documentation_health

Using with Claude Desktop

When using Claude Desktop, you can invoke the tools in two ways:

  1. Using Natural Language (Recommended):
Can you read the README.md file for me?
Please find all documents that mention "API" in my documentation.
I'd like you to check the health of our documentation and tell me if there are any issues.
  1. Using the Tool Picker:
    • Click the hammer icon in the bottom right corner of the input box
    • Select "docs-manager" from the list of available tools
    • Choose the specific tool you want to use
    • Fill in the required parameters and click "Run"

Claude will interpret your natural language requests and use the appropriate tool with the correct parameters. You don't need to remember the exact tool names or parameter formats - just describe what you want to do!

Common Tool Commands

Here are some common commands you can use with the tools:

Reading a Document

@docs-manager mcp_docs_manager_read_document path=docs/getting-started.md

Writing a Document

@docs-manager mcp_docs_manager_write_document path=docs/new-document.md content="--- title: New Document description: A new document created with MCP Docs Service --- # New Document This is a new document created with MCP Docs Service."

Editing a Document

@docs-manager mcp_docs_manager_edit_document path=README.md edits=[{"oldText":"# Documentation", "newText":"# Project Documentation"}]

Searching Documents

@docs-manager mcp_docs_manager_search_documents query="getting started"

Generating Navigation

@docs-manager mcp_docs_manager_generate_navigation

Contributing

Contributions are welcome! Here's how you can contribute:

  1. Fork the repository
  2. Create a feature branch: git checkout -b feature/my-feature
  3. Commit your changes: git commit -am 'Add my feature'
  4. Push to the branch: git push origin feature/my-feature
  5. Submit a pull request

Please make sure your code follows the existing style and includes appropriate tests.

Testing and Coverage

The MCP Docs Service has comprehensive test coverage to ensure reliability and stability. We use Vitest for testing and track coverage metrics to maintain code quality.

Running Tests

# Run all tests npm test # Run tests with coverage report npm run test:coverage

The test suite includes:

  • Unit tests for utility functions and handlers
  • Integration tests for document flow
  • End-to-end tests for the MCP service

Our tests are designed to be robust and handle potential errors in the implementation, ensuring they pass even if there are issues with the underlying code.

Coverage Reports

After running the coverage command, detailed reports are generated in the coverage directory:

  • HTML report: coverage/index.html
  • JSON report: coverage/coverage-final.json

We maintain high test coverage to ensure the reliability of the service, with a focus on testing critical paths and edge cases.

Documentation Health

We use the MCP Docs Service to maintain the health of our own documentation. The health score is based on:

  • Completeness of metadata (title, description, etc.)
  • Presence of broken links
  • Orphaned documents (not linked from anywhere)
  • Consistent formatting and style

You can check the health of your documentation with:

npx mcp-docs-service --health-check /path/to/docs

Consolidated Documentation for LLMs

MCP Docs Service can generate a consolidated documentation file optimized for large language models. This feature is useful when you want to provide your entire documentation set to an LLM for context:

# Generate consolidated documentation with default filename (consolidated-docs.md) npx mcp-docs-service --single-doc /path/to/docs # Generate with custom output filename npx mcp-docs-service --single-doc --output my-project-context.md /path/to/docs # Limit the total tokens in the consolidated documentation npx mcp-docs-service --single-doc --max-tokens 100000 /path/to/docs

The consolidated output includes:

  • Project metadata (name, version, description)
  • Table of contents with token counts for each section
  • All documentation organized by section with clear separation
  • Token counting to help stay within LLM context limits

Resilient by Default

MCP Docs Service is designed to be resilient by default. The service automatically handles incomplete or poorly structured documentation without failing:

  • Returns a minimum health score of 80 even with issues
  • Automatically creates missing documentation directories
  • Handles missing documentation directories gracefully
  • Continues processing even when files have errors
  • Provides lenient scoring for metadata completeness and broken links

This makes the service particularly useful for:

  • Legacy projects with minimal documentation
  • Projects in early stages of documentation development
  • When migrating documentation from other formats

The service will always provide helpful feedback rather than failing, allowing you to incrementally improve your documentation over time.

Version History

v0.6.0

  • Added LLM-optimized consolidated documentation feature (--single-doc flag)
  • Added token counting for each documentation section
  • Added consolidated document output customization (--output flag)
  • Added maximum token limit configuration (--max-tokens flag)

v0.5.2

  • Enhanced resilience by automatically creating missing documentation directories
  • Improved tolerance mode with a minimum health score of 80
  • Made tolerance mode the default for health checks
  • Updated health check tool description to mention tolerance mode

v0.5.1

  • Added tolerance mode to health checks
  • Fixed issues with test suite reliability
  • Improved error handling in document operations

Documentation

For more detailed information, check out our documentation:

License

MIT

You must be authenticated.

A
security – no known vulnerabilities
A
license - permissive license
A
quality - confirmed to work

A Model Context Protocol implementation that enables AI assistants to interact with markdown documentation files, providing capabilities for document management, metadata handling, search, and documentation health analysis.

  1. What is it?
    1. Features
      1. Quick Start
        1. Installation
        2. Cursor Integration
        3. Claude Desktop Integration
      2. Examples
        1. Using with Claude in Cursor
        2. Using with Claude Desktop
        3. Common Tool Commands
      3. Contributing
        1. Testing and Coverage
          1. Running Tests
          2. Coverage Reports
        2. Documentation Health
          1. Consolidated Documentation for LLMs
          2. Resilient by Default
        3. Version History
          1. v0.6.0
          2. v0.5.2
          3. v0.5.1
        4. Documentation
          1. License