import { NextAuthOptions } from 'next-auth'; import CredentialsProvider from 'next-auth/providers/credentials'; import GoogleProvider from 'next-auth/providers/google'; import { PrismaAdapter } from '@auth/prisma-adapter'; import { db } from './db'; import { comparePassword } from './hash'; export const authOptions: NextAuthOptions = { adapter: PrismaAdapter(db) as any, session: { strategy: 'jwt', }, providers: [ CredentialsProvider({ name: 'credentials', credentials: { email: { label: 'Email', type: 'email' }, password: { label: 'Password', type: 'password' }, }, async authorize(credentials) { if (!credentials?.email || !credentials?.password) { return null; } const user = await db.user.findUnique({ where: { email: credentials.email }, }); if (!user || !user.password) { return null; } const isPasswordValid = await comparePassword( credentials.password, user.password ); if (!isPasswordValid) { return null; } return { id: user.id, email: user.email, name: user.name, }; }, }), ...(process.env.GOOGLE_CLIENT_ID && process.env.GOOGLE_CLIENT_SECRET ? [ GoogleProvider({ clientId: process.env.GOOGLE_CLIENT_ID, clientSecret: process.env.GOOGLE_CLIENT_SECRET, }), ] : []), ], callbacks: { async jwt({ token, user }) { if (user) { token.id = user.id; } return token; }, async session({ session, token }) { if (session?.user) { session.user.id = token.id as string; } return session; }, }, pages: { signIn: '/login', error: '/login', }, secret: process.env.NEXTAUTH_SECRET, };