feat(api): add api endpoints for dynamic routes
Squashed commit of the following: commit9fdd731136
Author: zyachel <aricla@protonmail.com> Date: Mon Oct 30 01:25:32 2023 +0530 feat(api): add a catch-all route commit4dffbbc0ec
Author: zyachel <aricla@protonmail.com> Date: Mon Oct 30 01:24:10 2023 +0530 fix(api): refactor all endpoints a bit disallow methods other that GET properly type return types add type guards where needed make all endpoints return same response format for consistency commit264442448f
Author: Niklas Poslovski <niklas.poslovski@nikisoft.one> Date: Sun Oct 29 19:00:44 2023 +0100 Add API endpoints for all routes that contain IMDB data
This commit is contained in:
parent
2b00d5406a
commit
19f1700a55
5 changed files with 105 additions and 0 deletions
7
src/pages/api/[...error].ts
Normal file
7
src/pages/api/[...error].ts
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
import type { NextApiRequest, NextApiResponse } from 'next';
|
||||||
|
|
||||||
|
type ResponseData = { status: false; message: string };
|
||||||
|
|
||||||
|
export default async function handler(_: NextApiRequest, res: NextApiResponse<ResponseData>) {
|
||||||
|
res.status(400).json({ status: false, message: 'Not found' });
|
||||||
|
}
|
32
src/pages/api/find.ts
Normal file
32
src/pages/api/find.ts
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
import type { NextApiRequest, NextApiResponse } from 'next';
|
||||||
|
import Find, { type FindQueryParams } from 'src/interfaces/shared/search';
|
||||||
|
import basicSearch from 'src/utils/fetchers/basicSearch';
|
||||||
|
import getOrSetApiCache from 'src/utils/getOrSetApiCache';
|
||||||
|
import { findKey } from 'src/utils/constants/keys';
|
||||||
|
import { AppError, cleanQueryStr } from 'src/utils/helpers';
|
||||||
|
|
||||||
|
type ResponseData =
|
||||||
|
| { status: true; data: { title: null | string; results: null | Find } }
|
||||||
|
| { status: false; message: string };
|
||||||
|
|
||||||
|
export default async function handler(req: NextApiRequest, res: NextApiResponse<ResponseData>) {
|
||||||
|
try {
|
||||||
|
if (req.method !== 'GET') throw new AppError('Invalid method', 400);
|
||||||
|
|
||||||
|
const queryObj = req.query as FindQueryParams | Record<string, never>;
|
||||||
|
const query = queryObj.q?.trim();
|
||||||
|
|
||||||
|
if (!query) {
|
||||||
|
return res.status(200).json({ status: true, data: { title: null, results: null } });
|
||||||
|
}
|
||||||
|
|
||||||
|
const entries = Object.entries(queryObj);
|
||||||
|
const queryStr = cleanQueryStr(entries);
|
||||||
|
const results = await getOrSetApiCache(findKey(queryStr), basicSearch, queryStr);
|
||||||
|
|
||||||
|
res.status(200).json({ status: true, data: { title: query, results } });
|
||||||
|
} catch (error: any) {
|
||||||
|
const { message = 'Not found', statusCode = 404 } = error;
|
||||||
|
res.status(statusCode).json({ status: false, message });
|
||||||
|
}
|
||||||
|
}
|
23
src/pages/api/list/[listId].ts
Normal file
23
src/pages/api/list/[listId].ts
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
import type { NextApiRequest, NextApiResponse } from 'next';
|
||||||
|
import type List from 'src/interfaces/shared/list';
|
||||||
|
import list from 'src/utils/fetchers/list';
|
||||||
|
import getOrSetApiCache from 'src/utils/getOrSetApiCache';
|
||||||
|
import { listKey } from 'src/utils/constants/keys';
|
||||||
|
import { AppError } from 'src/utils/helpers';
|
||||||
|
|
||||||
|
type ResponseData = { status: true; data: List } | { status: false; message: string };
|
||||||
|
|
||||||
|
export default async function handler(req: NextApiRequest, res: NextApiResponse<ResponseData>) {
|
||||||
|
try {
|
||||||
|
if (req.method !== 'GET') throw new AppError('Invalid method', 400);
|
||||||
|
|
||||||
|
const listId = req.query.listId as string;
|
||||||
|
const pageNum = req.query.page as string | undefined;
|
||||||
|
|
||||||
|
const data = await getOrSetApiCache(listKey(listId, pageNum), list, listId, pageNum);
|
||||||
|
res.status(200).json({ status: true, data });
|
||||||
|
} catch (error: any) {
|
||||||
|
const { message = 'Not found', statusCode = 404 } = error;
|
||||||
|
res.status(statusCode).json({ status: false, message });
|
||||||
|
}
|
||||||
|
}
|
22
src/pages/api/name/[nameId].ts
Normal file
22
src/pages/api/name/[nameId].ts
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
import type { NextApiRequest, NextApiResponse } from 'next';
|
||||||
|
import type Name from 'src/interfaces/shared/name';
|
||||||
|
import name from 'src/utils/fetchers/name';
|
||||||
|
import getOrSetApiCache from 'src/utils/getOrSetApiCache';
|
||||||
|
import { nameKey } from 'src/utils/constants/keys';
|
||||||
|
import { AppError } from 'src/utils/helpers';
|
||||||
|
|
||||||
|
type ResponseData = { status: true; data: Name } | { status: false; message: string };
|
||||||
|
|
||||||
|
export default async function handler(req: NextApiRequest, res: NextApiResponse<ResponseData>) {
|
||||||
|
try {
|
||||||
|
if (req.method !== 'GET') throw new AppError('Invalid method', 400);
|
||||||
|
|
||||||
|
const nameId = req.query.nameId as string;
|
||||||
|
|
||||||
|
const data = await getOrSetApiCache(nameKey(nameId), name, nameId);
|
||||||
|
res.status(200).json({ status: true, data });
|
||||||
|
} catch (error: any) {
|
||||||
|
const { message = 'Not found', statusCode = 404 } = error;
|
||||||
|
res.status(statusCode).json({ status: false, message });
|
||||||
|
}
|
||||||
|
}
|
21
src/pages/api/title/[titleId].ts
Normal file
21
src/pages/api/title/[titleId].ts
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
import type { NextApiRequest, NextApiResponse } from 'next';
|
||||||
|
import type Title from 'src/interfaces/shared/title';
|
||||||
|
import title from 'src/utils/fetchers/title';
|
||||||
|
import getOrSetApiCache from 'src/utils/getOrSetApiCache';
|
||||||
|
import { titleKey } from 'src/utils/constants/keys';
|
||||||
|
import { AppError } from 'src/utils/helpers';
|
||||||
|
|
||||||
|
type ResponseData = { status: true; data: Title } | { status: false; message: string };
|
||||||
|
|
||||||
|
export default async function handler(req: NextApiRequest, res: NextApiResponse<ResponseData>) {
|
||||||
|
try {
|
||||||
|
if (req.method !== 'GET') throw new AppError('Invalid method', 400);
|
||||||
|
|
||||||
|
const titleId = req.query.titleId as string;
|
||||||
|
const data = await getOrSetApiCache(titleKey(titleId), title, titleId);
|
||||||
|
res.status(200).json({ status: true, data });
|
||||||
|
} catch (error: any) {
|
||||||
|
const { message = 'Not found', statusCode = 404 } = error;
|
||||||
|
res.status(statusCode).json({ status: false, message });
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue