53 lines
1.5 KiB
TypeScript
Raw Normal View History

2024-05-05 14:33:09 -07:00
import { colors } from "@/lib/colors"
2024-05-03 13:53:21 -07:00
import { User } from "@/lib/types"
import { currentUser } from "@clerk/nextjs"
import { Liveblocks } from "@liveblocks/node"
import { NextRequest } from "next/server"
const API_KEY = process.env.LIVEBLOCKS_SECRET_KEY!
const liveblocks = new Liveblocks({
secret: API_KEY!,
})
export async function POST(request: NextRequest) {
const clerkUser = await currentUser()
if (!clerkUser) {
return new Response("Unauthorized", { status: 401 })
}
const res = await fetch(
`https://database.ishaan1013.workers.dev/api/user?id=${clerkUser.id}`
)
2024-05-03 13:53:21 -07:00
const user = (await res.json()) as User
2024-05-05 14:33:09 -07:00
const colorNames = Object.keys(colors)
const randomColor = colorNames[
Math.floor(Math.random() * colorNames.length)
] as keyof typeof colors
const code = colors[randomColor]
2024-05-03 13:53:21 -07:00
// Create a session for the current user
// userInfo is made available in Liveblocks presence hooks, e.g. useOthers
const session = liveblocks.prepareSession(user.id, {
userInfo: {
name: user.name,
email: user.email,
2024-05-05 14:33:09 -07:00
color: randomColor,
2024-05-03 13:53:21 -07:00
},
})
// Give the user access to the room
user.sandbox.forEach((sandbox) => {
session.allow(`${sandbox.id}`, session.FULL_ACCESS)
})
user.usersToSandboxes.forEach((userToSandbox) => {
session.allow(`${userToSandbox.sandboxId}`, session.FULL_ACCESS)
})
// Authorize the user and return the result
const { body, status } = await session.authorize()
return new Response(body, { status })
}