@speckle/shared
Version:
Shared code between various Speckle JS packages
33 lines • 1.34 kB
JavaScript
import { err, ok } from 'true-myth/result';
import { Roles } from '../../../core/constants.js';
import { ensureImplicitProjectMemberWithWriteAccessFragment } from '../../fragments/projects.js';
import { ProjectNotEnoughPermissionsError } from '../../domain/authErrors.js';
import { checkIfAdminOverrideEnabledFragment } from '../../fragments/server.js';
export const canLoadPolicy = (loaders) => async ({ userId, projectId }) => {
if (publiclyLoadableProjects.includes(projectId)) {
return ok();
}
const hasAdminAccess = await checkIfAdminOverrideEnabledFragment(loaders)({
userId
});
if (hasAdminAccess.isOk && hasAdminAccess.value) {
return ok();
}
const ensuredWriteAccess = await ensureImplicitProjectMemberWithWriteAccessFragment(loaders)({
userId,
projectId,
role: Roles.Stream.Contributor
});
if (ensuredWriteAccess.isErr) {
if (ensuredWriteAccess.error.code === 'ProjectNotEnoughPermissions')
return err(new ProjectNotEnoughPermissionsError({
message: "Your role on this project doesn't give you permission to load."
}));
return err(ensuredWriteAccess.error);
}
return ok();
};
const publiclyLoadableProjects = [
'8be1007be1' // Demo models
];
//# sourceMappingURL=canLoad.js.map