2019-08-31 04:07:25 +05:00
|
|
|
/**
|
|
|
|
* current-user hook
|
|
|
|
*
|
2019-11-05 18:01:42 +05:00
|
|
|
* @description :: A hook definition. Extends Sails by adding shadow routes, implicit actions,
|
|
|
|
* and/or initialization logic.
|
2019-08-31 04:07:25 +05:00
|
|
|
* @docs :: https://sailsjs.com/docs/concepts/extending-sails/hooks
|
|
|
|
*/
|
|
|
|
|
|
|
|
module.exports = function defineCurrentUserHook(sails) {
|
|
|
|
const TOKEN_PATTERN = /^Bearer /;
|
|
|
|
|
2020-04-03 00:35:25 +05:00
|
|
|
const getUser = async (accessToken) => {
|
2019-08-31 04:07:25 +05:00
|
|
|
let id;
|
|
|
|
|
|
|
|
try {
|
2021-06-24 01:05:22 +05:00
|
|
|
id = sails.helpers.utils.verifyToken(accessToken);
|
2019-11-05 18:01:42 +05:00
|
|
|
} catch (error) {
|
|
|
|
return null;
|
2019-08-31 04:07:25 +05:00
|
|
|
}
|
|
|
|
|
2021-06-24 01:05:22 +05:00
|
|
|
return sails.helpers.users.getOne(id);
|
2019-08-31 04:07:25 +05:00
|
|
|
};
|
|
|
|
|
|
|
|
return {
|
|
|
|
/**
|
|
|
|
* Runs when this Sails app loads/lifts.
|
|
|
|
*/
|
|
|
|
|
2019-11-05 18:01:42 +05:00
|
|
|
async initialize() {
|
2019-08-31 04:07:25 +05:00
|
|
|
sails.log.info('Initializing custom hook (`current-user`)');
|
|
|
|
},
|
|
|
|
|
|
|
|
routes: {
|
|
|
|
before: {
|
|
|
|
'/*': {
|
2019-11-05 18:01:42 +05:00
|
|
|
async fn(req, res, next) {
|
2022-04-26 18:01:55 +05:00
|
|
|
let accessToken;
|
|
|
|
if (req.headers.authorization) {
|
|
|
|
if (TOKEN_PATTERN.test(req.headers.authorization)) {
|
|
|
|
accessToken = req.headers.authorization.replace(TOKEN_PATTERN, '');
|
|
|
|
}
|
|
|
|
} else if (req.cookies.accessToken) {
|
|
|
|
accessToken = req.cookies.accessToken;
|
|
|
|
}
|
2019-08-31 04:07:25 +05:00
|
|
|
|
2022-04-26 18:01:55 +05:00
|
|
|
if (accessToken) {
|
2019-08-31 04:07:25 +05:00
|
|
|
req.currentUser = await getUser(accessToken);
|
|
|
|
}
|
|
|
|
|
|
|
|
return next();
|
2019-11-05 18:01:42 +05:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2019-08-31 04:07:25 +05:00
|
|
|
};
|
|
|
|
};
|