-
Notifications
You must be signed in to change notification settings - Fork 53
Expand file tree
/
Copy pathdata.js
More file actions
53 lines (43 loc) · 1.57 KB
/
data.js
File metadata and controls
53 lines (43 loc) · 1.57 KB
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
// Import Node.js Dependencies
import fs from "node:fs";
import path from "node:path";
// Import Third-party Dependencies
import send from "@polka/send-type";
// Import Internal Dependencies
import { appCache } from "../cache.js";
import { logger } from "../logger.js";
// CONSTANTS
const kDefaultPayloadPath = path.join(process.cwd(), "nsecure-result.json");
export async function get(_req, res) {
if (appCache.startFromZero) {
logger.info("[data|get](no content)");
send(res, 204);
return;
}
try {
const { current, lru } = await appCache.payloadsList();
logger.info(`[data|get](current: ${current})`);
logger.debug(`[data|get](lru: ${lru})`);
send(res, 200, await appCache.getPayload(current));
}
catch {
logger.error(`[data|get](No cache yet. Creating one...)`);
const payload = JSON.parse(fs.readFileSync(kDefaultPayloadPath, "utf-8"));
const version = Object.keys(payload.dependencies[payload.rootDependencyName].versions)[0];
const formatted = `${payload.rootDependencyName}@${version}${payload.local ? "#local" : ""}`;
const payloadsList = {
lru: [formatted],
current: formatted,
older: [],
lastUsed: {
[formatted]: Date.now()
},
root: formatted
};
logger.info(`[data|get](dep: ${formatted}|version: ${version}|rootDependencyName: ${payload.rootDependencyName})`);
await appCache.updatePayloadsList(payloadsList);
appCache.updatePayload(formatted, payload);
logger.info(`[data|get](cache: created|payloadsList: ${payloadsList.lru})`);
send(res, 200, payload);
}
}