Spaces:
Running
Running
| import NextAuth, { type DefaultSession } from 'next-auth'; | |
| import GitHub from 'next-auth/providers/github'; | |
| import Google from 'next-auth/providers/google'; | |
| declare module 'next-auth' { | |
| interface Session { | |
| user: { | |
| /** The user's id. */ | |
| id: string; | |
| } & DefaultSession['user']; | |
| } | |
| } | |
| const restrictedPath = ['/project']; | |
| export const { | |
| handlers: { GET, POST }, | |
| auth, | |
| } = NextAuth({ | |
| providers: [ | |
| GitHub, | |
| Google({ | |
| clientId: process.env.GOOGLE_CLIENT_ID!, | |
| clientSecret: process.env.GOOGLE_SECRET!, | |
| }), | |
| ], | |
| callbacks: { | |
| // signIn({ profile }) { | |
| // if (profile?.email?.endsWith('@landing.ai')) { | |
| // return !!profile; | |
| // } else { | |
| // return '/unauthorized'; | |
| // } | |
| // }, | |
| jwt({ token, profile }) { | |
| if (profile) { | |
| token.id = profile.id || profile.sub; | |
| token.image = profile.avatar_url || profile.picture; | |
| } | |
| return token; | |
| }, | |
| session: ({ session, token }) => { | |
| if (session?.user && token?.id) { | |
| session.user.id = String(token.id); | |
| } | |
| return session; | |
| }, | |
| authorized({ request, auth }) { | |
| const isAdmin = !!auth?.user?.email?.endsWith('landing.ai'); | |
| return restrictedPath.find(path => | |
| request.nextUrl.pathname.startsWith(path), | |
| ) | |
| ? isAdmin | |
| : true; | |
| }, | |
| }, | |
| pages: { | |
| signIn: '/sign-in', // overrides the next-auth default signin page https://authjs.dev/guides/basics/pages | |
| }, | |
| }); | |
| export async function authEmail() { | |
| const session = await auth(); | |
| const email = session?.user?.email; | |
| return { email, isAdmin: !!email?.endsWith('landing.ai') }; | |
| } | |