Skip to content

Commit 00dae6d

Browse files
committed
switch to reused promiseOrTimeout
1 parent 9be9d05 commit 00dae6d

File tree

1 file changed

+9
-9
lines changed

1 file changed

+9
-9
lines changed

src/routes/getStatus.ts

Lines changed: 9 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -3,30 +3,30 @@ import { Logger } from "../utils/logger";
33
import { Request, Response } from "express";
44
import os from "os";
55
import redis from "../utils/redis";
6-
import { setTimeout } from "timers/promises";
6+
import { promiseOrTimeout } from "../utils/promise";
77

88
export async function getStatus(req: Request, res: Response): Promise<Response> {
99
const startTime = Date.now();
1010
let value = req.params.value as string[] | string;
1111
value = Array.isArray(value) ? value[0] : value;
1212
let processTime, redisProcessTime = -1;
13-
const timeoutPromise = async (): Promise<string> => {
14-
await setTimeout(5000);
15-
return "timeout";
16-
};
1713
try {
18-
const dbVersion = await Promise.race([db.prepare("get", "SELECT key, value FROM config where key = ?", ["version"]), timeoutPromise()])
14+
const dbVersion = await promiseOrTimeout(db.prepare("get", "SELECT key, value FROM config where key = ?", ["version"]), 5000)
1915
.then(e => {
20-
if (e === "timeout") return e;
2116
processTime = Date.now() - startTime;
2217
return e.value;
18+
})
19+
.catch(e => {
20+
Logger.error(`status: SQL query timed out: ${e}`);
2321
});
2422
let statusRequests: unknown = 0;
25-
const numberRequests = await Promise.race([redis.increment("statusRequest"), timeoutPromise()])
23+
const numberRequests = await promiseOrTimeout(redis.increment("statusRequest"), 5000)
2624
.then(e => {
27-
if (e === "timeout") return [-1];
2825
redisProcessTime = Date.now() - startTime;
2926
return e;
27+
}).catch(e => {
28+
Logger.error(`status: redis increment timed out ${e}`);
29+
return [-1];
3030
});
3131
statusRequests = numberRequests?.[0];
3232

0 commit comments

Comments
 (0)