A comprehensive starter template for building Model Context Protocol (MCP) servers with TypeScript. This template provides a solid foundation for developers of all skill levels to quickly bootstrap production-ready MCP projects.
- TypeScript First: Complete type safety with comprehensive type definitions
- Production Ready: Robust error handling, logging, and validation
- Modular Architecture: Clean separation of concerns following SOLID principles
- Comprehensive Testing: Unit tests with Jest and high coverage standards
- Docker Support: Containerization for easy deployment
- CI/CD Ready: GitHub Actions workflows included
- Developer Friendly: Extensive documentation and debugging tools
- Security Focused: Input validation and secure file operations
- Health Monitoring: Built-in health checks and metrics
- Node.js 18.0.0 or higher
- npm 8.0.0 or higher (or yarn/pnpm equivalent)
Choose your preferred package manager:
Using npm:
git clone https://github.com/onamfc/mcp-starter-template-ts.git
cd mcp-starter-template-ts
npm install
npm run build
npm start
Using yarn:
git clone https://github.com/onamfc/mcp-starter-template-ts.git
cd mcp-starter-template-ts
yarn install
yarn build
yarn start
Using pnpm:
git clone https://github.com/onamfc/mcp-starter-template-ts.git
cd mcp-starter-template-ts
pnpm install
pnpm build
pnpm start
For development with hot reloading:
npm run dev
This will start the server with automatic restarts when you modify source files.
src/
├── server.ts # Main MCP server implementation
├── types/ # TypeScript type definitions
│ └── index.ts
├── tools/ # MCP tools implementation
│ ├── setup.ts # Tool registration and management
│ ├── calculator.ts # Mathematical calculations
│ ├── filesystem.ts # File system operations
│ ├── text-processing.ts # Text manipulation and analysis
│ └── weather.ts # Weather information (mock)
├── resources/ # MCP resources implementation
│ ├── setup.ts # Resource registration and management
│ ├── config.ts # Configuration access
│ ├── docs.ts # Documentation resource
│ └── logs.ts # Logs access
├── utils/ # Utility functions
│ ├── config.ts # Configuration management
│ ├── logger.ts # Structured logging
│ ├── validation.ts # Input validation
│ ├── errors.ts # Error handling
│ └── health.ts # Health check utilities
└── __tests__/ # Test files
├── server.test.ts
├── tools/
└── utils/
The server can be configured through environment variables. Create a .env
file in the project root:
# Server Configuration
PORT=3000
HOST=localhost
LOG_LEVEL=info
NODE_ENV=development
# Feature Flags
ENABLE_HEALTH_CHECK=true
# Security
MAX_REQUEST_SIZE=10mb
CORS_ORIGINS=*
# External Services (if needed)
# WEATHER_API_KEY=your_api_key_here
# DATABASE_URL=your_database_url_here
Variable | Description | Default | Required |
---|---|---|---|
PORT |
Server port number | 3000 | No |
HOST |
Server host address | localhost | No |
LOG_LEVEL |
Logging level (error, warn, info, debug) | info | No |
NODE_ENV |
Environment (development, production, test) | development | No |
ENABLE_HEALTH_CHECK |
Enable health check endpoint | true | No |
MAX_REQUEST_SIZE |
Maximum request body size | 10mb | No |
CORS_ORIGINS |
Allowed CORS origins (comma-separated) | * | No |
Perform mathematical calculations with support for basic arithmetic operations.
Parameters:
expression
(string, required): Mathematical expression to evaluateprecision
(number, optional): Number of decimal places (default: 2)
Example:
{
"name": "calculate",
"arguments": {
"expression": "2 + 3 * 4",
"precision": 2
}
}
Read and write files within the project directory with security restrictions.
Parameters:
operation
(string, required): Operation type (read, write, list, exists)path
(string, required): File or directory path (relative to project root)content
(string, optional): Content to write (required for write operation)encoding
(string, optional): File encoding (utf8, base64, default: utf8)
Example:
{
"name": "filesystem",
"arguments": {
"operation": "read",
"path": "package.json"
}
}
Process and analyze text with various operations.
Parameters:
operation
(string, required): Operation type (count, uppercase, lowercase, reverse, wordcount, sentiment)text
(string, required): Text content to processoptions
(object, optional): Additional options for the operation
Example:
{
"name": "text-processing",
"arguments": {
"operation": "sentiment",
"text": "I love this amazing weather today!"
}
}
Get current weather information and forecasts (mock implementation).
Parameters:
location
(string, required): Location name or coordinatesunits
(string, optional): Temperature units (metric, imperial, kelvin, default: metric)forecast
(boolean, optional): Include 5-day forecast (default: false)
Example:
{
"name": "weather",
"arguments": {
"location": "New York, NY",
"units": "metric",
"forecast": true
}
}
Access current application configuration and settings.
Complete API documentation and usage examples.
Recent application logs and events.
npm run dev
- Start development server with hot reloadingnpm run build
- Build the project for productionnpm start
- Start the production servernpm test
- Run test suitenpm run test:watch
- Run tests in watch modenpm run test:coverage
- Run tests with coverage reportnpm run lint
- Run ESLintnpm run lint:fix
- Run ESLint with auto-fixnpm run format
- Format code with Prettiernpm run format:check
- Check code formattingnpm run type-check
- Run TypeScript type checkingnpm run clean
- Clean build artifactsnpm run health
- Check server healthnpm run validate-config
- Validate configuration
- Create a new file in
src/tools/your-tool.ts
- Implement the
ToolDefinition
interface - Add comprehensive error handling and logging
- Register the tool in
src/tools/setup.ts
- Add tests in
src/__tests__/tools/your-tool.test.ts
Example tool structure:
export const yourTool: ToolDefinition = {
name: 'your-tool',
description: 'Description of what your tool does',
inputSchema: {
type: 'object',
properties: {
// Define your parameters here
},
required: ['requiredParam'],
},
handler: async (args, context) => {
// Implement your tool logic here
// Always include proper error handling and logging
},
};
- Create a new file in
src/resources/your-resource.ts
- Implement the
ResourceDefinition
interface - Add the resource to
src/resources/setup.ts
- Add tests for the resource
Run the complete test suite:
npm test
Run tests in watch mode during development:
npm run test:watch
Generate coverage report:
npm run test:coverage
This project includes comprehensive code quality tools:
- ESLint: Linting with TypeScript support
- Prettier: Code formatting
- TypeScript: Type checking
- Jest: Testing framework
Run all quality checks:
npm run lint && npm run format:check && npm run type-check
docker build -t mcp-server .
docker run -p 3000:3000 mcp-server
For development with additional services:
docker-compose up --build
npm run build
- Set
NODE_ENV=production
- Configure appropriate log levels
- Set up proper CORS origins
- Configure external service credentials
- Set up monitoring and alerting
The server includes built-in health check endpoints:
- Health status:
GET http://localhost:3001/health
- Metrics:
GET http://localhost:3001/metrics
- All file operations are restricted to the project directory
- Input validation is performed on all tool parameters
- Expressions in calculator tool are sanitized to prevent code injection
- Request logging includes tracking for security auditing
- Error messages do not expose sensitive system information
Server won't start:
- Check that the port is not already in use
- Verify Node.js version (must be 18.0.0 or higher)
- Run
npm run validate-config
to check configuration
Tools not working:
- Check the logs for detailed error messages
- Verify input parameters match the tool schema
- Ensure file paths are relative and within project directory
Build failures:
- Run
npm run clean
to remove old build artifacts - Check for TypeScript errors with
npm run type-check
- Verify all dependencies are installed
Test failures:
- Make sure you're in the project root directory
- Check that all environment variables are set correctly
- Run tests individually to isolate issues:
npm test -- --testNamePattern="specific test"
Enable debug logging:
LOG_LEVEL=debug npm run dev
- Check the troubleshooting section above
- Review the API documentation at
resource://docs/api
- Check recent logs at
resource://logs/recent
- Open an issue on the project repository
We welcome contributions! Please follow these guidelines:
- Fork the repository
- Create a feature branch:
git checkout -b feature/your-feature-name
- Make your changes with tests
- Run the full test suite:
npm test
- Run quality checks:
npm run lint && npm run format:check && npm run type-check
- Commit your changes with a descriptive message
- Push to your fork and submit a pull request
- Follow the existing code style and patterns
- Add comprehensive tests for new features
- Include JSDoc comments for all public functions
- Update documentation for any API changes
- Ensure all tests pass and coverage remains high
Use conventional commit format:
feat: add new weather tool
fix: resolve validation error in calculator
docs: update installation instructions
test: add tests for file system tool
chore: update dependencies
MIT License - see LICENSE file for details.
See CHANGELOG.md for version history and updates.
- Documentation: Check the
/docs
directory for detailed guides - Issues: Report bugs or request features via GitHub issues
- Discussions: Join community discussions for questions and ideas
- Add more built-in tools (HTTP client, database operations)
- Implement plugin system for external tools
- Add WebSocket transport support
- Create web-based admin interface
- Add metrics and monitoring dashboard
- Implement rate limiting and request quotas
- Add authentication and authorization
- Create tool marketplace integration