MCP-Gateway
by adcwa
MCP-Gateway provides unified management capabilities for MCP Servers, enabling AI Agents to quickly connect to various data sources. It simplifies access to databases, REST APIs, and other external services.
Last updated: N/A
MCP-Gateway
MCP-Gateway is a service that provides MCP Server unified management capabilities, helping AI Agents quickly connect to various data sources. Through MCP Server, AI Agents can easily access databases, REST APIs, and other external services without worrying about specific connection details.
Features
- HTTP interface management: Support for exporting OpenAPI structures, converting HTTP to MCP Server YAML format, and versioning of interfaces.
- Convert curl commands to HTTP interfaces: Easily transform curl commands into properly formatted HTTP interfaces.
- Import/Export OpenAPI: Convert between HTTP interfaces and OpenAPI specifications for easy integration with existing API frameworks.
- MCP Server management: Support for managing MCP Server metadata, selecting multiple HTTP structures to update metadata, publishing MCP Servers (compiling to WebAssembly for dynamic loading), and version control.
- Routing management: Support for route configuration, such as matching
xxx/mcp-server/{name}
to MCP Server with name{name}
.
Architecture
MCP-Gateway consists of three core modules:
- HTTP Interface Management: Defines and manages API configurations.
- MCP Server Management: Manages MCP Server instances, compiles them to WebAssembly, and handles runtime execution.
- Routing Management: Manages routing rules for MCP Servers.
Getting Started
Prerequisites
- Go 1.19 or higher
- Git
Installation
-
Clone the repository:
git clone https://github.com/wangfeng/mcp-gateway2.git cd mcp-gateway2
-
Install dependencies:
go mod tidy
-
Run the server:
go run cmd/server/main.go
-
The server will start on port 8080 by default. You can customize the port by setting the
PORT
environment variable.
Testing
To test the API, run the test client:
go run test/client.go
This will:
- List available HTTP interfaces
- Create an MCP Server using one of the interfaces
- Compile the MCP Server to WebAssembly
- Activate the MCP Server
- Invoke a tool on the MCP Server
To test the curl conversion feature, run the curl test client:
go run test/curl/curl_client.go
This will:
- Convert several curl commands to HTTP interfaces
- Create an MCP Server using the converted interfaces
- Compile and activate the MCP Server
- Invoke a tool from the MCP Server
To test the OpenAPI conversion feature, run the OpenAPI test client:
go run test/openapi/openapi_client.go
This will:
- Export an existing HTTP interface to OpenAPI format
- Import a sample OpenAPI specification to create new HTTP interfaces
- Perform a round-trip conversion (export to OpenAPI and import back)
API Documentation
HTTP Interfaces
GET /api/http-interfaces
: List all HTTP interfacesGET /api/http-interfaces/:id
: Get a specific HTTP interfacePOST /api/http-interfaces
: Create a new HTTP interfacePUT /api/http-interfaces/:id
: Update an HTTP interfaceDELETE /api/http-interfaces/:id
: Delete an HTTP interfaceGET /api/http-interfaces/:id/versions
: Get all versions of an HTTP interfaceGET /api/http-interfaces/:id/versions/:version
: Get a specific version of an HTTP interfaceGET /api/http-interfaces/:id/openapi
: Export an HTTP interface to OpenAPI formatPOST /api/http-interfaces/from-curl
: Create a new HTTP interface from a curl commandPOST /api/http-interfaces/from-openapi
: Create new HTTP interfaces from an OpenAPI specification
MCP Servers
GET /api/mcp-servers
: List all MCP ServersGET /api/mcp-servers/:id
: Get a specific MCP ServerPOST /api/mcp-servers
: Create a new MCP Server from HTTP interfacesPUT /api/mcp-servers/:id
: Update an MCP ServerDELETE /api/mcp-servers/:id
: Delete an MCP ServerGET /api/mcp-servers/:id/versions
: Get all versions of an MCP ServerGET /api/mcp-servers/:id/versions/:version
: Get a specific version of an MCP ServerPOST /api/mcp-servers/:id/compile
: Compile an MCP Server to WebAssemblyPOST /api/mcp-servers/:id/activate
: Activate an MCP ServerPOST /api/mcp-servers/:id/tools/:tool
: Invoke a tool in an MCP Server
Curl to HTTP Interface Conversion
The system supports converting curl commands to HTTP interfaces. Simply send a POST request to /api/http-interfaces/from-curl
with the following JSON body:
{
"command": "curl -H \"Content-Type: application/json\" https://api.example.com/resource",
"name": "example-api",
"description": "Example API endpoint"
}
The system will parse the curl command and create a properly formatted HTTP interface that can be used to create MCP Servers.
OpenAPI Conversion
Export to OpenAPI
You can export any HTTP interface to OpenAPI format by sending a GET request to /api/http-interfaces/:id/openapi
. The response will be a properly formatted OpenAPI 3.0.0 specification that can be used with other OpenAPI tools.
Import from OpenAPI
You can create new HTTP interfaces from an OpenAPI specification by sending a POST request to /api/http-interfaces/from-openapi
with the following JSON body:
go run test/openapi/openapi_client.go
{
"name": "my-api",
"description": "My API description",
"spec": {
"openapi": "3.0.0",
"info": {
"title": "Sample API",
"description": "A sample API",
"version": "1.0.0"
},
"paths": {
"/users": {
"get": {
"summary": "Get all users",
"responses": {
"200": {
"description": "A list of users"
}
}
}
}
}
}
}
The system will parse the OpenAPI specification and create HTTP interfaces for each path/operation combination.
License
MIT