mcp_server_go
If you are the rightful owner of mcp_server_go and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
A Go implementation of a Model Context Protocol (MCP) server that provides database querying capabilities through a JSON-RPC interface.
MCP Server (Go)
A Go implementation of a Model Context Protocol (MCP) server that provides database querying capabilities through a JSON-RPC interface.
Features
- JSON-RPC 2.0 protocol implementation
- Server-Sent Events (SSE) for real-time communication
- SQLite database integration
- Tool-based architecture for extensible functionality
- Authentication support
Available Tools
-
Query Tool
- Execute SQL queries against the database
- Returns results in tabular format
-
List Tables Tool
- List all available tables in the database
Getting Started
Prerequisites
- Go 1.x
- SQLite3
Installation
- Clone the repository:
git clone <repository-url>
cd mcp_server_go
- Install dependencies:
go mod download
Configuration
The server uses a simple token-based authentication system. The expected token is hardcoded as "abcd" in the server configuration.
Running the Server
go run main.go
The server will start on port 8777.
API Documentation
Authentication
All requests must include an Authorization header with the format:
Authorization: Bearer <token>
Endpoints
1. Root Endpoint (/
)
- Method: GET
- Purpose: Establishes a Server-Sent Events (SSE) connection
- Response: Returns an endpoint URL for message communication
2. Messages Endpoint (/messages/{sessionID}
)
- Method: POST
- Purpose: Handle client requests
- Supported Methods:
initialize
: Initialize the connectiontools/list
: List available toolstools/call
: Execute a specific tool
Example Usage
- Initialize connection:
{
"jsonrpc": "2.0",
"id": 1,
"method": "initialize",
"params": {}
}
- List available tools:
{
"jsonrpc": "2.0",
"id": 2,
"method": "tools/list",
"params": {}
}
- Execute a query:
{
"jsonrpc": "2.0",
"id": 3,
"method": "tools/call",
"params": {
"name": "query",
"arguments": {
"query": "SELECT * FROM your_table"
}
}
}
Project Structure
mcp_server_go/
├── main.go # Main server implementation
├── pkg/
│ ├── messages/ # Message structures
│ ├── methods/ # Request handling methods
│ └── tools/ # Tool implementations
└── mcp.db # SQLite database file