budibase/packages/server/src/api/routes/permission.js

48 lines
1.4 KiB
JavaScript
Raw Normal View History

const Router = require("@koa/router")
const controller = require("../controllers/permission")
const authorized = require("../../middleware/authorized")
2021-02-05 16:58:25 +01:00
const {
BUILDER,
PermissionLevels,
} = require("@budibase/auth/permissions")
2021-02-05 16:58:25 +01:00
const Joi = require("joi")
const joiValidator = require("../../middleware/joi-validator")
const router = Router()
function generateValidator() {
2021-02-05 16:58:25 +01:00
const permLevelArray = Object.values(PermissionLevels)
// prettier-ignore
return joiValidator.params(Joi.object({
level: Joi.string().valid(...permLevelArray).required(),
resourceId: Joi.string(),
roleId: Joi.string(),
2021-02-05 16:58:25 +01:00
}).unknown(true))
}
router
.get("/api/permission/builtin", authorized(BUILDER), controller.fetchBuiltin)
.get("/api/permission/levels", authorized(BUILDER), controller.fetchLevels)
.get("/api/permission", authorized(BUILDER), controller.fetch)
.get(
"/api/permission/:resourceId",
authorized(BUILDER),
controller.getResourcePerms
)
// adding a specific role/level for the resource overrides the underlying access control
.post(
"/api/permission/:roleId/:resourceId/:level",
2021-02-05 16:58:25 +01:00
authorized(BUILDER),
generateValidator(),
2021-02-05 16:58:25 +01:00
controller.addPermission
)
// deleting the level defaults it back the underlying access control for the resource
.delete(
"/api/permission/:roleId/:resourceId/:level",
2021-02-05 16:58:25 +01:00
authorized(BUILDER),
generateValidator(),
2021-02-05 16:58:25 +01:00
controller.removePermission
)
module.exports = router