UNPKG

@unito/integration-sdk

Version:

Integration SDK

38 lines (37 loc) 1.57 kB
import { default as Logger } from '../resources/logger.js'; function onFinish(req, res, next) { res.on('finish', function () { const logger = res.locals.logger ?? new Logger(); const error = res.locals.error; const durationInNs = Number(process.hrtime.bigint() - res.locals.requestStartTime); const durationInMs = (durationInNs / 1_000_000) | 0; const message = `${req.method} ${req.originalUrl} ${res.statusCode} - ${durationInMs} ms`; const metadata = { duration: durationInNs, // Use reserved and standard attributes of Datadog // https://app.datadoghq.com/logs/pipelines/standard-attributes http: { method: req.method, status_code: res.statusCode, url_details: { path: req.originalUrl } }, ...(error ? { error: { kind: error.message, stack: (error.originalError?.details?.stack ?? error.details?.stack), message: error.originalError?.message ?? error.message, }, } : {}), }; if ([404, 429].includes(res.statusCode)) { logger.warn(message, metadata); } else if (res.statusCode >= 400) { logger.error(message, metadata); } else if (req.originalUrl !== '/health') { // Don't log successful health check requests logger.info(message, metadata); } }); next(); } export default onFinish;