Some fixes post testing.

This commit is contained in:
mike12345567 2023-07-25 18:52:59 +01:00
parent 66fbdfe4e8
commit 43bfb943a3
5 changed files with 23 additions and 16 deletions

View File

@ -10,6 +10,7 @@ import { getAccountByTenantId } from "../accounts"
// extract from shared-core to make easily accessible from backend-core // extract from shared-core to make easily accessible from backend-core
export const isBuilder = sdk.users.isBuilder export const isBuilder = sdk.users.isBuilder
export const isAdmin = sdk.users.isAdmin export const isAdmin = sdk.users.isAdmin
export const isGlobalBuilder = sdk.users.isGlobalBuilder
export const isAdminOrBuilder = sdk.users.isAdminOrBuilder export const isAdminOrBuilder = sdk.users.isAdminOrBuilder
export const hasAdminPermissions = sdk.users.hasAdminPermissions export const hasAdminPermissions = sdk.users.hasAdminPermissions
export const hasBuilderPermissions = sdk.users.hasBuilderPermissions export const hasBuilderPermissions = sdk.users.hasBuilderPermissions

View File

@ -14,6 +14,10 @@ export function isBuilder(user: User | ContextUser, appId?: string) {
return false return false
} }
export function isGlobalBuilder(user: User | ContextUser) {
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

View File

@ -447,17 +447,20 @@ export const grantAppBuilder = async (ctx: Ctx) => {
export const addAppBuilder = async (ctx: Ctx) => { export const addAppBuilder = async (ctx: Ctx) => {
const { userId, appId } = ctx.params const { userId, appId } = ctx.params
const user = await userSdk.db.getUser(userId) const user = await userSdk.db.getUser(userId)
if (!user.builder?.global || user.admin?.global) { if (!user.builder?.appBuilder && !userSdk.core.isGlobalBuilder(user)) {
ctx.body = { message: "User already admin - no permissions updated." }
return
}
if (!user.builder?.appBuilder) {
ctx.throw( ctx.throw(
400, 400,
"Unable to update access, user must be granted app builder permissions." "Unable to update access, user must be granted app builder permissions."
) )
} }
if (userSdk.core.isGlobalBuilder(user)) {
ctx.body = { message: "User already admin - no permissions updated." }
return
}
const prodAppId = dbCore.getProdAppID(appId) const prodAppId = dbCore.getProdAppID(appId)
if (!user.builder) {
user.builder = {}
}
if (!user.builder.apps) { if (!user.builder.apps) {
user.builder.apps = [] user.builder.apps = []
} }
@ -469,19 +472,19 @@ export const addAppBuilder = async (ctx: Ctx) => {
export const removeAppBuilder = async (ctx: Ctx) => { export const removeAppBuilder = async (ctx: Ctx) => {
const { userId, appId } = ctx.params const { userId, appId } = ctx.params
const user = await userSdk.db.getUser(userId) const user = await userSdk.db.getUser(userId)
if (!user.builder?.global || user.admin?.global) { if (!user.builder?.appBuilder && !userSdk.core.isGlobalBuilder(user)) {
ctx.body = { message: "User already admin - no permissions removed." }
return
}
if (!user.builder?.appBuilder) {
ctx.throw( ctx.throw(
400, 400,
"Unable to update access, user must be granted app builder permissions." "Unable to update access, user must be granted app builder permissions."
) )
} }
if (userSdk.core.isGlobalBuilder(user)) {
ctx.body = { message: "User already admin - no permissions removed." }
return
}
const prodAppId = dbCore.getProdAppID(appId) const prodAppId = dbCore.getProdAppID(appId)
const indexOf = user.builder?.apps?.indexOf(prodAppId) const indexOf = user.builder?.apps?.indexOf(prodAppId)
if (indexOf && indexOf !== -1) { if (user.builder && indexOf != undefined && indexOf !== -1) {
user.builder.apps = user.builder.apps!.splice(indexOf, 1) user.builder.apps = user.builder.apps!.splice(indexOf, 1)
} }
await userSdk.db.save(user, { hashPassword: false }) await userSdk.db.save(user, { hashPassword: false })

View File

@ -48,7 +48,7 @@ describe("/api/global/users/:userId/app/builder", () => {
await config.api.users.grantBuilderToApp(user._id!, MOCK_APP_ID) await config.api.users.grantBuilderToApp(user._id!, MOCK_APP_ID)
const updated = await getUser(user._id!) const updated = await getUser(user._id!)
expect(updated.builder?.appBuilder).toBe(true) expect(updated.builder?.appBuilder).toBe(true)
expect(updated.builder?.apps).toBe([MOCK_APP_ID]) expect(updated.builder?.apps![0]).toBe(MOCK_APP_ID)
}) })
}) })
@ -57,10 +57,10 @@ describe("/api/global/users/:userId/app/builder", () => {
const user = await grantAppBuilder() const user = await grantAppBuilder()
await config.api.users.grantBuilderToApp(user._id!, MOCK_APP_ID) await config.api.users.grantBuilderToApp(user._id!, MOCK_APP_ID)
let updated = await getUser(user._id!) let updated = await getUser(user._id!)
expect(updated.builder?.apps).toBe([MOCK_APP_ID]) expect(updated.builder?.apps![0]).toBe(MOCK_APP_ID)
await config.api.users.revokeBuilderToApp(user._id!, MOCK_APP_ID) await config.api.users.revokeBuilderToApp(user._id!, MOCK_APP_ID)
updated = await getUser(user._id!) updated = await getUser(user._id!)
expect(updated.builder?.apps).toBe([]) expect(updated.builder?.apps!.length).toBe(0)
}) })
}) })
}) })

View File

@ -163,8 +163,7 @@ export class UserAPI extends TestAPI {
revokeBuilderToApp = ( revokeBuilderToApp = (
userId: string, userId: string,
appId: string, appId: string
statusCode: number = 200
) => { ) => {
return this.request return this.request
.delete(`/api/global/users/${userId}/app/${appId}/builder`) .delete(`/api/global/users/${userId}/app/${appId}/builder`)