loading…
Search for a command to run...
loading…
Converts any OpenAPI 3.x specification into a fully functional MCP server with OAuth 2.1 support and a purely functional architecture.
Converts any OpenAPI 3.x specification into a fully functional MCP server with OAuth 2.1 support and a purely functional architecture.
A generic TypeScript library for converting OpenAPI specifications into MCP (Model Context Protocol) servers. Built with a purely functional architecture using Ramda.
R.pipe()npm install contex zod
import { createMcpServer, isOk } from 'contex';
const result = await createMcpServer({
name: 'My API Server',
version: '1.0.0',
openApiSpec: './openapi.yaml',
baseUrl: 'https://api.example.com',
});
if (isOk(result)) {
await result.value.start();
console.log('MCP server running on port 3000');
}
import { createMcpServer, isOk } from 'contex';
const result = await createMcpServer({
name: 'Secure API Server',
version: '1.0.0',
openApiSpec: './openapi.yaml',
baseUrl: 'https://api.example.com',
auth: {
type: 'oauth2',
clientId: process.env.CLIENT_ID,
clientSecret: process.env.CLIENT_SECRET,
authorizationUrl: 'https://auth.example.com/authorize',
tokenUrl: 'https://auth.example.com/token',
scopes: ['read', 'write'],
pkce: true, // Enabled by default
},
server: {
port: 3000,
transport: 'streamable-http',
},
});
if (isOk(result)) {
await result.value.start();
}
createMcpServer(config) - Create MCP server from OpenAPI speccreateCustomMcpServer(name, version, tools, resources) - Create server with custom toolsThe library uses a Result<T, E> monad for error handling:
import { isOk, isErr, fold, formatError } from 'contex';
const result = await createMcpServer(config);
// Pattern matching with type guards
if (isOk(result)) {
const server = result.value;
} else {
console.error(formatError(result.error));
}
// Or use fold
const server = fold(
(error) => { console.error(error); return null; },
(server) => server
)(result);
import {
parseOpenApiSpec,
extractOperations,
buildToolsPipeline,
buildResourcesPipeline,
} from 'contex';
// Parse OpenAPI spec
const specResult = await parseOpenApiSpec('./openapi.yaml');
if (isOk(specResult)) {
const spec = specResult.value;
// Extract operations
const operations = extractOperations(spec);
// Build tools
const tools = buildToolsPipeline('https://api.example.com')(operations);
// Build resources
const resources = buildResourcesPipeline(spec);
}
See docs/ARCHITECTURE.md for details.
See the examples/ directory for complete examples:
basic-server.ts - Basic MCP server from OpenAPIwith-oauth.ts - Server with OAuth authenticationcustom-tools.ts - Server with custom tool definitionsSeveral similar libraries exist in the ecosystem:
| Library | Description |
|---|---|
| openapi-mcpserver-generator | Generates MCP server code from OpenAPI specs |
| openapi-mcp-generator | TypeScript tool for OpenAPI → MCP conversion |
| openapi-to-mcp-converter | Automatic OpenAPI to MCP Server conversion |
| openapi-mcp-server | Bridge between OpenAPI and MCP for Claude Desktop |
| api-to-mcp | Turn any API into MCP tools |
| Stainless | Commercial platform for MCP server generation |
| Speakeasy | Commercial tool for generating MCP servers |
| Feature | Existing Tools | This Library |
|---|---|---|
| Architecture | Mostly imperative/OOP | Purely functional |
| Error Handling | Exceptions | Result monad |
| OAuth Support | Limited/varies | Full OAuth 2.1 + PKCE |
| Runtime | Code generation | Runtime conversion |
| Composability | Low | High (R.pipe) |
# Install dependencies
npm install
# Run tests
npm test
# Type check
npm run typecheck
# Build
npm run build
MIT
Выполни в терминале:
claude mcp add contex -- npx Не уверен что выбрать?
Найди свой стек за 60 секунд
Автор?
Embed-бейдж для README
Похожее
Все в категории development