187 lines
4.5 KiB
TypeScript
Raw Normal View History

2024-05-26 12:18:09 -07:00
"use server"
2024-05-26 12:18:09 -07:00
import { revalidatePath } from "next/cache"
import { z } from "zod"
export async function createSandbox(body: {
2024-05-26 12:18:09 -07:00
type: string
name: string
userId: string
visibility: string
}) {
const res = await fetch(
2024-05-26 18:37:36 -07:00
`${process.env.NEXT_PUBLIC_DATABASE_WORKER_URL}/api/sandbox`,
{
method: "PUT",
headers: {
"Content-Type": "application/json",
2024-05-26 18:37:36 -07:00
Authorization: `${process.env.NEXT_PUBLIC_WORKERS_KEY}`,
},
body: JSON.stringify(body),
}
2024-05-26 12:18:09 -07:00
)
2024-04-27 16:22:35 -04:00
2024-05-26 12:18:09 -07:00
return await res.text()
}
export async function updateSandbox(body: {
2024-05-26 12:18:09 -07:00
id: string
name?: string
visibility?: "public" | "private"
}) {
2024-05-26 18:37:36 -07:00
await fetch(`${process.env.NEXT_PUBLIC_DATABASE_WORKER_URL}/api/sandbox`, {
method: "POST",
headers: {
"Content-Type": "application/json",
2024-05-26 18:37:36 -07:00
Authorization: `${process.env.NEXT_PUBLIC_WORKERS_KEY}`,
},
body: JSON.stringify(body),
2024-05-26 12:18:09 -07:00
})
2024-05-26 12:18:09 -07:00
revalidatePath("/dashboard")
}
export async function deleteSandbox(id: string) {
2024-05-26 18:37:36 -07:00
await fetch(
`${process.env.NEXT_PUBLIC_DATABASE_WORKER_URL}/api/sandbox?id=${id}`,
{
method: "DELETE",
headers: {
Authorization: `${process.env.NEXT_PUBLIC_WORKERS_KEY}`,
},
}
)
2024-05-26 12:18:09 -07:00
revalidatePath("/dashboard")
}
2024-05-01 01:29:16 -04:00
export async function shareSandbox(sandboxId: string, email: string) {
const res = await fetch(
2024-05-26 18:37:36 -07:00
`${process.env.NEXT_PUBLIC_DATABASE_WORKER_URL}/api/sandbox/share`,
{
method: "POST",
headers: {
"Content-Type": "application/json",
2024-05-26 18:37:36 -07:00
Authorization: `${process.env.NEXT_PUBLIC_WORKERS_KEY}`,
},
body: JSON.stringify({ sandboxId, email }),
}
2024-05-26 12:18:09 -07:00
)
const text = await res.text()
2024-05-01 01:53:49 -04:00
if (res.status !== 200) {
2024-05-26 12:18:09 -07:00
return { success: false, message: text }
2024-05-01 01:29:16 -04:00
}
2024-05-01 01:53:49 -04:00
2024-05-26 12:18:09 -07:00
revalidatePath(`/code/${sandboxId}`)
return { success: true, message: "Shared successfully." }
2024-05-01 01:29:16 -04:00
}
2024-05-01 02:22:02 -04:00
export async function unshareSandbox(sandboxId: string, userId: string) {
2024-05-26 18:37:36 -07:00
await fetch(
`${process.env.NEXT_PUBLIC_DATABASE_WORKER_URL}/api/sandbox/share`,
{
method: "DELETE",
headers: {
"Content-Type": "application/json",
Authorization: `${process.env.NEXT_PUBLIC_WORKERS_KEY}`,
},
body: JSON.stringify({ sandboxId, userId }),
}
)
2024-05-01 02:22:02 -04:00
2024-05-26 12:18:09 -07:00
revalidatePath(`/code/${sandboxId}`)
2024-05-17 23:18:15 -07:00
}
export async function toggleLike(sandboxId: string, userId: string) {
await fetch(
`${process.env.NEXT_PUBLIC_DATABASE_WORKER_URL}/api/sandbox/like`,
{
method: "POST",
headers: {
"Content-Type": "application/json",
Authorization: `${process.env.NEXT_PUBLIC_WORKERS_KEY}`,
},
body: JSON.stringify({ sandboxId, userId }),
}
)
revalidatePath(`/[username]`, "page")
revalidatePath(`/dashboard`, "page")
}
const UpdateErrorSchema = z.object({
error: z
.union([
z.string(),
z.array(
z.object({
path: z.array(z.string()),
message: z.string(),
})
),
])
.optional(),
})
export async function updateUser(prevState: any, formData: FormData) {
const data = Object.fromEntries(formData)
const schema = z.object({
id: z.string(),
username: z.string(),
oldUsername: z.string(),
name: z.string(),
})
console.log(data)
try {
const validatedData = schema.parse(data)
const changedUsername = validatedData.username !== validatedData.oldUsername
const res = await fetch(
`${process.env.NEXT_PUBLIC_DATABASE_WORKER_URL}/api/user`,
{
method: "PUT",
headers: {
"Content-Type": "application/json",
Authorization: `${process.env.NEXT_PUBLIC_WORKERS_KEY}`,
},
body: JSON.stringify({
id: validatedData.id,
username: data.username ?? undefined,
name: data.name ?? undefined,
}),
}
)
const responseData = await res.json()
// Validate the response using our error schema
const parseResult = UpdateErrorSchema.safeParse(responseData)
if (!parseResult.success) {
return { error: "Unexpected error occurred" }
}
if (parseResult.data.error) {
return parseResult.data
}
if (changedUsername) {
const newRoute = `/@${validatedData.username}`
return { message: "Successfully updated", newRoute }
}
revalidatePath(`/[username]`, "page")
return { message: "Successfully updated" }
} catch (error) {
if (error instanceof z.ZodError) {
console.log(error)
return {
error: error.errors?.[0].message,
}
}
return { error: "An unexpected error occurred" }
}
}