serverless
Version:
Serverless Framework - Build web, mobile and IoT applications with serverless architectures using AWS Lambda, Azure Functions, Google CloudFunctions & more
57 lines (46 loc) • 1.41 kB
JavaScript
;
const dayjs = require('dayjs');
const { style } = require('@serverless/utils/log');
module.exports = (msgParam) => {
let msg = msgParam;
const dateFormat = 'YYYY-MM-DD HH:mm:ss.SSS';
if (!msg.startsWith('REPORT')) msg = msg.trimRight();
if (msg.startsWith('START')) {
msg = 'START';
return style.aside(msg);
}
if (msg.startsWith('REPORT')) {
const splitted = msg.split('\t');
const durationItem = splitted[1];
const maxMemoryUsedItem = splitted[4];
const initDurationItem = splitted[5];
// Simplify the output and trim out unnecessary information
msg = `END ${durationItem} (init:${initDurationItem.split(':')[1]}) ${maxMemoryUsedItem.slice(
4
)}`;
return style.aside(msg);
}
if (msg.trim() === 'Process exited before completing request') {
return style.error(msg);
}
const splitted = msg.split('\t');
if (splitted.length < 3) {
return msg;
}
let date = '';
let reqId = '';
let level = '';
if (!isNaN(new Date(splitted[0]).getTime())) {
date = splitted[0];
reqId = splitted[1];
} else if (!isNaN(new Date(splitted[1]).getTime())) {
date = splitted[1];
reqId = splitted[2];
level = `${splitted[0]}\t`;
} else {
return msg;
}
const text = msg.split(`${reqId}\t`)[1];
const time = dayjs(date).format(dateFormat);
return `${style.aside(`${time}\t`)}${level}${text}`;
};