Turns document generation into native AI operations. Exposes PDF creation, screenshot capture, and document rendering as MCP tools that any compatible agent can call directly. Useful when you need your AI assistant to produce formatted outputs beyond plain text, like generating reports, capturing web page screenshots, or creating printable documents on demand. The stdio transport means it runs as a local process, so document generation happens on your machine without external API dependencies. Reach for this when you want Claude or other MCP clients to handle the full pipeline from content creation to formatted delivery.
Public tool metadata for what this MCP can expose to an agent.
docapi_generate_pdfConvert HTML to a PDF using DocAPI's headless Chromium renderer. Full CSS support: Flexbox, Grid, custom fonts, gradients, shadows. Args: - html (string): HTML to render. Inline styles and <style> tags work. Google Fonts URLs supported. - format ('A4' | 'Letter' | 'Legal' | 'T...5 paramsConvert HTML to a PDF using DocAPI's headless Chromium renderer. Full CSS support: Flexbox, Grid, custom fonts, gradients, shadows. Args: - html (string): HTML to render. Inline styles and <style> tags work. Google Fonts URLs supported. - format ('A4' | 'Letter' | 'Legal' | 'T...
htmlstringformatstringA4 · Letter · Legal · Tabloiddefault: A4landscapebooleanmargin_inchesnumberprint_backgroundbooleandocapi_capture_screenshotScreenshot a URL or render HTML and capture it as an image. Returns the image inline so you can view it immediately. Common uses: Open Graph images (1200×630), social cards, page thumbnails, template previews. Args: - url (string, optional): A live URL to screenshot. Provide u...5 paramsScreenshot a URL or render HTML and capture it as an image. Returns the image inline so you can view it immediately. Common uses: Open Graph images (1200×630), social cards, page thumbnails, template previews. Args: - url (string, optional): A live URL to screenshot. Provide u...
urlstringhtmlstringwidthintegerformatstringpng · jpegdefault: pngheightintegerdocapi_check_creditsCheck remaining API credits and USDC top-up address for agent accounts. Only applicable to agent accounts (registered via docapi_register_agent). Human subscription accounts use monthly plan limits instead. Returns: { credits, usdc_address, rate, suggested_topup_usdc }Check remaining API credits and USDC top-up address for agent accounts. Only applicable to agent accounts (registered via docapi_register_agent). Human subscription accounts use monthly plan limits instead. Returns: { credits, usdc_address, rate, suggested_topup_usdc }
No parameter schema in public metadata yet.
docapi_register_agentRegister a new DocAPI agent account programmatically. Returns an API key and USDC address — no email, no dashboard, no human step required. Use this when building software that needs PDF or screenshot generation. After registering, embed the api_key in the software and wire up...1 paramsRegister a new DocAPI agent account programmatically. Returns an API key and USDC address — no email, no dashboard, no human step required. Use this when building software that needs PDF or screenshot generation. After registering, embed the api_key in the software and wire up...
notify_emailstringdocapi_generate_invoiceGenerate a professionally formatted invoice PDF from structured data. Returns a base64-encoded PDF. Args: - from_name (string): Sender's name or business name - from_email (string, optional): Sender's email - from_address (string, optional): Sender's address (\n for line break...15 paramsGenerate a professionally formatted invoice PDF from structured data. Returns a base64-encoded PDF. Args: - from_name (string): Sender's name or business name - from_email (string, optional): Sender's email - from_address (string, optional): Sender's address (\n for line break...
datestringnotesstringto_namestringdue_datestringlogo_urlstringto_emailstringfrom_namestringfrom_emailstringfrom_phonestringline_itemsarrayto_addressstringtax_percentnumberfrom_addressstringinvoice_numberstringcurrency_symbolstringThe MCP registry provides MCP clients with a list of MCP servers, like an app store for MCP servers.
📤 Publish my MCP server | ⚡️ Live API docs | 👀 Ecosystem vision | 📖 Full documentation
2025-10-24 update: The Registry API has entered an API freeze (v0.1) 🎉. For the next month or more, the API will remain stable with no breaking changes, allowing integrators to confidently implement support. This freeze applies to v0.1 while development continues on v0. We'll use this period to validate the API in real-world integrations and gather feedback to shape v1 for general availability. Thank you to everyone for your contributions and patience—your involvement has been key to getting us here!
2025-09-08 update: The registry has launched in preview 🎉 (announcement blog post). While the system is now more stable, this is still a preview release and breaking changes or data resets may occur. A general availability (GA) release will follow later. We'd love your feedback in GitHub discussions or in the #registry-dev Discord (joining details here).
Current key maintainers:
We use multiple channels for collaboration - see modelcontextprotocol.io/community/communication.
Often (but not always) ideas flow through this pipeline:
# Start full development environment
make dev-compose
This starts the registry at localhost:8080 with PostgreSQL. The database uses ephemeral storage and is reset each time you restart the containers, ensuring a clean state for development and testing.
Note: The registry uses ko to build container images. The make dev-compose command automatically builds the registry image with ko and loads it into your local Docker daemon before starting the services.
By default, the registry seeds from the production API with a filtered subset of servers (to keep startup fast). This ensures your local environment mirrors production behavior and all seed data passes validation. For offline development you can seed from a file without validation with MCP_REGISTRY_SEED_FROM=data/seed.json MCP_REGISTRY_ENABLE_REGISTRY_VALIDATION=false make dev-compose.
The setup can be configured with environment variables in docker-compose.yml - see .env.example for a reference.
Pre-built Docker images are automatically published to GitHub Container Registry:
# Run latest stable release
docker run -p 8080:8080 ghcr.io/modelcontextprotocol/registry:latest
# Run latest from main branch (continuous deployment)
docker run -p 8080:8080 ghcr.io/modelcontextprotocol/registry:main
# Run specific release version
docker run -p 8080:8080 ghcr.io/modelcontextprotocol/registry:v1.0.0
# Run development build from main branch
docker run -p 8080:8080 ghcr.io/modelcontextprotocol/registry:main-20250906-abc123d
Available tags:
latest, v1.0.0, v1.1.0, etc.main (latest main branch build)main-<date>-<sha> (specific commit builds)To publish a server, we've built a simple CLI. You can use it with:
# Build the latest CLI
make publisher
# Use it!
./bin/mcp-publisher --help
See the publisher guide for more details.
# Run lint, unit tests and integration tests
make check
There are also a few more helpful commands for development. Run make help to learn more, or look in Makefile.
├── cmd/ # Application entry points
│ └── publisher/ # Server publishing tool
├── data/ # Seed data
├── deploy/ # Deployment configuration (Pulumi)
├── docs/ # Documentation
├── internal/ # Private application code
│ ├── api/ # HTTP handlers and routing
│ ├── auth/ # Authentication (GitHub OAuth, JWT, namespace blocking)
│ ├── config/ # Configuration management
│ ├── database/ # Data persistence (PostgreSQL)
│ ├── service/ # Business logic
│ ├── telemetry/ # Metrics and monitoring
│ └── validators/ # Input validation
├── pkg/ # Public packages
│ ├── api/ # API types and structures
│ │ └── v0/ # Version 0 API types
│ └── model/ # Data models for server.json
├── scripts/ # Development and testing scripts
├── tests/ # Integration tests
└── tools/ # CLI tools and utilities
└── validate-*.sh # Schema validation tools
Publishing supports multiple authentication methods:
The registry validates namespace ownership when publishing. E.g. to publish...:
io.github.domdomegg/my-cool-mcp you must login to GitHub as domdomegg, or be in a GitHub Action on domdomegg's reposme.adamjones/my-cool-mcp you must prove ownership of adamjones.me via DNS or HTTP challengeCheck out community projects to explore notable registry-related work created by the community.
See the documentation for more details if your question has not been answered here!
DOCAPI_API_KEY*secretYour DocAPI API key from docapi.co
io.github.ericm1018/skillfm-llm-cost-optimizer-openai-anthropic-usage
io.github.mikerawsonnz/llm-orchestration-agent
io.github.mikerawsonnz/authenticated-llm-agent
labforgedev/copilot-memory-mcp
csoai-org/agent-prompt-injection-firewall-mcp
io.github.mikerawsonnz/authenticated-multi-llm-agent