UNPKG

@speckle/shared

Version:

Shared code between various Speckle JS packages

31 lines 1.57 kB
"use strict"; 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