aboutsummaryrefslogtreecommitdiff
path: root/pages/api/anify
diff options
context:
space:
mode:
authorFactiven <[email protected]>2023-09-13 00:45:53 +0700
committerGitHub <[email protected]>2023-09-13 00:45:53 +0700
commit7327a69b55a20b99b14ee0803d6cf5f8b88c45ef (patch)
treecbcca777593a8cc4b0282e7d85a6fc51ba517e25 /pages/api/anify
parentUpdate issue templates (diff)
downloadmoopa-7327a69b55a20b99b14ee0803d6cf5f8b88c45ef.tar.xz
moopa-7327a69b55a20b99b14ee0803d6cf5f8b88c45ef.zip
Update v4 - Merge pre-push to main (#71)
* Create build-test.yml * initial v4 commit * update: github workflow * update: push on branch * Update .github/ISSUE_TEMPLATE/bug_report.md * configuring next.config.js file
Diffstat (limited to 'pages/api/anify')
-rw-r--r--pages/api/anify/info/[id].js37
-rw-r--r--pages/api/anify/page/[...params].js41
-rw-r--r--pages/api/anify/schedule.js53
3 files changed, 0 insertions, 131 deletions
diff --git a/pages/api/anify/info/[id].js b/pages/api/anify/info/[id].js
deleted file mode 100644
index c33d158..0000000
--- a/pages/api/anify/info/[id].js
+++ /dev/null
@@ -1,37 +0,0 @@
-import axios from "axios";
-import cacheData from "memory-cache";
-
-const API_KEY = process.env.API_KEY;
-
-// Function to fetch new data
-export async function fetchInfo(id) {
- try {
- const { data } = await axios.get(
- `https://api.anify.tv/info/${id}?apikey=${API_KEY}`
- );
- return data;
- } catch (error) {
- console.error("Error fetching data:", error);
- return null;
- }
-}
-
-export default async function handler(req, res) {
- try {
- const id = req.query.id;
- const cached = cacheData.get(id);
- if (cached) {
- return res.status(200).json(cached);
- } else {
- const data = await fetchInfo(id);
- if (data) {
- res.status(200).json(data);
- cacheData.put(id, data, 1000 * 60 * 10);
- } else {
- res.status(404).json({ message: "Schedule not found" });
- }
- }
- } catch (error) {
- res.status(500).json({ error });
- }
-}
diff --git a/pages/api/anify/page/[...params].js b/pages/api/anify/page/[...params].js
deleted file mode 100644
index 80dda6c..0000000
--- a/pages/api/anify/page/[...params].js
+++ /dev/null
@@ -1,41 +0,0 @@
-import axios from "axios";
-import cacheData from "memory-cache";
-
-const API_KEY = process.env.API_KEY;
-
-// Function to fetch new data
-async function fetchData(id, providerId, chapterId) {
- try {
- const res = await fetch(
- `https://api.anify.tv/pages?id=${id}&providerId=${providerId}&readId=${chapterId}&apikey=${API_KEY}`
- );
- const data = await res.json();
- return data;
- // return { id, providerId, chapterId };
- } catch (error) {
- console.error("Error fetching data:", error);
- return null;
- }
-}
-
-export default async function handler(req, res) {
- try {
- const id = req.query.params;
- const chapter = req.query.chapter;
- // res.status(200).json({ id, chapter });
- const cached = cacheData.get(chapter);
- if (cached) {
- return res.status(200).json(cached);
- } else {
- const data = await fetchData(id[0], id[1], chapter);
- if (data) {
- res.status(200).json(data);
- cacheData.put(id[2], data, 1000 * 60 * 10);
- } else {
- res.status(404).json({ message: "Manga/Novel not found :(" });
- }
- }
- } catch (error) {
- res.status(500).json({ error });
- }
-}
diff --git a/pages/api/anify/schedule.js b/pages/api/anify/schedule.js
deleted file mode 100644
index 99f10d6..0000000
--- a/pages/api/anify/schedule.js
+++ /dev/null
@@ -1,53 +0,0 @@
-import axios from "axios";
-import cacheData from "memory-cache";
-import cron from "cron";
-
-const API_KEY = process.env.API_KEY;
-
-// Function to fetch new data
-async function fetchData() {
- try {
- const { data } = await axios.get(
- `https://api.anify.tv/schedule?apikey=${API_KEY}`
- );
- return data;
- } catch (error) {
- console.error("Error fetching data:", error);
- return null;
- }
-}
-
-// Function to refresh the cache with new data
-async function refreshCache() {
- const newData = await fetchData();
- if (newData) {
- cacheData.put("schedule", newData, 1000 * 60 * 15);
- console.log("Cache refreshed successfully.");
- }
-}
-
-// Schedule cache refresh every Monday at 00:00 AM (local time)
-const job = new cron.CronJob("0 0 * * 1", () => {
- refreshCache();
-});
-job.start();
-
-export default async function handler(req, res) {
- try {
- const cached = cacheData.get("schedule");
- if (cached) {
- return res.status(200).json(cached);
- } else {
- const data = await fetchData();
-
- if (data) {
- res.status(200).json(data);
- cacheData.put("schedule", data, 1000 * 60 * 60 * 24 * 7);
- } else {
- res.status(404).json({ message: "Schedule not found" });
- }
- }
- } catch (error) {
- res.status(500).json({ error });
- }
-}