42 lines
1.1 KiB
TypeScript
42 lines
1.1 KiB
TypeScript
import { GetServerSidePropsContext } from 'next'
|
|
import { User } from '@typebot.io/prisma'
|
|
import { isNotDefined } from '@typebot.io/lib'
|
|
import { sign } from 'jsonwebtoken'
|
|
import { getServerSession } from 'next-auth'
|
|
import { authOptions } from './api/auth/[...nextauth]'
|
|
import { env } from '@typebot.io/env'
|
|
|
|
export default function Page() {
|
|
return null
|
|
}
|
|
|
|
export async function getServerSideProps(context: GetServerSidePropsContext) {
|
|
const session = await getServerSession(context.req, context.res, authOptions)
|
|
if (isNotDefined(session?.user))
|
|
return {
|
|
redirect: {
|
|
permanent: false,
|
|
destination: `/signin?redirectPath=%2Ffeedback`,
|
|
},
|
|
}
|
|
const sleekplanToken = createSSOToken(session?.user as User)
|
|
return {
|
|
redirect: {
|
|
permanent: false,
|
|
destination: `https://feedback.typebot.io?sso=${sleekplanToken}`,
|
|
},
|
|
}
|
|
}
|
|
|
|
const createSSOToken = (user: User) => {
|
|
if (!env.SLEEKPLAN_SSO_KEY) return
|
|
const userData = {
|
|
mail: user.email,
|
|
id: user.id,
|
|
name: user.name,
|
|
img: user.image,
|
|
}
|
|
|
|
return sign(userData, env.SLEEKPLAN_SSO_KEY, { algorithm: 'HS256' })
|
|
}
|