diff options
Diffstat (limited to 'pages/api/consumet')
| -rw-r--r-- | pages/api/consumet/episode/[id].js | 63 | ||||
| -rw-r--r-- | pages/api/consumet/source/[...params].js | 36 |
2 files changed, 99 insertions, 0 deletions
diff --git a/pages/api/consumet/episode/[id].js b/pages/api/consumet/episode/[id].js new file mode 100644 index 0000000..60bb4fb --- /dev/null +++ b/pages/api/consumet/episode/[id].js @@ -0,0 +1,63 @@ +import axios from "axios"; +import cacheData from "memory-cache"; + +const API_URL = process.env.API_URI; + +export default async function handler(req, res) { + try { + const id = req.query.id; + const dub = req.query.dub || false; + + const providers = ["enime", "gogoanime"]; + const datas = []; + + const cached = cacheData.get(id + dub); + if (cached) { + return res.status(200).json(cached); + } else { + async function fetchData(provider) { + try { + const data = await fetch( + dub && provider === "gogoanime" + ? `${API_URL}/meta/anilist/info/${id}?dub=true` + : `${API_URL}/meta/anilist/info/${id}?provider=${provider}` + ).then((res) => { + if (!res.ok) { + switch (res.status) { + case 404: { + return null; + } + } + } + return res.json(); + }); + if (data.episodes.length > 0) { + datas.push({ + providerId: provider, + episodes: dub ? data.episodes : data.episodes.reverse(), + }); + } + } catch (error) { + console.error( + `Error fetching data for provider '${provider}':`, + error + ); + } + } + if (dub === false) { + await Promise.all(providers.map((provider) => fetchData(provider))); + } else { + await fetchData("gogoanime"); + } + + if (datas.length === 0) { + return res.status(404).json({ message: "Anime not found" }); + } else { + cacheData.put(id + dub, { data: datas }, 1000 * 60 * 60 * 15); // 15 minutes + res.status(200).json({ data: datas }); + } + } + } catch (error) { + res.status(500).json({ error }); + } +} diff --git a/pages/api/consumet/source/[...params].js b/pages/api/consumet/source/[...params].js new file mode 100644 index 0000000..e589d4a --- /dev/null +++ b/pages/api/consumet/source/[...params].js @@ -0,0 +1,36 @@ +import axios from "axios"; +import cacheData from "memory-cache"; + +const API_URL = process.env.API_URI; + +export default async function handler(req, res) { + const query = req.query.params; + try { + const provider = query[0]; + const id = query[1]; + + const cached = cacheData.get(id); + if (cached) { + return res.status(200).json(cached); + } else { + let datas; + + const { data } = await axios.get( + `${API_URL}/meta/anilist/watch/${id}?provider=${provider}` + ); + + if (data) { + datas = data; + cacheData.put(id, data, 1000 * 60 * 5); + } + + if (!datas) { + return res.status(404).json({ message: "Source not found" }); + } + + res.status(200).json(datas); + } + } catch (error) { + res.status(500).json({ error }); + } +} |