Best uses for Restful API, Microservice, or SaaS Project
ack-nestjs-boilerplate-mongoose is a NestJs Boilerplate with Mongoose and MongoDB as Database.
Made with following
You can Request Feature or Report Bug with following this link
ack-nestjs-boilerplate-mongoose still on trial and error phase and the test will base on real projects or cases. So there will be (always) have new update and new features.
If you change env value of APP_MODE
to secure
that will trigger more Middleware
and Guard
.
TimestampMiddleware
, tolerant 5 minutes of request.UserAgentMiddleware
, whitelist of user agent.ApiKeyGuard
, check api key based on database.CorsMiddleware
, check cors based on configs.
You can see our e2e testing file
or read the documentation on section environment.
Describes which version of the main packages and main tools.
Name | Version |
---|---|
NestJs | v8.x |
NodeJs | v17.x |
Typescript | v4.x |
Mongoose | v6.x |
MongoDB | v5.x |
Yarn | v1.x |
NPM | v8.x |
Docker | v20.x |
Docker Compose | v2.x |
ack-nestjs-boilerplate-mongoose have some objective.
- Simple, scalable and secure
- Avoid spaghetti code
- Component based
- Reusable component
- Easy to maintenance
- Support for all microservice patterns
- NestJs v8.x π₯³
- Production Ready π₯
- Typescript π
- Authentication and Authorization (JWT, OAuth2, API Key, Basic Auth, Role Management) πͺ
- Mongodb Integrate by Using Mongoose Package π
- Database Migration (NestJs-Command)
- Storage Management with AWS (S3), and can switch with Internal Storage using FS Package
- Server Side Pagination (3 Types)
- Url Versioning
- Request Validation Pipe with Custom Message π
- Custom Error Status Code π€«
- Logger (Morgan) and Debugger (Winston) π
- Centralize Configuration π€
- Centralize Exception Filter, and Custom Error Structure
- Multi-language (i18n) π£
- Timezone Awareness, and Custom Timezone
- Request Timeout, and Custom Timeout (Override) βοΈ
- Dynamic Setting from Database πΏ
- Maintenance Mode on / off π€
- Cache Manager Implementation, can switch with Redis, Memcached, or anything else
- Advance Example π₯Ά
- Support Docker Installation
- Support CI/CD with Github Action or Jenkins
- Husky GitHook For Check Source Code, and Run Test Before Commit πΆ
- Linter with EsLint for Typescript
- Etc.
We assume that everyone who comes here is programmer with intermediate knowledge
and we also need to understand more before we begin in order to reduce the knowledge gap.
- Understand NestJs Fundamental, Main Framework. NodeJs Framework with support fully TypeScript.
- UnderstandTypescript Fundamental, Programming Language. It will help us to write and read the code.
- Understand ExpressJs Fundamental, NodeJs Base Framework. It will help us in understanding how the NestJs Framework works.
- Understand what NoSql is and how it works as a database, especially MongoDB.
- Understand Microservice Architecture and the design pattern.
- The Twelve Factor Apps
- Optional, Understand Docker that can help you to run the project
Next development
- Pagination Optimization, Pagination Category
- Default Timezone, and custom timezone (by
x-timezone
) - Add response header
x-custom-lang
,x-timestamp
, andx-timezone
, andx-request-id
- Add
x-request-id
middleware - Add
x-request-id
per debugger log, to make more specific log per request - Cors optimization allowed header, and allowed method
- Implement Cache Manager for response (for improve performance)
- Response Timeout, custom timeout with decorator
- Convert time using
ms package
in Config Module. Centralize - Add
cSpell
- Add
ErrorLogInterceptor
- Add
LoggerInterceptor
- Timezone in serialization and dto
- Utils unit test
- Add
Redis
Configuration - Update Documentation
- Versioning Serialization (Low Priority)
- Docker Compose File Mongodb Replication Set (Low Priority)
- Swagger (Low Priority)
Let's go into deep ! π
Import endpoints.json into postman or see our e2e testing
Nestjs microservice or Kafka integration will put in separate repo ack-microservice-nestjs-boilerplate-mongoose.
Distributed under MIT licensed.
Thanks goes to these wonderful people
PSheon |
aallithioo |
Tiaamoo |