nextauthjs

    nextauthjs/next-auth

    #994 this week

    Authentication for the Web.

    authentication
    web
    backend
    frontend
    auth
    csrf
    jwt
    nextauth
    nextjs
    TypeScript
    ISC
    28.2K stars
    4.0K forks
    28.2K GitHub watchers
    Updated 5/4/2026
    View on GitHub

    Backblaze Generative Media Hackathon

    Build the next generation of AI media apps with Genblaze, stored on Backblaze B2. $10,000 in prizes.

    Enter the hackathon

    Loading star history...

    Use Cases & Benefits

    • NextAuth.js provides flexible, full-stack authentication for web applications supporting OAuth 2.0+, OIDC, email/passwordless, and passkeys.
    • Built with TypeScript, it supports many databases and frameworks like Next.js, React, Nuxt, and SvelteKit, running in any JS runtime.
    • Strengths include strong security defaults, encrypted JWTs, CSRF protection, and session management; limitations may include complexity for custom setups.
    • Organizations can use it to implement secure, scalable authentication while retaining full control over user data and infrastructure.
    • Ideal for modern web apps needing robust, extensible authentication with support for multiple providers and passwordless sign-in.

    About next-auth

    [!NOTE] The Auth.js/NextAuth.js project is not provided by, nor otherwise affiliated with Vercel Inc. or its subsidiaries. Any contributions to this project by individuals affiliated with Vercel are made in their personal capacity.


    Auth.js

    Authentication for the Web.

    Open Source. Full Stack. Own Your Data.

    X (formerly known Twitter) NPM next-auth@latest release NPM next-auth@beta release Downloads GitHub Stars TypeScript

    Auth.js is a set of open-source packages that are built on standard Web APIs for authentication in modern applications with any framework on any platform in any JS runtime.

    Need help? See authjs.dev for the documentation, or join our community on Discord  TypeScript .

    Sponsored Looking for a hosted alternative? Use Clerk →

    Features

    Flexible and easy to use

    • Designed to work with any OAuth service, it supports 2.0+, OIDC
    • Built-in support for many popular sign-in services
    • Email/Passwordless authentication
    • Passkeys/WebAuthn support
    • Bring Your Database - or none! - stateless authentication with any backend (Active Directory, LDAP, etc.)
    • Runtime-agnostic, runs anywhere! (Docker, Node.js, Serverless, etc.)

    Own your data

    Auth.js can be used with or without a database.

    Secure by default

    • Promotes the use of passwordless sign-in mechanisms
    • Designed to be secure by default and encourage best practices for safeguarding user data
    • Uses Cross-Site Request Forgery (CSRF) Tokens on POST routes (sign in, sign out)
    • Default cookie policy aims for the most restrictive policy appropriate for each cookie
    • When JSON Web Tokens are used, they are encrypted by default (JWE) with A256CBC-HS512
    • Features tab/window syncing and session polling to support short-lived sessions
    • Attempts to implement the latest guidance published by Open Web Application Security Project

    Advanced configuration allows you to define your routines to handle controlling what accounts are allowed to sign in, for encoding and decoding JSON Web Tokens and to set custom cookie security policies and session properties, so you can control who can sign in and how often sessions have to be re-validated.

    TypeScript

    Auth.js libraries are written with type safety in mind. Check out the docs for more information.

    Security

    If you think you have found a vulnerability (or are not sure) in Auth.js or any of the related packages (i.e. Adapters), we ask you to read our Security Policy to reach out responsibly. Please do not open Pull Requests/Issues/Discussions before consulting with us.

    Acknowledgments

    Auth.js is made possible thanks to all of its contributors.

    Sponsors

    We have an OpenCollective for companies and individuals looking to contribute financially to the project!

    Clerk Logo
    Clerk
    💵
    Auth0 Logo
    Auth0
    💵
    FusionAuth Logo
    FusionAuth
    💵
    Stytch Logo
    Stytch
    💵
    Prisma Logo
    Prisma
    💵
    Neon Logo
    Neon
    💵
    Beyond Identity Logo
    Beyond Identity
    💵
    Lowdefy Logo
    Lowdefy
    💵
    Descope Logo
    Descope
    💵
    Badass Courses Logo
    Badass Courses
    💵
    Encore Logo
    Encore
    💵
    Sent.dm Logo
    Sent.dm
    💵
    Arcjet Logo
    Arcjet
    💵
    Route4Me Logo
    Route4Me
    💵
    Netlight logo
    Netlight
    ☁️
    Checkly Logo
    Checkly
    ☁️
    superblog Logo
    superblog
    ☁️
    Vercel Logo
    Vercel
    ☁️
    • 💵 Financial Sponsor
    • ☁️ Infrastructure Support

    Contributing

    We're open to all community contributions! If you'd like to contribute in any way, please first read our Contributing Guide.

    [!NOTE] The Auth.js/NextAuth.js project is not provided by, nor otherwise affiliated with Vercel Inc. or its subsidiaries. Any contributions to this project by individuals affiliated with Vercel are made in their personal capacity.

    License

    ISC

    Discover Repositories

    Search across tracked repositories by name or description