Creating a New Tool
Use the Starter Kit
We strongly recommend using our Toolserver Starter repository. It has everything you need to create, run, and deploy an MCP server with optional token gating.
- 
Clone the Starter git clone https://github.com/<your-organization>/toolserver-starter.git cd toolserver-starter npm install
- 
Choose Your Entry Point - src/index.ts: A simple, open-access example (“echo” service).
- src/index-gated.ts: A token-gated variant that checks if the caller holds a minimum token balance before serving requests.
 
- 
Run Locally npx tsx src/index.tsor npx tsx src/index-gated.tsThen open another terminal: npx @wong2/mcp-cli --sse http://localhost:3000/sseYou’ll see the service is discoverable via MCP. 
- 
Set Environment Variables (for token gating) - RPC_URL: Your chain’s RPC endpoint (e.g., Base, Sepolia, or mainnet).
- STRAWBERRY_NETWORK_ID: Numeric chain ID.
- LOCALHOST_TOKEN: Address of the ERC-20 token that gates usage.
 
Expand the Example
From here, you can add multiple tools under one server, or create more sophisticated routes in your src/index(-gated).ts file. For instance, you might add an image-processing API that accepts a base64 string and returns the processed image.
Key Steps:
- Edit server.setRequestHandler(ListToolsRequestSchema, ...)to list new tools.
- Implement your logic in server.setRequestHandler(CallToolRequestSchema, ...)for each tool.
- If you need a more advanced gating model (pay-per-call), see Advanced Topics → Metered Billing.