Skip to content

branch42-labs/nestjs-mcp-server

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

11 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

NestJS MCP Server Template

NestJS TypeScript Fastify PostgreSQL Redis Docker

Production-ready NestJS boilerplate with Model Context Protocol (MCP) server, RAG capabilities, and comprehensive developer tooling

Features β€’ Quick Start β€’ Documentation β€’ License


πŸš€ Overview

A comprehensive, production-ready NestJS template that combines modern backend architecture with AI capabilities through the Model Context Protocol (MCP). Perfect for building intelligent applications, LMS platforms, content management systems, or any project requiring semantic search and AI integration.

Note: This template extends ultimate-nestjs-boilerplate by @niraj-khatiwada with MCP server, RAG pipeline, and AI capabilities. All credits for the excellent foundation go to the original author.

What Makes This Different?

  • πŸ€– Built-in MCP Server: Expose your data to AI agents with standardized protocol
  • πŸ” RAG Pipeline: Semantic search with pgvector and local embeddings (no API costs)
  • πŸ” Modern Auth: Better Auth with support for OAuth, 2FA, magic links, and more
  • ⚑ High Performance: Fastify adapter (2x faster than Express)
  • 🎯 Production Ready: Docker, monitoring, graceful shutdown, health checks
  • πŸ› οΈ Developer Experience: Swagger, GraphQL playground, hot reload, Bull Board UI

✨ Features

Core Framework

  • βœ… NestJS with Fastify adapter for high performance
  • βœ… TypeScript for type safety and better DX
  • βœ… PostgreSQL with TypeORM for robust data management
  • βœ… Redis for caching and queue management

Authentication & Security

  • βœ… Better Auth: Complete auth solution supporting:
    • Email/Password, OAuth, Magic Links, Passkeys
    • Two-Factor Authentication (2FA)
    • Role-based access control (RBAC)
    • Session management
  • βœ… API Key Management: Secure programmatic access with SHA-256 hashing
  • βœ… Rate Limiting: Redis-backed request throttling
  • βœ… Input Validation: class-validator with custom decorators

AI & Search Capabilities

  • βœ… MCP Server: Model Context Protocol implementation for AI agents
  • βœ… RAG Pipeline: Retrieval-Augmented Generation with semantic search
  • βœ… pgvector: PostgreSQL extension for vector similarity search
  • βœ… Local Embeddings: Hugging Face Transformers (no API costs)
  • βœ… Content Chunking: Intelligent text splitting for better search accuracy

API Protocols

  • βœ… REST API: Versioned endpoints with Swagger documentation
  • βœ… GraphQL API: Apollo Server with type-safe schema
  • βœ… WebSocket: Socket.io with Redis adapter for clustering

Background Processing

  • βœ… BullMQ: Redis-based job queue with retry logic
  • βœ… Worker Process: Dedicated worker for heavy computations
  • βœ… Bull Board: Web UI for monitoring jobs and queues

Email System

  • βœ… React Email: Beautiful, responsive email templates
  • βœ… MailPit: Local SMTP server for testing
  • βœ… Auto-compilation: TSX to HTML at build time

Developer Tools

  • βœ… Swagger UI: Interactive API documentation
  • βœ… OpenAPI Codegen: Auto-generate frontend API clients
  • βœ… Dependency Graph: Visualize module dependencies
  • βœ… ERD Generator: Database schema visualization
  • βœ… Hot Reload: Fast development iteration

DevOps & Monitoring

  • βœ… Docker: Dev and prod configurations with docker-compose
  • βœ… Prometheus + Grafana: Optional monitoring dashboards
  • βœ… Pino Logging: Structured JSON logs
  • βœ… Health Checks: Kubernetes-ready endpoints
  • βœ… Graceful Shutdown: Zero downtime deployments
  • βœ… GitHub Actions: CI/CD pipeline included

Code Quality

  • βœ… ESLint + Prettier: Code formatting and linting
  • βœ… Husky + Commitlint: Git hooks for quality enforcement
  • βœ… Jest: Unit and E2E testing
  • βœ… SWC: Fast compilation (faster than Webpack)

Other Features

  • βœ… i18n: Internationalization support
  • βœ… File Uploads: Local and AWS S3 support
  • βœ… Pagination: Offset and cursor-based
  • βœ… Sentry Integration: Error tracking (ready to configure)
  • βœ… pnpm: Fast, disk-efficient package manager

🎯 Use Cases

This template is perfect for:

  • πŸ“š Learning Management Systems (LMS): Course content with semantic search
  • πŸ€– AI-Powered Applications: Chat agents, document search, RAG systems
  • πŸ“ Content Management: Blog, documentation, knowledge bases
  • 🏒 SaaS Platforms: Multi-tenant apps with auth and API keys
  • πŸ”§ Internal Tools: Admin dashboards, background job processing
  • πŸš€ Startup MVPs: Production-ready foundation to move fast

πŸš€ Quick Start

Prerequisites

  • Node.js 18+ or Bun
  • Docker & Docker Compose
  • pnpm (recommended) or npm

1. Use This Template

Click the "Use this template" button on GitHub or:

git clone https://github.com/branch42-team/nestjs-mcp-server.git my-project
cd my-project
pnpm install

2. Environment Setup

cp .env.example .env
cp .env.docker.example .env.docker

Edit .env files with your configuration.

3. Start Development Environment

# Start all services (PostgreSQL, Redis, MailPit, etc.)
pnpm docker:dev:up

# Run database migrations
docker exec -it nestjs-server sh
pnpm migration:up
exit

4. Access Your Services

5. Create Your First User

Visit Swagger UI and use:

  • POST /api/auth/sign-up/email to create an account
  • POST /api/auth/sign-in/email to login

πŸ“š Documentation

Core Features

πŸ”’ Better Auth

Modern authentication framework handling all auth patterns out of the box:

  • Email/Password: Traditional auth with secure password hashing
  • OAuth: Google, GitHub, and more (easily extensible)
  • Magic Links: Passwordless authentication
  • Passkeys: WebAuthn support for biometric auth
  • Two-Factor Authentication: TOTP-based 2FA
  • Role-Based Access Control: Admin/User roles with guards
  • Session Management: Redis-backed sessions with auto-refresh

Learn more about Better Auth β†’

πŸ€– MCP Server

Model Context Protocol server implementation enabling AI agents to query your data:

Key Features:

  • 6 pre-built tools for course/content management
  • API key authentication with user-scoped permissions
  • Enrollment-based authorization (example use case)
  • Semantic search with RAG pipeline
  • Interactive CLI client included

Quick Example:

  1. Create API key via Swagger: POST /api/v1/user/api-keys
  2. Setup CLI:
    cd mcp-client
    echo "MCP_API_KEY=your-key" > .env
    pnpm install && pnpm dev
  3. Query naturally:
    > list courses
    > find lessons about variables
    > search typescript
    

Documentation:

πŸ”‘ API Key Management

Secure programmatic access for integrations and MCP clients:

Endpoints:

  • POST /api/v1/user/api-keys - Create new key
  • GET /api/v1/user/api-keys - List your keys
  • GET /api/v1/user/api-keys/:id - Get key details
  • DELETE /api/v1/user/api-keys/:id - Revoke key

Security Features:

  • SHA-256 hashed storage (raw key shown once)
  • Optional expiration dates
  • Usage tracking (lastUsedAt)
  • Instant revocation
  • User-scoped permissions

πŸš€ Automatic Frontend API Generation

Generate type-safe API clients from your Swagger spec:

# On your frontend project
pnpm codegen

This auto-generates all API calls with TanStack Query hooks. Import and use immediately:

import { useGetUserProfile } from '@/api/generated';

function Profile() {
  const { data, isLoading } = useGetUserProfile();
  // Fully typed, with caching, refetching, etc.
}

OpenAPI Codegen

🚨 Server & Database Monitoring

Optional Prometheus + Grafana setup for production monitoring:

Enable monitoring:

# In .env
COMPOSE_PROFILES=monitoring

Metrics tracked:

  • HTTP request duration/rate
  • Database connection pool stats
  • Queue job latency and throughput
  • Memory and CPU usage
  • Custom business metrics

Dashboards:

Server Monitoring: Server Monitoring

Database Monitoring: Database Monitoring

πŸ“¬ Email Management

React Email for beautiful, testable email templates:

  • Design emails in React with type safety
  • Preview all templates in local web UI
  • Automatic compilation to HTML at build time
  • Spam, accessibility, and responsiveness checks

Commands:

# Preview templates in browser
pnpm email:dev

# Auto-compiled during build (handled automatically)
pnpm email:build

MailPit for local testing:

  • SMTP server runs automatically in dev mode
  • Web UI at http://localhost:18025
  • Catch all outgoing emails
  • No real emails sent during development

MailPit


🐳 Docker Commands

Development

# Start all services
pnpm docker:dev:up

