From 953c99a9f3b3a8fa24a99f4e907b38ca465e4949 Mon Sep 17 00:00:00 2001 From: Ritesh Ghosh Date: Sun, 13 Aug 2023 19:42:21 +0530 Subject: feat(animeProducer): added `animeProducer` controller --- src/controllers/animeProducer.controller.ts | 37 +++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) create mode 100644 src/controllers/animeProducer.controller.ts (limited to 'src') diff --git a/src/controllers/animeProducer.controller.ts b/src/controllers/animeProducer.controller.ts new file mode 100644 index 0000000..5776a80 --- /dev/null +++ b/src/controllers/animeProducer.controller.ts @@ -0,0 +1,37 @@ +import createHttpError from "http-errors"; +import { RequestHandler } from "express"; +import { scrapeProducerAnimes } from "../parsers"; +import { + AnimeProducerPathParams, + AnimeProducerQueryParams, +} from "../models/controllers"; + +// /anime/producer/${name}?page=${page} +const getProducerAnimes: RequestHandler< + AnimeProducerPathParams, + Awaited>, + unknown, + AnimeProducerQueryParams +> = async (req, res, next) => { + try { + const name: string | null = req.params.name + ? decodeURIComponent(req.params.name as string) + : null; + + const page: number = req.query.page + ? Number(decodeURIComponent(req.query?.page as string)) + : 1; + + if (name === null) { + throw createHttpError.BadRequest("Anime producer name required"); + } + + const data = await scrapeProducerAnimes(name, page); + res.status(200).json(data); + } catch (err: any) { + console.error(err); + next(err); + } +}; + +export default getProducerAnimes; -- cgit v1.2.3