magento-api-mcp
Enables searching and retrieving Magento 2 REST API documentation offline via local OpenAPI parsing, supporting endpoint search, schema lookup, and category browsing.
README
Magento 2 REST API MCP Server
A local STDIO MCP server that provides tools to search and retrieve Magento 2 REST API documentation from OpenAPI (swagger) specifications.
Features
- Search Endpoints: Full-text search across all Magento 2 REST API endpoints
- Get Endpoint Details: Retrieve complete documentation for specific API endpoints
- List Categories: Browse endpoints by category tags (carts, customers, products, etc.)
- Search Schemas: Find data models and schema definitions
- Get Schema Details: View complete schema/model definitions with all properties
- Offline Operation: Works entirely offline using local swagger.json file
- Fast Startup: Only re-parses if swagger.json has been modified
How it Works
- Parsing: On startup, the server parses the OpenAPI 3.0 swagger.json file
- Indexing: Extracts endpoints, parameters, responses, and schemas
- Storage: Stores data in a local SQLite database with FTS5 indexes
- Searching: Provides full-text search across paths, descriptions, parameters, and schemas
Installation
Requirements
- Python 3.10 or higher
- uv (recommended) or pip
Install from Source
cd magento-api-mcp
pip install -e .
Usage
Running the Server
magento-api-mcp
The server starts immediately and parses the swagger.json file on first run or when the file has been modified.
Configuration
- Database Location: Default is
~/.mcp/magento-api/database.db- Override with
MAGENTO_API_DB_PATHenvironment variable
- Override with
- Swagger File: Default is
data/swagger.jsonin the package directory- Override with
MAGENTO_API_SWAGGER_PATHenvironment variable
- Override with
Using with an MCP Client
Configure your MCP client to run the magento-api-mcp command:
{
"mcpServers": {
"magento-api": {
"command": "magento-api-mcp"
}
}
}
Or with custom swagger file:
{
"mcpServers": {
"magento-api": {
"command": "magento-api-mcp",
"env": {
"MAGENTO_API_SWAGGER_PATH": "/path/to/your/swagger.json"
}
}
}
}
MCP Tools
1. search_endpoints
Search for API endpoints using keywords.
Parameters:
queries: List of 1-3 short keyword queries (e.g., ["cart", "customer"])filter_by_method: Optional HTTP method filter (GET, POST, PUT, DELETE)filter_by_tag: Optional category filter (e.g., "carts/mine")
Example:
search_endpoints(queries=["cart operations"], filter_by_method="GET")
2. get_endpoint_details
Get complete documentation for a specific endpoint.
Parameters:
path: Exact API path (e.g., "/V1/carts/mine")method: Optional HTTP method (if omitted, returns all methods for this path)
Example:
get_endpoint_details(path="/V1/carts/mine", method="GET")
Returns:
- HTTP method and path
- Category and operation ID
- Summary and description
- Parameters table with types and descriptions
- Request body schema (if applicable)
- Response codes and schemas
3. list_tags
List all available API category tags.
Returns: Hierarchical list of all endpoint categories with counts.
4. search_schemas
Search for data schemas/models by keyword.
Parameters:
query: Keyword to search for
Example:
search_schemas(query="customer")
5. get_schema
Get complete definition of a schema/model.
Parameters:
schema_name: Exact schema name (e.g., "quote-data-cart-interface")
Returns: Full schema with type, description, and all properties in JSON format.
Verification Scripts
Test each component independently:
# Test the OpenAPI parser
python3 tests/verify_parser.py
# Test database ingestion
python3 tests/verify_db.py
# Test MCP server and all tools
python3 tests/verify_server.py
Database Schema
The server uses SQLite with the following tables:
- endpoints: All API endpoints with FTS5 index
- parameters: Endpoint parameters
- responses: Response definitions
- schemas: Data model definitions with FTS5 index
- metadata: Ingestion tracking
Advantages Over Web Scraping
- No Network Dependency: Works completely offline
- Instant Startup: ~2-5 seconds vs minutes of web scraping
- Structured Data: Access to complete OpenAPI metadata
- Precise Search: Filter by method, category, response code
- Schema Resolution: Navigate complex nested data structures
- Deterministic: No HTML parsing or website structure changes
Example Queries
| Query | Tool | Purpose |
|---|---|---|
["cart"] |
search_endpoints | Find all cart-related endpoints |
["customer", "authentication"] |
search_endpoints | Find customer auth endpoints |
/V1/carts/mine |
get_endpoint_details | Get complete cart endpoint docs |
customer |
search_schemas | Find customer-related schemas |
quote-data-cart-interface |
get_schema | View cart data structure |
Development
Project Structure
magento-api-mcp/
├── magento_api_mcp/
│ ├── __init__.py
│ ├── config.py # Configuration
│ ├── parser.py # OpenAPI parser
│ ├── ingest.py # Database ingestion
│ └── server.py # MCP server with tools
├── tests/
│ ├── verify_parser.py # Parser verification
│ ├── verify_db.py # Database verification
│ └── verify_server.py # Server verification
├── data/
│ └── swagger.json # OpenAPI specification
├── pyproject.toml
└── README.md
Adding New Tools
To add new MCP tools, edit magento_api_mcp/server.py and use the @mcp.tool() decorator.
Using Different Swagger Files
The server can work with any OpenAPI 3.0 swagger file. Simply set the MAGENTO_API_SWAGGER_PATH environment variable:
export MAGENTO_API_SWAGGER_PATH=/path/to/different-api-swagger.json
magento-api-mcp
License
MIT
Contributing
Contributions welcome! Please test all changes with the verification scripts before submitting.
Support
For issues or questions, please check:
- Run verification scripts to diagnose issues
- Check database location and permissions
- Verify swagger.json is valid OpenAPI 3.0 format
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.