Skip to content

Commit

Permalink
Merge pull request bitpay#1807 from micahriggan/feature/request-logging
Browse files Browse the repository at this point in the history
Better request logging
  • Loading branch information
micahriggan authored Dec 19, 2018
2 parents 8ea1da3 + 98852ce commit 3f9fbcd
Showing 1 changed file with 30 additions and 4 deletions.
34 changes: 30 additions & 4 deletions packages/bitcore-node/src/routes/middleware.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,14 +5,40 @@ type TimedRequest = {
startTime?: Date;
} & express.Request;

function LogObj(logOut: { [key: string]: string }) {
logger.info(
`${logOut.time} | ${logOut.ip} | ${logOut.phase} | ${logOut.took} | ${logOut.method} | ${logOut.status} | ${
logOut.url
}`
);
}

export function LogRequest(req: TimedRequest, res: express.Response, next: express.NextFunction) {
req.startTime = new Date();
res.on('finish', () => {
const ip = req.header('CF-Connecting-IP') || req.socket.remoteAddress || req.hostname;
const logOut = {
time: req.startTime.toTimeString(),
ip: ip.padStart(12, ' '),
phase: 'START'.padStart(8, ' '),
method: req.method.padStart(6, ' '),
status: '...'.padStart(5, ' '),
url: `${req.baseUrl}${req.url}`,
took: '...'.padStart(10, ' ')
};
LogObj(logOut);

const LogPhase = (phase: string) => () => {
const endTime = new Date();
const startTime = req.startTime ? req.startTime : endTime;
const totalTime = endTime.getTime() - startTime.getTime();
const totalTimeMsg = `${totalTime} ms`.padStart(10, ' ');;
logger.info(`${startTime.toTimeString()} | ${totalTimeMsg} | ${req.method} | ${req.baseUrl}${req.url}`);
});
const totalTimeMsg = `${totalTime} ms`;
logOut.phase = phase.padStart(8, ' ');
logOut.took = totalTimeMsg.padStart(10, ' ');
logOut.status = res.statusCode.toString().padStart(5, ' ');
LogObj(logOut);
};

res.on('finish', LogPhase('END'));
res.on('close', LogPhase('CLOSED'));
next();
}

0 comments on commit 3f9fbcd

Please sign in to comment.