CoastalCommitsPastes/client/lib/server/auth.ts

62 lines
1.4 KiB
TypeScript
Raw Normal View History

import { PrismaAdapter } from "@next-auth/prisma-adapter"
import { NextAuthOptions } from "next-auth"
import GitHubProvider from "next-auth/providers/github"
import { prisma } from "@lib/server/prisma"
import config from "@lib/config"
const providers: NextAuthOptions["providers"] = [
GitHubProvider({
2022-11-14 19:00:21 -08:00
clientId: config.github_client_id,
clientSecret: config.github_client_secret,
2022-11-12 00:58:21 -08:00
})
]
export const authOptions: NextAuthOptions = {
// see https://github.com/prisma/prisma/issues/16117 / https://github.com/shadcn/taxonomy
adapter: PrismaAdapter(prisma as any),
session: {
strategy: "jwt"
},
pages: {
signIn: "/signin"
},
providers,
callbacks: {
async session({ token, session }) {
if (token) {
session.user.id = token.id
session.user.name = token.name
session.user.email = token.email
session.user.image = token.picture
session.user.role = token.role
}
return session
},
async jwt({ token, user }) {
const dbUser = await prisma.user.findFirst({
where: {
email: token.email
}
})
if (!dbUser) {
2022-11-12 00:58:21 -08:00
// TODO: user should be defined? should we invalidate/signout?
if (user) {
token.id = user.id
token.role = "user"
}
return token
}
return {
id: dbUser.id,
2022-11-14 18:39:42 -08:00
name: dbUser.displayName,
email: dbUser.email,
picture: dbUser.image,
2022-11-17 22:36:53 -08:00
role: dbUser.role || "user"
}
}
}
} as const