1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
import axios from "axios";
import cron from "cron";
import { rateLimiterRedis, redis } from "@/lib/redis";
// Function to fetch new data
async function fetchData() {
try {
const { data } = await axios.get(
`https://api.anify.tv/schedule?fields=[id,coverImage,title,bannerImage]`
);
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) {
if (redis) {
await redis.set(
"schedule",
JSON.stringify(newData),
"EX",
60 * 60 * 24 * 7
);
}
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 {
let cached;
if (redis) {
try {
const ipAddress = req.socket.remoteAddress;
await rateLimiterRedis.consume(ipAddress);
} catch (error) {
return res.status(429).json({
error: `Too Many Requests, retry after ${error.msBeforeNext / 1000}`,
});
}
cached = await redis.get("schedule");
}
if (cached) {
return res.status(200).json(JSON.parse(cached));
} else {
const data = await fetchData();
if (data) {
// cacheData.put("schedule", data, 1000 * 60 * 60 * 24 * 7);
if (redis) {
await redis.set(
"schedule",
JSON.stringify(data),
"EX",
60 * 60 * 24 * 7
);
}
return res.status(200).json(data);
} else {
return res.status(404).json({ message: "Schedule not found" });
}
}
} catch (error) {
res.status(500).json({ error });
}
}
|