mcp-server-ddd-sample
v1.0.0
Published
A sample of MCP implementation using DDD structure with some APIs call.
Maintainers
Readme
MCP Server DDD Sample
This repository is a sample implementation of a Model Context Protocol (MCP) server in Node.js/TypeScript, designed to demonstrate a clean, layered architecture using Domain-Driven Design (DDD) principles. It provides tools to obtain Bitcoin-related information via external APIs.
Key Points
- Sample Project: This codebase is intended as a reference for structuring MCP servers with DDD, not for production use.
- MCP Protocol: Communicates via stdio using the MCP protocol (
@modelcontextprotocol/sdk). - Layered DDD Architecture: Clear separation of domain, application, infrastructure, and interface layers.
Project Structure
src/
├── domain/ # Domain models and response interfaces
│ └── models/
│ └── responses/
│ ├── block/
│ │ └── IBlockResponse.ts
│ └── fees/
│ └── IFeesRecommendedResponse.ts
├── infrastructure/ # External API clients and request services
│ ├── interfaces/
│ │ └── IApiClient.ts
│ └── services/
│ ├── clients/
│ │ └── MempoolApiClientService.ts
│ └── requests/
│ ├── BlockRequestService.ts
│ └── FeesRequestService.ts
├── application/ # Business logic and helpers
│ ├── services/
│ │ ├── BlockService.ts
│ │ └── FeesService.ts
│ └── helpers/
│ └── format.ts
├── interface/ # Controllers (MCP tool registration)
│ └── controllers/
│ ├── base/
│ │ └── BaseToolsController.ts
│ ├── BlockToolsController.ts
│ ├── FeesToolsController.ts
│ ├── PingController.ts
│ └── index.ts
├── shared/ # Shared types/parameters
│ └── parameters/
│ └── IBlockRequestParameter.ts
└── main.ts # Application entry pointGetting Started
git clone https://github.com/alexandresanlim/mcp-server-ddd-sample.git
cd mcp-server-ddd-sample
npm install
npm run buildUsage
After building, you can run the server directly:
node build/main.jsOr, if registered as a binary (for example, mcp-server-ddd-sample):
npm link
mcp-server-ddd-sampleThe server will start on standard output (stdio) and wait for MCP requests.
Example Tools (Sample)
- get-recommended-fees: Get recommended Bitcoin transaction fees.
Integration Example
To use this MCP server as a tool provider in a client (e.g., Claude client), add a configuration like:
"btc-server": {
"command": "node",
"args": [
"{your path project}/mcp-server-ddd-sample/build/main.js"
]
},Contributing
Pull requests are welcome! Feel free to open issues or suggest improvements for this sample repository.
