aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAbdelaziz Mahdy <[email protected]>2024-12-22 15:32:56 -0400
committerAbdelaziz Mahdy <[email protected]>2024-12-22 15:32:56 -0400
commitf1f5db84f98818af2c047ea375832e5ded5f021a (patch)
tree8bac1a56c3e1a6000b64e1face8157fc5eb0da56
parent2d5377cbc58bd84dcd0585798e77995265c8727b (diff)
downloadaniwatch-api-f1f5db84f98818af2c047ea375832e5ded5f021a.tar.xz
aniwatch-api-f1f5db84f98818af2c047ea375832e5ded5f021a.zip
feat(cache): add Cache-Control middleware and update .env.example
-rw-r--r--.env.example6
-rw-r--r--src/config/cache_control_middleware.ts15
-rw-r--r--src/server.ts2
3 files changed, 23 insertions, 0 deletions
diff --git a/.env.example b/.env.example
index 8513245..ecbd080 100644
--- a/.env.example
+++ b/.env.example
@@ -23,3 +23,9 @@ ANIWATCH_API_MAX_REQS=70
# env to use optional redis caching functionality
ANIWATCH_API_REDIS_CONN_URL=<rediss://default:[email protected]:6379>
+
+# Cache-Control settings for Vercel Edge Caching
+# s-maxage specifies the maximum amount of time a resource is considered fresh when served by a CDN cache
+S_MAXAGE=60
+# stale-while-revalidate specifies the amount of time a resource is served stale while a new one is fetched
+STALE_WHILE_REVALIDATE=30
diff --git a/src/config/cache_control_middleware.ts b/src/config/cache_control_middleware.ts
new file mode 100644
index 0000000..5543ddc
--- /dev/null
+++ b/src/config/cache_control_middleware.ts
@@ -0,0 +1,15 @@
+import type { MiddlewareHandler } from "hono";
+
+// Define middleware to add Cache-Control header
+const cacheControlMiddleware: MiddlewareHandler = async (c, next) => {
+ const sMaxAge = process.env.S_MAXAGE || "60";
+ const staleWhileRevalidate = process.env.STALE_WHILE_REVALIDATE || "30";
+ c.header(
+ "Cache-Control",
+ `s-maxage=${sMaxAge}, stale-while-revalidate=${staleWhileRevalidate}`
+ );
+
+ await next();
+};
+
+export default cacheControlMiddleware;
diff --git a/src/server.ts b/src/server.ts
index 41a64c5..780d25b 100644
--- a/src/server.ts
+++ b/src/server.ts
@@ -5,6 +5,7 @@ import corsConfig from "./config/cors.js";
import { ratelimit } from "./config/ratelimit.js";
import { hianimeRouter } from "./routes/hianime.js";
+import cacheControlMiddleware from "./config/cache_control_middleware.js";
import { Hono } from "hono";
import { logger } from "hono/logger";
@@ -26,6 +27,7 @@ const app = new Hono<{ Variables: AniwatchAPIVariables }>();
app.use(logger());
app.use(corsConfig);
+app.use(cacheControlMiddleware);
// CAUTION: For personal deployments, "refrain" from having an env
// named "ANIWATCH_API_HOSTNAME". You may face rate limitting