Files
drop/server/api/v1/collection/[id]/index.get.ts
2025-09-20 11:21:53 +10:00

37 lines
975 B
TypeScript

import aclManager from "~~/server/internal/acls";
import userLibraryManager from "~~/server/internal/userlibrary";
export default defineEventHandler(async (h3) => {
const userId = await aclManager.getUserIdACL(h3, ["collections:read"]);
if (!userId)
throw createError({
statusCode: 403,
message: "Requires authentication",
});
const id = getRouterParam(h3, "id");
if (!id)
throw createError({
statusCode: 400,
message: "ID required in route params",
});
// Fetch specific collection
// Will not return the default collection
const collection = await userLibraryManager.fetchCollection(id);
if (!collection)
throw createError({
statusCode: 404,
message: "Collection not found",
});
// Verify user owns this collection
if (collection.userId !== userId)
throw createError({
statusCode: 403,
message: "Not authorized to access this collection",
});
return collection;
});