This repository provides a production-grade backend template for Node.js applications using Express.js and MongoDB. It includes a foundational structure, environment configuration, and a basic User model to help jump start backend development.
- Production-Grade Setup: Configured for scalability, security, and performance.
- Express.js: Minimalist web framework for routing and middleware.
- MongoDB: Integrated with Mongoose ORM for schema management and database operations.
- User Model: Pre-configured with basic fields like
name
,email
, andpassword
. - Prettier: Code formatting with custom rules for maintaining code consistency.
- Environment Configuration:
.env
file for secure storage of sensitive data (e.g., database credentials, API keys). - Git Best Practices:
.gitignore
for keeping sensitive files out of version control.
Backend-Template/
├── public/ # Public assets (if any)
│ └── temp/ # Temporary files or uploads
├── src/ # Main application code
│ ├── controllers/ # Route controllers (business logic)
│ ├── models/ # Mongoose models (database schema)
│ ├── routes/ # Route definitions (API endpoints)
│ ├── middlewares/ # Custom middleware (e.g., authentication)
│ ├── config/ # Configuration files (e.g., database setup)
│ ├── services/ # Service logic (e.g., external API calls, utilities)
│ └── app.js # Main application file
├── .env # Environment variables
├── .gitignore # Ignored files for version control
├── .prettierignore # Files ignored by Prettier
├── .prettierrc # Prettier configuration
├── package.json # Project dependencies and scripts
├── package-lock.json # Lockfile for consistent dependency versions
└── README.md # Project documentation
- Node.js (v14 or later)
- MongoDB (local or cloud instance)
- Environment variables configured in a
.env
file
Create a .env
file in the root directory and add the following:
# Example .env file
PORT=Your Port
MONGODB_URL=MongoDB URL
CORS_ORIGIN=*
ACCESS_TOKEN_SECRET=Darshan Vasani
ACCESS_TOKEN_EXPIRY=1d
REFRESH_TOKEN_SECRET=Backend
REFRESH_TOKEN_EXPIRY=10d
CLOUDINARY_CLOUD_NAME=
CLOUDINARY_API_KEY=
CLOUDINARY_API_SECRET=
-
Clone the repository:
git clone /~https://github.com/dpvasani/Backend-Template.git cd Backend-Template
-
Install dependencies:
npm install
-
Set up your MongoDB connection in the
.env
file. -
Start the server:
npm run dev
Feel free to open issues or create pull requests if you have suggestions for improvements!
This project is licensed under the MIT License.