@synchronized-console/shared 2.25.7 → 2.31.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/commonjs/acc/helpers/types.d.ts +46 -0
- package/dist/commonjs/acc/helpers/types.d.ts.map +1 -0
- package/dist/commonjs/acc/helpers/types.js +3 -0
- package/dist/commonjs/acc/helpers/types.js.map +1 -0
- package/dist/commonjs/acc/index.d.ts +2 -0
- package/dist/commonjs/acc/index.d.ts.map +1 -0
- package/dist/commonjs/acc/index.js +18 -0
- package/dist/commonjs/acc/index.js.map +1 -0
- package/dist/commonjs/authz/checks/dashboards.d.ts +5 -0
- package/dist/commonjs/authz/checks/dashboards.d.ts.map +1 -0
- package/dist/commonjs/authz/checks/dashboards.js +11 -0
- package/dist/commonjs/authz/checks/dashboards.js.map +1 -0
- package/dist/commonjs/authz/domain/authErrors.d.ts +98 -3
- package/dist/commonjs/authz/domain/authErrors.d.ts.map +1 -1
- package/dist/commonjs/authz/domain/authErrors.js +66 -3
- package/dist/commonjs/authz/domain/authErrors.js.map +1 -1
- package/dist/commonjs/authz/domain/automate/operations.d.ts +5 -0
- package/dist/commonjs/authz/domain/automate/operations.d.ts.map +1 -0
- package/dist/commonjs/authz/domain/automate/operations.js +3 -0
- package/dist/commonjs/authz/domain/automate/operations.js.map +1 -0
- package/dist/commonjs/authz/domain/automate/types.d.ts +10 -0
- package/dist/commonjs/authz/domain/automate/types.d.ts.map +1 -0
- package/dist/commonjs/authz/domain/automate/types.js +3 -0
- package/dist/commonjs/authz/domain/automate/types.js.map +1 -0
- package/dist/commonjs/authz/domain/context.d.ts +12 -0
- package/dist/commonjs/authz/domain/context.d.ts.map +1 -1
- package/dist/commonjs/authz/domain/dashboards/operations.d.ts +5 -0
- package/dist/commonjs/authz/domain/dashboards/operations.d.ts.map +1 -0
- package/dist/commonjs/authz/domain/dashboards/operations.js +3 -0
- package/dist/commonjs/authz/domain/dashboards/operations.js.map +1 -0
- package/dist/commonjs/authz/domain/dashboards/types.d.ts +7 -0
- package/dist/commonjs/authz/domain/dashboards/types.d.ts.map +1 -0
- package/dist/commonjs/authz/domain/dashboards/types.js +3 -0
- package/dist/commonjs/authz/domain/dashboards/types.js.map +1 -0
- package/dist/commonjs/authz/domain/loaders.d.ts +63 -45
- package/dist/commonjs/authz/domain/loaders.d.ts.map +1 -1
- package/dist/commonjs/authz/domain/loaders.js +27 -21
- package/dist/commonjs/authz/domain/loaders.js.map +1 -1
- package/dist/commonjs/authz/domain/savedViews/operations.d.ts +10 -0
- package/dist/commonjs/authz/domain/savedViews/operations.d.ts.map +1 -0
- package/dist/commonjs/authz/domain/savedViews/operations.js +3 -0
- package/dist/commonjs/authz/domain/savedViews/operations.js.map +1 -0
- package/dist/commonjs/authz/domain/savedViews/types.d.ts +26 -0
- package/dist/commonjs/authz/domain/savedViews/types.d.ts.map +1 -0
- package/dist/commonjs/authz/domain/savedViews/types.js +6 -0
- package/dist/commonjs/authz/domain/savedViews/types.js.map +1 -0
- package/dist/commonjs/authz/domain/workspaces/operations.d.ts +2 -1
- package/dist/commonjs/authz/domain/workspaces/operations.d.ts.map +1 -1
- package/dist/commonjs/authz/domain/workspaces/types.d.ts +3 -0
- package/dist/commonjs/authz/domain/workspaces/types.d.ts.map +1 -1
- package/dist/commonjs/authz/fragments/automate.d.ts +7 -0
- package/dist/commonjs/authz/fragments/automate.d.ts.map +1 -0
- package/dist/commonjs/authz/fragments/automate.js +22 -0
- package/dist/commonjs/authz/fragments/automate.js.map +1 -0
- package/dist/commonjs/authz/fragments/dashboards.d.ts +8 -0
- package/dist/commonjs/authz/fragments/dashboards.d.ts.map +1 -0
- package/dist/commonjs/authz/fragments/dashboards.js +48 -0
- package/dist/commonjs/authz/fragments/dashboards.js.map +1 -0
- package/dist/commonjs/authz/fragments/projects.d.ts +13 -1
- package/dist/commonjs/authz/fragments/projects.d.ts.map +1 -1
- package/dist/commonjs/authz/fragments/projects.js +25 -1
- package/dist/commonjs/authz/fragments/projects.js.map +1 -1
- package/dist/commonjs/authz/fragments/savedViews.d.ts +30 -0
- package/dist/commonjs/authz/fragments/savedViews.d.ts.map +1 -0
- package/dist/commonjs/authz/fragments/savedViews.js +122 -0
- package/dist/commonjs/authz/fragments/savedViews.js.map +1 -0
- package/dist/commonjs/authz/fragments/workspaces.d.ts +9 -1
- package/dist/commonjs/authz/fragments/workspaces.d.ts.map +1 -1
- package/dist/commonjs/authz/fragments/workspaces.js +47 -1
- package/dist/commonjs/authz/fragments/workspaces.js.map +1 -1
- package/dist/commonjs/authz/helpers/graphql.d.ts +1 -1
- package/dist/commonjs/authz/helpers/graphql.d.ts.map +1 -1
- package/dist/commonjs/authz/helpers/graphql.js +1 -1
- package/dist/commonjs/authz/helpers/graphql.js.map +1 -1
- package/dist/commonjs/authz/index.d.ts +1 -0
- package/dist/commonjs/authz/index.d.ts.map +1 -1
- package/dist/commonjs/authz/index.js +1 -0
- package/dist/commonjs/authz/index.js.map +1 -1
- package/dist/commonjs/authz/policies/automate/function/canEditFunction.d.ts +10 -0
- package/dist/commonjs/authz/policies/automate/function/canEditFunction.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/automate/function/canEditFunction.js +19 -0
- package/dist/commonjs/authz/policies/automate/function/canEditFunction.js.map +1 -0
- package/dist/commonjs/authz/policies/dashboard/canCreateToken.d.ts +10 -0
- package/dist/commonjs/authz/policies/dashboard/canCreateToken.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/dashboard/canCreateToken.js +45 -0
- package/dist/commonjs/authz/policies/dashboard/canCreateToken.js.map +1 -0
- package/dist/commonjs/authz/policies/dashboard/canDelete.d.ts +10 -0
- package/dist/commonjs/authz/policies/dashboard/canDelete.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/dashboard/canDelete.js +45 -0
- package/dist/commonjs/authz/policies/dashboard/canDelete.js.map +1 -0
- package/dist/commonjs/authz/policies/dashboard/canEdit.d.ts +10 -0
- package/dist/commonjs/authz/policies/dashboard/canEdit.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/dashboard/canEdit.js +43 -0
- package/dist/commonjs/authz/policies/dashboard/canEdit.js.map +1 -0
- package/dist/commonjs/authz/policies/dashboard/canRead.d.ts +10 -0
- package/dist/commonjs/authz/policies/dashboard/canRead.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/dashboard/canRead.js +42 -0
- package/dist/commonjs/authz/policies/dashboard/canRead.js.map +1 -0
- package/dist/commonjs/authz/policies/index.d.ts +62 -1
- package/dist/commonjs/authz/policies/index.d.ts.map +1 -1
- package/dist/commonjs/authz/policies/index.js +52 -4
- package/dist/commonjs/authz/policies/index.js.map +1 -1
- package/dist/commonjs/authz/policies/project/canLoad.d.ts.map +1 -1
- package/dist/commonjs/authz/policies/project/canLoad.js +6 -0
- package/dist/commonjs/authz/policies/project/canLoad.js.map +1 -1
- package/dist/commonjs/authz/policies/project/canReadAccIntegrationSettings.d.ts +10 -0
- package/dist/commonjs/authz/policies/project/canReadAccIntegrationSettings.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/project/canReadAccIntegrationSettings.js +35 -0
- package/dist/commonjs/authz/policies/project/canReadAccIntegrationSettings.js.map +1 -0
- package/dist/commonjs/authz/policies/project/canUpdateEmbedTokens.d.ts +10 -0
- package/dist/commonjs/authz/policies/project/canUpdateEmbedTokens.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/project/canUpdateEmbedTokens.js +52 -0
- package/dist/commonjs/authz/policies/project/canUpdateEmbedTokens.js.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canCreate.d.ts +6 -0
- package/dist/commonjs/authz/policies/project/savedViews/canCreate.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canCreate.js +31 -0
- package/dist/commonjs/authz/policies/project/savedViews/canCreate.js.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canCreateSavedViewGroupToken.d.ts +6 -0
- package/dist/commonjs/authz/policies/project/savedViews/canCreateSavedViewGroupToken.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canCreateSavedViewGroupToken.js +61 -0
- package/dist/commonjs/authz/policies/project/savedViews/canCreateSavedViewGroupToken.js.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canEditDescription.d.ts +6 -0
- package/dist/commonjs/authz/policies/project/savedViews/canEditDescription.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canEditDescription.js +14 -0
- package/dist/commonjs/authz/policies/project/savedViews/canEditDescription.js.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canEditTitle.d.ts +6 -0
- package/dist/commonjs/authz/policies/project/savedViews/canEditTitle.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canEditTitle.js +14 -0
- package/dist/commonjs/authz/policies/project/savedViews/canEditTitle.js.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canMove.d.ts +6 -0
- package/dist/commonjs/authz/policies/project/savedViews/canMove.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canMove.js +14 -0
- package/dist/commonjs/authz/policies/project/savedViews/canMove.js.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canRead.d.ts +11 -0
- package/dist/commonjs/authz/policies/project/savedViews/canRead.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canRead.js +15 -0
- package/dist/commonjs/authz/policies/project/savedViews/canRead.js.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canSetAsHomeView.d.ts +6 -0
- package/dist/commonjs/authz/policies/project/savedViews/canSetAsHomeView.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canSetAsHomeView.js +45 -0
- package/dist/commonjs/authz/policies/project/savedViews/canSetAsHomeView.js.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canUpdate.d.ts +6 -0
- package/dist/commonjs/authz/policies/project/savedViews/canUpdate.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canUpdate.js +14 -0
- package/dist/commonjs/authz/policies/project/savedViews/canUpdate.js.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canUpdateGroup.d.ts +6 -0
- package/dist/commonjs/authz/policies/project/savedViews/canUpdateGroup.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/project/savedViews/canUpdateGroup.js +14 -0
- package/dist/commonjs/authz/policies/project/savedViews/canUpdateGroup.js.map +1 -0
- package/dist/commonjs/authz/policies/workspace/canCreateDashboards.d.ts +10 -0
- package/dist/commonjs/authz/policies/workspace/canCreateDashboards.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/workspace/canCreateDashboards.js +39 -0
- package/dist/commonjs/authz/policies/workspace/canCreateDashboards.js.map +1 -0
- package/dist/commonjs/authz/policies/workspace/canCreateWorkspace.d.ts +10 -0
- package/dist/commonjs/authz/policies/workspace/canCreateWorkspace.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/workspace/canCreateWorkspace.js +51 -0
- package/dist/commonjs/authz/policies/workspace/canCreateWorkspace.js.map +1 -0
- package/dist/commonjs/authz/policies/workspace/canListDashboards.d.ts +10 -0
- package/dist/commonjs/authz/policies/workspace/canListDashboards.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/workspace/canListDashboards.js +26 -0
- package/dist/commonjs/authz/policies/workspace/canListDashboards.js.map +1 -0
- package/dist/commonjs/authz/policies/workspace/canReadMemberEmail.d.ts +1 -1
- package/dist/commonjs/authz/policies/workspace/canReadMemberEmail.d.ts.map +1 -1
- package/dist/commonjs/authz/policies/workspace/canReadMemberEmail.js +1 -20
- package/dist/commonjs/authz/policies/workspace/canReadMemberEmail.js.map +1 -1
- package/dist/commonjs/authz/policies/workspace/{canUpdateEmbedOptions.d.ts → canUseWorkspacePlanFeature.d.ts} +13 -5
- package/dist/commonjs/authz/policies/workspace/canUseWorkspacePlanFeature.d.ts.map +1 -0
- package/dist/commonjs/authz/policies/workspace/canUseWorkspacePlanFeature.js +27 -0
- package/dist/commonjs/authz/policies/workspace/canUseWorkspacePlanFeature.js.map +1 -0
- package/dist/commonjs/automate/helpers/types.d.ts +313 -51
- package/dist/commonjs/automate/helpers/types.d.ts.map +1 -1
- package/dist/commonjs/automate/helpers/types.js +12 -2
- package/dist/commonjs/automate/helpers/types.js.map +1 -1
- package/dist/commonjs/blobs/index.d.ts +17 -0
- package/dist/commonjs/blobs/index.d.ts.map +1 -0
- package/dist/commonjs/blobs/index.js +114 -0
- package/dist/commonjs/blobs/index.js.map +1 -0
- package/dist/commonjs/core/constants.d.ts +4 -2
- package/dist/commonjs/core/constants.d.ts.map +1 -1
- package/dist/commonjs/core/constants.js +24 -4
- package/dist/commonjs/core/constants.js.map +1 -1
- package/dist/commonjs/core/helpers/encoding.d.ts +2 -0
- package/dist/commonjs/core/helpers/encoding.d.ts.map +1 -0
- package/dist/commonjs/core/helpers/encoding.js +15 -0
- package/dist/commonjs/core/helpers/encoding.js.map +1 -0
- package/dist/commonjs/core/helpers/error.d.ts +11 -0
- package/dist/commonjs/core/helpers/error.d.ts.map +1 -1
- package/dist/commonjs/core/helpers/error.js +60 -2
- package/dist/commonjs/core/helpers/error.js.map +1 -1
- package/dist/commonjs/core/helpers/url.d.ts +24 -0
- package/dist/commonjs/core/helpers/url.d.ts.map +1 -1
- package/dist/commonjs/core/helpers/url.js +30 -0
- package/dist/commonjs/core/helpers/url.js.map +1 -1
- package/dist/commonjs/core/helpers/utility.d.ts +16 -0
- package/dist/commonjs/core/helpers/utility.d.ts.map +1 -1
- package/dist/commonjs/core/helpers/utility.js +22 -1
- package/dist/commonjs/core/helpers/utility.js.map +1 -1
- package/dist/commonjs/core/index.d.ts +2 -0
- package/dist/commonjs/core/index.d.ts.map +1 -1
- package/dist/commonjs/core/index.js +2 -0
- package/dist/commonjs/core/index.js.map +1 -1
- package/dist/commonjs/core/utils/base64.d.ts +3 -0
- package/dist/commonjs/core/utils/base64.d.ts.map +1 -0
- package/dist/commonjs/core/utils/base64.js +25 -0
- package/dist/commonjs/core/utils/base64.js.map +1 -0
- package/dist/commonjs/environment/{multiRegionConfig.d.ts → db.d.ts} +54 -5
- package/dist/commonjs/environment/db.d.ts.map +1 -0
- package/dist/commonjs/environment/{multiRegionConfig.js → db.js} +45 -10
- package/dist/commonjs/environment/db.js.map +1 -0
- package/dist/commonjs/environment/featureFlags.d.ts +25 -0
- package/dist/commonjs/environment/featureFlags.d.ts.map +1 -0
- package/dist/commonjs/environment/featureFlags.js +6 -0
- package/dist/commonjs/environment/featureFlags.js.map +1 -0
- package/dist/commonjs/environment/index.d.ts +2 -15
- package/dist/commonjs/environment/index.d.ts.map +1 -1
- package/dist/commonjs/environment/index.js +44 -7
- package/dist/commonjs/environment/index.js.map +1 -1
- package/dist/commonjs/environment/node.d.ts +5 -0
- package/dist/commonjs/environment/node.d.ts.map +1 -0
- package/dist/commonjs/environment/node.js +15 -0
- package/dist/commonjs/environment/node.js.map +1 -0
- package/dist/commonjs/images/base64.d.ts +2 -0
- package/dist/commonjs/images/base64.d.ts.map +1 -0
- package/dist/commonjs/images/base64.js +19 -0
- package/dist/commonjs/images/base64.js.map +1 -0
- package/dist/commonjs/index.d.ts +1 -0
- package/dist/commonjs/index.d.ts.map +1 -1
- package/dist/commonjs/index.js +1 -0
- package/dist/commonjs/index.js.map +1 -1
- package/dist/commonjs/observability/index.d.ts.map +1 -1
- package/dist/commonjs/observability/index.js +19 -2
- package/dist/commonjs/observability/index.js.map +1 -1
- package/dist/commonjs/queue/config.d.ts +3 -0
- package/dist/commonjs/queue/config.d.ts.map +1 -1
- package/dist/commonjs/queue/config.js +14 -5
- package/dist/commonjs/queue/config.js.map +1 -1
- package/dist/commonjs/rich-text-editor/helpers/index.d.ts +13 -1
- package/dist/commonjs/rich-text-editor/helpers/index.d.ts.map +1 -1
- package/dist/commonjs/rich-text-editor/helpers/index.js +1 -0
- package/dist/commonjs/rich-text-editor/helpers/index.js.map +1 -1
- package/dist/commonjs/saved-views/helpers/defaultGroup.d.ts +23 -0
- package/dist/commonjs/saved-views/helpers/defaultGroup.d.ts.map +1 -0
- package/dist/commonjs/saved-views/helpers/defaultGroup.js +58 -0
- package/dist/commonjs/saved-views/helpers/defaultGroup.js.map +1 -0
- package/dist/commonjs/saved-views/index.d.ts +2 -0
- package/dist/commonjs/saved-views/index.d.ts.map +1 -0
- package/dist/commonjs/saved-views/index.js +18 -0
- package/dist/commonjs/saved-views/index.js.map +1 -0
- package/dist/commonjs/viewer/helpers/route.d.ts +42 -7
- package/dist/commonjs/viewer/helpers/route.d.ts.map +1 -1
- package/dist/commonjs/viewer/helpers/route.js +149 -38
- package/dist/commonjs/viewer/helpers/route.js.map +1 -1
- package/dist/commonjs/viewer/helpers/state.d.ts +59 -6
- package/dist/commonjs/viewer/helpers/state.d.ts.map +1 -1
- package/dist/commonjs/viewer/helpers/state.js +100 -23
- package/dist/commonjs/viewer/helpers/state.js.map +1 -1
- package/dist/commonjs/workers/fileimport/job.d.ts +85 -9
- package/dist/commonjs/workers/fileimport/job.d.ts.map +1 -1
- package/dist/commonjs/workers/fileimport/job.js +21 -10
- package/dist/commonjs/workers/fileimport/job.js.map +1 -1
- package/dist/commonjs/workers/previews/job.d.ts +37 -20
- package/dist/commonjs/workers/previews/job.d.ts.map +1 -1
- package/dist/commonjs/workers/previews/job.js +23 -2
- package/dist/commonjs/workers/previews/job.js.map +1 -1
- package/dist/commonjs/workspaces/helpers/features.d.ts +55 -5
- package/dist/commonjs/workspaces/helpers/features.d.ts.map +1 -1
- package/dist/commonjs/workspaces/helpers/features.js +180 -114
- package/dist/commonjs/workspaces/helpers/features.js.map +1 -1
- package/dist/commonjs/workspaces/helpers/plans.d.ts +1 -0
- package/dist/commonjs/workspaces/helpers/plans.d.ts.map +1 -1
- package/dist/commonjs/workspaces/helpers/plans.js.map +1 -1
- package/dist/esm/acc/helpers/types.d.ts +46 -0
- package/dist/esm/acc/helpers/types.d.ts.map +1 -0
- package/dist/esm/acc/helpers/types.js +2 -0
- package/dist/esm/acc/helpers/types.js.map +1 -0
- package/dist/esm/acc/index.d.ts +2 -0
- package/dist/esm/acc/index.d.ts.map +1 -0
- package/dist/esm/acc/index.js +2 -0
- package/dist/esm/acc/index.js.map +1 -0
- package/dist/esm/authz/checks/dashboards.d.ts +5 -0
- package/dist/esm/authz/checks/dashboards.d.ts.map +1 -0
- package/dist/esm/authz/checks/dashboards.js +7 -0
- package/dist/esm/authz/checks/dashboards.js.map +1 -0
- package/dist/esm/authz/domain/authErrors.d.ts +98 -3
- package/dist/esm/authz/domain/authErrors.d.ts.map +1 -1
- package/dist/esm/authz/domain/authErrors.js +65 -2
- package/dist/esm/authz/domain/authErrors.js.map +1 -1
- package/dist/esm/authz/domain/automate/operations.d.ts +5 -0
- package/dist/esm/authz/domain/automate/operations.d.ts.map +1 -0
- package/dist/esm/authz/domain/automate/operations.js +2 -0
- package/dist/esm/authz/domain/automate/operations.js.map +1 -0
- package/dist/esm/authz/domain/automate/types.d.ts +10 -0
- package/dist/esm/authz/domain/automate/types.d.ts.map +1 -0
- package/dist/esm/authz/domain/automate/types.js +2 -0
- package/dist/esm/authz/domain/automate/types.js.map +1 -0
- package/dist/esm/authz/domain/context.d.ts +12 -0
- package/dist/esm/authz/domain/context.d.ts.map +1 -1
- package/dist/esm/authz/domain/dashboards/operations.d.ts +5 -0
- package/dist/esm/authz/domain/dashboards/operations.d.ts.map +1 -0
- package/dist/esm/authz/domain/dashboards/operations.js +2 -0
- package/dist/esm/authz/domain/dashboards/operations.js.map +1 -0
- package/dist/esm/authz/domain/dashboards/types.d.ts +7 -0
- package/dist/esm/authz/domain/dashboards/types.d.ts.map +1 -0
- package/dist/esm/authz/domain/dashboards/types.js +2 -0
- package/dist/esm/authz/domain/dashboards/types.js.map +1 -0
- package/dist/esm/authz/domain/loaders.d.ts +63 -45
- package/dist/esm/authz/domain/loaders.d.ts.map +1 -1
- package/dist/esm/authz/domain/loaders.js +27 -21
- package/dist/esm/authz/domain/loaders.js.map +1 -1
- package/dist/esm/authz/domain/savedViews/operations.d.ts +10 -0
- package/dist/esm/authz/domain/savedViews/operations.d.ts.map +1 -0
- package/dist/esm/authz/domain/savedViews/operations.js +2 -0
- package/dist/esm/authz/domain/savedViews/operations.js.map +1 -0
- package/dist/esm/authz/domain/savedViews/types.d.ts +26 -0
- package/dist/esm/authz/domain/savedViews/types.d.ts.map +1 -0
- package/dist/esm/authz/domain/savedViews/types.js +3 -0
- package/dist/esm/authz/domain/savedViews/types.js.map +1 -0
- package/dist/esm/authz/domain/workspaces/operations.d.ts +2 -1
- package/dist/esm/authz/domain/workspaces/operations.d.ts.map +1 -1
- package/dist/esm/authz/domain/workspaces/types.d.ts +3 -0
- package/dist/esm/authz/domain/workspaces/types.d.ts.map +1 -1
- package/dist/esm/authz/fragments/automate.d.ts +7 -0
- package/dist/esm/authz/fragments/automate.d.ts.map +1 -0
- package/dist/esm/authz/fragments/automate.js +17 -0
- package/dist/esm/authz/fragments/automate.js.map +1 -0
- package/dist/esm/authz/fragments/dashboards.d.ts +8 -0
- package/dist/esm/authz/fragments/dashboards.d.ts.map +1 -0
- package/dist/esm/authz/fragments/dashboards.js +42 -0
- package/dist/esm/authz/fragments/dashboards.js.map +1 -0
- package/dist/esm/authz/fragments/projects.d.ts +13 -1
- package/dist/esm/authz/fragments/projects.d.ts.map +1 -1
- package/dist/esm/authz/fragments/projects.js +24 -1
- package/dist/esm/authz/fragments/projects.js.map +1 -1
- package/dist/esm/authz/fragments/savedViews.d.ts +30 -0
- package/dist/esm/authz/fragments/savedViews.d.ts.map +1 -0
- package/dist/esm/authz/fragments/savedViews.js +117 -0
- package/dist/esm/authz/fragments/savedViews.js.map +1 -0
- package/dist/esm/authz/fragments/workspaces.d.ts +9 -1
- package/dist/esm/authz/fragments/workspaces.d.ts.map +1 -1
- package/dist/esm/authz/fragments/workspaces.js +45 -1
- package/dist/esm/authz/fragments/workspaces.js.map +1 -1
- package/dist/esm/authz/helpers/graphql.d.ts +1 -1
- package/dist/esm/authz/helpers/graphql.d.ts.map +1 -1
- package/dist/esm/authz/helpers/graphql.js +1 -1
- package/dist/esm/authz/helpers/graphql.js.map +1 -1
- package/dist/esm/authz/index.d.ts +1 -0
- package/dist/esm/authz/index.d.ts.map +1 -1
- package/dist/esm/authz/index.js +1 -0
- package/dist/esm/authz/index.js.map +1 -1
- package/dist/esm/authz/policies/automate/function/canEditFunction.d.ts +10 -0
- package/dist/esm/authz/policies/automate/function/canEditFunction.d.ts.map +1 -0
- package/dist/esm/authz/policies/automate/function/canEditFunction.js +15 -0
- package/dist/esm/authz/policies/automate/function/canEditFunction.js.map +1 -0
- package/dist/esm/authz/policies/dashboard/canCreateToken.d.ts +10 -0
- package/dist/esm/authz/policies/dashboard/canCreateToken.d.ts.map +1 -0
- package/dist/esm/authz/policies/dashboard/canCreateToken.js +41 -0
- package/dist/esm/authz/policies/dashboard/canCreateToken.js.map +1 -0
- package/dist/esm/authz/policies/dashboard/canDelete.d.ts +10 -0
- package/dist/esm/authz/policies/dashboard/canDelete.d.ts.map +1 -0
- package/dist/esm/authz/policies/dashboard/canDelete.js +41 -0
- package/dist/esm/authz/policies/dashboard/canDelete.js.map +1 -0
- package/dist/esm/authz/policies/dashboard/canEdit.d.ts +10 -0
- package/dist/esm/authz/policies/dashboard/canEdit.d.ts.map +1 -0
- package/dist/esm/authz/policies/dashboard/canEdit.js +39 -0
- package/dist/esm/authz/policies/dashboard/canEdit.js.map +1 -0
- package/dist/esm/authz/policies/dashboard/canRead.d.ts +10 -0
- package/dist/esm/authz/policies/dashboard/canRead.d.ts.map +1 -0
- package/dist/esm/authz/policies/dashboard/canRead.js +38 -0
- package/dist/esm/authz/policies/dashboard/canRead.js.map +1 -0
- package/dist/esm/authz/policies/index.d.ts +62 -1
- package/dist/esm/authz/policies/index.d.ts.map +1 -1
- package/dist/esm/authz/policies/index.js +52 -4
- package/dist/esm/authz/policies/index.js.map +1 -1
- package/dist/esm/authz/policies/project/canLoad.d.ts.map +1 -1
- package/dist/esm/authz/policies/project/canLoad.js +6 -0
- package/dist/esm/authz/policies/project/canLoad.js.map +1 -1
- package/dist/esm/authz/policies/project/canReadAccIntegrationSettings.d.ts +10 -0
- package/dist/esm/authz/policies/project/canReadAccIntegrationSettings.d.ts.map +1 -0
- package/dist/esm/authz/policies/project/canReadAccIntegrationSettings.js +31 -0
- package/dist/esm/authz/policies/project/canReadAccIntegrationSettings.js.map +1 -0
- package/dist/esm/authz/policies/project/canUpdateEmbedTokens.d.ts +10 -0
- package/dist/esm/authz/policies/project/canUpdateEmbedTokens.d.ts.map +1 -0
- package/dist/esm/authz/policies/project/canUpdateEmbedTokens.js +48 -0
- package/dist/esm/authz/policies/project/canUpdateEmbedTokens.js.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canCreate.d.ts +6 -0
- package/dist/esm/authz/policies/project/savedViews/canCreate.d.ts.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canCreate.js +27 -0
- package/dist/esm/authz/policies/project/savedViews/canCreate.js.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canCreateSavedViewGroupToken.d.ts +6 -0
- package/dist/esm/authz/policies/project/savedViews/canCreateSavedViewGroupToken.d.ts.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canCreateSavedViewGroupToken.js +57 -0
- package/dist/esm/authz/policies/project/savedViews/canCreateSavedViewGroupToken.js.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canEditDescription.d.ts +6 -0
- package/dist/esm/authz/policies/project/savedViews/canEditDescription.d.ts.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canEditDescription.js +10 -0
- package/dist/esm/authz/policies/project/savedViews/canEditDescription.js.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canEditTitle.d.ts +6 -0
- package/dist/esm/authz/policies/project/savedViews/canEditTitle.d.ts.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canEditTitle.js +10 -0
- package/dist/esm/authz/policies/project/savedViews/canEditTitle.js.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canMove.d.ts +6 -0
- package/dist/esm/authz/policies/project/savedViews/canMove.d.ts.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canMove.js +10 -0
- package/dist/esm/authz/policies/project/savedViews/canMove.js.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canRead.d.ts +11 -0
- package/dist/esm/authz/policies/project/savedViews/canRead.d.ts.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canRead.js +11 -0
- package/dist/esm/authz/policies/project/savedViews/canRead.js.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canSetAsHomeView.d.ts +6 -0
- package/dist/esm/authz/policies/project/savedViews/canSetAsHomeView.d.ts.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canSetAsHomeView.js +41 -0
- package/dist/esm/authz/policies/project/savedViews/canSetAsHomeView.js.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canUpdate.d.ts +6 -0
- package/dist/esm/authz/policies/project/savedViews/canUpdate.d.ts.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canUpdate.js +10 -0
- package/dist/esm/authz/policies/project/savedViews/canUpdate.js.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canUpdateGroup.d.ts +6 -0
- package/dist/esm/authz/policies/project/savedViews/canUpdateGroup.d.ts.map +1 -0
- package/dist/esm/authz/policies/project/savedViews/canUpdateGroup.js +10 -0
- package/dist/esm/authz/policies/project/savedViews/canUpdateGroup.js.map +1 -0
- package/dist/esm/authz/policies/workspace/canCreateDashboards.d.ts +10 -0
- package/dist/esm/authz/policies/workspace/canCreateDashboards.d.ts.map +1 -0
- package/dist/esm/authz/policies/workspace/canCreateDashboards.js +35 -0
- package/dist/esm/authz/policies/workspace/canCreateDashboards.js.map +1 -0
- package/dist/esm/authz/policies/workspace/canCreateWorkspace.d.ts +10 -0
- package/dist/esm/authz/policies/workspace/canCreateWorkspace.d.ts.map +1 -0
- package/dist/esm/authz/policies/workspace/canCreateWorkspace.js +47 -0
- package/dist/esm/authz/policies/workspace/canCreateWorkspace.js.map +1 -0
- package/dist/esm/authz/policies/workspace/canListDashboards.d.ts +10 -0
- package/dist/esm/authz/policies/workspace/canListDashboards.d.ts.map +1 -0
- package/dist/esm/authz/policies/workspace/canListDashboards.js +22 -0
- package/dist/esm/authz/policies/workspace/canListDashboards.js.map +1 -0
- package/dist/esm/authz/policies/workspace/canReadMemberEmail.d.ts +1 -1
- package/dist/esm/authz/policies/workspace/canReadMemberEmail.d.ts.map +1 -1
- package/dist/esm/authz/policies/workspace/canReadMemberEmail.js +2 -21
- package/dist/esm/authz/policies/workspace/canReadMemberEmail.js.map +1 -1
- package/dist/esm/authz/policies/workspace/{canUpdateEmbedOptions.d.ts → canUseWorkspacePlanFeature.d.ts} +13 -5
- package/dist/esm/authz/policies/workspace/canUseWorkspacePlanFeature.d.ts.map +1 -0
- package/dist/esm/authz/policies/workspace/canUseWorkspacePlanFeature.js +23 -0
- package/dist/esm/authz/policies/workspace/canUseWorkspacePlanFeature.js.map +1 -0
- package/dist/esm/automate/helpers/types.d.ts +313 -51
- package/dist/esm/automate/helpers/types.d.ts.map +1 -1
- package/dist/esm/automate/helpers/types.js +11 -1
- package/dist/esm/automate/helpers/types.js.map +1 -1
- package/dist/esm/blobs/index.d.ts +17 -0
- package/dist/esm/blobs/index.d.ts.map +1 -0
- package/dist/esm/blobs/index.js +111 -0
- package/dist/esm/blobs/index.js.map +1 -0
- package/dist/esm/core/constants.d.ts +4 -2
- package/dist/esm/core/constants.d.ts.map +1 -1
- package/dist/esm/core/constants.js +24 -4
- package/dist/esm/core/constants.js.map +1 -1
- package/dist/esm/core/helpers/encoding.d.ts +2 -0
- package/dist/esm/core/helpers/encoding.d.ts.map +1 -0
- package/dist/esm/core/helpers/encoding.js +11 -0
- package/dist/esm/core/helpers/encoding.js.map +1 -0
- package/dist/esm/core/helpers/error.d.ts +11 -0
- package/dist/esm/core/helpers/error.d.ts.map +1 -1
- package/dist/esm/core/helpers/error.js +56 -1
- package/dist/esm/core/helpers/error.js.map +1 -1
- package/dist/esm/core/helpers/url.d.ts +24 -0
- package/dist/esm/core/helpers/url.d.ts.map +1 -1
- package/dist/esm/core/helpers/url.js +30 -0
- package/dist/esm/core/helpers/url.js.map +1 -1
- package/dist/esm/core/helpers/utility.d.ts +16 -0
- package/dist/esm/core/helpers/utility.d.ts.map +1 -1
- package/dist/esm/core/helpers/utility.js +19 -0
- package/dist/esm/core/helpers/utility.js.map +1 -1
- package/dist/esm/core/index.d.ts +2 -0
- package/dist/esm/core/index.d.ts.map +1 -1
- package/dist/esm/core/index.js +2 -0
- package/dist/esm/core/index.js.map +1 -1
- package/dist/esm/core/utils/base64.d.ts +3 -0
- package/dist/esm/core/utils/base64.d.ts.map +1 -0
- package/dist/esm/core/utils/base64.js +21 -0
- package/dist/esm/core/utils/base64.js.map +1 -0
- package/dist/esm/environment/{multiRegionConfig.d.ts → db.d.ts} +54 -5
- package/dist/esm/environment/db.d.ts.map +1 -0
- package/dist/esm/environment/{multiRegionConfig.js → db.js} +40 -7
- package/dist/esm/environment/db.js.map +1 -0
- package/dist/esm/environment/featureFlags.d.ts +25 -0
- package/dist/esm/environment/featureFlags.d.ts.map +1 -0
- package/dist/esm/environment/featureFlags.js +5 -0
- package/dist/esm/environment/featureFlags.js.map +1 -0
- package/dist/esm/environment/index.d.ts +2 -15
- package/dist/esm/environment/index.d.ts.map +1 -1
- package/dist/esm/environment/index.js +44 -7
- package/dist/esm/environment/index.js.map +1 -1
- package/dist/esm/environment/node.d.ts +5 -0
- package/dist/esm/environment/node.d.ts.map +1 -0
- package/dist/esm/environment/node.js +11 -0
- package/dist/esm/environment/node.js.map +1 -0
- package/dist/esm/images/base64.d.ts +2 -0
- package/dist/esm/images/base64.d.ts.map +1 -0
- package/dist/esm/images/base64.js +15 -0
- package/dist/esm/images/base64.js.map +1 -0
- package/dist/esm/index.d.ts +1 -0
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +1 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/observability/index.d.ts.map +1 -1
- package/dist/esm/observability/index.js +19 -2
- package/dist/esm/observability/index.js.map +1 -1
- package/dist/esm/queue/config.d.ts +3 -0
- package/dist/esm/queue/config.d.ts.map +1 -1
- package/dist/esm/queue/config.js +12 -4
- package/dist/esm/queue/config.js.map +1 -1
- package/dist/esm/rich-text-editor/helpers/index.d.ts +13 -1
- package/dist/esm/rich-text-editor/helpers/index.d.ts.map +1 -1
- package/dist/esm/rich-text-editor/helpers/index.js +1 -0
- package/dist/esm/rich-text-editor/helpers/index.js.map +1 -1
- package/dist/esm/saved-views/helpers/defaultGroup.d.ts +23 -0
- package/dist/esm/saved-views/helpers/defaultGroup.d.ts.map +1 -0
- package/dist/esm/saved-views/helpers/defaultGroup.js +51 -0
- package/dist/esm/saved-views/helpers/defaultGroup.js.map +1 -0
- package/dist/esm/saved-views/index.d.ts +2 -0
- package/dist/esm/saved-views/index.d.ts.map +1 -0
- package/dist/esm/saved-views/index.js +2 -0
- package/dist/esm/saved-views/index.js.map +1 -0
- package/dist/esm/viewer/helpers/route.d.ts +42 -7
- package/dist/esm/viewer/helpers/route.d.ts.map +1 -1
- package/dist/esm/viewer/helpers/route.js +140 -30
- package/dist/esm/viewer/helpers/route.js.map +1 -1
- package/dist/esm/viewer/helpers/state.d.ts +59 -6
- package/dist/esm/viewer/helpers/state.d.ts.map +1 -1
- package/dist/esm/viewer/helpers/state.js +97 -22
- package/dist/esm/viewer/helpers/state.js.map +1 -1
- package/dist/esm/workers/fileimport/job.d.ts +85 -9
- package/dist/esm/workers/fileimport/job.d.ts.map +1 -1
- package/dist/esm/workers/fileimport/job.js +20 -9
- package/dist/esm/workers/fileimport/job.js.map +1 -1
- package/dist/esm/workers/previews/job.d.ts +37 -20
- package/dist/esm/workers/previews/job.d.ts.map +1 -1
- package/dist/esm/workers/previews/job.js +20 -1
- package/dist/esm/workers/previews/job.js.map +1 -1
- package/dist/esm/workspaces/helpers/features.d.ts +55 -5
- package/dist/esm/workspaces/helpers/features.d.ts.map +1 -1
- package/dist/esm/workspaces/helpers/features.js +173 -113
- package/dist/esm/workspaces/helpers/features.js.map +1 -1
- package/dist/esm/workspaces/helpers/plans.d.ts +1 -0
- package/dist/esm/workspaces/helpers/plans.d.ts.map +1 -1
- package/dist/esm/workspaces/helpers/plans.js.map +1 -1
- package/package.json +110 -8
- package/src/acc/helpers/types.ts +42 -0
- package/src/acc/index.ts +1 -0
- package/src/authz/checks/dashboards.spec.ts +46 -0
- package/src/authz/checks/dashboards.ts +14 -0
- package/src/authz/domain/authErrors.ts +87 -2
- package/src/authz/domain/automate/operations.ts +5 -0
- package/src/authz/domain/automate/types.ts +9 -0
- package/src/authz/domain/context.ts +8 -0
- package/src/authz/domain/dashboards/operations.ts +3 -0
- package/src/authz/domain/dashboards/types.ts +6 -0
- package/src/authz/domain/loaders.ts +40 -24
- package/src/authz/domain/savedViews/operations.ts +11 -0
- package/src/authz/domain/savedViews/types.ts +25 -0
- package/src/authz/domain/workspaces/operations.ts +3 -1
- package/src/authz/domain/workspaces/types.ts +4 -0
- package/src/authz/fragments/automate.spec.ts +120 -0
- package/src/authz/fragments/automate.ts +36 -0
- package/src/authz/fragments/dashboards.ts +90 -0
- package/src/authz/fragments/projects.spec.ts +135 -10
- package/src/authz/fragments/projects.ts +53 -1
- package/src/authz/fragments/savedViews.spec.ts +551 -0
- package/src/authz/fragments/savedViews.ts +245 -0
- package/src/authz/fragments/workspaces.spec.ts +234 -7
- package/src/authz/fragments/workspaces.ts +84 -0
- package/src/authz/helpers/graphql.ts +2 -2
- package/src/authz/index.ts +1 -0
- package/src/authz/policies/automate/function/canEditFunction.spec.ts +87 -0
- package/src/authz/policies/automate/function/canEditFunction.ts +46 -0
- package/src/authz/policies/dashboard/canCreateToken.ts +89 -0
- package/src/authz/policies/dashboard/canDelete.ts +84 -0
- package/src/authz/policies/dashboard/canEdit.ts +79 -0
- package/src/authz/policies/dashboard/canRead.ts +83 -0
- package/src/authz/policies/index.spec.ts +13 -0
- package/src/authz/policies/index.ts +52 -4
- package/src/authz/policies/project/automation/canCreate.spec.ts +2 -1
- package/src/authz/policies/project/automation/canDelete.spec.ts +2 -1
- package/src/authz/policies/project/automation/canUpdate.spec.ts +2 -1
- package/src/authz/policies/project/canBroadcastActivity.spec.ts +2 -2
- package/src/authz/policies/project/canDelete.spec.ts +2 -2
- package/src/authz/policies/project/canLeave.spec.ts +2 -2
- package/src/authz/policies/project/canLoad.spec.ts +17 -1
- package/src/authz/policies/project/canLoad.ts +7 -0
- package/src/authz/policies/project/canMoveToWorkspace.spec.ts +6 -10
- package/src/authz/policies/project/canPublish.spec.ts +2 -1
- package/src/authz/policies/project/canRead.spec.ts +2 -3
- package/src/authz/policies/project/canReadAccIntegrationSettings.spec.ts +133 -0
- package/src/authz/policies/project/canReadAccIntegrationSettings.ts +87 -0
- package/src/authz/policies/project/canReadSettings.spec.ts +2 -2
- package/src/authz/policies/project/canReadWebhooks.spec.ts +2 -2
- package/src/authz/policies/project/canUpdate.spec.ts +2 -5
- package/src/authz/policies/project/canUpdateEmbedTokens.spec.ts +132 -0
- package/src/authz/policies/project/canUpdateEmbedTokens.ts +101 -0
- package/src/authz/policies/project/comment/canArchive.spec.ts +6 -5
- package/src/authz/policies/project/comment/canCreate.spec.ts +2 -2
- package/src/authz/policies/project/comment/canEdit.spec.ts +6 -5
- package/src/authz/policies/project/model/canDelete.spec.ts +6 -2
- package/src/authz/policies/project/model/canUpdate.spec.ts +2 -5
- package/src/authz/policies/project/savedViews/canCreate.spec.ts +186 -0
- package/src/authz/policies/project/savedViews/canCreate.ts +81 -0
- package/src/authz/policies/project/savedViews/canCreateSavedViewGroupToken.spec.ts +250 -0
- package/src/authz/policies/project/savedViews/canCreateSavedViewGroupToken.ts +117 -0
- package/src/authz/policies/project/savedViews/canEditDescription.spec.ts +206 -0
- package/src/authz/policies/project/savedViews/canEditDescription.ts +67 -0
- package/src/authz/policies/project/savedViews/canEditTitle.spec.ts +204 -0
- package/src/authz/policies/project/savedViews/canEditTitle.ts +67 -0
- package/src/authz/policies/project/savedViews/canMove.spec.ts +204 -0
- package/src/authz/policies/project/savedViews/canMove.ts +67 -0
- package/src/authz/policies/project/savedViews/canRead.ts +72 -0
- package/src/authz/policies/project/savedViews/canSetAsHomeView.spec.ts +248 -0
- package/src/authz/policies/project/savedViews/canSetAsHomeView.ts +108 -0
- package/src/authz/policies/project/savedViews/canUpdate.spec.ts +191 -0
- package/src/authz/policies/project/savedViews/canUpdate.ts +67 -0
- package/src/authz/policies/project/savedViews/canUpdateGroup.spec.ts +227 -0
- package/src/authz/policies/project/savedViews/canUpdateGroup.ts +63 -0
- package/src/authz/policies/project/version/canUpdate.spec.ts +6 -5
- package/src/authz/policies/workspace/canCreateDashboards.ts +71 -0
- package/src/authz/policies/workspace/canCreateWorkspace.spec.ts +380 -0
- package/src/authz/policies/workspace/canCreateWorkspace.ts +77 -0
- package/src/authz/policies/workspace/canListDashboards.ts +53 -0
- package/src/authz/policies/workspace/canReadMemberEmail.spec.ts +25 -36
- package/src/authz/policies/workspace/canReadMemberEmail.ts +11 -34
- package/src/authz/policies/workspace/canReceiveProjectsUpdatedMessage.spec.ts +2 -5
- package/src/authz/policies/workspace/{canUpdateEmbedOptions.spec.ts → canUseWorkspacePlanFeature.spec.ts} +40 -38
- package/src/authz/policies/workspace/canUseWorkspacePlanFeature.ts +69 -0
- package/src/automate/helpers/types.ts +17 -3
- package/src/blobs/index.ts +121 -0
- package/src/core/constants.ts +25 -4
- package/src/core/helpers/encoding.ts +12 -0
- package/src/core/helpers/error.spec.ts +215 -0
- package/src/core/helpers/error.ts +58 -1
- package/src/core/helpers/url.ts +33 -0
- package/src/core/helpers/utility.spec.ts +19 -1
- package/src/core/helpers/utility.ts +31 -0
- package/src/core/index.ts +2 -0
- package/src/core/utils/base64.spec.ts +31 -0
- package/src/core/utils/base64.ts +19 -0
- package/src/environment/db.spec.ts +48 -0
- package/src/environment/{multiRegionConfig.ts → db.ts} +62 -8
- package/src/environment/featureFlags.ts +25 -0
- package/src/environment/index.spec.ts +126 -0
- package/src/environment/index.ts +51 -24
- package/src/environment/node.ts +11 -0
- package/src/images/base64.spec.ts +42 -0
- package/src/images/base64.ts +15 -0
- package/src/index.ts +1 -0
- package/src/observability/index.ts +22 -2
- package/src/queue/config.ts +18 -6
- package/src/rich-text-editor/helpers/index.ts +15 -1
- package/src/saved-views/helpers/defaultGroup.spec.ts +12 -0
- package/src/saved-views/helpers/defaultGroup.ts +70 -0
- package/src/saved-views/index.ts +1 -0
- package/src/tests/fakes.ts +55 -4
- package/src/viewer/helpers/route.spec.ts +353 -0
- package/src/viewer/helpers/route.ts +180 -25
- package/src/viewer/helpers/state.spec.ts +252 -0
- package/src/viewer/helpers/state.ts +158 -27
- package/src/workers/fileimport/job.ts +40 -21
- package/src/workers/previews/job.ts +23 -1
- package/src/workspaces/helpers/features.spec.ts +99 -0
- package/src/workspaces/helpers/features.ts +215 -119
- package/src/workspaces/helpers/plans.ts +1 -0
- package/dist/commonjs/authz/policies/workspace/canUpdateEmbedOptions.d.ts.map +0 -1
- package/dist/commonjs/authz/policies/workspace/canUpdateEmbedOptions.js +0 -44
- package/dist/commonjs/authz/policies/workspace/canUpdateEmbedOptions.js.map +0 -1
- package/dist/commonjs/environment/multiRegionConfig.d.ts.map +0 -1
- package/dist/commonjs/environment/multiRegionConfig.js.map +0 -1
- package/dist/esm/authz/policies/workspace/canUpdateEmbedOptions.d.ts.map +0 -1
- package/dist/esm/authz/policies/workspace/canUpdateEmbedOptions.js +0 -40
- package/dist/esm/authz/policies/workspace/canUpdateEmbedOptions.js.map +0 -1
- package/dist/esm/environment/multiRegionConfig.d.ts.map +0 -1
- package/dist/esm/environment/multiRegionConfig.js.map +0 -1
- package/src/authz/policies/workspace/canUpdateEmbedOptions.ts +0 -89
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { DashboardContext, UserContext } from '../domain/context.js'
|
|
2
|
+
import { AuthCheckContextLoaderKeys } from '../domain/loaders.js'
|
|
3
|
+
import { AuthPolicyCheck } from '../domain/policies.js'
|
|
4
|
+
|
|
5
|
+
export const isDashboardOwner: AuthPolicyCheck<
|
|
6
|
+
typeof AuthCheckContextLoaderKeys.getDashboard,
|
|
7
|
+
UserContext & DashboardContext
|
|
8
|
+
> =
|
|
9
|
+
(loaders) =>
|
|
10
|
+
async ({ userId, dashboardId }) => {
|
|
11
|
+
const dashboard = await loaders.getDashboard({ dashboardId })
|
|
12
|
+
if (!dashboard) return false
|
|
13
|
+
return dashboard.ownerId === userId
|
|
14
|
+
}
|
|
@@ -94,6 +94,15 @@ export const WorkspaceNotEnoughPermissionsError = defineAuthError({
|
|
|
94
94
|
message: 'You do not have enough permissions in the workspace to perform this action'
|
|
95
95
|
})
|
|
96
96
|
|
|
97
|
+
export const EligibleForExclusiveWorkspaceError = defineAuthError({
|
|
98
|
+
code: 'UserEligibleForExclusiveWorkspace',
|
|
99
|
+
message:
|
|
100
|
+
'Cannot create workspace: ' +
|
|
101
|
+
'You are a member or eligible to become a member of an exclusive workspace. ' +
|
|
102
|
+
'This is due to you having received an invite to the workspace ' +
|
|
103
|
+
'or having a matching verified email.'
|
|
104
|
+
})
|
|
105
|
+
|
|
97
106
|
export const WorkspaceReadOnlyError = defineAuthError({
|
|
98
107
|
code: 'WorkspaceReadOnly',
|
|
99
108
|
message: 'The workspace is in a read only mode, upgrade your plan to unlock it'
|
|
@@ -107,8 +116,8 @@ export const WorkspaceLimitsReachedError = defineAuthError<
|
|
|
107
116
|
message: 'Workspace limits have been reached'
|
|
108
117
|
})
|
|
109
118
|
|
|
110
|
-
export const
|
|
111
|
-
code: '
|
|
119
|
+
export const WorkspacePlanNoFeatureAccessError = defineAuthError({
|
|
120
|
+
code: 'WorkspacePlanNoFeatureAccessError',
|
|
112
121
|
message: 'Your workspace plan does not have access to this feature.'
|
|
113
122
|
})
|
|
114
123
|
|
|
@@ -172,6 +181,82 @@ export const VersionNotFoundError = defineAuthError({
|
|
|
172
181
|
message: 'Version not found'
|
|
173
182
|
})
|
|
174
183
|
|
|
184
|
+
export const AutomateNotEnabledError = defineAuthError({
|
|
185
|
+
code: 'AutomateNotEnabled',
|
|
186
|
+
message: 'Automate is not enabled on this server'
|
|
187
|
+
})
|
|
188
|
+
|
|
189
|
+
export const AutomateFunctionNotFoundError = defineAuthError({
|
|
190
|
+
code: 'AutomateFunctionNotFound',
|
|
191
|
+
message: 'Function not found'
|
|
192
|
+
})
|
|
193
|
+
|
|
194
|
+
export const AutomateFunctionNotCreatorError = defineAuthError({
|
|
195
|
+
code: 'AutomateFunctionNotCreator',
|
|
196
|
+
message: 'You are not the function creator and cannot make changes to it.'
|
|
197
|
+
})
|
|
198
|
+
|
|
199
|
+
export const AccIntegrationNotEnabledError = defineAuthError({
|
|
200
|
+
code: 'AccIntegrationNotEnabled',
|
|
201
|
+
message: 'The ACC Integration is not enabled on this server or project'
|
|
202
|
+
})
|
|
203
|
+
|
|
204
|
+
export const SavedViewNotFoundError = defineAuthError({
|
|
205
|
+
code: 'SavedViewNotFound',
|
|
206
|
+
message: 'Saved view not found'
|
|
207
|
+
})
|
|
208
|
+
|
|
209
|
+
export const SavedViewNoAccessError = defineAuthError({
|
|
210
|
+
code: 'SavedViewNoAccess',
|
|
211
|
+
message: 'You do not have access to this saved view'
|
|
212
|
+
})
|
|
213
|
+
|
|
214
|
+
export const SavedViewInvalidUpdateError = defineAuthError({
|
|
215
|
+
code: 'SavedViewInvalidUpdate',
|
|
216
|
+
message: 'The requested update is invalid'
|
|
217
|
+
})
|
|
218
|
+
|
|
219
|
+
export const SavedViewGroupNotFoundError = defineAuthError({
|
|
220
|
+
code: 'SavedViewGroupNotFound',
|
|
221
|
+
message: 'Saved view group not found'
|
|
222
|
+
})
|
|
223
|
+
|
|
224
|
+
export const UngroupedSavedViewGroupLockError = defineAuthError({
|
|
225
|
+
code: 'UngroupedSavedViewGroupLock',
|
|
226
|
+
message: 'The default/ungrouped group cannot be modified.'
|
|
227
|
+
})
|
|
228
|
+
|
|
229
|
+
export const DashboardsNotEnabledError = defineAuthError({
|
|
230
|
+
code: 'DashboardsNotEnabled',
|
|
231
|
+
message: 'Dashboards are not enabled for this server or workspaces.'
|
|
232
|
+
})
|
|
233
|
+
|
|
234
|
+
export const DashboardNotFoundError = defineAuthError({
|
|
235
|
+
code: 'DashboardNotFound',
|
|
236
|
+
message: 'Dashboard not found'
|
|
237
|
+
})
|
|
238
|
+
|
|
239
|
+
export const DashboardNoProjectsError = defineAuthError({
|
|
240
|
+
code: 'DashboardNoProjects',
|
|
241
|
+
message:
|
|
242
|
+
'Dashboard has no projects added to it. You need to add at least one project before sharing.'
|
|
243
|
+
})
|
|
244
|
+
|
|
245
|
+
export const DashboardProjectsNotEnoughPermissionsError = defineAuthError<
|
|
246
|
+
'DashboardProjectsNotEnoughPermissions',
|
|
247
|
+
{
|
|
248
|
+
projectIds: string[]
|
|
249
|
+
}
|
|
250
|
+
>({
|
|
251
|
+
code: 'DashboardProjectsNotEnoughPermissions',
|
|
252
|
+
message: 'You do not have sufficient access to some projects in this workspace.'
|
|
253
|
+
})
|
|
254
|
+
|
|
255
|
+
export const DashboardNotOwnerError = defineAuthError({
|
|
256
|
+
code: 'DashboardNotOwner',
|
|
257
|
+
message: 'You must be a dashboard owner to perform this action'
|
|
258
|
+
})
|
|
259
|
+
|
|
175
260
|
// Resolve all exported error types
|
|
176
261
|
export type AllAuthErrors = ValueOf<{
|
|
177
262
|
[key in keyof typeof import('./authErrors.js')]: typeof import('./authErrors.js')[key] extends new (
|
|
@@ -7,8 +7,16 @@ export type MaybeUserContext = { userId?: string }
|
|
|
7
7
|
export type WorkspaceContext = { workspaceId: string }
|
|
8
8
|
export type MaybeWorkspaceContext = { workspaceId?: string }
|
|
9
9
|
|
|
10
|
+
export type DashboardContext = { dashboardId: string }
|
|
11
|
+
|
|
10
12
|
export type CommentContext = { commentId: string }
|
|
11
13
|
|
|
12
14
|
export type ModelContext = { modelId: string }
|
|
13
15
|
|
|
14
16
|
export type VersionContext = { versionId: string }
|
|
17
|
+
|
|
18
|
+
export type AutomateFunctionContext = { functionId: string }
|
|
19
|
+
|
|
20
|
+
export type SavedViewContext = { savedViewId: string }
|
|
21
|
+
|
|
22
|
+
export type SavedViewGroupContext = { savedViewGroupId: string }
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { OverrideProperties } from 'type-fest'
|
|
2
|
-
import { MaybeAsync } from '../../core/index.js'
|
|
2
|
+
import { MaybeAsync, StringEnum, StringEnumValues } from '../../core/index.js'
|
|
3
3
|
import type { GetServerRole } from './core/operations.js'
|
|
4
4
|
import type {
|
|
5
5
|
GetProject,
|
|
@@ -10,6 +10,7 @@ import type {
|
|
|
10
10
|
import type {
|
|
11
11
|
GetAdminOverrideEnabled,
|
|
12
12
|
GetEnv,
|
|
13
|
+
GetUserWorkspaces,
|
|
13
14
|
GetWorkspace,
|
|
14
15
|
GetWorkspaceLimits,
|
|
15
16
|
GetWorkspaceModelCount,
|
|
@@ -23,6 +24,9 @@ import type {
|
|
|
23
24
|
import { GetComment } from './comments/operations.js'
|
|
24
25
|
import { GetModel } from './models/operations.js'
|
|
25
26
|
import { GetVersion } from './versions/operations.js'
|
|
27
|
+
import { GetAutomateFunction } from './automate/operations.js'
|
|
28
|
+
import { GetSavedView, GetSavedViewGroup } from './savedViews/operations.js'
|
|
29
|
+
import { GetDashboard } from './dashboards/operations.js'
|
|
26
30
|
|
|
27
31
|
// utility type that ensures all properties functions that return promises
|
|
28
32
|
type PromiseAll<T> = {
|
|
@@ -52,42 +56,52 @@ type AuthContextLoaderMappingDefinition<
|
|
|
52
56
|
*/
|
|
53
57
|
|
|
54
58
|
/* v8 ignore start */
|
|
55
|
-
export const AuthCheckContextLoaderKeys =
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
59
|
+
export const AuthCheckContextLoaderKeys = StringEnum([
|
|
60
|
+
'getEnv',
|
|
61
|
+
'getAutomateFunction',
|
|
62
|
+
'getDashboard',
|
|
63
|
+
'getProject',
|
|
64
|
+
'getProjectRoleCounts',
|
|
65
|
+
'getProjectRole',
|
|
66
|
+
'getProjectModelCount',
|
|
67
|
+
'getServerRole',
|
|
68
|
+
'getWorkspace',
|
|
69
|
+
'getUsersCurrentAndEligibleToBecomeAMemberWorkspaces',
|
|
70
|
+
'getWorkspaceRole',
|
|
71
|
+
'getWorkspaceSeat',
|
|
72
|
+
'getWorkspaceModelCount',
|
|
73
|
+
'getWorkspaceProjectCount',
|
|
74
|
+
'getWorkspacePlan',
|
|
75
|
+
'getWorkspaceLimits',
|
|
76
|
+
'getWorkspaceSsoProvider',
|
|
77
|
+
'getWorkspaceSsoSession',
|
|
78
|
+
'getAdminOverrideEnabled',
|
|
79
|
+
'getComment',
|
|
80
|
+
'getModel',
|
|
81
|
+
'getVersion',
|
|
82
|
+
'getSavedView',
|
|
83
|
+
'getSavedViewGroup'
|
|
84
|
+
])
|
|
85
|
+
|
|
76
86
|
export const Loaders = AuthCheckContextLoaderKeys // shorter alias
|
|
77
87
|
/* v8 ignore end */
|
|
78
88
|
|
|
79
|
-
export type AuthCheckContextLoaderKeys =
|
|
80
|
-
|
|
89
|
+
export type AuthCheckContextLoaderKeys = StringEnumValues<
|
|
90
|
+
typeof AuthCheckContextLoaderKeys
|
|
91
|
+
>
|
|
81
92
|
|
|
82
93
|
export type AllAuthCheckContextLoaders = AuthContextLoaderMappingDefinition<{
|
|
83
94
|
getEnv: GetEnv
|
|
84
95
|
getAdminOverrideEnabled: GetAdminOverrideEnabled
|
|
96
|
+
getAutomateFunction: GetAutomateFunction
|
|
97
|
+
getDashboard: GetDashboard
|
|
85
98
|
getProject: GetProject
|
|
86
99
|
getProjectRole: GetProjectRole
|
|
87
100
|
getProjectRoleCounts: GetProjectRoleCounts
|
|
88
101
|
getProjectModelCount: GetProjectModelCount
|
|
89
102
|
getServerRole: GetServerRole
|
|
90
103
|
getWorkspace: GetWorkspace
|
|
104
|
+
getUsersCurrentAndEligibleToBecomeAMemberWorkspaces: GetUserWorkspaces
|
|
91
105
|
getWorkspaceRole: GetWorkspaceRole
|
|
92
106
|
getWorkspaceLimits: GetWorkspaceLimits
|
|
93
107
|
getWorkspacePlan: GetWorkspacePlan
|
|
@@ -99,6 +113,8 @@ export type AllAuthCheckContextLoaders = AuthContextLoaderMappingDefinition<{
|
|
|
99
113
|
getComment: GetComment
|
|
100
114
|
getModel: GetModel
|
|
101
115
|
getVersion: GetVersion
|
|
116
|
+
getSavedView: GetSavedView
|
|
117
|
+
getSavedViewGroup: GetSavedViewGroup
|
|
102
118
|
}>
|
|
103
119
|
|
|
104
120
|
export type AuthCheckContextLoaders<
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { SavedView, SavedViewGroup } from './types.js'
|
|
2
|
+
|
|
3
|
+
export type GetSavedView = (args: {
|
|
4
|
+
projectId: string
|
|
5
|
+
savedViewId: string
|
|
6
|
+
}) => Promise<SavedView | null>
|
|
7
|
+
|
|
8
|
+
export type GetSavedViewGroup = (args: {
|
|
9
|
+
projectId: string
|
|
10
|
+
groupId: string
|
|
11
|
+
}) => Promise<SavedViewGroup | null>
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { StringEnum, StringEnumValues } from '../../../core/helpers/utility.js'
|
|
2
|
+
|
|
3
|
+
export const SavedViewVisibility = StringEnum(['public', 'authorOnly'])
|
|
4
|
+
export type SavedViewVisibility = StringEnumValues<typeof SavedViewVisibility>
|
|
5
|
+
|
|
6
|
+
export type SavedView = {
|
|
7
|
+
id: string
|
|
8
|
+
name: string
|
|
9
|
+
authorId: string | null
|
|
10
|
+
groupId: string | null
|
|
11
|
+
projectId: string
|
|
12
|
+
visibility: SavedViewVisibility
|
|
13
|
+
resourceIds: string[]
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export type SavedViewGroup = {
|
|
17
|
+
id: string
|
|
18
|
+
projectId: string
|
|
19
|
+
/**
|
|
20
|
+
* null means default/ungrouped group
|
|
21
|
+
*/
|
|
22
|
+
name: string | null
|
|
23
|
+
authorId: string | null
|
|
24
|
+
resourceIds: string[]
|
|
25
|
+
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { WorkspaceRoles, WorkspaceSeatType } from '../../../core/constants.js'
|
|
2
|
-
import { FeatureFlags } from '../../../environment/
|
|
2
|
+
import { FeatureFlags } from '../../../environment/featureFlags.js'
|
|
3
3
|
import { WorkspaceLimits } from '../../../workspaces/helpers/limits.js'
|
|
4
4
|
import { WorkspacePlan } from '../../../workspaces/index.js'
|
|
5
5
|
import { UserContext, WorkspaceContext } from '../context.js'
|
|
@@ -7,6 +7,8 @@ import { Workspace, WorkspaceSsoProvider, WorkspaceSsoSession } from './types.js
|
|
|
7
7
|
|
|
8
8
|
export type GetWorkspace = (args: WorkspaceContext) => Promise<Workspace | null>
|
|
9
9
|
|
|
10
|
+
export type GetUserWorkspaces = (args: UserContext) => Promise<Workspace[]>
|
|
11
|
+
|
|
10
12
|
export type GetWorkspaceRole = (
|
|
11
13
|
args: UserContext & WorkspaceContext
|
|
12
14
|
) => Promise<WorkspaceRoles | null>
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest'
|
|
2
|
+
import {
|
|
3
|
+
ensureAutomateEnabledFragment,
|
|
4
|
+
ensureAutomateFunctionCreatorFragment
|
|
5
|
+
} from './automate.js'
|
|
6
|
+
import { OverridesOf } from '../../tests/helpers/types.js'
|
|
7
|
+
import { parseFeatureFlags } from '../../environment/index.js'
|
|
8
|
+
import cryptoRandomString from 'crypto-random-string'
|
|
9
|
+
import {
|
|
10
|
+
AutomateFunctionNotCreatorError,
|
|
11
|
+
AutomateFunctionNotFoundError,
|
|
12
|
+
AutomateNotEnabledError
|
|
13
|
+
} from '../domain/authErrors.js'
|
|
14
|
+
|
|
15
|
+
describe('ensureAutomateEnabledFragment', () => {
|
|
16
|
+
const buildFragment = (
|
|
17
|
+
overrides?: OverridesOf<typeof ensureAutomateEnabledFragment>
|
|
18
|
+
) =>
|
|
19
|
+
ensureAutomateEnabledFragment({
|
|
20
|
+
getEnv: async () =>
|
|
21
|
+
parseFeatureFlags({
|
|
22
|
+
FF_AUTOMATE_MODULE_ENABLED: 'true'
|
|
23
|
+
}),
|
|
24
|
+
...overrides
|
|
25
|
+
})
|
|
26
|
+
|
|
27
|
+
it('returns ok when automate is enabled', async () => {
|
|
28
|
+
const result = await buildFragment()({})
|
|
29
|
+
expect(result).toBeAuthOKResult()
|
|
30
|
+
})
|
|
31
|
+
|
|
32
|
+
it('returns err when automate is disabled', async () => {
|
|
33
|
+
const result = await buildFragment({
|
|
34
|
+
getEnv: async () =>
|
|
35
|
+
parseFeatureFlags({
|
|
36
|
+
FF_AUTOMATE_MODULE_ENABLED: 'false'
|
|
37
|
+
})
|
|
38
|
+
})({})
|
|
39
|
+
expect(result).toBeAuthErrorResult({
|
|
40
|
+
code: AutomateNotEnabledError.code
|
|
41
|
+
})
|
|
42
|
+
})
|
|
43
|
+
})
|
|
44
|
+
|
|
45
|
+
describe('ensureAutomateFunctionCreatorFragment', () => {
|
|
46
|
+
const buildFragment = (
|
|
47
|
+
overrides?: OverridesOf<typeof ensureAutomateFunctionCreatorFragment>
|
|
48
|
+
) =>
|
|
49
|
+
ensureAutomateFunctionCreatorFragment({
|
|
50
|
+
getAutomateFunction: async ({ functionId }) => {
|
|
51
|
+
return {
|
|
52
|
+
id: functionId,
|
|
53
|
+
name: cryptoRandomString({ length: 9 }),
|
|
54
|
+
functionCreator: {
|
|
55
|
+
synchronizedUserId: 'foo',
|
|
56
|
+
synchronizedServerOrigin: 'example.org'
|
|
57
|
+
},
|
|
58
|
+
workspaceIds: []
|
|
59
|
+
}
|
|
60
|
+
},
|
|
61
|
+
...overrides
|
|
62
|
+
})
|
|
63
|
+
|
|
64
|
+
it('returns ok when user is function creator', async () => {
|
|
65
|
+
const userId = cryptoRandomString({ length: 9 })
|
|
66
|
+
|
|
67
|
+
const result = await buildFragment({
|
|
68
|
+
getAutomateFunction: async ({ functionId }) => {
|
|
69
|
+
return {
|
|
70
|
+
id: functionId,
|
|
71
|
+
name: cryptoRandomString({ length: 9 }),
|
|
72
|
+
functionCreator: {
|
|
73
|
+
synchronizedUserId: userId,
|
|
74
|
+
synchronizedServerOrigin: 'example.org'
|
|
75
|
+
},
|
|
76
|
+
workspaceIds: []
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
})({
|
|
80
|
+
userId,
|
|
81
|
+
functionId: cryptoRandomString({ length: 9 })
|
|
82
|
+
})
|
|
83
|
+
|
|
84
|
+
expect(result).toBeAuthOKResult()
|
|
85
|
+
})
|
|
86
|
+
|
|
87
|
+
it('return err if function is not found', async () => {
|
|
88
|
+
const result = await buildFragment({
|
|
89
|
+
getAutomateFunction: async () => null
|
|
90
|
+
})({
|
|
91
|
+
userId: cryptoRandomString({ length: 9 }),
|
|
92
|
+
functionId: cryptoRandomString({ length: 9 })
|
|
93
|
+
})
|
|
94
|
+
expect(result).toBeAuthErrorResult({
|
|
95
|
+
code: AutomateFunctionNotFoundError.code
|
|
96
|
+
})
|
|
97
|
+
})
|
|
98
|
+
|
|
99
|
+
it('returns err if user is not function creator', async () => {
|
|
100
|
+
const result = await buildFragment({
|
|
101
|
+
getAutomateFunction: async ({ functionId }) => {
|
|
102
|
+
return {
|
|
103
|
+
id: functionId,
|
|
104
|
+
name: cryptoRandomString({ length: 9 }),
|
|
105
|
+
functionCreator: {
|
|
106
|
+
synchronizedUserId: cryptoRandomString({ length: 9 }),
|
|
107
|
+
synchronizedServerOrigin: 'example.org'
|
|
108
|
+
},
|
|
109
|
+
workspaceIds: []
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
})({
|
|
113
|
+
userId: cryptoRandomString({ length: 9 }),
|
|
114
|
+
functionId: cryptoRandomString({ length: 9 })
|
|
115
|
+
})
|
|
116
|
+
expect(result).toBeAuthErrorResult({
|
|
117
|
+
code: AutomateFunctionNotCreatorError.code
|
|
118
|
+
})
|
|
119
|
+
})
|
|
120
|
+
})
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { err, ok } from 'true-myth/result'
|
|
2
|
+
import {
|
|
3
|
+
AutomateFunctionNotCreatorError,
|
|
4
|
+
AutomateFunctionNotFoundError,
|
|
5
|
+
AutomateNotEnabledError
|
|
6
|
+
} from '../domain/authErrors.js'
|
|
7
|
+
import { Loaders } from '../domain/loaders.js'
|
|
8
|
+
import { AuthPolicyEnsureFragment } from '../domain/policies.js'
|
|
9
|
+
import { AutomateFunctionContext, MaybeUserContext } from '../domain/context.js'
|
|
10
|
+
|
|
11
|
+
export const ensureAutomateEnabledFragment: AuthPolicyEnsureFragment<
|
|
12
|
+
typeof Loaders.getEnv,
|
|
13
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-object-type
|
|
14
|
+
{},
|
|
15
|
+
InstanceType<typeof AutomateNotEnabledError>
|
|
16
|
+
> = (loaders) => async () => {
|
|
17
|
+
const env = await loaders.getEnv()
|
|
18
|
+
if (!env.FF_AUTOMATE_MODULE_ENABLED) return err(new AutomateNotEnabledError())
|
|
19
|
+
return ok()
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
export const ensureAutomateFunctionCreatorFragment: AuthPolicyEnsureFragment<
|
|
23
|
+
typeof Loaders.getAutomateFunction,
|
|
24
|
+
MaybeUserContext & AutomateFunctionContext,
|
|
25
|
+
InstanceType<
|
|
26
|
+
typeof AutomateFunctionNotFoundError | typeof AutomateFunctionNotCreatorError
|
|
27
|
+
>
|
|
28
|
+
> =
|
|
29
|
+
(loaders) =>
|
|
30
|
+
async ({ userId, functionId }) => {
|
|
31
|
+
const automateFunction = await loaders.getAutomateFunction({ functionId })
|
|
32
|
+
if (!automateFunction) return err(new AutomateFunctionNotFoundError())
|
|
33
|
+
if (!userId || automateFunction.functionCreator?.synchronizedUserId !== userId)
|
|
34
|
+
return err(new AutomateFunctionNotCreatorError())
|
|
35
|
+
return ok()
|
|
36
|
+
}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { err, ok } from 'true-myth/result'
|
|
2
|
+
import {
|
|
3
|
+
DashboardNotFoundError,
|
|
4
|
+
DashboardProjectsNotEnoughPermissionsError,
|
|
5
|
+
DashboardsNotEnabledError,
|
|
6
|
+
WorkspacePlanNoFeatureAccessError
|
|
7
|
+
} from '../domain/authErrors.js'
|
|
8
|
+
import { Loaders } from '../domain/loaders.js'
|
|
9
|
+
import { AuthPolicyEnsureFragment } from '../domain/policies.js'
|
|
10
|
+
import { DashboardContext, UserContext, WorkspaceContext } from '../domain/context.js'
|
|
11
|
+
import {
|
|
12
|
+
isWorkspaceFeatureFlagOn,
|
|
13
|
+
WorkspaceFeatureFlags
|
|
14
|
+
} from '../../workspaces/index.js'
|
|
15
|
+
import { ensureMinimumProjectRoleFragment } from './projects.js'
|
|
16
|
+
|
|
17
|
+
export const ensureDashboardsEnabledFragment: AuthPolicyEnsureFragment<
|
|
18
|
+
typeof Loaders.getEnv,
|
|
19
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-object-type
|
|
20
|
+
{},
|
|
21
|
+
InstanceType<typeof DashboardsNotEnabledError>
|
|
22
|
+
> = (loaders) => async () => {
|
|
23
|
+
const env = await loaders.getEnv()
|
|
24
|
+
if (!env.FF_DASHBOARDS_MODULE_ENABLED) return err(new DashboardsNotEnabledError())
|
|
25
|
+
return ok()
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
export const ensureWorkspaceDashboardsFeatureAccessFragment: AuthPolicyEnsureFragment<
|
|
29
|
+
typeof Loaders.getWorkspacePlan,
|
|
30
|
+
WorkspaceContext,
|
|
31
|
+
InstanceType<typeof WorkspacePlanNoFeatureAccessError>
|
|
32
|
+
> =
|
|
33
|
+
(loaders) =>
|
|
34
|
+
async ({ workspaceId }) => {
|
|
35
|
+
const plan = await loaders.getWorkspacePlan({ workspaceId })
|
|
36
|
+
if (!plan) return err(new WorkspacePlanNoFeatureAccessError())
|
|
37
|
+
|
|
38
|
+
const isFlagOn = isWorkspaceFeatureFlagOn({
|
|
39
|
+
workspaceFeatureFlags: plan.featureFlags,
|
|
40
|
+
feature: WorkspaceFeatureFlags.dashboards
|
|
41
|
+
})
|
|
42
|
+
if (!isFlagOn) return err(new WorkspacePlanNoFeatureAccessError())
|
|
43
|
+
|
|
44
|
+
return ok()
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
export const ensureDashboardProjectsReadAccess: AuthPolicyEnsureFragment<
|
|
48
|
+
| typeof Loaders.getDashboard
|
|
49
|
+
| typeof Loaders.getProjectRole
|
|
50
|
+
| typeof Loaders.getProject
|
|
51
|
+
| typeof Loaders.getServerRole
|
|
52
|
+
| typeof Loaders.getEnv
|
|
53
|
+
| typeof Loaders.getWorkspaceRole
|
|
54
|
+
| typeof Loaders.getWorkspace
|
|
55
|
+
| typeof Loaders.getWorkspaceSsoProvider
|
|
56
|
+
| typeof Loaders.getWorkspaceSsoSession,
|
|
57
|
+
DashboardContext & UserContext,
|
|
58
|
+
InstanceType<
|
|
59
|
+
typeof DashboardNotFoundError | typeof DashboardProjectsNotEnoughPermissionsError
|
|
60
|
+
>
|
|
61
|
+
> =
|
|
62
|
+
(loaders) =>
|
|
63
|
+
async ({ userId, dashboardId }) => {
|
|
64
|
+
const dashboard = await loaders.getDashboard({ dashboardId })
|
|
65
|
+
if (!dashboard) return err(new DashboardNotFoundError())
|
|
66
|
+
|
|
67
|
+
const allProjectResults: [
|
|
68
|
+
string,
|
|
69
|
+
Awaited<ReturnType<ReturnType<typeof ensureMinimumProjectRoleFragment>>>
|
|
70
|
+
][] = await Promise.all(
|
|
71
|
+
dashboard.projectIds.map(async (projectId) => {
|
|
72
|
+
return [
|
|
73
|
+
projectId,
|
|
74
|
+
await ensureMinimumProjectRoleFragment(loaders)({ projectId, userId })
|
|
75
|
+
]
|
|
76
|
+
})
|
|
77
|
+
)
|
|
78
|
+
|
|
79
|
+
const projectAccessErrors = allProjectResults.filter(([, e]) => e.isErr)
|
|
80
|
+
|
|
81
|
+
return projectAccessErrors.length
|
|
82
|
+
? err(
|
|
83
|
+
new DashboardProjectsNotEnoughPermissionsError({
|
|
84
|
+
payload: {
|
|
85
|
+
projectIds: projectAccessErrors.map(([projectId]) => projectId)
|
|
86
|
+
}
|
|
87
|
+
})
|
|
88
|
+
)
|
|
89
|
+
: ok()
|
|
90
|
+
}
|