Auth System Starter with Passport.js, JWT, Role-Based Access, and Social Logins
Welcome to the Auth System Starterβan open-source, feature-rich authentication boilerplate built with Node.js, Express.js, and MongoDB. This project supports multiple authentication methods (including manual signup/login with JWT and social logins using Passport.js), role-based access control, email verification, and more.
This repository is a perfect starting point for developers looking to implement authentication in their applications quickly. Feel free to contribute, fine-tune, and customize as per your needs!
Features
- π Authentication Options:
- Manual login/signup with JWT.
- Social logins with Google, Facebook, GitHub, and Apple ID.
- π‘ Role-Based Access Control (RBAC):
- Create and manage custom roles.
- Assign multiple roles to users.
- π§ Email Verification:
- Secure email verification using NodeMailer.
- π Secure Password Storage:
- π Modular Project Structure:
- Controllers for business logic, helpers for utilities.
- π Swagger Documentation:
- API routes fully documented for easy integration.
- π Scalable and Open Source:
- Designed for extensibility and contributions from the community.
Project Structure
Hereβs an organized project structure to help you navigate the codebase:
π auth-system-starter
βββ π config
β βββ db.js # MongoDB connection setup
β βββ passport.js # Passport strategies configuration
βββ π controllers
β βββ authController.js # Handles authentication logic
β βββ userController.js # Manages user-related actions
βββ π helpers
β βββ sendEmail.js # Email utility for sending emails
βββ π middlewares
β βββ authMiddleware.js # Middleware for role-based access and JWT validation
βββ π models
β βββ User.js # Mongoose schema for User
β βββ Role.js # Mongoose schema for Role
βββ π routes
β βββ authRoutes.js # Routes for authentication and authorization
β βββ userRoutes.js # Routes for user management
βββ π utils
β βββ swagger.js # Swagger setup for API documentation
βββ .env.example # Environment variables
βββ README.md # Project documentation
βββ package.json # Project dependencies and scripts
βββ index.js # Entry point of the application
Getting Started
Follow these steps to get this project up and running:
1. Create Project
npx create-express-auth-starter
2. Install Dependencies
Install using your preferred package manager:
npm install
# or
yarn install
# or
pnpm install
3. Set Environment Variables
Create a .env
file in the project root and add the following:
PORT=5000
MONGO_URI=your-mongodb-connection-string
JWT_SECRET=your-jwt-secret
EMAIL_USER=your-email@example.com
EMAIL_PASSWORD=your-email-password
GOOGLE_CLIENT_ID=your-google-client-id
GOOGLE_CLIENT_SECRET=your-google-client-secret
FACEBOOK_CLIENT_ID=your-facebook-client-id
FACEBOOK_CLIENT_SECRET=your-facebook-client-secret
GITHUB_CLIENT_ID=your-github-client-id
GITHUB_CLIENT_SECRET=your-github-client-secret
APPLE_CLIENT_ID=your-apple-client-id
APPLE_CLIENT_SECRET=your-apple-client-secret
CLIENT_URL=http://localhost:3000 # Replace with your frontend URL
4. Get Google ENVs
- Go to https://console.cloud.google.com/apis/dashboard
- Click on create New Project
data:image/s3,"s3://crabby-images/a1a0d/a1a0d7074349057cdd1e89d615f709205f6f3ddd" alt="Image"
- Give a name
data:image/s3,"s3://crabby-images/df3e5/df3e55a3984b0ed734653df1e3a624db1ec12d6f" alt="Image"
- Go to the project's dashboard using this dropdown
data:image/s3,"s3://crabby-images/56486/564860acc7b0964984065704d970179ee0b76c0e" alt="Image"
- Go to Library Section and search for Google People API and enable it
data:image/s3,"s3://crabby-images/f4851/f4851b70bef21e253bc5a4df0d643b346a93a393" alt="Image"
- Go to the credentials and click on create credentials
data:image/s3,"s3://crabby-images/38b54/38b54a07e8815ddcd8c87ca5e96855f15ba67cc6" alt="Image"
- Click on OAuth Client ID and then on Configure Consent Screen
data:image/s3,"s3://crabby-images/5c4d3/5c4d35bd3f4a53305c81e6a9a9ffa964c5a1e2fe" alt="Image"
- Click on External and then create
data:image/s3,"s3://crabby-images/91330/913309d2d2f4c6eb45cc10df8d33fbaf90591e50" alt="Image"
- Configure your app
data:image/s3,"s3://crabby-images/30015/30015abfe73dda6a72bee2753dee13a78b4a00f3" alt="Image"
- Once set Now go to the same Create OAuth Client ID Again this time you will be able to create the application
data:image/s3,"s3://crabby-images/068e1/068e1358747455920c646984b1548ff235d0b4b8" alt="Image"
- Add the redirect url as given
data:image/s3,"s3://crabby-images/c7eca/c7eca6e1e3f6e88bc72d98eeebb0a12e513b0708" alt="Image"
- Now Copy and Paste
data:image/s3,"s3://crabby-images/1ba5c/1ba5cc34f359ef4a44280c8156dc6da7cfaa1e3c" alt="Image"
- You can hit the google auth by GET Request over http://localhost:5000/api/auth/google
5. Get Github ENVs
6. Get Facebook ENVs
7. Start the Server in development mode
npm run dev
# or
yarn dev
# or
pnpm run dev
The server will start on http://localhost:5000
.
Swagger API Documentation
The API documentation is available at:
http://localhost:5000/api-docs
Swagger is pre-configured to provide an interactive interface for testing and understanding the API endpoints.
Contributing
We welcome contributions to improve this project! Hereβs how you can help:
- Fork this repository.
- Create a feature branch (
git checkout -b feature-name
).
- Commit your changes (
git commit -m "Add feature"
).
- Push to the branch (
git push origin feature-name
).
- Open a pull request.
Publishing as an NPM, PNPM, or Yarn Package
To make this project available to the public as a package:
1. Prepare for Publishing
- Ensure
package.json
has the relevant metadata:
{
"name": "auth-system-starter",
"version": "1.0.0",
"description": "A starter project for authentication with Passport.js, JWT, and role-based access control.",
"main": "server.js",
"keywords": ["authentication", "passport.js", "jwt", "nodejs", "express"],
"author": "Faraz Ahmad <farazahmad31048@gmail.com>",
"license": "MIT"
}
License
This project is licensed under the MIT License. Feel free to use, modify, and distribute it.
Community
- π Star this repository to show your support.
- π¬ Join discussions and share your ideas or issues.
- π Contribute to make it even better.
Letβs build amazing applications together! π