mirror of https://github.com/pelias/api.git
51 lines
1.2 KiB
51 lines
1.2 KiB
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;
|
|
|