2024-04-17 21:24:57 -04:00
|
|
|
import { currentUser } from "@clerk/nextjs"
|
|
|
|
import { redirect } from "next/navigation"
|
|
|
|
|
|
|
|
export default async function AppAuthLayout({
|
|
|
|
children,
|
|
|
|
}: {
|
|
|
|
children: React.ReactNode
|
|
|
|
}) {
|
|
|
|
const user = await currentUser()
|
|
|
|
|
|
|
|
if (!user) {
|
|
|
|
redirect("/")
|
|
|
|
}
|
|
|
|
|
2024-04-17 22:55:02 -04:00
|
|
|
const dbUser = await fetch(`http://localhost:8787/api/user?id=${user.id}`)
|
|
|
|
const dbUserJSON = await dbUser.json()
|
2024-04-17 21:24:57 -04:00
|
|
|
|
2024-04-17 22:55:02 -04:00
|
|
|
if (!dbUserJSON?.id) {
|
|
|
|
const res = await fetch("http://localhost:8787/api/user", {
|
|
|
|
method: "POST",
|
|
|
|
headers: {
|
|
|
|
"Content-Type": "application/json",
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
id: user.id,
|
|
|
|
name: user.firstName + " " + user.lastName,
|
|
|
|
email: user.emailAddresses[0].emailAddress,
|
|
|
|
}),
|
|
|
|
})
|
|
|
|
} else {
|
|
|
|
// user already exists in db
|
|
|
|
}
|
2024-04-17 21:24:57 -04:00
|
|
|
|
|
|
|
return <>{children}</>
|
|
|
|
}
|