A comprehensive MCP server that helps AI coding agents understand and implement the Universal Tool Calling Protocol (UTCP)
- π€ LLM-Powered Expert Agent: Ask questions in natural language to an OpenAI-powered agent with deep UTCP knowledge
- π Documentation Search: Semantic search across complete UTCP specification
- β Manual Validation: Validate UTCP manuals against v1.0.1 spec with detailed errors
- π¨ Code Generation: Generate UTCP manual templates for HTTP, CLI, MCP, SSE protocols
- π OpenAPI Conversion: Convert OpenAPI 3.0 specs to UTCP manuals automatically
- π Examples Library: Ready-to-use examples for weather APIs, GitHub, databases, CLI tools
- π‘ Best Practices: Built-in guidance for naming, authentication, and implementation
npm install -g utcp-docsgit clone https://github.com/yourusername/utcp-docs-mcp-server.git
cd utcp-docs-mcp-server
npm install
npm run build
npm linkAdd to your claude_desktop_config.json:
{
"mcpServers": {
"utcp-docs": {
"command": "utcp-docs",
"env": {
"DOCS_PATH": "/path/to/utcp-docs",
"OPENAI_API_KEY": "sk-..."
}
}
}
}Add to .cursor/mcp.json in your project:
{
"mcpServers": {
"utcp-docs": {
"command": "npx",
"args": ["utcp-docs"],
"env": {
"OPENAI_API_KEY": "sk-..."
}
}
}
}Create a .env file or set in your MCP config:
# OpenAI API Key (required for ask_utcp_expert tool)
OPENAI_API_KEY=sk-...
# Documentation path (default: current directory)
DOCS_PATH=.
# Server configuration
SERVER_NAME=utcp-docs
SERVER_VERSION=1.0.0
LOG_LEVEL=infoNEW! Ask an OpenAI-powered agent any question about UTCP:
{
"tool": "ask_utcp_expert",
"arguments": {
"question": "How do I authenticate with bearer tokens?"
}
}The agent:
- Has deep knowledge of the entire UTCP specification
- Retrieves relevant documentation automatically
- Provides detailed explanations with code examples
- Includes source references
- Offers best practices and guidance
Example Questions:
- "What is body_template and when should I use it?"
- "Show me a complete HTTP tool example with OAuth2"
- "How do I chain CLI commands together?"
- "Why is my tool name failing validation?"
Requires: OpenAI API key (set OPENAI_API_KEY environment variable)
Search the complete UTCP specification:
{
"tool": "search_utcp_docs",
"arguments": {
"query": "how to implement HTTP authentication",
"section": "protocols", // optional: introduction, protocols, guides, api
"limit": 5 // optional: max results
}
}Example Response:
# Search Results for "HTTP authentication"
## Result 1: HTTP Protocol Authentication
**Section:** protocols
**Relevance:** 45
Authentication in HTTP protocols can be configured using the auth field...
Validate your UTCP manual against the specification:
{
"tool": "validate_utcp_manual",
"arguments": {
"manual": {
"manual_version": "1.0.0",
"utcp_version": "1.0.1",
"tools": [...]
}
}
}Response:
β
Valid UTCP Manual
The manual passes all validation checks and conforms to UTCP v1.0.1 specification.
Or with errors:
β Invalid UTCP Manual
## Errors
- /tools/0/name: Tool name "GetWeather" must use snake_case
- /tools/0/tool_call_template: HTTP template requires a URL
## Warnings
- /tools/0/description: Tool description should be at least 10 characters
Generate a UTCP manual template:
{
"tool": "generate_utcp_manual",
"arguments": {
"tool_name": "get_weather",
"description": "Get current weather for a location",
"protocol": "http",
"endpoint": "https://api.openweathermap.org/data/2.5/weather",
"method": "GET",
"parameters": {
"location": {
"type": "string",
"description": "City name",
"required": true
}
},
"include_auth": true
}
}Supported Protocols:
http- RESTful HTTP APIscli- Command-line toolsmcp- Model Context Protocol serverssse- Server-Sent Eventsstreamable_http- Streaming HTTP responses
Convert OpenAPI 3.0 specifications to UTCP manuals:
{
"tool": "convert_openapi_to_utcp",
"arguments": {
"openapi_spec": {
"openapi": "3.0.0",
"info": { "title": "My API", "version": "1.0.0" },
"paths": {
"/users": {
"get": {
"operationId": "getUsers",
"summary": "List users"
}
}
}
}
}
}Get ready-to-use example UTCP manuals:
{
"tool": "get_utcp_examples",
"arguments": {
"use_case": "weather" // weather, github, database, cli-tool
}
}Available Examples:
weather- OpenWeatherMap API integrationgithub- GitHub REST API (repos, issues)database- Database query tools via MCPcli-tool- Git command-line wrapper
Get UTCP implementation best practices:
{
"tool": "get_best_practices",
"arguments": {
"topic": "naming" // naming, authentication, error-handling, testing, general
}
}The server provides these resources via MCP:
| Resource URI | Description |
|---|---|
utcp://docs/full |
Complete UTCP documentation (9700+ lines) |
utcp://docs/introduction |
UTCP introduction and overview |
utcp://docs/protocols |
All protocol documentation |
utcp://examples/weather |
Weather API example manual |
utcp://examples/github |
GitHub API example manual |
utcp://schema/manual |
UTCP JSON Schema for validation |
// 1. Generate a template
const result = await callTool("generate_utcp_manual", {
tool_name: "send_email",
description: "Send an email via SendGrid API",
protocol: "http",
endpoint: "https://api.sendgrid.com/v3/mail/send",
method: "POST",
parameters: {
to: { type: "string", description: "Recipient email", required: true },
subject: { type: "string", description: "Email subject", required: true },
body: { type: "string", description: "Email body", required: true }
},
include_auth: true
});
// 2. Validate the generated manual
const validation = await callTool("validate_utcp_manual", {
manual: JSON.parse(result)
});
// 3. Get best practices for authentication
const practices = await callTool("get_best_practices", {
topic: "authentication"
});// 1. Read your OpenAPI spec
const openApiSpec = JSON.parse(fs.readFileSync("api-spec.json"));
// 2. Convert to UTCP
const utcpManual = await callTool("convert_openapi_to_utcp", {
openapi_spec: openApiSpec
});
// 3. Validate the result
const validation = await callTool("validate_utcp_manual", {
manual: JSON.parse(utcpManual)
});// Search for specific implementation details
const results = await callTool("search_utcp_docs", {
query: "how to handle streaming responses",
section: "protocols",
limit: 3
});
// Get an example to reference
const example = await callTool("get_utcp_examples", {
use_case: "github"
});# Clone repository
git clone https://github.com/yourusername/utcp-docs-mcp-server.git
cd utcp-docs-mcp-server
# Install dependencies
npm install
# Build
npm run build
# Run in development mode
npm run dev# Run all tests
npm test
# Run tests in watch mode
npm run test:watch
# Generate coverage report
npm run test:coverageutcp-docs/
βββ src/
β βββ index.ts # Entry point
β βββ server.ts # MCP server implementation
β βββ types/
β β βββ utcp.ts # TypeScript types
β βββ services/
β β βββ documentation.ts # Documentation search
β β βββ validator.ts # UTCP validation
β β βββ generator.ts # Manual generation
β β βββ converter.ts # OpenAPI conversion
β βββ schemas/
β βββ utcp-manual.schema.json
βββ docs/
β βββ examples/ # Example UTCP manuals
βββ tests/
β βββ services/ # Unit tests
βββ llms.txt # Complete UTCP documentation
βββ package.json
- Node.js: 20.x or higher
- TypeScript: 5.3 or higher
- MCP SDK: 1.0.4 or higher
Contributions are welcome! Please follow these steps:
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
- Write tests for new features
- Follow TypeScript best practices
- Update documentation for API changes
- Ensure all tests pass before submitting PR
Issue: Error: Cannot find module 'ajv-formats'
Solution:
npm install ajv-formats
npm run buildIssue: Error loading llms.txt
Solution: Ensure DOCS_PATH environment variable points to the correct directory:
export DOCS_PATH=/path/to/utcp-docsIssue: Tool names failing validation
Solution: Use snake_case naming:
- β
get_user_data - β
GetUserData - β
getUserData
MIT License - see LICENSE file for details
- UTCP Team for creating the Universal Tool Calling Protocol
- Anthropic for the Model Context Protocol
- All contributors to this project
- Issues: GitHub Issues
- Discussions: GitHub Discussions
- Email: support@example.com
Built with β€οΈ for the AI development community
Making UTCP implementation easier, one tool at a time.