51 lines
992 B
TypeScript
Raw Normal View History

2025-01-05 21:58:07 +01:00
import { FreshContext, Handlers } from "$fresh/server.ts";
2023-07-31 04:19:04 +02:00
import { getMovie } from "@lib/tmdb.ts";
2023-08-01 17:50:00 +02:00
import { json } from "@lib/helpers.ts";
2025-01-06 16:14:29 +01:00
import { createCache } from "@lib/cache.ts";
2023-07-31 04:19:04 +02:00
type CachedMovieCredits = {
lastUpdated: number;
data: unknown;
};
const CACHE_INTERVAL = 1000 * 60 * 24 * 30;
2025-01-06 16:14:29 +01:00
const cache = createCache<CachedMovieCredits>({ expires: CACHE_INTERVAL });
2023-07-31 04:19:04 +02:00
2023-08-01 17:50:00 +02:00
const GET = async (
2023-07-31 04:19:04 +02:00
_req: Request,
2025-01-05 21:58:07 +01:00
_ctx: FreshContext,
2023-07-31 04:19:04 +02:00
) => {
const id = _ctx.params.id;
if (!id) {
return new Response("Bad Request", {
status: 400,
});
}
const cacheId = `/movie/${id}`;
2025-01-06 16:14:29 +01:00
const cachedResponse = cache.get(cacheId);
2023-07-31 04:19:04 +02:00
if (
cachedResponse && Date.now() < (cachedResponse.lastUpdated + CACHE_INTERVAL)
) {
2023-08-01 17:50:00 +02:00
return json(cachedResponse.data);
2023-07-31 04:19:04 +02:00
}
const res = await getMovie(+id);
cache.set(
cacheId,
JSON.stringify({
lastUpdated: Date.now(),
data: res,
}),
);
2023-08-01 17:50:00 +02:00
return json(res);
};
export const handler: Handlers = {
GET,
2023-07-31 04:19:04 +02:00
};