30 lines
887 B
TypeScript
30 lines
887 B
TypeScript
import { readFileSync } from "fs";
|
|
import { resolve } from "path";
|
|
import type { NextApiRequest, NextApiResponse } from "next";
|
|
|
|
interface IFileError {
|
|
message: string;
|
|
name: string;
|
|
stack?: string;
|
|
code: string;
|
|
errno: number;
|
|
syscall: string;
|
|
path: string;
|
|
}
|
|
|
|
export default function handler(req: NextApiRequest, res: NextApiResponse<string>) {
|
|
if (req.method !== "GET") return res.status(405).end();
|
|
|
|
try {
|
|
const path = resolve("./public", "projects", "list.json");
|
|
const data = readFileSync(path).toString();
|
|
if (!req.query.swr) console.debug("[API/projects]\tRequest for project list");
|
|
res.status(200).send(data);
|
|
} catch (err) {
|
|
console.error(`[API/projects]\tError in request for project list! Code: ${(err as IFileError).code}`);
|
|
res.status(500);
|
|
} finally {
|
|
res.end();
|
|
}
|
|
}
|