Handling role numbering.

This commit is contained in:
mike12345567 2024-10-14 18:00:41 +01:00
parent 243391d6cb
commit 676cb3f92e
1 changed files with 24 additions and 5 deletions

View File

@ -157,7 +157,7 @@ export function builtinRoleToNumber(id: string) {
break break
} }
if (Array.isArray(role.inherits)) { if (Array.isArray(role.inherits)) {
// TODO: role inheritance throw new Error("Built-in roles don't support multi-inheritance")
} else { } else {
role = builtins[role.inherits!] role = builtins[role.inherits!]
} }
@ -176,18 +176,37 @@ export async function roleToNumber(id: string) {
const hierarchy = (await getUserRoleHierarchy(id, { const hierarchy = (await getUserRoleHierarchy(id, {
defaultPublic: true, defaultPublic: true,
})) as RoleDoc[] })) as RoleDoc[]
for (let role of hierarchy) { const findNumber = (role: RoleDoc): number => {
if (!role.inherits) { if (!role.inherits) {
continue return 0
} }
if (Array.isArray(role.inherits)) { if (Array.isArray(role.inherits)) {
// TODO: role inheritance // find the built-in roles, get their number, sort it, then get the last one
const highestBuiltin: number | undefined = role.inherits
.map(roleId => {
const foundRole = hierarchy.find(role => role._id === roleId)
if (foundRole) {
return findNumber(foundRole) + 1
}
})
.filter(number => !!number)
.sort()
.pop()
if (highestBuiltin != undefined) {
return highestBuiltin
}
} else if (isBuiltin(role.inherits)) { } else if (isBuiltin(role.inherits)) {
return builtinRoleToNumber(role.inherits) + 1 return builtinRoleToNumber(role.inherits) + 1
} }
}
return 0 return 0
} }
let highest = 0
for (let role of hierarchy) {
const roleNumber = findNumber(role)
highest = Math.max(roleNumber, highest)
}
return highest
}
/** /**
* Returns whichever builtin roleID is lower. * Returns whichever builtin roleID is lower.