'use strict'; function rejectableRequest(req, res, promise, msg) { return promise.error(function (err) { res.error(err); }).catch(function (err) { console.error('[ERROR] \'' + msg + '\''); // The stack contains the message as well, so no need to log the message when we log the stack console.error(err.stack || err.message || JSON.stringify(err)); res.error(err); }); } module.exports.rejectableRequest = rejectableRequest; module.exports.promisableRequest = module.exports.promiseRequest = function promiseRequest(req, res, promise, msg) { promise = promise.then(function (result) { if (result._cache) { res.setHeader('Cache-Control', 'public, max-age=' + (result._cache / 1000)); res.setHeader('Expires', new Date(Date.now() + result._cache).toUTCString()); } if (result._mime) { res.setHeader('Content-Type', result._mime); } if (result._value) { result = result._value; } res.send(result); }); return rejectableRequest(req, res, promise, msg); };