/nestjs-mongoos

Primary LanguageTypeScriptMIT LicenseMIT

Contributors Forks Stargazers Issues MIT License

NestJs NodeJs Typescript MongoDB JWT Jest Yarn Docker

ACK NestJs Boilerplate Mongoose 🔥 🚀

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

Important

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.

  1. TimestampMiddleware, tolerant 5 minutes of request.
  2. UserAgentMiddleware, whitelist of user agent.
  3. ApiKeyGuard, check api key based on database.
  4. CorsMiddleware, check cors based on configs.

You can see our e2e testing file or read the documentation on section environment.

Build with

Describes which version .

Name Version
NestJs v9.x
NodeJs v18.x
Typescript v4.x
Mongoose v6.x
MongoDB v5.x
Yarn v1.x
NPM v8.x
Docker v20.x
Docker Compose v2.x

Objective

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

Features

  • NestJs v9.x 🥳
  • Production Ready 🔥
  • Typescript 🚀
  • Authentication and Authorization (JWT, OAuth2, API Key, Basic Auth, Role Management) 💪
  • User Agent Check
  • MongoDB Integrate by Using Mongoose Package 🎉
  • Database Migration (NestJs-Command)
  • Storage with AWS (S3)
  • 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 Request Custom Timeout (Override) ⌛️
  • Dynamic Setting from Database 🗿
  • Maintenance Mode on / off 🐤
  • Server Side Pagination
  • Cache Manager Implementation
  • 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

Prerequisites

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.

  1. Understand NestJs Fundamental, Main Framework. NodeJs Framework with support fully TypeScript.
  2. UnderstandTypescript Fundamental, Programming Language. It will help us to write and read the code.
  3. Understand ExpressJs Fundamental, NodeJs Base Framework. It will help us in understanding how the NestJs Framework works.
  4. Understand what NoSql is and how it works as a database, especially MongoDB.
  5. Optional, Understand Microservice Architecture and the design pattern.
  6. Optional,The Twelve Factor Apps
  7. Optional, Understand Docker that can help you to run the project

Todo

Next development

  • Import data form excel
  • Utils unit test
  • Update Documentation
  • Timezone in serialization and dto
  • Versioning Serialization
  • Docker Compose File Mongodb Replication Set (Low Priority)
  • Swagger (Low Priority)

Example

ack-nestjs-boilerplate-mongoose has advance example. Feel free to check it by yourself.

Documentation

Let's go into deep ! 🚀

Endpoints

Import endpoints.json into postman or see our e2e testing

Microservice

Support pub/sub design pattern

Nestjs microservice or Kafka integration will put in separate repo ack-microservice-nestjs-boilerplate-mongoose.

License

Distributed under MIT licensed.

Contributors

Thanks goes to these wonderful people

Boilerplate

PSheon
PSheon

aallithioo
aallithioo

Documentation

Tiaamoo
Tiaamoo

Contact

Andre Christi kan

Github LinkedIn Instagram