/Next-Auth-v5

Next-Auth-v5 showcases the implementation of authentication and various key features using Next.js 14, NextAuth v5, TypeScript, Tailwind CSS, Shadcn UI, Prisma, and MongoDB.

Primary LanguageTypeScript

Next.js NextAuth Project

Welcome to the Next.js NextAuth project! This project showcases the implementation of authentication and various key features using Next.js 14, NextAuth v5, Tailwind CSS, Shadcn UI, Prisma, and MongoDB.

Prerequisites

Before you begin, ensure you have the following installed:

Getting Started

  1. Clone the repository:

    git clone git@github.com:diwashbhattarai999/Next-Auth-v5.git
    
  2. Change into the project directory:

    cd next-auth-v5
    
  3. Install dependencies:

    npm install
    
  4. Set up environment variables in .env file at root directory:

    DATABASE_URL=your-mongodb-url
    GOOGLE_CLIENT_ID=your-google-client-id
    GOOGLE_CLIENT_SECRET=your-google-client-secret
    GITHUB_CLIENT_ID=your-github-client-id
    GITHUB_CLIENT_SECRET=your-github-client-secret
    NEXTAUTH_URL=http://localhost:3000
    AUTH_SECRET=your-auth-secret-token
    RESEND_API_KEY=your-resend-api-key
    
  5. Run the development server:

    npm run dev
    
  6. Open your browser and navigate to http://localhost:3000 to view the project.

Tech Stack

  • Next.js 14: The foundation for building React applications with server-side rendering and more.
  • Tailwind CSS: A utility-first CSS framework for building modern designs.
  • Shadcn UI: A UI component library for Next.js.
  • Prisma: A modern database toolkit for TypeScript and Node.js.
  • MongoDB: A NoSQL database for storing user data.

Key Features

Key Features

  • 🔐 Authentication:

    • Next-auth v5 (Auth.js)
    • Credentials Provider
    • OAuth Provider (Google & GitHub)
  • 🔒 Security:

    • Forgot password functionality
    • Email verification
    • Two-factor verification (2FA)
  • 👥 User Management:

    • User roles (Admin & User)
    • Flexible login (Redirect or Modal)
    • Register, Forgot Password, Verification components
  • 🧩 Components & Utilities:

    • Reusable Login and Logout buttons
    • Role Gate for access control
    • Middleware, session, and callback exploration
    • Hooks: useCurrentUser, useRole
    • Utilities: currentUser, currentRole
  • 🌐 Examples & Demonstrations:

    • Server and client-side rendering examples
    • Render content based on roles
    • Protect API routes and server actions
  • ⚙️ Settings Page Functionality:

    • Change email with new verification
    • Change password with old password confirmation
    • Enable/disable 2FA
    • Change user role (for development)

Feel free to explore each feature and adapt the project to suit your specific needs. Happy coding!

Live Demo

The application is deployed on here.

Author

Credits

This project was built by following a tutorial from Code with Antonio