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

61 lines
1.5 KiB
JavaScript
Raw Normal View History

const { getUserPermissions } = require("../utilities/security/roles")
const {
PermissionTypes,
doesHaveResourcePermission,
doesHaveBasePermission,
} = require("../utilities/security/permissions")
function hasResource(ctx) {
return ctx.resourceId != null
}
const WEBHOOK_ENDPOINTS = new RegExp(
["webhooks/trigger", "webhooks/schema"].join("|")
)
2020-10-12 12:57:37 +02:00
module.exports = (permType, permLevel = null) => async (ctx, next) => {
// webhooks don't need authentication, each webhook unique
if (WEBHOOK_ENDPOINTS.test(ctx.request.url)) {
return next()
2020-10-12 12:57:37 +02:00
}
2020-06-18 17:59:31 +02:00
if (!ctx.user) {
2021-03-09 12:27:12 +01:00
return ctx.throw(403, "No user info found")
2020-06-18 17:59:31 +02:00
}
2021-04-11 12:35:55 +02:00
const isAuthed = ctx.isAuthenticated
const { basePermissions, permissions } = await getUserPermissions(
ctx.appId,
ctx.roleId
)
2020-05-27 18:23:01 +02:00
// TODO: need to determine if the user has permission to build here, global cookie
// this may need to change in the future, right now only admins
// can have access to builder features, this is hard coded into
// our rules
2021-04-12 12:20:01 +02:00
if (isAuthed) {
return next()
} else if (permType === PermissionTypes.BUILDER) {
return ctx.throw(403, "Not Authorized")
}
2020-05-27 18:23:01 +02:00
if (
hasResource(ctx) &&
doesHaveResourcePermission(permissions, permLevel, ctx)
) {
return next()
}
if (!isAuthed) {
ctx.throw(403, "Session not authenticated")
}
if (!doesHaveBasePermission(permType, permLevel, basePermissions)) {
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
}