budibase/packages/server/src/middleware/authorized.js

65 lines
1.7 KiB
JavaScript
Raw Normal View History

const {
BUILTIN_ROLE_IDS,
getUserPermissionIds,
} = require("../utilities/security/roles")
const {
PermissionTypes,
doesHavePermission,
} = require("../utilities/security/permissions")
const env = require("../environment")
const { isAPIKeyValid } = require("../utilities/security/apikey")
const { AuthTypes } = require("../constants")
2020-05-27 18:23:01 +02:00
const ADMIN_ROLES = [BUILTIN_ROLE_IDS.ADMIN, BUILTIN_ROLE_IDS.BUILDER]
const LOCAL_PASS = new RegExp(["webhooks/trigger", "webhooks/schema"].join("|"))
module.exports = (permType, permLevel = null) => async (ctx, next) => {
// webhooks can pass locally
if (!env.CLOUD && LOCAL_PASS.test(ctx.request.url)) {
return next()
}
if (env.CLOUD && ctx.headers["x-api-key"] && ctx.headers["x-instanceid"]) {
2020-10-12 12:57:37 +02:00
// api key header passed by external webhook
if (await isAPIKeyValid(ctx.headers["x-api-key"])) {
ctx.auth = {
authenticated: AuthTypes.EXTERNAL,
apiKey: ctx.headers["x-api-key"],
}
2020-10-12 12:57:37 +02:00
ctx.user = {
appId: ctx.headers["x-instanceid"],
2020-10-12 12:57:37 +02:00
}
return next()
}
ctx.throw(403, "API key invalid")
}
// don't expose builder endpoints in the cloud
if (env.CLOUD && permType === PermissionTypes.BUILDER) return
if (!ctx.auth.authenticated) {
2020-05-27 18:23:01 +02:00
ctx.throw(403, "Session not authenticated")
}
2020-06-18 17:59:31 +02:00
if (!ctx.user) {
ctx.throw(403, "User not found")
}
const role = ctx.user.role
const permissions = await getUserPermissionIds(ctx.appId, role._id)
if (ADMIN_ROLES.indexOf(role._id) !== -1) {
return next()
2020-05-27 18:23:01 +02:00
}
if (permType === PermissionTypes.BUILDER) {
2020-05-27 18:23:01 +02:00
ctx.throw(403, "Not Authorized")
}
if (!doesHavePermission(permType, permLevel, permissions)) {
ctx.throw(403, "User does not have permission")
}
2020-05-27 18:23:01 +02:00
return next()
2020-05-27 18:23:01 +02:00
}