session-open-group-server-l.../lib.dialect.js
2019-11-25 05:57:19 +00:00

64 lines
1.7 KiB
JavaScript

let dispatcher
function setup(utilities) {
//console.log('lib.dialect utilities dispatcher', utilities.dispatcher?true:false);
({ dispatcher } = utilities);
}
function sendResponse(json, resp) {
const ts = new Date().getTime();
const diff = ts-resp.start;
if (diff > 1000) {
// this could be to do the client's connection speed
// how because we stop the clock before we send the response...
console.log(`${resp.path} served in ${ts - resp.start}ms`);
}
if (json.meta && json.meta.code) {
resp.status(json.meta.code);
}
if (resp.prettyPrint) {
json=JSON.stringify(json,null,4);
}
resp.type('application/json');
resp.setHeader("Access-Control-Allow-Origin", "*");
resp.send(json);
}
function validUser(token, res, cb) {
return new Promise(function(resolve, rej) {
dispatcher.getUserClientByToken(token, (usertoken, err) => {
if (err) {
console.error('token err', err);
const resObj={
meta: {
code: 500,
error_message: err
}
};
console.error('error trying to verify token:', token);
sendResponse(resObj, res);
return resolve();
}
if (usertoken === null) {
// could be they didn't log in through a server restart
const resObj={
meta: {
code: 401,
error_message: "Call requires authentication: Authentication required to fetch token."
}
};
console.error('token does not exist:', token);
sendResponse(resObj, res);
return resolve();
}
if (cb) cb(usertoken)
resolve(usertoken)
});
});
}
module.exports = {
setup,
sendResponse,
validUser
}