Supports converting Markdown documents into professional formats like PDF using the Carbone conversion engine.
Utilizes OnlyOffice as a specialized conversion engine to ensure high-fidelity transformations for complex document formats.
Carbone MCP Server
Official Carbone MCP server โ Turn AI assistants into document automation experts. Generate professional PDFs, invoices, reports, and more using natural language.
Give Claude, ChatGPT, and other AI assistants the power to:
Convert between 100+ document formats instantly
Generate documents from templates with JSON data
Manage template libraries with versioning
Fill PDF forms programmatically
Create batch documents (invoices, certificates, letters)
Features
๐ Document Conversion โ 100+ format combinations (PDF, DOCX, XLSX, PNG, HTML, CSVโฆ)
๐ Template Engine โ Generate documents from JSON data with
{d.field}tags๐ Template Library โ Upload, version, categorize, and manage reusable templates
๐จ PDF Customization โ Watermarks, passwords, encryption, multiple converter engines
๐ Localization โ Multi-language support, currency conversion, timezone handling
โก Batch Generation โ Create hundreds of documents in one request
Requirements
Node.js 18+ (Node 24 recommended)
A Carbone API key โ get one free at account.carbone.io
Quick Start
Option 1: Using npx (Recommended โ No Installation)
export CARBONE_API_KEY=your_api_key_here
npx -y carbone-mcpOption 2: Building from Source
git clone https://github.com/carboneio/carbone-mcp
cd carbone-mcp
npm install && npm run build
CARBONE_API_KEY=your_key node dist/index.jsInstallation
Claude Desktop
1. Edit the config file
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"carbone": {
"command": "npx",
"args": ["-y", "carbone-mcp"],
"env": {
"CARBONE_API_KEY": "your_api_key_here"
}
}
}
}{
"mcpServers": {
"carbone": {
"command": "/path/to/node",
"args": ["/absolute/path/to/carbone-mcp/dist/index.js"],
"env": {
"CARBONE_API_KEY": "your_api_key_here"
}
}
}
}2. Restart Claude Desktop
Try asking: "What can Carbone do?" or "Convert this file to PDF: /path/to/document.docx"
VS Code (Cline / Copilot)
Add to your VS Code settings or create .vscode/mcp.json:
{
"mcp": {
"servers": {
"carbone": {
"command": "npx",
"args": ["-y", "carbone-mcp"],
"env": {
"CARBONE_API_KEY": "your_api_key_here"
}
}
}
}
}Cursor
Add to ~/.cursor/mcp.json (global) or .cursor/mcp.json (project):
{
"mcpServers": {
"carbone": {
"command": "npx",
"args": ["-y", "carbone-mcp"],
"env": {
"CARBONE_API_KEY": "your_api_key_here"
}
}
}
}Remote HTTP (mcp.carbone.io)
Connect directly to the hosted Carbone MCP endpoint โ no local installation needed.
Claude Desktop:
{
"mcpServers": {
"carbone": {
"type": "streamable-http",
"url": "https://mcp.carbone.io",
"headers": {
"Authorization": "Bearer your_api_key_here"
}
}
}
}VS Code / Cursor:
{
"mcp": {
"servers": {
"carbone": {
"type": "streamable-http",
"url": "https://mcp.carbone.io",
"headers": {
"Authorization": "Bearer your_api_key_here"
}
}
}
}
}Environment Variables
Required (stdio mode, cloud API):
CARBONE_API_KEYโ Your Carbone API key (get one free โ). Not required whenCARBONE_BASE_URLpoints to your own on-premise server, or when running in HTTP mode (clients supply their own key viaAuthorization: Bearer).
Variable | Default | Description |
|
| Override for self-hosted or staging environments. When set to a custom URL, |
|
| Request timeout in milliseconds (max: 60000) |
|
| Transport mode: |
|
| HTTP server port (only used when |
|
| HTTP endpoint path (only used when |
|
| Maximum request body size in bytes (10 MB default) |
On-premise example (no API key needed):
CARBONE_BASE_URL=https://your-carbone-server.com \
node dist/index.jsSelf-hosted HTTP mode example:
CARBONE_API_KEY=your_key \
CARBONE_BASE_URL=https://your-carbone-server.com \
MCP_TRANSPORT=http \
MCP_PORT=3000 \
node dist/index.jsAvailable Tools
Document Operations
Tool | Description | Docs |
| Convert documents between 100+ formats without storing a template | |
| Generate documents from templates by merging with JSON data |
Template Management
Tool | Description | Docs |
| Browse your template library with filtering by category or search (tags are returned per template but not filterable server-side) | |
| List all template categories in your account | |
| List all tags used across your templates | |
| Store reusable templates with versioning, categorization, and metadata | |
| Rename, categorize, tag, deploy, or expire template versions | |
| Soft-delete templates (marked for removal, gone after ~24h) | |
| Download original template files (DOCX, XLSX, PDF, etc.) |
Discovery
Tool | Description | Docs |
| Check Carbone API health and current version | |
| View all supported formats, features, and examples |
๐ Full API Reference โ โ Detailed parameters, schemas, and examples
Common Use Cases
๐ Document Conversion
"Convert this Word document to PDF: /path/to/contract.docx"
"Turn my Excel spreadsheet into CSV format"
"Convert this HTML page to a PNG image"
"Convert my Markdown README to PDF"
"Convert this PPTX to PNG โ use OnlyOffice for best fidelity"
"Extract text from this PDF by converting it to TXT"๐ผ Finance & Invoicing
"Generate an invoice using template T123 with: {customer: 'Acme Corp', total: 1500, items: [...]}"
"Create 500 invoices from my billing data and bundle them in a ZIP"
"Generate a French invoice for my Paris client โ use EUR currency and fr-fr locale"
"Render this monthly report for each client in clients.json and ZIP them all"
"Generate invoice-{d.id}.pdf for each row in my sales data"โ๏ธ Legal & Compliance
"Add a CONFIDENTIAL watermark to this contract before sending it"
"Convert this NDA to PDF/A format for long-term archiving"
"Generate a password-protected PDF โ open password: 'secret123'"
"Create signed offer letters for each candidate using this DOCX template"
"Generate a compliance report with a DRAFT watermark, 20% opacity, rotated -45ยฐ"๐ฅ HR & People Operations
"Create personalized onboarding documents for all 50 new employees in this JSON"
"Generate an employment contract for each person in new-hires.json"
"Build payslips for every employee in my payroll export"
"Create training certificates for everyone who passed this month"
"Fill out the performance review template with each employee's data"๐ Localization & Multi-Language
"Generate this invoice in French, German, and Spanish from the same template"
"Render the report with timezone America/New_York so dates show in Eastern time"
"Convert all prices from EUR to USD using today's exchange rates"
"Generate the contract in fr-fr locale so numbers use European formatting"๐ PDF Security & Advanced Options
"Convert this DOCX to a password-protected PDF"
"Add a semi-transparent DRAFT watermark to every page"
"Generate a PDF/A-1b compliant version of this document for archiving"
"Export only pages 1โ5 of this presentation as a PDF"
"Convert each slide of this PPTX to a separate PDF page"๐ Template Management
"Upload this invoice template and tag it 'sales' and 'finance'"
"What templates do I have in the 'contracts' category?"
"Show me all templates tagged 'hr'"
"Download template T456 so I can edit it locally"
"Deploy version V789 as the active version without deleting the others"
"Schedule this old template for deletion in 30 days"Debugging
Using MCP Inspector
Test and debug the server interactively:
npx @modelcontextprotocol/inspector npx carbone-mcpOr from a local build:
npx @modelcontextprotocol/inspector node dist/index.jsOpen http://localhost:5173 to view all tools, test calls, and inspect request/response JSON โ no AI inference needed.
View Server Logs
# macOS โ Claude Desktop logs
tail -f ~/Library/Logs/Claude/mcp*.log
# Windows
Get-Content "$env:APPDATA\Claude\logs\mcp*.log" -Wait -Tail 50Look for:
โ
Carbone MCP Server v1.x.x started (stdio)โ Any error messages or stack traces
Health Check (HTTP mode only)
When running in HTTP mode, the server exposes a health endpoint:
curl http://localhost:3000/health{
"mcp": { "version": "1.0.0" },
"carbone": { "version": "4.x.x" }
}The carbone field shows backend connectivity:
{ "version": "..." }โ reachable and authenticated{ "error": "unauthorized", "message": "..." }โ reachable but no/invalid API key{ "error": "unreachable", "message": "..." }โ network error, timeout, or unexpected response
Security
โ ๏ธ API Key Protection
Never commit
CARBONE_API_KEYto version controlUse environment variables or a secret manager
Rotate API keys regularly at account.carbone.io
โ ๏ธ Template Safety
Only upload templates from trusted sources
Review templates before deploying them
Use template versioning for easy rollback
โ ๏ธ Data Privacy
Carbone does not store your document data after rendering
Use
CARBONE_BASE_URLto point to a self-hosted instance for maximum controlSee Privacy Policy for details
Development
npm run dev # Run with tsx (no build needed)
npm run build # Compile TypeScript โ dist/
npm test # Run unit tests
npm run test:watch # Watch mode
npm run test:integration # Real API tests (requires CARBONE_TEST_API_KEY)
npm run test:coverage # Coverage reportDocker Deployment
Build image
docker build -t carbone-mcp:latest .Run as stdio (for AI clients)
docker run -i --rm \
-e CARBONE_API_KEY=your_key_here \
carbone-mcp:latestClaude Desktop config (Docker stdio)
{
"mcpServers": {
"carbone": {
"command": "docker",
"args": ["run", "-i", "--rm",
"-e", "CARBONE_API_KEY=your_key_here",
"carbone-mcp:latest"]
}
}
}Run as HTTP server
docker run -d \
-p 3000:3000 \
-e CARBONE_API_KEY=your_key_here \
-e MCP_TRANSPORT=http \
-e MCP_PORT=3000 \
carbone-mcp:latestDocker Compose (HTTP mode)
services:
carbone-mcp:
image: carbone-mcp:latest
ports:
- 3000:3000
environment:
- CARBONE_API_KEY=${CARBONE_API_KEY:-}
- CARBONE_BASE_URL=${CARBONE_BASE_URL:-https://api.carbone.io}
- CARBONE_TIMEOUT=${CARBONE_TIMEOUT:-60000}
- MCP_TRANSPORT=http
- MCP_PORT=3000
- MCP_PATH=/
restart: unless-stoppedStart it:
CARBONE_API_KEY=your_key docker compose up -dThen connect your AI client to http://your-server:3000.
Template Syntax
Design templates in Word, Excel, LibreOffice, or HTML with {d.field} tags:
Dear {d.customer.name},
Your invoice total is {d.total:formatC(EUR)}.
Items:
{d.items[i].description} {d.items[i].quantity}x {d.items[i].price:formatC(EUR)}
{d.items[i+1]}Guides & best practices:
Supported Output Formats
Category | Formats |
Documents | PDF, DOCX, XLSX, PPTX, ODT, ODS, ODP, RTF, EPUB |
Images | PNG, JPG, WEBP, SVG, TIFF, BMP, GIF |
Web / Text | HTML, TXT, CSV, MD, XML |
Full conversion matrix: carbone.io/documentation
Contributing
We welcome contributions:
๐ Report bugs via GitHub Issues
๐ก Request features or suggest improvements
๐ Improve documentation
๐งช Add tests to increase coverage
๐ง Submit pull requests with bug fixes or enhancements
See CONTRIBUTING.md for guidelines.
Support
๐ Documentation: carbone.io/documentation
๐ Bug Reports: GitHub Issues
๐ฌ Live Chat: carbone.io (bottom-right widget)
๐ง Enterprise: contact@carbone.io
Links
License
Apache 2.0 โ see LICENSE
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.