aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/pages/api/v1/load.ts
diff options
context:
space:
mode:
author简律纯 <hsiangnianian@outlook.com>2023-04-18 03:02:17 +0800
committer简律纯 <hsiangnianian@outlook.com>2023-04-18 03:02:17 +0800
commit4919f028c884a041da7ff098abb02389b4eac598 (patch)
treeb0f482568c4b8c8a680ce6e2e70a7b7ca87dc190 /pages/api/v1/load.ts
parentb135aac8531c1e1488147ad8c6f98eddbdbe0c99 (diff)
downloadHydroRoll-4919f028c884a041da7ff098abb02389b4eac598.tar.gz
HydroRoll-4919f028c884a041da7ff098abb02389b4eac598.zip
✨add envshare docs
Diffstat (limited to 'pages/api/v1/load.ts')
-rw-r--r--pages/api/v1/load.ts36
1 files changed, 0 insertions, 36 deletions
diff --git a/pages/api/v1/load.ts b/pages/api/v1/load.ts
deleted file mode 100644
index ddbfac0..0000000
--- a/pages/api/v1/load.ts
+++ /dev/null
@@ -1,36 +0,0 @@
-import { NextRequest, NextResponse } from "next/server";
-import { Redis } from "@upstash/redis";
-
-const redis = Redis.fromEnv();
-export default async function handler(req: NextRequest) {
- const url = new URL(req.url);
- const id = url.searchParams.get("id");
- if (!id) {
- return new NextResponse("id param is missing", { status: 400 });
- }
- const key = ["envshare", id].join(":");
-
- const [data, _] = await Promise.all([
- await redis.hgetall<{ encrypted: string; remainingReads: number | null; iv: string }>(key),
- await redis.incr("envshare:metrics:reads"),
- ]);
- if (!data) {
- return new NextResponse("Not Found", { status: 404 });
- }
- if (data.remainingReads !== null && data.remainingReads < 1) {
- await redis.del(key);
- return new NextResponse("Not Found", { status: 404 });
- }
-
- let remainingReads: number | null = null;
- if (data.remainingReads !== null) {
- // Decrement the number of reads and return the remaining reads
- remainingReads = await redis.hincrby(key, "remainingReads", -1);
- }
-
- return NextResponse.json({ iv: data.iv, encrypted: data.encrypted, remainingReads });
-}
-
-export const config = {
- runtime: "edge",
-};