1
0
Fork 0
mirror of https://github.com/plankanban/planka.git synced 2025-07-19 21:29:43 +02:00
planka/server/api/hooks/current-user/index.js

125 lines
3.2 KiB
JavaScript
Raw Normal View History

/*!
* Copyright (c) 2024 PLANKA Software GmbH
* Licensed under the Fair Use License: https://github.com/plankanban/planka/blob/master/LICENSE.md
*/
2019-08-31 04:07:25 +05:00
/**
* current-user hook
*
* @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 /;
const getSessionAndUser = async (accessToken, httpOnlyToken) => {
let payload;
2019-08-31 04:07:25 +05:00
try {
payload = sails.helpers.utils.verifyJwtToken(accessToken);
} catch (error) {
return null;
2019-08-31 04:07:25 +05:00
}
const session = await Session.qm.getOneUndeletedByAccessToken(accessToken);
if (!session) {
return null;
}
if (session.httpOnlyToken && httpOnlyToken !== session.httpOnlyToken) {
return null;
}
const user = await User.qm.getOneById(payload.subject, {
withDeactivated: false,
});
if (!user) {
return null;
}
if (user.passwordChangedAt > payload.issuedAt) {
return null;
}
return {
session,
user,
};
2019-08-31 04:07:25 +05:00
};
return {
/**
* Runs when this Sails app loads/lifts.
*/
async initialize() {
2019-08-31 04:07:25 +05:00
sails.log.info('Initializing custom hook (`current-user`)');
},
routes: {
before: {
'/api/*': {
async fn(req, res, next) {
const { authorization: authorizationHeader } = req.headers;
if (authorizationHeader && TOKEN_PATTERN.test(authorizationHeader)) {
const accessToken = authorizationHeader.replace(TOKEN_PATTERN, '');
const { internalAccessToken } = sails.config.custom;
if (internalAccessToken && accessToken === internalAccessToken) {
req.currentUser = User.INTERNAL;
} else {
const { httpOnlyToken } = req.cookies;
const sessionAndUser = await getSessionAndUser(accessToken, httpOnlyToken);
if (sessionAndUser) {
const { session, user } = sessionAndUser;
if (user.language) {
req.setLocale(user.language);
}
Object.assign(req, {
currentSession: session,
currentUser: user,
});
if (req.isSocket) {
sails.sockets.join(req, `@accessToken:${session.accessToken}`);
sails.sockets.join(req, `@user:${user.id}`);
}
2022-10-03 12:11:19 +02:00
}
}
2019-08-31 04:07:25 +05:00
}
return next();
},
},
'/attachments/*': {
async fn(req, res, next) {
const { accessToken, httpOnlyToken } = req.cookies;
if (accessToken) {
const sessionAndUser = await getSessionAndUser(accessToken, httpOnlyToken);
if (sessionAndUser) {
const { session, user } = sessionAndUser;
Object.assign(req, {
currentSession: session,
currentUser: user,
});
}
}
2019-08-31 04:07:25 +05:00
return next();
},
},
},
},
2019-08-31 04:07:25 +05:00
};
};