mirror of
https://github.com/SrIzan10/next-auth.git
synced 2026-05-01 10:55:20 +00:00
119 lines
4.6 KiB
JavaScript
119 lines
4.6 KiB
JavaScript
import NextAuth from 'next-auth'
|
|
import Providers from 'next-auth/providers'
|
|
|
|
// For more information on each option (and a full list of options) go to
|
|
// https://next-auth.js.org/configuration/options
|
|
const options = {
|
|
// https://next-auth.js.org/configuration/providers
|
|
providers: [
|
|
Providers.Email({
|
|
server: process.env.NEXTAUTH_EMAIL_SERVER,
|
|
from: process.env.NEXTAUTH_EMAIL_FROM
|
|
}),
|
|
Providers.Apple({
|
|
clientId: process.env.NEXTAUTH_APPLE_ID,
|
|
clientSecret: {
|
|
appleId: process.env.NEXTAUTH_APPLE_ID,
|
|
teamId: process.env.NEXTAUTH_APPLE_TEAM_ID,
|
|
privateKey: process.env.NEXTAUTH_APPLE_PRIVATE_KEY,
|
|
keyId: process.env.NEXTAUTH_APPLE_KEY_ID
|
|
}
|
|
}),
|
|
Providers.Auth0({
|
|
clientId: process.env.NEXTAUTH_AUTH0_ID,
|
|
clientSecret: process.env.NEXTAUTH_AUTH0_SECRET,
|
|
domain: process.env.NEXTAUTH_AUTH0_DOMAIN
|
|
}),
|
|
Providers.Facebook({
|
|
clientId: process.env.NEXTAUTH_FACEBOOK_ID,
|
|
clientSecret: process.env.NEXTAUTH_FACEBOOK_SECRET
|
|
}),
|
|
Providers.GitHub({
|
|
clientId: process.env.NEXTAUTH_GITHUB_ID,
|
|
clientSecret: process.env.NEXTAUTH_GITHUB_SECRET
|
|
}),
|
|
Providers.Google({
|
|
clientId: process.env.NEXTAUTH_GOOGLE_ID,
|
|
clientSecret: process.env.NEXTAUTH_GOOGLE_SECRET
|
|
}),
|
|
Providers.Twitter({
|
|
clientId: process.env.NEXTAUTH_TWITTER_ID,
|
|
clientSecret: process.env.NEXTAUTH_TWITTER_SECRET
|
|
})
|
|
],
|
|
// Database optional. MySQL, Maria DB, Postgres and MongoDB are supported.
|
|
// https://next-auth.js.org/configuration/database
|
|
//
|
|
// Notes:
|
|
// * You must to install an appropriate node_module for your database
|
|
// * The Email provider requires a database (OAuth providers do not)
|
|
database: process.env.NEXTAUTH_DATABASE_URL,
|
|
|
|
// The secret should be set to a reasonably long random string.
|
|
// It is used to sign cookies and to sign and encrypt JSON Web Tokens, unless
|
|
// a seperate secret is defined explicitly for encrypting the JWT.
|
|
secret: process.env.NEXTAUTH_SECRET,
|
|
|
|
session: {
|
|
// Use JSON Web Tokens for session instead of database sessions.
|
|
// This option can be used with or without a database for users/accounts.
|
|
// Note: `jwt` is automatically set to `true` if no database is specified.
|
|
jwt: true
|
|
|
|
// Seconds - How long until an idle session expires and is no longer valid.
|
|
// maxAge: 30 * 24 * 60 * 60, // 30 days
|
|
|
|
// Seconds - Throttle how frequently to write to database to extend a session.
|
|
// Use it to limit write operations. Set to 0 to always update the database.
|
|
// Note: This option is ignored if using JSON Web Tokens
|
|
// updateAge: 24 * 60 * 60, // 24 hours
|
|
},
|
|
|
|
// JSON Web tokens are only used for sessions if the `jwt: true` session
|
|
// option is set - or by default if no database is specified.
|
|
// https://next-auth.js.org/configuration/options#jwt
|
|
jwt: {
|
|
// A secret to use for key generation (you should set this explicitly)
|
|
// secret: 'INp8IvdIyeMcoGAgFGoA61DdBglwwSqnXJZkgz8PSnw',
|
|
|
|
// Set to true to use encryption (default: false)
|
|
// encryption: true,
|
|
|
|
// You can define your own encode/decode functions for signing and encryption
|
|
// if you want to override the default behaviour.
|
|
// async encode({ secret, token, maxAge }) {},
|
|
// async decode({ secret, token, maxAge }) {},
|
|
},
|
|
|
|
// You can define custom pages to override the built-in pages.
|
|
// The routes shown here are the default URLs that will be used when a custom
|
|
// pages is not specified for that route.
|
|
// https://next-auth.js.org/configuration/pages
|
|
pages: {
|
|
// signIn: '/api/auth/signin', // Displays signin buttons
|
|
// signOut: '/api/auth/signout', // Displays form with sign out button
|
|
// error: '/api/auth/error', // Error code passed in query string as ?error=
|
|
// verifyRequest: '/api/auth/verify-request', // Used for check email page
|
|
// newUser: null // If set, new users will be directed here on first sign in
|
|
},
|
|
|
|
// Callbacks are asynchronous functions you can use to control what happens
|
|
// when an action is performed.
|
|
// https://next-auth.js.org/configuration/callbacks
|
|
callbacks: {
|
|
// async signIn(user, account, profile) { return Promise.resolve(true) },
|
|
// async redirect(url, baseUrl) { return Promise.resolve(baseUrl) },
|
|
// async session(session, user) { return Promise.resolve(session) },
|
|
// async jwt(token, user, account, profile, isNewUser) { return Promise.resolve(token) }
|
|
},
|
|
|
|
// Events are useful for logging
|
|
// https://next-auth.js.org/configuration/events
|
|
events: { },
|
|
|
|
// Enable debug messages in the console if you are having problems
|
|
debug: false
|
|
}
|
|
|
|
export default (req, res) => NextAuth(req, res, options)
|