1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-25 00:07:47 +01:00

Don't expose user permissions when extendedPermissions is disabled, cleanup controller.js

This commit is contained in:
Benjamin Ludewig 2018-12-19 13:35:54 +01:00 committed by Ivar Conradi Østhus
parent abe4f8cf16
commit b38da68d28
3 changed files with 37 additions and 38 deletions

View File

@ -25,7 +25,7 @@ class AdminApi extends Controller {
);
this.app.use('/events', new EventController(stores).router);
this.app.use('/metrics', new MetricsController(perms, stores).router);
this.app.use('/user', new UserController().router);
this.app.use('/user', new UserController(perms).router);
}
index(req, res) {

View File

@ -3,17 +3,21 @@
const Controller = require('../controller');
class UserController extends Controller {
constructor() {
super();
constructor(perms) {
super(perms);
this.get('/', this.getUser);
this.get('/logout', this.logout);
}
getUser(req, res) {
if (req.user) {
const user = Object.assign({}, req.user);
if (!this.extendedPermissions) {
delete user.permissions;
}
return res
.status(200)
.json(req.user)
.json(user)
.end();
} else {
return res.status(404).end();

View File

@ -6,55 +6,50 @@ const { requirePermission } = require('./../permissions');
* Base class for Controllers to standardize binding to express Router.
*/
class Controller {
constructor(extendedPerms) {
constructor(extendedPermissions) {
const router = Router();
this.app = router;
this.extendedPerms = extendedPerms;
this.extendedPermissions = extendedPermissions;
}
checkPermission(permission) {
if (this.extendedPermissions && permission) {
return requirePermission(permission);
}
return (res, req, next) => next();
}
get(path, handler, permission) {
if (this.extendedPerms && permission) {
this.app.get(
path,
requirePermission(permission),
this.checkPermission(permission),
handler.bind(this)
);
}
this.app.get(path, handler.bind(this));
}
post(path, handler, permission) {
if (this.extendedPerms && permission) {
this.app.post(
path,
requirePermission(permission),
this.checkPermission(permission),
handler.bind(this)
);
}
this.app.post(path, handler.bind(this));
}
put(path, handler, permission) {
if (this.extendedPerms && permission) {
this.app.put(
path,
requirePermission(permission),
this.checkPermission(permission),
handler.bind(this)
);
}
this.app.put(path, handler.bind(this));
}
delete(path, handler, permission) {
if (this.extendedPerms && permission) {
this.app.delete(
path,
requirePermission(permission),
this.checkPermission(permission),
handler.bind(this)
);
}
this.app.delete(path, handler.bind(this));
}
use(path, router) {
this.app.use(path, router);