From 3f56389f55ef116f8cea17c15c684798fb942290 Mon Sep 17 00:00:00 2001 From: Mohamed Bassem Date: Fri, 27 Dec 2024 19:21:43 +0000 Subject: feat: Add REST APIs for manipulating highlights. Fixes #620 --- .../app/api/v1/highlights/[highlightId]/route.ts | 50 ++++++++++++++++++++++ apps/web/app/api/v1/highlights/route.ts | 30 +++++++++++++ 2 files changed, 80 insertions(+) create mode 100644 apps/web/app/api/v1/highlights/[highlightId]/route.ts create mode 100644 apps/web/app/api/v1/highlights/route.ts (limited to 'apps/web/app/api/v1/highlights') diff --git a/apps/web/app/api/v1/highlights/[highlightId]/route.ts b/apps/web/app/api/v1/highlights/[highlightId]/route.ts new file mode 100644 index 00000000..aa92e7ce --- /dev/null +++ b/apps/web/app/api/v1/highlights/[highlightId]/route.ts @@ -0,0 +1,50 @@ +import { NextRequest } from "next/server"; +import { buildHandler } from "@/app/api/v1/utils/handler"; + +import { zUpdateHighlightSchema } from "@hoarder/shared/types/highlights"; + +export const dynamic = "force-dynamic"; + +export const GET = ( + req: NextRequest, + { params }: { params: { highlightId: string } }, +) => + buildHandler({ + req, + handler: async ({ api }) => { + const highlight = await api.highlights.get({ + highlightId: params.highlightId, + }); + return { status: 200, resp: highlight }; + }, + }); + +export const PATCH = ( + req: NextRequest, + { params }: { params: { highlightId: string } }, +) => + buildHandler({ + req, + bodySchema: zUpdateHighlightSchema.omit({ highlightId: true }), + handler: async ({ api, body }) => { + const highlight = await api.highlights.update({ + highlightId: params.highlightId, + ...body!, + }); + return { status: 200, resp: highlight }; + }, + }); + +export const DELETE = ( + req: NextRequest, + { params }: { params: { highlightId: string } }, +) => + buildHandler({ + req, + handler: async ({ api }) => { + const highlight = await api.highlights.delete({ + highlightId: params.highlightId, + }); + return { status: 200, resp: highlight }; + }, + }); diff --git a/apps/web/app/api/v1/highlights/route.ts b/apps/web/app/api/v1/highlights/route.ts new file mode 100644 index 00000000..ebb96bae --- /dev/null +++ b/apps/web/app/api/v1/highlights/route.ts @@ -0,0 +1,30 @@ +import { NextRequest } from "next/server"; +import { buildHandler } from "@/app/api/v1/utils/handler"; + +import { zNewHighlightSchema } from "@hoarder/shared/types/highlights"; + +import { adaptPagination, zPagination } from "../utils/pagination"; + +export const dynamic = "force-dynamic"; + +export const GET = (req: NextRequest) => + buildHandler({ + req, + searchParamsSchema: zPagination, + handler: async ({ api, searchParams }) => { + const resp = await api.highlights.getAll({ + ...searchParams, + }); + return { status: 200, resp: adaptPagination(resp) }; + }, + }); + +export const POST = (req: NextRequest) => + buildHandler({ + req, + bodySchema: zNewHighlightSchema, + handler: async ({ body, api }) => { + const resp = await api.highlights.create(body!); + return { status: 200, resp }; + }, + }); -- cgit v1.2.3-70-g09d2