Swagger MCP
Scrapes Swagger UI to dynamically generate MCP tools at runtime using LLMs.
swagger-mcp
Overview
swagger-mcp is a tool designed to scrape Swagger UI by extracting the swagger.json file and dynamically generating well-defined mcp tools at runtime. These tools can be utilized by the MCP client for further tool selection.
📽️ Demo Video
Check out demo video showcasing the project in action:
🙌 Support
If you find this project valuable, please support me on LinkedIn by:
- 👍 Liking and sharing our demo post
- 💬 Leaving your thoughts and feedback in the comments
- 🔗 Connecting with me for future updates
Your support on LinkedIn will help me reach more people and improve the project!
Prerequisites
To use swagger-mcp, ensure you have the following dependencies:
- LLM Model API Key / Local LLM: Requires access to OpenAI, Claude, or Ollama models.
- Any MCP Client: (Used mark3labs - mcphost)
Installation and Setup
Follow these steps to install and run swagger-mcp:
go install github.com/danishjsheikh/swagger-mcp@latest
swagger-mcp
Run Configuration
To run swagger-mcp directly, use:
swagger-mcp --specUrl=https://your_swagger_api_docs.json
Main flags:
--specUrl: Swagger/OpenAPI JSON URL (required)--sseMode: Run in SSE mode (default: false, if true runs as SSE server, otherwise uses stdio)--sseAddr: SSE server listen address in IP:Port or :Port format (if empty, will use IP:Port from --sseUrl)--sseUrl: SSE server base URL (if empty, will use sseAddr to generate, e.g. http://IP:Port or http://localhost:Port)- If both --sseAddr and --sseUrl are set, they are used as-is without auto-complement.
--baseUrl: Override base URL for API requests--security: API security type (basic,apiKey, orbearer)--basicAuth: Basic auth in user:password format--bearerAuth: Bearer token for Authorization header--apiKeyAuth: API key(s), formatpassAs:name=value(e.g.header:token=abc,query:user=foo,cookie:sid=xxx)- See main.go for all supported flags and options.
MCP Configuration
To integrate with mcphost, include the following configuration in .mcp.json:
{
"mcpServers":
{
"swagger_loader": {
"command": "swagger-mcp",
"args": ["--specUrl=<swagger/doc.json_url>"]
}
}
}
Demo Flow
-
Some Backend:
go install github.com/danishjsheikh/go-backend-demo@latest go-backend-demo -
Ollama
ollama run llama3.2 -
MCP Client
go install github.com/mark3labs/mcphost@latest mcphost -m ollama:llama3.2 --config <.mcp.json_file_path>
Flow Diagram

🛠️ Need Help
I am working on improving tool definitions to enhance:
✅ Better error handling for more accurate responses
✅ LLM behavior control to ensure it relies only on API responses and does not use its own memory
✅ Preventing hallucinations and random data generation by enforcing strict data retrieval from APIs
If you have insights or suggestions on improving these aspects, please contribute by:
- Sharing your experience with similar implementations
- Suggesting modifications to tool definitions
- Providing feedback on current limitations
Your input will be invaluable in making this tool more reliable and effective! 🚀
相关服务器
Alpha Vantage MCP Server
赞助Access financial market data: realtime & historical stock, ETF, options, forex, crypto, commodities, fundamentals, technical indicators, & more
AI Design Blueprint Doctrine
The industry-standard doctrine for safe, observable, and steerable AI agent UX — browse 10 principles, curated examples, and application guides via MCP.
Smriti MCP
Smriti is a Model Context Protocol (MCP) server that provides persistent, graph-based memory for LLM applications. Built on LadybugDB (embedded property graph database), it uses EcphoryRAG-inspired multi-stage retrieval - combining cue extraction, graph traversal, vector similarity, and multi-hop association - to deliver human-like memory recall.
Remote MCP Server (Authless)
An authentication-free remote MCP server deployable on Cloudflare Workers.
DHTMLX MCP Server
The DHTMLX MCP server provides real-time access to official docs and a smart RAG.
LLM API Benchmark MCP Server
Benchmark LLM APIs for throughput and Time To First Token (TTFT) under various concurrency levels.
Playwright MCP Explorer
An intelligent tool that uses MCP to autonomously explore websites and generate Playwright tests from natural language descriptions.
Just Prompt
A unified interface for various Large Language Model (LLM) providers, including OpenAI, Anthropic, Google Gemini, Groq, DeepSeek, and Ollama.
XcodeMCP
An MCP server to control Xcode on macOS using JavaScript for Automation (JXA).
Dieter Rams
Evaluates product designs against Dieter Rams' 10 principles of good design.
Figma Copilot
Enables AI assistants to interact with and automate Figma designs programmatically.