Making sure booleans returned from user role functions in shared core.
This commit is contained in:
parent
f18b9d7a70
commit
52d05c2910
|
@ -2,7 +2,7 @@ import { ContextUser, User } from "@budibase/types"
|
||||||
import { getProdAppID } from "./applications"
|
import { getProdAppID } from "./applications"
|
||||||
|
|
||||||
// checks if a user is specifically a builder, given an app ID
|
// checks if a user is specifically a builder, given an app ID
|
||||||
export function isBuilder(user: User | ContextUser, appId?: string) {
|
export function isBuilder(user: User | ContextUser, appId?: string): boolean {
|
||||||
if (!user) {
|
if (!user) {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
@ -14,35 +14,36 @@ export function isBuilder(user: User | ContextUser, appId?: string) {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
export function isGlobalBuilder(user: User | ContextUser) {
|
export function isGlobalBuilder(user: User | ContextUser): boolean {
|
||||||
return (isBuilder(user) && !hasAppBuilderPermissions(user)) || isAdmin(user)
|
return (isBuilder(user) && !hasAppBuilderPermissions(user)) || isAdmin(user)
|
||||||
}
|
}
|
||||||
|
|
||||||
// alias for hasAdminPermission, currently do the same thing
|
// alias for hasAdminPermission, currently do the same thing
|
||||||
// in future whether someone has admin permissions and whether they are
|
// in future whether someone has admin permissions and whether they are
|
||||||
// an admin for a specific resource could be separated
|
// an admin for a specific resource could be separated
|
||||||
export function isAdmin(user: User | ContextUser) {
|
export function isAdmin(user: User | ContextUser): boolean {
|
||||||
if (!user) {
|
if (!user) {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
return hasAdminPermissions(user)
|
return hasAdminPermissions(user)
|
||||||
}
|
}
|
||||||
|
|
||||||
export function isAdminOrBuilder(user: User | ContextUser, appId?: string) {
|
export function isAdminOrBuilder(user: User | ContextUser, appId?: string): boolean {
|
||||||
return isBuilder(user, appId) || isAdmin(user)
|
return isBuilder(user, appId) || isAdmin(user)
|
||||||
}
|
}
|
||||||
|
|
||||||
// check if they are a builder within an app (not necessarily a global builder)
|
// check if they are a builder within an app (not necessarily a global builder)
|
||||||
export function hasAppBuilderPermissions(user?: User | ContextUser) {
|
export function hasAppBuilderPermissions(user?: User | ContextUser): boolean {
|
||||||
if (!user) {
|
if (!user) {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
const appLength = user.builder?.apps?.length
|
const appLength = user.builder?.apps?.length
|
||||||
return !user.builder?.global && appLength && appLength > 0
|
const isGlobalBuilder = !!user.builder?.global
|
||||||
|
return !isGlobalBuilder && appLength != null && appLength > 0
|
||||||
}
|
}
|
||||||
|
|
||||||
// checks if a user is capable of building any app
|
// checks if a user is capable of building any app
|
||||||
export function hasBuilderPermissions(user?: User | ContextUser) {
|
export function hasBuilderPermissions(user?: User | ContextUser): boolean {
|
||||||
if (!user) {
|
if (!user) {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
@ -50,9 +51,9 @@ export function hasBuilderPermissions(user?: User | ContextUser) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// checks if a user is capable of being an admin
|
// checks if a user is capable of being an admin
|
||||||
export function hasAdminPermissions(user?: User | ContextUser) {
|
export function hasAdminPermissions(user?: User | ContextUser): boolean {
|
||||||
if (!user) {
|
if (!user) {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
return user.admin?.global
|
return !!user.admin?.global
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue