Files
talk/middleware/authorization.js
T

66 lines
2.1 KiB
JavaScript

/**
* authorization contains the references to the authorization middleware.
* @type {Object}
*/
const authorization = (module.exports = {
middleware: [],
});
const debug = require('debug')('talk:middleware:authorization');
const { ErrNotAuthorized } = require('../errors');
/**
* has returns true if the user has at least one of the roles specified,
* otherwise it will return false.
* @param {Object} user the user to check for roles
* @param {Array} roles roles to check if the user has
* @return {Boolean} true if the user has some the roles required, false
* otherwise
*/
authorization.has = (user, ...roles) => {
// If no user is specified, then they can't have the roles you want!
if (!user) {
return false;
}
// If no roles are specified, then any user has the roles you want!
if (!roles || roles.length === 0) {
return true;
}
// If there's a user, and roles, then check to see that the user has at least
// one of those roles.
return roles.some(role => user.role === role);
};
/**
* needed is a connect middleware layer that ensures that all requests coming
* here are both authenticated and match a set of roles required to continue.
* @param {Array} roles all the roles that a user must have
* @return {Callback} connect middleware
*/
authorization.needed = (...roles) => [
// Insert the pre-needed middleware.
...authorization.middleware,
// Insert the actual middleware to check for the required role.
(req, res, next) => {
// All routes that are wrapped with this middleware actually require a role.
if (!req.user) {
debug(`No user on request, returning with ErrNotAuthorized`);
return next(new ErrNotAuthorized());
}
// Check to see if the current user has all the roles requested for the given
// array of roles requested, if one is not on the user, then this will
// evaluate to true.
if (!authorization.has(req.user, ...roles)) {
debug('User does not have all the required roles to access this page');
return next(new ErrNotAuthorized());
}
// Looks like they're allowed!
return next();
},
];