Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@my-mcp-serversay hello to John"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
MCP Server Template
A starter template for building MCP (Model Context Protocol) servers in TypeScript
What You Get
A working MCP server with an example
hellotoolTypeScript with ES modules
Testing with Vitest
Linting (ESLint) and formatting (Prettier)
CI pipeline and npm publishing workflow
VS Code, Claude Desktop, and Cursor configuration examples
┌─────────────────┐ ┌────────────┐ ┌──────────────────┐
│ AI Assistant │────▶│ MCP Client │────▶│ Your MCP Server │
│ (Copilot/Claude) │◀────│ │◀────│ │
└─────────────────┘ └────────────┘ └──────────────────┘Quick Start
1. Create your project
npx -y degit matracey/mcp-server-template my-mcp-server
cd my-mcp-server
npm install2. Customize
Update
name,description, andbininpackage.jsonReplace the example
hellotool insrc/server.tswith your own toolsUpdate the server name/version in
src/server.ts
3. Build and test
npm run build
npm test4. Run locally
npm run dev # Run with auto-restart on file changes
npm start # Run the built versionAdding Tools
Edit src/server.ts and register a new tool:
server.tool(
'my_tool',
'Description of what this tool does.',
{
param: z.string().describe('Parameter description'),
},
async ({ param }) => {
return {
content: [{ type: 'text' as const, text: `Result: ${param}` }],
}
}
)The template includes an example hello tool to demonstrate the pattern.
Client Configuration
Once published (or running locally), configure your AI client:
VS Code (GitHub Copilot)
Add to .vscode/mcp.json:
{
"servers": {
"my-server": {
"type": "stdio",
"command": "npx",
"args": ["-y", "my-mcp-server"]
}
}
}Claude Desktop
Add to claude_desktop_config.json:
{
"mcpServers": {
"my-server": {
"command": "npx",
"args": ["-y", "my-mcp-server"]
}
}
}Cursor
Add to .cursor/mcp.json:
{
"mcpServers": {
"my-server": {
"command": "npx",
"args": ["-y", "my-mcp-server"]
}
}
}Replace
my-mcp-serverwith your published package name.
Project Structure
src/
├── index.ts # Entry point — stdio transport setup
├── server.ts # MCP server & tool definitions
├── __tests__/ # Tests (vitest)
└── data/ # Static data (if needed)
scripts/ # Dev-time scriptsDevelopment
Prerequisites
Node.js >= 20
npm
Commands
npm run build # TypeScript compilation
npm test # Run tests
npm run test:watch # Watch mode
npm run test:coverage # With coverage report
npm run dev # Run with auto-restart on changes
npm run validate # Run all CI checks (format, lint, build, test)Contributing
Contributions are welcome! Please see CONTRIBUTING.md for guidelines.
License
MIT — see LICENSE for details.
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.