{"id":25188639,"url":"https://github.com/montasim/node-express-boilerplate","last_synced_at":"2026-01-23T09:40:36.952Z","repository":{"id":252404718,"uuid":"772615729","full_name":"montasim/node-express-boilerplate","owner":"montasim","description":"A boilerplate/starter project for quickly building RESTful APIs using Node.js, Express, and Mongoose.","archived":false,"fork":false,"pushed_at":"2024-09-08T05:10:39.000Z","size":2538,"stargazers_count":2,"open_issues_count":1,"forks_count":1,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-02-09T20:36:44.717Z","etag":null,"topics":["api-boilerplate","api-starter","node-backend","node-express-boilerplate","node-express-mongodb-boilerplate","rest-api","rest-api-boilerplate","rest-api-starter","secure-api","swagger-api"],"latest_commit_sha":null,"homepage":"https://node-express-boilerplate-eta.vercel.app","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/montasim.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":"SECURITY.md","support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2024-03-15T14:45:15.000Z","updated_at":"2024-11-13T18:56:32.000Z","dependencies_parsed_at":"2024-09-08T06:22:12.510Z","dependency_job_id":"f1f1d18b-09e3-469c-8cea-75b1883b5629","html_url":"https://github.com/montasim/node-express-boilerplate","commit_stats":null,"previous_names":["montasim/node-express-boilerplate"],"tags_count":13,"template":true,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/montasim%2Fnode-express-boilerplate","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/montasim%2Fnode-express-boilerplate/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/montasim%2Fnode-express-boilerplate/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/montasim%2Fnode-express-boilerplate/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/montasim","download_url":"https://codeload.github.com/montasim/node-express-boilerplate/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":247157276,"owners_count":20893221,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["api-boilerplate","api-starter","node-backend","node-express-boilerplate","node-express-mongodb-boilerplate","rest-api","rest-api-boilerplate","rest-api-starter","secure-api","swagger-api"],"created_at":"2025-02-09T20:29:35.889Z","updated_at":"2026-01-23T09:40:31.933Z","avatar_url":"https://github.com/montasim.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"[//]: # 'NODE EXPRESS BOILERPLATE'\r\n\r\n# \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=24\u0026duration=1\u0026pause=1\u0026color=EB008B\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=335\u0026height=40\u0026lines=NODE+EXPRESS+BOILERPLATE\" alt=\"LIBRARY MANAGEMENT SYSTEM SERVER\" /\u003e\r\n\r\n[![]()]()\r\n\r\n\u003c!-- GitHub actions badges start --\u003e\r\n\u003cdiv\u003e\r\n    \u003cimg loading=\"lazy\" alt=\"Continuous Integration\" src=\"https://github.com/montasim/node-express-boilerplate/actions/workflows/ci.yml/badge.svg?labelColor=EB008B\u0026color=00B8B5\"\u003e\r\n    \u003cimg loading=\"lazy\" alt=\"Build on Merge\" src=\"https://github.com/montasim/node-express-boilerplate/actions/workflows/build-on-merge.yml/badge.svg?labelColor=EB008B\u0026color=00B8B5\"\u003e\r\n    \u003cimg loading=\"lazy\" alt=\"Automated Release Workflow for PR Merges\" src=\"https://github.com/montasim/node-express-boilerplate/actions/workflows/create-release.yml/badge.svg?labelColor=EB008B\u0026color=00B8B5\"\u003e\r\n\u003c/div\u003e\r\n\u003c!-- GitHub actions badges end --\u003e\r\n\r\n\u003c!-- repository summary badges start --\u003e\r\n\u003cdiv\u003e\r\n    \u003cimg alt=\"Wakatime coding time badge\" src=\"https://wakatime.com/badge/user/bb224c90-7cb7-4c45-953e-a9e26c1cb06c/project/018e21fa-6cc2-477a-be0c-b5e44ca67f1c.svg?labelColor=EB008B\u0026color=00B8B5\"\u003e\r\n    \u003cimg alt=\"GitHub release\" src=\"https://img.shields.io/github/release/montasim/node-express-boilerplate?labelColor=EB008B\u0026color=00B8B5\"\u003e\r\n    \u003cimg alt=\"GitHub last commit\" src=\"https://img.shields.io/github/last-commit/montasim/node-express-boilerplate?labelColor=EB008B\u0026color=00B8B5\"\u003e\r\n    \u003cimg alt=\"GitHub commit activity\" src=\"https://img.shields.io/github/commit-activity/w/montasim/node-express-boilerplate?labelColor=EB008B\u0026color=00B8B5\"\u003e\r\n    \u003cimg alt=\"GitHub contributors\" src=\"https://img.shields.io/github/contributors/montasim/node-express-boilerplate?labelColor=EB008B\u0026color=00B8B5\"\u003e\r\n    \u003cimg alt=\"GitHub repo file count\" src=\"https://img.shields.io/github/directory-file-count/montasim/node-express-boilerplate?labelColor=EB008B\u0026color=00B8B5\"\u003e\r\n    \u003cimg alt=\"GitHub repo size\" src=\"https://img.shields.io/github/repo-size/montasim/node-express-boilerplate?labelColor=EB008B\u0026color=00B8B5\"\u003e\r\n    \u003cimg alt=\"GitHub license\" src=\"https://img.shields.io/github/license/montasim/node-express-boilerplate?labelColor=EB008B\u0026color=00B8B5\"\u003e\r\n\u003c/div\u003e\r\n\u003c!-- repository summary badges end --\u003e\r\n\r\n\u003cbr/\u003e\r\n\r\nA boilerplate/starter project for quickly building RESTful APIs using Node.js, Express, and Mongoose.\r\n\r\n[//]: # 'CONTENTS'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=120\u0026height=40\u0026lines=CONTENTS:\" alt=\"CONTENTS:\" /\u003e\r\n\r\n1. [FEATURES](#1-features)\r\n2. [PREREQUISITES](#2-prerequisites)\r\n3. [SETUP](#3-setup)\r\n4. [RUNNING THE SCRIPT](#4-running-the-script)\r\n5. [ERROR HANDLING](#5-error-handling)\r\n6. [HOSTING](#6-hosting)\r\n7. [USED PACKAGES](#7-used-packages)\r\n8. [TOOLS](#8-tools)\r\n9. [ARTICLES](#9-articles)\r\n10. [DO NOT FORGET TO DO](#10-do-not-forget-to-do)\r\n11. [TUTORIALS](#11-tutorials)\r\n12. [INSPIRATIONS](#12-inspirations)\r\n13. [CONTRIBUTE](#13-contribute)\r\n14. [CONTRIBUTORS](#14-contributors)\r\n15. [SPECIAL THANKS](#15-special-thanks)\r\n16. [LICENSE](#16-license)\r\n17. [CONTACT](#17-contact)\r\n\r\n\u003cbr/\u003e\r\n\r\n[//]: # '1. FEATURES'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=120\u0026height=40\u0026lines=1.+FEATURES\" alt=\"1. FEATURES\" id=\"1-features\" /\u003e\r\n\r\n1. Authentication:\r\n\r\n    - Handles user login, logout, password resets, and email verification processes.\r\n    - Ensures secure access through bearer token authentication.\r\n\r\n2. User Profile Management:\r\n\r\n    - Facilitates fetching and updating user profile information based on username. Respects privacy settings and only returns allowed information.\r\n\r\n3. Permission and Role Management:\r\n\r\n    - Manages permissions and roles within the system, allowing for the creation of new roles, modification of existing ones, and deletion of roles based on IDs.\r\n\r\n4. Error and Request Handling:\r\n\r\n    - Includes comprehensive handling of unsupported methods and detailed error responses to ensure robustness and reliability of the API.\r\n\r\n### APIs\r\n\r\n1. User\r\n    - Auth\r\n        - Signup: `POST /api/{{VERSION}}/auth/signup`\r\n        - Verify signup using email: `GET /api/{{VERSION}}/auth/verify/verification-token`\r\n        - Login: `POST /api/{{VERSION}}/auth/login`\r\n        - Request password reset email: `PUT /api/{{VERSION}}/auth/request-new-password`\r\n        - Resend password reset email: `PUT /api/{{VERSION}}/auth/resend-verification/verification-token`\r\n        - Reset password: `PUT /api/{{VERSION}}/auth/reset-password/verification-token`\r\n        - Logout: `GET /api/{{VERSION}}/auth/logout`\r\n    - Profile\r\n        - Update personal information:\r\n        - Reset password:\r\n        - Delete account:\r\n2. Admin\r\n    - Admin\r\n        - Create admin: `POST /api/{{VERSION}}/admin`\r\n        - Verify admin request using email: `GET /api/{{VERSION}}/admin/verify/verification-token`\r\n        - Admin Login: `/api/{{VERSION}}/admin/login`\r\n        - Request password reset email: `PUT /api/{{VERSION}}/admin/request-new-password`\r\n        - Resend password reset email: `GET /api/{{VERSION}}/admin/resend-verification/token-id`\r\n        - Reset password: `PUT /api/{{VERSION}}/admin/reset-password/verification-token`\r\n        - Logout: `GET /api/{{VERSION}}/admin/logout`\r\n    - Permission\r\n        - Create permission: `POST /api/{{VERSION}}/permissions`\r\n        - Create default permission: `POST /api/{{VERSION}}/permissions/default`\r\n        - Get all permissions: `GET /api/{{VERSION}}/permissions`\r\n        - Get permission by ID: `GET /api/{{VERSION}}/permissions/permission-id`\r\n        - Update permission by ID: `PUT /api/{{VERSION}}/permissions/permission-id`\r\n        - Delete permission by ID: `DELETE /api/{{VERSION}}/permissions/permission-id`\r\n        - Delete permission by list: `DELETE /api/{{VERSION}}/permissions?ids=permission-id1,permission-id2`\r\n    - Role\r\n        - Create role: `POST /api/{{VERSION}}/roles`\r\n        - Create default role: `POST /api/{{VERSION}}/roles/default`\r\n        - Get all roles: `GET /api/{{VERSION}}/roles`\r\n        - Get role by ID: `GET /api/{{VERSION}}/roles/role-id`\r\n        - Update role by ID: `PUT /api/{{VERSION}}/roles/role-id`\r\n        - Delete role by ID: `DELETE /api/{{VERSION}}/roles/role-id`\r\n        - Delete role by list: `DELETE /api/{{VERSION}}/roles?ids=role-id1,role-id2`\r\n3. Public\r\n    - Detect\r\n        - User device detection\r\n\r\n\u003cbr/\u003e\r\n\r\n[//]: # 'PREREQUISITES'\r\n[//]: # '2. PREREQUISITES'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=168\u0026height=40\u0026lines=2.+PREREQUISITES\" alt=\"2. PREREQUISITES\" id=\"2-prerequisites\" /\u003e\r\n\r\n1. Node.js (v20.x or higher)\r\n2. Yarn (v1.22.x or higher)\r\n\r\nEnsure you have `Node.js` and `Yarn` installed by running `node -v` and `yarn -v` in your terminal. These commands will display the current version of each installed on your system. If these are not installed, follow the installation instructions on the [Node.js website](https://nodejs.org/) and the [Yarn website](https://classic.yarnpkg.com/en/).\r\n\r\n\u003cbr/\u003e\r\n\r\n[//]: # '3. SETUP'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=80\u0026height=40\u0026lines=3.+SETUP\" alt=\"3. SETUP\" id=\"3-setup\" /\u003e\r\n\r\n1. **Clone the repository and navigate to the directory:**\r\n\r\n    ```bash\r\n    git clone https://github.com/montasim/node-express-boilerplate.git\r\n    cd node-express-boilerplate\r\n    ```\r\n\r\n2. **Install the dependencies:**\r\n\r\n    ```bash\r\n    yarn install\r\n    ```\r\n\r\n3. **Configuring the Environment:**\r\n\r\n    Create a `.env.development` or `.env.staging` or `.env.production` file in the root directory of the project and populate it with the necessary environment variables. See the [.env.example](.env.example) file for an example.\r\n\r\n\u003cbr/\u003e\r\n\r\n[//]: # '4. RUNNING THE SCRIPT'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=230\u0026height=40\u0026lines=4.+RUNNING+THE+SCRIPT\" alt=\"4. RUNNING THE SCRIPT\" id=\"4-running-the-script\" /\u003e\r\n\r\n1. **Running the Application:**\r\n\r\n    To start the application in development mode, use:\r\n\r\n    ```bash\r\n    yarn dev\r\n    ```\r\n\r\n    This will run the server with nodemon, automatically restarting when any changes are made.\r\n\r\n2. **To build and run the application in production mode, use:**\r\n\r\n    ```bash\r\n    yarn start\r\n    ```\r\n\r\n    This will build the application and start the server using the built files.\r\n\r\n    This script first builds the project by linting the code, fixing lint issues, running prettier, and then starts the application with pm2.\r\n\r\n3. **Testing:**\r\n\r\n    To run the tests configured with Jest, use:\r\n\r\n    ```bash\r\n    yarn test\r\n    ```\r\n\r\n    This will build the project and then run all the Jest tests.\r\n\r\n4. **Linting and Code Formatting:**\r\n\r\n    - To check for linting errors:\r\n\r\n        ```bash\r\n        yarn lint:check\r\n        ```\r\n\r\n    - To fix linting errors:\r\n\r\n        ```bash\r\n        yarn lint:fix\r\n        ```\r\n\r\n    - To check if files are formatted correctly:\r\n\r\n        ```bash\r\n        yarn prettier:check\r\n        ```\r\n\r\n    - To format files:\r\n\r\n        ```bash\r\n        yarn prettier:fix\r\n        ```\r\n\r\n5. **Generating Documentation:**\r\n\r\n    To generate code documentation with JSDoc, run:\r\n\r\n    ```bash\r\n    yarn generate-docs\r\n    ```\r\n\r\n    This will create documentation based on your JSDoc comments.\r\n\r\n6. **Release Management:**\r\n\r\n    To create a new release, you can use:\r\n\r\n    ```bash\r\n    yarn release\r\n    ```\r\n\r\n    This will automatically bump the version, update the CHANGELOG, and create a commit and a tag.\r\n\r\n    For minor or major releases:\r\n\r\n    ```bash\r\n    yarn release:minor\r\n    yarn release:major\r\n    ```\r\n\r\n7. **Cleanup:**\r\n\r\n    To clean up dependencies and rebuild the project:\r\n\r\n    ```bash\r\n    yarn clean\r\n    ```\r\n\r\n    This command initializes the auto cleanup process and then forces a rebuild.\r\n    \u003cbr/\u003e\r\n\r\n### Docker\r\n\r\n1. **Build the Docker Compose Services:**\r\n\r\n    ```bash\r\n    yarn docker:build-dev\r\n    ```\r\n\r\n2. **Run the Docker Compose Services:**\r\n\r\n    ```bash\r\n    yarn docker:run-dev\r\n    ```\r\n\r\n3. **Stop the Containers:**\r\n\r\n    ```bash\r\n    yarn docker:stop-dev\r\n    ```\r\n\r\n4. **Rebuild the Containers:**\r\n\r\n    ```bash\r\n    yarn docker:rebuild-dev\r\n    ```\r\n\r\n[//]: # '5. ERROR HANDLING'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=195\u0026height=40\u0026lines=5.+ERROR+HANDLING\" alt=\"5. ERROR HANDLING\" id=\"5-error-handling\" /\u003e\r\n\r\n\u003cbr/\u003e\r\n\r\n[//]: # '6. HOSTING'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=112\u0026height=40\u0026lines=6.+HOSTING\" alt=\"6. HOSTING\" id=\"6-hosting\" /\u003e\r\n\r\n[![Deploy to Vercel](https://vercel.com/button)](https://vercel.com/import/project?template=https://github.com/montasim/node-express-boilerplate)\r\n\r\n\u003cdetails\u003e\r\n    \u003csummary\u003e\r\n        Step-by-step guide on setting up your own Vercel instance:\r\n    \u003c/summary\u003e\r\n\r\nVercel is the recommended option for hosting the files since it is free and easy to set up.\r\n\r\n1.  Go to [vercel.com](https://vercel.com/).\r\n2.  Click on `Log in`.\r\n    ![Login page](https://files.catbox.moe/qwqrjn.png)\r\n3.  Sign in with GitHub by pressing `Continue with GitHub`.\r\n    ![Sign in with GitHub](https://files.catbox.moe/18vwjq.png)\r\n4.  Sign in to GitHub and allow access to all repositories if prompted.\r\n5.  [Fork this repo.](https://github.com/montasim/node-express-boilerplate/fork)\r\n6.  Go back to your [Vercel dashboard](https://vercel.com/dashboard).\r\n7.  To import a project, click the `Add New...` button and select the `Project` option.\r\n    ![Add new project](https://files.catbox.moe/h1a87z.png)\r\n8.  Click the `Continue with GitHub` button, search for the required Git Repository and import it by clicking the `Import` button. Alternatively, you can import a Third-Party Git Repository using the `Import Third-Party Git Repository -\u003e` link at the bottom of the page.\r\n    ![Select GitHub project](https://files.catbox.moe/9ubkss.png)\r\n9.  Create a personal access token (PAT) [here](https://github.com/settings/tokens/new) and enable the `repo` and `user` permissions (this allows access to see private repo and user stats).\r\n10. Copy all the .env.development file as environment variables in the Vercel dashboard.\r\n11. Click deploy, and you're good to go. See your domains to use the API!\r\n\u003c/details\u003e\r\n\r\n\u003cbr/\u003e\r\n\r\n[//]: # '7. USED PACKAGES'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=185\u0026height=40\u0026lines=7.+USED+PACKAGES\" alt=\"7. USED PACKAGES\" id=\"7-used-packages\" /\u003e\r\n\r\n\u003cdetails\u003e\r\n    \u003csummary\u003e\r\n        List of used packages:\r\n    \u003c/summary\u003e\r\n\r\n1. `Node.js (v20.x or higher)`: The runtime environment for executing JavaScript on the server side.\r\n2. `Express.js (v4.19.x or higher)`: The web application framework for creating server-side logic.\r\n3. `MongoDB (v6.8.x or higher)`: The NoSQL database for storing and retrieving data.\r\n4. `@googleapis/drive (v8.11.0)`: A library for interacting with Google Drive API.\r\n5. `bcrypt (v5.1.1)`: A library to help you hash passwords.\r\n6. `compression (v1.7.4)`: Middleware to compress response bodies for all requests.\r\n7. `cors (v2.8.5)`: Middleware to enable Cross-Origin Resource Sharing.\r\n8. `dompurify (v3.1.5)`: A library to sanitize HTML to prevent XSS attacks.\r\n9. `dotenv (v16.4.5)`: A module to load environment variables from a .env file.\r\n10. `express-useragent (v1.0.15)`: A user agent middleware for Express.\r\n11. `glob (v10.4.2)`: A library to match files using the patterns the shell uses.\r\n12. `helmet (v7.1.0)`: Middleware to secure Express apps by setting various HTTP headers.\r\n13. `hpp (v0.2.3)`: Middleware to protect against HTTP Parameter Pollution attacks.\r\n14. `jest (v29.7.0)`: A testing framework for JavaScript.\r\n15. `joi (v17.13.3)`: A library for data validation.\r\n16. `jsdom (v24.1.0)`: A library to simulate a web browser environment in Node.js.\r\n17. `jsonwebtoken (v9.0.2)`: A library to sign, verify, and decode JSON Web Tokens.\r\n18. `moment (v2.30.1)`: A library for parsing, validating, manipulating, and formatting dates.\r\n19. `mongodb (v6.8.0)`: MongoDB driver for Node.js.\r\n20. `mongoose (v8.4.4)`: An ODM (Object Data Modeling) library for MongoDB and Node.js.\r\n21. `morgan (v1.10.0)`: HTTP request logger middleware for Node.js.\r\n22. `multer (v1.4.5-lts.1)`: Middleware for handling multipart/form-data, used for file uploads.\r\n23. `node-cache (v5.1.2)`: A caching library for Node.js.\r\n24. `nodemailer (v6.9.14)`: A module for sending emails.\r\n25. `pm2 (v5.4.1)`: A production process manager for Node.js applications.\r\n26. `request-ip (v3.3.0)`: A library to retrieve a request's IP address.\r\n27. `supertest (v7.0.0)`: A library for testing HTTP assertions.\r\n28. `terser (v5.31.1)`: A JavaScript parser, mangler, and compressor toolkit for ES6+.\r\n29. `uuid (v10.0.0)`: A library to generate RFC4122 UUIDs.\r\n30. `winston (v3.13.0)`: A logging library for Node.js.\r\n31. `winston-daily-rotate-file (v5.0.0)`: Transport for winston to log to daily rotated files.\r\n32. `winston-mongodb (v5.1.1)`: Transport for winston to log to a MongoDB collection.\r\n\r\n### Development Dependencies\r\n\r\n1. `@babel/core (v7.24.7)`: The core of Babel, a JavaScript compiler.\r\n2. `@babel/preset-env (v7.24.7)`: A Babel preset to compile ES6+ down to ES5.\r\n3. `eslint (v9.5.0)`: A tool for identifying and reporting on patterns in JavaScript.\r\n4. `jsdoc (v4.0.3)`: A tool for generating documentation from JavaScript source code.\r\n5. `nodemon (v3.1.4)`: A utility that will monitor for any changes in your source and automatically restart your server.\r\n6. `prettier (v3.3.2)`: An opinionated code formatter.\r\n7. `standard-version (v9.5.0)`: A utility for versioning and changelog management.\r\n8. \u003c/details\u003e\r\n\r\n\u003cbr/\u003e\r\n\r\n[//]: # '8. TOOLS'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=85\u0026height=40\u0026lines=8.+TOOLS\" alt=\"8. TOOLS\" id=\"8-tools\" /\u003e\r\n\r\n1. [WebStorm](https://www.jetbrains.com/webstorm/)\r\n2. [Postman](https://www.postman.com/)\r\n3. [Swagify.io](https://swagify.io/convert/)\r\n\r\n\u003cbr/\u003e\r\n\r\n[//]: # '9. ARTICLES'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=115\u0026height=40\u0026lines=9.+ARTICLES\" alt=\"9. ARTICLES\" id=\"9-articles\" /\u003e\r\n\r\n1. [StackOverflow answer on file upload to Google Drive](https://stackoverflow.com/questions/65181932/how-i-can-upload-file-to-google-drive-with-google-drive-api).\r\n\r\n\u003cbr/\u003e\r\n\r\n[//]: # '10. DO NOT FORGET TO DO'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=255\u0026height=40\u0026lines=10.+DO+NOT+FORGET+TO+DO\" alt=\"10. DO NOT FORGET TO DO\" id=\"10-do-not-forget-to-do\" /\u003e\r\n\r\n\u003cbr/\u003e\r\n\r\n[//]: # '11. TUTORIALS'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=135\u0026height=40\u0026lines=11.+TUTORIALS\" alt=\"11. TUTORIALS\" id=\"11-tutorials\" /\u003e\r\n\r\n1. [Google Drive file upload tutorial](https://www.youtube.com/watch?v=bkaQTLCBBeo\u0026t=600s).\r\n\r\n\u003cbr/\u003e\r\n\r\n[//]: # '12. INSPIRATIONS'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=170\u0026height=40\u0026lines=12.+INSPIRATIONS\" alt=\"12. INSPIRATIONS\" id=\"12-inspirations\" /\u003e\r\n\r\n\u003cbr/\u003e\r\n\r\n[//]: # '13. CONTRIBUTE'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=155\u0026height=40\u0026lines=13.+CONTRIBUTE\" alt=\"13. CONTRIBUTE\" id=\"13-contribute\" /\u003e\r\n\r\nContributions are always welcome!\r\nPlease read the [contribution guidelines](CONTRIBUTION.md) and [contributor license agreement](CLA.md).\r\n\r\n\u003cbr/\u003e\r\n\r\n[//]: # '14. CONTRIBUTORS'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=185\u0026height=40\u0026lines=14.+CONTRIBUTORS\" alt=\"14. CONTRIBUTORS\" id=\"14-contributors\" /\u003e\r\n\r\n\u003cimg loading=\"lazy\" src=\"https://badges.pufler.dev/contributors/montasim/node-express-boilerplate?size=50\u0026padding=5\u0026perRow=10\u0026bots=true\" alt=\"contributors\" /\u003e\r\n\r\n\u003cbr/\u003e\r\n\r\n[//]: # '15. SPECIAL THANKS'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=195\u0026height=40\u0026lines=15.+SPECIAL+THANKS\" alt=\"15. SPECIAL THANKS\" id=\"15-special-thanks\" /\u003e\r\n\r\n\u003cbr/\u003e\r\n\r\n[//]: # '16. LICENSE'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=108\u0026height=40\u0026lines=16.+LICENSE\" alt=\"16. LICENSE\" id=\"16-license\" /\u003e\r\n\r\n[![Licence](https://img.shields.io/github/license/Ileriayo/markdown-badges?style=for-the-badge)](./LICENSE)\r\n\r\n\u003cbr/\u003e\r\n\r\n[//]: # '17. CONTACT'\r\n\r\n## \u003cimg loading=\"lazy\" src=\"https://readme-typing-svg.demolab.com?font=Poppins\u0026weight=700\u0026size=20\u0026duration=1\u0026pause=1\u0026color=00B8B5\u0026center=true\u0026vCenter=true\u0026repeat=false\u0026width=130\u0026height=40\u0026lines=17.+CONTACT\" alt=\"17. CONTACT\" id=\"17-contact\" /\u003e\r\n\r\n\u003c!-- social media links start --\u003e\r\n\u003ctable align=\"center\"\u003e\r\n    \u003cthead align=\"center\"\u003e\r\n        \u003ctr\u003e\r\n            \u003cth\u003e\r\n                \u003ca href=\"https://www.linkedin.com/in/montasim\" target=\"_blank\" rel=\"noopener noreferrer\" title=\"linkedin.com/in/montasim\"\u003e\r\n                    \u003cimg loading=\"lazy\" alt=\"linkedin icon\" src=\"https://cdn.simpleicons.org/linkedin/EB008B\" width=\"35px\"\u003e\r\n                \u003c/a\u003e\r\n            \u003c/th\u003e\r\n            \u003cth\u003e\r\n                \u003ca href=\"https://www.github.com/montasim\" target=\"_blank\" rel=\"noopener noreferrer\" title=\"github.com/montasim\"\u003e\r\n                    \u003cimg loading=\"lazy\" alt=\"github icon\" src=\"https://cdn.simpleicons.org/github/EB008B\" width=\"35px\"\u003e\r\n                \u003c/a\u003e\r\n            \u003c/th\u003e\r\n            \u003cth\u003e\r\n                \u003ca href=\"https://stackoverflow.com/users/20348607/montasim\" target=\"_blank\" rel=\"noopener noreferrer\" title=\"stackoverflow.com/users/20348607/montasim\"\u003e\r\n                    \u003cimg loading=\"lazy\" alt=\"github icon\" src=\"https://cdn.simpleicons.org/stackoverflow/EB008B\" width=\"35px\"\u003e\r\n                \u003c/a\u003e\r\n            \u003c/th\u003e\r\n            \u003cth\u003e\r\n                \u003ca href=\"https://montasim-dev.web.app/\" target=\"_blank\" rel=\"noopener noreferrer\" title=\"montasim-dev.web.app\"\u003e\r\n                    \u003cimg loading=\"lazy\" alt=\"web icon\" src=\"https://cdn.simpleicons.org/googlechrome/EB008B\" width=\"35px\"\u003e\r\n                \u003c/a\u003e\r\n            \u003c/th\u003e\r\n            \u003cth\u003e\r\n                \u003ca href=\"mailto:montasimmamun@gmail.com\" target=\"_blank\" rel=\"noopener noreferrer\" title=\"montasimmamun@gmail.com\"\u003e\r\n                    \u003cimg loading=\"lazy\" alt=\"gmail icon\" src=\"https://cdn.simpleicons.org/gmail/EB008B\" width=\"35px\"\u003e\r\n                \u003c/a\u003e\r\n            \u003c/th\u003e\r\n            \u003cth\u003e\r\n                \u003ca href=\"https://www.facebook.com/montasimmamun/\" target=\"_blank\" rel=\"noopener noreferrer\" title=\"facebook.com/montasimmamun\"\u003e\r\n                    \u003cimg loading=\"lazy\" alt=\"facebook icon\" src=\"https://cdn.simpleicons.org/facebook/EB008B\" width=\"35px\"\u003e\r\n                \u003c/a\u003e\r\n            \u003c/th\u003e\r\n            \u003cth\u003e\r\n                \u003ca href=\"https://x.com/montasimmamun\" target=\"_blank\" rel=\"noopener noreferrer\" title=\"https://x.com/montasimmamun\"\u003e\r\n                    \u003cimg loading=\"lazy\" alt=\"x icon\" src=\"https://cdn.simpleicons.org/x/EB008B\" width=\"35px\"\u003e\r\n                \u003c/a\u003e\r\n            \u003c/th\u003e\r\n        \u003c/tr\u003e\r\n    \u003c/thead\u003e\r\n\u003c/table\u003e\r\n\u003c!-- social media links end --\u003e\r\n\r\n\u003cbr/\u003e\r\n\u003cbr/\u003e\r\n\u003cbr/\u003e\r\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmontasim%2Fnode-express-boilerplate","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fmontasim%2Fnode-express-boilerplate","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmontasim%2Fnode-express-boilerplate/lists"}