mirror of
https://github.com/Drop-OSS/drop.git
synced 2025-11-12 07:42:40 +10:00
33 lines
979 B
TypeScript
33 lines
979 B
TypeScript
import aclManager from "~/server/internal/acls";
|
|
import { defineClientEventHandler } from "~/server/internal/clients/event-handler";
|
|
import userLibraryManager from "~/server/internal/userlibrary";
|
|
|
|
export default defineClientEventHandler(async (h3, { fetchUser }) => {
|
|
const user = await fetchUser();
|
|
|
|
const id = getRouterParam(h3, "id");
|
|
if (!id)
|
|
throw createError({
|
|
statusCode: 400,
|
|
statusMessage: "ID required in route params",
|
|
});
|
|
|
|
// Verify collection exists and user owns it
|
|
// Will not return the default collection
|
|
const collection = await userLibraryManager.fetchCollection(id);
|
|
if (!collection)
|
|
throw createError({
|
|
statusCode: 404,
|
|
statusMessage: "Collection not found",
|
|
});
|
|
|
|
if (collection.userId !== user.id)
|
|
throw createError({
|
|
statusCode: 403,
|
|
statusMessage: "Not authorized to delete this collection",
|
|
});
|
|
|
|
await userLibraryManager.deleteCollection(id);
|
|
return { success: true };
|
|
});
|