Files
speckle-server/packages/server/modules/core/authz.ts
T
Gergő Jedlicska 968d2f2520 auth/lib (#4242)
* wip

* wip

* feat(authz): wip policy shape

* wip

* fix(authz): canReadProject with latest pattern

* wip

* feat(shared): simplify authz checks and policies

* feat(shared): port role weights into shared

* test(shared): some more tests for authz

* test(shared): more query project tests

* typo!

* feat(shared): ff loading refinements

* feat(shared): example authorization policy integration

* authz loaders init

* chore(authz): naming etc

* wip

* fix(authz): authz error objects

Co-authored-by: Kristaps Fabians Geikins <fabis94@users.noreply.github.com>
Co-authored-by: Gergő Jedlicska <gjedlicska@users.noreply.github.com>

* fix(authz): use correct role weights

* chore(authz): use codes from errors in tests

* chore(authz): wow

* chore(authz): fix more tests, add more tests

* chore(authz): fix some tests, add some tests (again)

* fix(authz): fix tests again

* fix(server): you need to await !!!! otherwise it crashes the server.

---------

Co-authored-by: Charles Driesler <chuck@speckle.systems>
Co-authored-by: Kristaps Fabians Geikins <fabis94@users.noreply.github.com>
Co-authored-by: Gergő Jedlicska <gjedlicska@users.noreply.github.com>
2025-03-21 16:37:36 +01:00

28 lines
997 B
TypeScript

import { getStreamFactory } from '@/modules/core/repositories/streams'
import { defineLoaders } from '@/modules/loaders'
import { getFeatureFlags } from '@/modules/shared/helpers/envHelper'
import { db } from '@/db/knex'
import { getUserServerRoleFactory } from '@/modules/shared/repositories/acl'
export const defineModuleLoaders = () => {
const getStream = getStreamFactory({ db })
const getUserServerRole = getUserServerRoleFactory({ db })
defineLoaders({
getEnv: getFeatureFlags,
getProject: async ({ projectId }) => {
const project = await getStream({ streamId: projectId })
if (!project) return null
return { ...project, projectId: project.id }
},
getProjectRole: async ({ userId, projectId }) => {
const project = await getStream({ streamId: projectId, userId })
return project?.role ?? null
},
getServerRole: async ({ userId }) => {
const role = await getUserServerRole({ userId })
return role ?? null
}
})
}