Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/niraj-khatiwada/ultimate-nestjs-boilerplate
Advanced Nest.js boilerplate for scalable startups.
https://github.com/niraj-khatiwada/ultimate-nestjs-boilerplate
aws backend docker grafana graphql nestjs postgresql prometheus websockets
Last synced: about 1 month ago
JSON representation
Advanced Nest.js boilerplate for scalable startups.
- Host: GitHub
- URL: https://github.com/niraj-khatiwada/ultimate-nestjs-boilerplate
- Owner: niraj-khatiwada
- Created: 2024-10-13T09:38:51.000Z (3 months ago)
- Default Branch: main
- Last Pushed: 2024-12-02T08:22:38.000Z (about 1 month ago)
- Last Synced: 2024-12-02T09:29:19.816Z (about 1 month ago)
- Topics: aws, backend, docker, grafana, graphql, nestjs, postgresql, prometheus, websockets
- Language: TypeScript
- Homepage:
- Size: 1.9 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Ultimate Nest.js Boilerplate ⚡
Advanced Nest.js boilerplate for scalable startups.## Features📦
- [x] NestJS with Fastify
- [x] Postgres
- [x] TypeORM
- [x] Offset and Cursor based Pagination
- [x] REST & GraphQL API
- [x] Swagger Documentation and API versioning for REST API
- [x] Automatic API generation on the frontend using OpenAPI Codegen [Learn More](#1-automatic-api-generation-on-the-frontend)
- [x] Websockets
- [x] BullMQ for Queues. Bull board UI to inspect your jobs.
- [x] Worker server for processing background tasks like queues.
- [x] Caching using Redis
- [x] Pino for Logging
- [x] Rate Limiter using Redis
- [x] Graceful Shutdown
- [x] Server & Database monitoring with Prometheus & Grafana [Learn More](#4-server-monitoring)
- [x] File Uploads using AWS S3
- [x] Sentry
- [x] Testing with Jest
- [x] Internationalization using i18n
- [x] pnpm
- [x] Docker: Dev & Prod ready from single script. [Learn More](#5-docker)
- [x] Github Actions
- [x] Commitlint & Husky
- [x] SWC instead of Webpack
- [x] Dependency Graph Visualizer [Learn More](#2-dependency-graph-)
- [x] Database Entity Relationship Diagram Generator [Learn More](#3-database-entity-relationship-diagram️)### 1. Automatic API generation on the Frontend 🚀
You can automatically generate and use all of your backend API in frontend in just one command, thanks to Swagger and OpenAPI spec. Running `pnpm codegen` on the frontend (example [repo](https://github.com/niraj-khatiwada/openapi-codegen)) will automatically generate all API's bootstrapped with [Tanstack Query](https://tanstack.com/query/latest) ready to be used with just one import. See complete example [here](https://github.com/niraj-khatiwada/openapi-codegen)
### 2. Dependency Graph 📈
Visualize all of your project modules and their dependencies. Also, detect circular dependencies.
NOTE: Make sure [Graphviz](https://www.graphviz.org/) is installed first.
- All dependencies:
```
pnpm graph:app
```- Only circular dependencies:
```
pnpm graph:circular
```### 3. Database Entity Relationship Diagram🛢️
Visualize your database entities and their relationships.
```
pnpm erd:generate
```### 4. Server & Database Monitoring 📊
Prometheus & Grafana are available with Docker setup only. You might only need to monitor your server or database when the user base grows or when you want to debug some specific issues. That's why this step is completely optional. If you want to monitor your server or database, just enable `monitoring` profile in your `.env` i.e. `COMPOSE_PROFILES=monitoring`.
Server Monitoring Dashboard:
![alt text](./github-assets/server-monitoring.png)Database Monitoring Dashboard:
![alt text](./github-assets/database-monitoring.png)### 5. Docker 🐬
##### For local development:
- Start container:
```
pnpm docker:dev:up
```- Stop container:
```
pnpm docker:dev:down
```##### For prod build:
- Start container:
```
pnpm docker:prod:up
```- Stop container:
```
pnpm docker:prod:down
```##### Deployment:
```
sh ./bin/deploy.sh
```or run workflow `.github/workflows/main.yml` via GitHub Actions.
This boilerplate is extended from [nestjs-boilerplate](https://github.com/vndevteam/nestjs-boilerplate?tab=readme-ov-file)