mirror of
https://github.com/wassname/talk.git
synced 2026-06-29 04:28:20 +08:00
a7e9c0c776
- Updated enum values to be uppercase - Updated services to expose service models - Updated models to only export the mongoose model - Moved all mongoose static methods over to new services - Updated tests to refelct new setup BREAKING - Status that were uppercased (caps) have caused issues with the admin pages
58 lines
1.9 KiB
JavaScript
58 lines
1.9 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').ErrNotAuthorized;
|
|
|
|
/**
|
|
* has returns true if the user has all the roles specified, otherwise it will
|
|
* return false.
|
|
* @param {Object} user the user to check for roles
|
|
* @param {Array} roles all the roles that a user must have
|
|
* @return {Boolean} true if the user has all the roles required, false
|
|
* otherwise
|
|
*/
|
|
authorization.has = (user, ...roles) => roles.every((role) => {
|
|
|
|
// TODO: remove toUpperCase once we've migrated over the roles.
|
|
return user.roles.indexOf(role.toUpperCase()) >= 0;
|
|
});
|
|
|
|
/**
|
|
* 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 middlware.
|
|
...authorization.middleware,
|
|
|
|
// Insert the actual middleware to check for the required role.
|
|
(req, res, next) => {
|
|
|
|
// All routes that are wrapepd with this middleware actually require a role.
|
|
if (!req.user) {
|
|
debug(`No user on request, returning with ${ErrNotAuthorized}`);
|
|
return next(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(ErrNotAuthorized);
|
|
}
|
|
|
|
// Looks like they're allowed!
|
|
return next();
|
|
}
|
|
];
|