Files
timmy-tower/artifacts/api-server/src/middlewares/response-time.ts

35 lines
1.1 KiB
TypeScript

import type { Request, Response, NextFunction } from "express";
import { makeLogger } from "../lib/logger.js";
import { latencyHistogram } from "../lib/histogram.js";
import { requestCounters } from "../lib/request-counters.js";
const logger = makeLogger("http");
export function responseTimeMiddleware(req: Request, res: Response, next: NextFunction): void {
const startedAt = Date.now();
res.on("finish", () => {
const durationMs = Date.now() - startedAt;
const route = req.route?.path as string | undefined;
const routeKey = `${req.method} ${route ?? req.path}`;
latencyHistogram.record(routeKey, durationMs);
requestCounters.record(res.statusCode);
logger.info("request", {
request_id: res.locals["requestId"] ?? null,
method: req.method,
path: req.path,
route: route ?? null,
status: res.statusCode,
duration_ms: durationMs,
ip:
(req.headers["x-forwarded-for"] as string | undefined)?.split(",")[0]?.trim() ??
req.socket.remoteAddress ??
null,
});
});
next();
}