|
|
|
const _ = require('lodash');
|
|
|
|
|
|
|
|
class Debug {
|
|
|
|
constructor(moduleName){
|
|
|
|
this.name = moduleName || 'unnamed module';
|
|
|
|
}
|
|
|
|
|
|
|
|
push(req, value){
|
|
|
|
if (!req || _.isEmpty(req.clean) || !req.clean.enableDebug){
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
req.debug = req.debug || [];
|
|
|
|
switch(typeof value) {
|
|
|
|
case 'function':
|
|
|
|
req.debug.push({[this.name]: value()});
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
req.debug.push({[this.name]: value});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
beginTimer(req, debugMsg){
|
|
|
|
if (req && !_.isEmpty(req.clean) && req.clean.enableDebug){
|
|
|
|
// debugMsg is optional
|
|
|
|
this.push(req, () => {
|
|
|
|
if (debugMsg){
|
|
|
|
return `Timer Began. ${debugMsg}`;
|
|
|
|
} else {
|
|
|
|
return `Timer Began`;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
return Date.now();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
stopTimer(req, startTime, debugMsg){
|
|
|
|
if (req && !_.isEmpty(req.clean) && req.clean.enableDebug){
|
|
|
|
let timeElapsed = Date.now() - startTime;
|
|
|
|
this.push(req, () => {
|
|
|
|
if (debugMsg){
|
|
|
|
return `Timer Stopped. ${timeElapsed} ms. ${debugMsg}`;
|
|
|
|
} else {
|
|
|
|
return `Timer Stopped. ${timeElapsed} ms`;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = Debug;
|