# Stop all services
pnpm docker:dev:down

# View logs
docker logs nestjs-server -f

Production

# Build and start production containers
pnpm docker:prod:up

# Stop production containers
pnpm docker:prod:down

Deployment

# Quick deploy script
sh ./bin/deploy.sh

# Or use GitHub Actions
# Workflow: .github/workflows/main.yml

πŸ› οΈ Development Tools

Dependency Graph

Visualize module dependencies and detect circular references:

# Requires Graphviz: brew install graphviz

# All dependencies
pnpm graph:app

# Only circular dependencies
pnpm graph:circular

Dependency Graph

Database ERD

Generate entity relationship diagrams:

pnpm erd:generate

ERD


πŸ—οΈ Project Structure

.
β”œβ”€β”€ src/
β”‚   β”œβ”€β”€ api/              # API modules (courses, users, etc.)
β”‚   β”œβ”€β”€ auth/             # Authentication (Better Auth integration)
β”‚   β”œβ”€β”€ mcp/              # MCP server implementation
β”‚   β”œβ”€β”€ config/           # Configuration modules
β”‚   β”œβ”€β”€ database/         # TypeORM setup and migrations
β”‚   β”œβ”€β”€ services/         # Shared services (embeddings, AWS, etc.)
β”‚   β”œβ”€β”€ worker/           # Background job processors
β”‚   └── main.ts           # Application entry point
β”œβ”€β”€ mcp-client/           # Interactive CLI client for MCP
β”œβ”€β”€ docker-compose.yml    # Base Docker configuration
β”œβ”€β”€ docker-compose.dev.yml   # Development overrides
β”œβ”€β”€ docker-compose.prod.yml  # Production overrides
└── docs/                 # Additional documentation

πŸ§ͺ Testing

# Unit tests
pnpm test

# E2E tests
pnpm test:e2e

# Coverage
pnpm test:cov

# Watch mode
pnpm test:watch

πŸ”§ Customization Guide

1. Remove Example Features

This template includes a course management system as an example. To adapt for your use case:

Remove course-related code:

# Delete course modules
rm -rf src/api/courses

# Remove from app.module.ts imports
# Update database migrations

Or keep and modify:

  • Rename entities to match your domain
  • Adjust the MCP tools in src/mcp/tools/
  • Update RAG pipeline in src/api/courses/courses-rag.service.ts

2. Add Your Own Modules

# Generate new module
nest g module features/my-feature
nest g service features/my-feature
nest g controller features/my-feature

3. Configure Authentication

Add OAuth providers (edit src/auth/better-auth.service.ts):

plugins: [
  oauth({
    github: {
      clientId: process.env.GITHUB_CLIENT_ID,
      clientSecret: process.env.GITHUB_CLIENT_SECRET,
    },
  }),
],

4. Customize MCP Tools

Add your own tools in src/mcp/tools/:

export const myCustomTool: Tool = {
  name: 'my_custom_tool',
  description: 'Description for AI agents',
  inputSchema: {
    type: 'object',
    properties: {
      /* ... */
    },
  },
};

πŸ“¦ Tech Stack

Category Technology Purpose
Runtime Node.js + TypeScript Server runtime with type safety
Framework NestJS + Fastify Enterprise architecture, 2x Express performance
Database PostgreSQL 16 ACID-compliant relational database
Vector Store pgvector Native Postgres vector extension
ORM TypeORM Mature ORM with migrations
Cache/Queue Redis + BullMQ In-memory cache and job queue
Auth Better Auth Modern authentication framework
API REST + GraphQL + WebSocket Multiple protocol support
Embeddings Hugging Face Transformers Local, cost-free embeddings
Email React Email + MailPit Template management + testing
Monitoring Prometheus + Grafana Metrics and dashboards
Logging Pino Structured JSON logging
Testing Jest Unit and E2E tests

🀝 Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'feat: add amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

πŸ“„ License

This project is licensed under the MIT License - see the LICENSE file for details.


πŸ™ Acknowledgments

This template is built upon the excellent foundation of:

Additional Credits


🌟 Star History

If you find this template useful, please consider giving it a star ⭐


Built with ❀️ by Branch42 Team

Based on ultimate-nestjs-boilerplate by @niraj-khatiwada

Report Bug β€’ Request Feature

About

Production-ready NestJS template with Model Context Protocol (MCP) server, RAG pipeline, pgvector semantic search, Better Auth, and comprehensive developer tooling. Docker-ready with REST/GraphQL/WebSocket APIs.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors