@speckle/shared
Version:
Shared code between various Speckle JS packages
31 lines • 1.57 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.canCreateSavedViewPolicy = void 0;
const constants_js_1 = require("../../../../core/constants.js");
const index_js_1 = require("../../../../workspaces/index.js");
const authErrors_js_1 = require("../../../domain/authErrors.js");
const projects_js_1 = require("../../../fragments/projects.js");
const result_1 = require("true-myth/result");
const canCreateSavedViewPolicy = (loaders) => async ({ userId, projectId }) => {
const canUseSavedViews = await (0, projects_js_1.ensureCanUseProjectWorkspacePlanFeatureFragment)(loaders)({
projectId,
feature: index_js_1.WorkspacePlanFeatures.SavedViews
});
if (canUseSavedViews.isErr)
return (0, result_1.err)(canUseSavedViews.error);
const ensuredWriteAccess = await (0, projects_js_1.ensureImplicitProjectMemberWithWriteAccessFragment)(loaders)({
userId,
projectId,
role: constants_js_1.Roles.Stream.Contributor
});
if (ensuredWriteAccess.isErr) {
if (ensuredWriteAccess.error.code === 'ProjectNotEnoughPermissions')
return (0, result_1.err)(new authErrors_js_1.ProjectNotEnoughPermissionsError({
message: "Your role on this project doesn't give you permission to save views. You need the Can edit or Project owner role."
}));
return (0, result_1.err)(ensuredWriteAccess.error);
}
return (0, result_1.ok)();
};
exports.canCreateSavedViewPolicy = canCreateSavedViewPolicy;
//# sourceMappingURL=canCreate.js.map