@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,353 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest'
|
|
2
|
+
import {
|
|
3
|
+
createGetParamFromResources,
|
|
4
|
+
parseResourceFromString,
|
|
5
|
+
parseUrlParameters,
|
|
6
|
+
resourceBuilder
|
|
7
|
+
} from './route.js'
|
|
8
|
+
|
|
9
|
+
describe('Viewer Route Helpers', () => {
|
|
10
|
+
describe('parseResourceFromString', () => {
|
|
11
|
+
it('parses "all" as ViewerAllModelsResource', () => {
|
|
12
|
+
const resource = parseResourceFromString('all')
|
|
13
|
+
expect(resource.type).toBe('all-models')
|
|
14
|
+
expect(resource.toString()).toBe('all')
|
|
15
|
+
})
|
|
16
|
+
|
|
17
|
+
it('parses modelId as ViewerModelResource', () => {
|
|
18
|
+
const resource = parseResourceFromString('abc123')
|
|
19
|
+
expect(resource.type).toBe('Model')
|
|
20
|
+
expect(resource.toString()).toBe('abc123')
|
|
21
|
+
})
|
|
22
|
+
|
|
23
|
+
it('parses modelId@versionId as ViewerModelResource', () => {
|
|
24
|
+
const resource = parseResourceFromString('abc123@ver456')
|
|
25
|
+
expect(resource.type).toBe('Model')
|
|
26
|
+
expect(resource.toString()).toBe('abc123@ver456')
|
|
27
|
+
})
|
|
28
|
+
|
|
29
|
+
it('parses $folderName as ViewerModelFolderResource', () => {
|
|
30
|
+
const resource = parseResourceFromString('$myFolder')
|
|
31
|
+
expect(resource.type).toBe('ModelFolder')
|
|
32
|
+
expect(resource.toString()).toBe('$myFolder') // keep casing
|
|
33
|
+
})
|
|
34
|
+
|
|
35
|
+
it('parses 32-char string as ViewerObjectResource', () => {
|
|
36
|
+
const objectId = '1234567890abcdef1234567890abcdef'
|
|
37
|
+
const resource = parseResourceFromString(objectId)
|
|
38
|
+
expect(resource.type).toBe('Object')
|
|
39
|
+
expect(resource.toString()).toBe(objectId)
|
|
40
|
+
})
|
|
41
|
+
|
|
42
|
+
it('parses modelId with uppercase as ViewerModelResource and lowercases it', () => {
|
|
43
|
+
const resource = parseResourceFromString('ABC123')
|
|
44
|
+
expect(resource.type).toBe('Model')
|
|
45
|
+
expect(resource.toString()).toBe('abc123')
|
|
46
|
+
})
|
|
47
|
+
|
|
48
|
+
it('parses $FOLDERNAME with uppercase as ViewerModelFolderResource and lowercases it', () => {
|
|
49
|
+
const resource = parseResourceFromString('$FOLDERNAME')
|
|
50
|
+
expect(resource.type).toBe('ModelFolder')
|
|
51
|
+
expect(resource.toString()).toBe('$FOLDERNAME')
|
|
52
|
+
})
|
|
53
|
+
|
|
54
|
+
it('parses modelId@versionId with uppercase as ViewerModelResource and lowercases it', () => {
|
|
55
|
+
const resource = parseResourceFromString('ABC123@VER456')
|
|
56
|
+
expect(resource.type).toBe('Model')
|
|
57
|
+
expect(resource.toString()).toBe('abc123@ver456')
|
|
58
|
+
})
|
|
59
|
+
})
|
|
60
|
+
|
|
61
|
+
describe('parseUrlParameters', () => {
|
|
62
|
+
it('returns empty array for empty string', () => {
|
|
63
|
+
expect(parseUrlParameters('')).toEqual([])
|
|
64
|
+
})
|
|
65
|
+
|
|
66
|
+
it('parses single modelId', () => {
|
|
67
|
+
const resources = parseUrlParameters('abc123')
|
|
68
|
+
expect(resources).toHaveLength(1)
|
|
69
|
+
expect(resources[0].type).toBe('Model')
|
|
70
|
+
expect(resources[0].toString()).toBe('abc123')
|
|
71
|
+
})
|
|
72
|
+
|
|
73
|
+
it('parses multiple modelIds and sorts them', () => {
|
|
74
|
+
const resources = parseUrlParameters('zxy,abc')
|
|
75
|
+
expect(resources).toHaveLength(2)
|
|
76
|
+
expect(resources[0].toString()).toBe('abc')
|
|
77
|
+
expect(resources[1].toString()).toBe('zxy')
|
|
78
|
+
})
|
|
79
|
+
|
|
80
|
+
it('parses modelId@versionId and $folder', () => {
|
|
81
|
+
const resources = parseUrlParameters('abc@ver,$folder')
|
|
82
|
+
expect(resources).toHaveLength(2)
|
|
83
|
+
expect(resources.some((r) => r.type === 'Model')).toBe(true)
|
|
84
|
+
expect(resources.some((r) => r.type === 'ModelFolder')).toBe(true)
|
|
85
|
+
})
|
|
86
|
+
|
|
87
|
+
it('removes duplicate resources', () => {
|
|
88
|
+
const resources = parseUrlParameters('abc,abc,ABC')
|
|
89
|
+
expect(resources).toHaveLength(1)
|
|
90
|
+
expect(resources[0].toString()).toBe('abc')
|
|
91
|
+
})
|
|
92
|
+
|
|
93
|
+
it('handles all resource types together', () => {
|
|
94
|
+
const objectId = '1234567890abcdef1234567890abcdef'
|
|
95
|
+
const resources = parseUrlParameters(`all,abc@ver,$folder,${objectId}`)
|
|
96
|
+
expect(resources).toHaveLength(4)
|
|
97
|
+
expect(resources.some((r) => r.type === 'all-models')).toBe(true)
|
|
98
|
+
expect(resources.some((r) => r.type === 'Model')).toBe(true)
|
|
99
|
+
expect(resources.some((r) => r.type === 'ModelFolder')).toBe(true)
|
|
100
|
+
expect(resources.some((r) => r.type === 'Object')).toBe(true)
|
|
101
|
+
})
|
|
102
|
+
|
|
103
|
+
it('handles whitespace and ignores empty parts', () => {
|
|
104
|
+
const resources = parseUrlParameters('abc, , ,def')
|
|
105
|
+
expect(resources).toHaveLength(2)
|
|
106
|
+
expect(resources[0].toString()).toBe('abc')
|
|
107
|
+
expect(resources[1].toString()).toBe('def')
|
|
108
|
+
})
|
|
109
|
+
|
|
110
|
+
it('lowercases all resource strings', () => {
|
|
111
|
+
const resources = parseUrlParameters('ABC,$FOLDER,DEF@VER')
|
|
112
|
+
expect(resources.map((r) => r.toString()).sort()).toEqual(
|
|
113
|
+
['$FOLDER', 'abc', 'def@ver'].sort()
|
|
114
|
+
)
|
|
115
|
+
})
|
|
116
|
+
|
|
117
|
+
it('sorts resources alphabetically by toString', () => {
|
|
118
|
+
const resources = parseUrlParameters('z,abc,def')
|
|
119
|
+
expect(resources.map((r) => r.toString())).toEqual(['abc', 'def', 'z'])
|
|
120
|
+
})
|
|
121
|
+
})
|
|
122
|
+
|
|
123
|
+
describe('createGetParamFromResources', () => {
|
|
124
|
+
it('returns empty string for empty resource array', () => {
|
|
125
|
+
expect(createGetParamFromResources([])).toBe('')
|
|
126
|
+
})
|
|
127
|
+
|
|
128
|
+
it('returns single resource string for one resource', () => {
|
|
129
|
+
const resources = [parseResourceFromString('abc123')]
|
|
130
|
+
expect(createGetParamFromResources(resources)).toBe('abc123')
|
|
131
|
+
})
|
|
132
|
+
|
|
133
|
+
it('returns comma-separated, sorted, lowercased resource strings', () => {
|
|
134
|
+
const resources = [
|
|
135
|
+
parseResourceFromString('ZXY'),
|
|
136
|
+
parseResourceFromString('abc'),
|
|
137
|
+
parseResourceFromString('DEF@VER')
|
|
138
|
+
]
|
|
139
|
+
expect(createGetParamFromResources(resources)).toBe('abc,def@ver,zxy')
|
|
140
|
+
})
|
|
141
|
+
|
|
142
|
+
it('removes duplicate resources (case-insensitive)', () => {
|
|
143
|
+
const resources = [
|
|
144
|
+
parseResourceFromString('abc'),
|
|
145
|
+
parseResourceFromString('ABC'),
|
|
146
|
+
parseResourceFromString('Abc')
|
|
147
|
+
]
|
|
148
|
+
expect(createGetParamFromResources(resources)).toBe('abc')
|
|
149
|
+
})
|
|
150
|
+
|
|
151
|
+
it('handles all resource types and sorts them', () => {
|
|
152
|
+
const objectId = '1234567890abcdef1234567890abcdef'
|
|
153
|
+
const resources = [
|
|
154
|
+
parseResourceFromString('all'),
|
|
155
|
+
parseResourceFromString('abc@ver'),
|
|
156
|
+
parseResourceFromString('$folder'),
|
|
157
|
+
parseResourceFromString(objectId)
|
|
158
|
+
]
|
|
159
|
+
expect(createGetParamFromResources(resources)).toBe(
|
|
160
|
+
`$folder,1234567890abcdef1234567890abcdef,abc@ver,all`
|
|
161
|
+
.split(',')
|
|
162
|
+
.sort()
|
|
163
|
+
.join(',')
|
|
164
|
+
)
|
|
165
|
+
})
|
|
166
|
+
|
|
167
|
+
it('handles resources with mixed case and sorts them', () => {
|
|
168
|
+
const resources = [
|
|
169
|
+
parseResourceFromString('DEF@VER'),
|
|
170
|
+
parseResourceFromString('abc'),
|
|
171
|
+
parseResourceFromString('ZXY')
|
|
172
|
+
]
|
|
173
|
+
expect(createGetParamFromResources(resources)).toBe('abc,def@ver,zxy')
|
|
174
|
+
})
|
|
175
|
+
|
|
176
|
+
it('handles resources with $ in folder names', () => {
|
|
177
|
+
const resources = [
|
|
178
|
+
parseResourceFromString('$FolderA'),
|
|
179
|
+
parseResourceFromString('$folderb')
|
|
180
|
+
]
|
|
181
|
+
expect(createGetParamFromResources(resources)).toBe('$FolderA,$folderb')
|
|
182
|
+
})
|
|
183
|
+
})
|
|
184
|
+
|
|
185
|
+
describe('resourceBuilder', () => {
|
|
186
|
+
it('can add a single model', () => {
|
|
187
|
+
const builder = resourceBuilder().addModel('abc123')
|
|
188
|
+
expect(builder.length).toBe(1)
|
|
189
|
+
expect(builder.toResources()[0].type).toBe('Model')
|
|
190
|
+
expect(builder.toString()).toBe('abc123')
|
|
191
|
+
})
|
|
192
|
+
|
|
193
|
+
it('can add a model with version', () => {
|
|
194
|
+
const builder = resourceBuilder().addModel('abc123', 'ver456')
|
|
195
|
+
expect(builder.length).toBe(1)
|
|
196
|
+
expect(builder.toResources()[0].toString()).toBe('abc123@ver456')
|
|
197
|
+
})
|
|
198
|
+
|
|
199
|
+
it('can add all models', () => {
|
|
200
|
+
const builder = resourceBuilder().addAllModels()
|
|
201
|
+
expect(builder.length).toBe(1)
|
|
202
|
+
expect(builder.toResources()[0].type).toBe('all-models')
|
|
203
|
+
expect(builder.toString()).toBe('all')
|
|
204
|
+
})
|
|
205
|
+
|
|
206
|
+
it('can add a model folder', () => {
|
|
207
|
+
const builder = resourceBuilder().addModelFolder('MyFolder')
|
|
208
|
+
expect(builder.length).toBe(1)
|
|
209
|
+
expect(builder.toResources()[0].type).toBe('ModelFolder')
|
|
210
|
+
expect(builder.toString()).toBe('$MyFolder')
|
|
211
|
+
})
|
|
212
|
+
|
|
213
|
+
it('can add an object', () => {
|
|
214
|
+
const objectId = '1234567890abcdef1234567890abcdef'
|
|
215
|
+
const builder = resourceBuilder().addObject(objectId)
|
|
216
|
+
expect(builder.length).toBe(1)
|
|
217
|
+
expect(builder.toResources()[0].type).toBe('Object')
|
|
218
|
+
expect(builder.toString()).toBe(objectId)
|
|
219
|
+
})
|
|
220
|
+
|
|
221
|
+
it('can add from string with multiple resources', () => {
|
|
222
|
+
const builder = resourceBuilder().addFromString('abc,def@ver,$folder')
|
|
223
|
+
expect(builder.length).toBe(3)
|
|
224
|
+
expect(builder.toString().split(',').sort()).toEqual(
|
|
225
|
+
['abc', 'def@ver', '$folder'].sort()
|
|
226
|
+
)
|
|
227
|
+
})
|
|
228
|
+
|
|
229
|
+
it('can clear versionIds', () => {
|
|
230
|
+
const builder = resourceBuilder().addResources('abc,def@ver')
|
|
231
|
+
expect(builder.length).toBe(2)
|
|
232
|
+
expect(builder.toString()).toBe('abc,def@ver')
|
|
233
|
+
|
|
234
|
+
builder.clearVersions()
|
|
235
|
+
expect(builder.length).toBe(2)
|
|
236
|
+
expect(builder.toString()).toBe('abc,def')
|
|
237
|
+
})
|
|
238
|
+
|
|
239
|
+
it('can add resources array', () => {
|
|
240
|
+
const resources = [
|
|
241
|
+
parseResourceFromString('abc'),
|
|
242
|
+
parseResourceFromString('def@ver')
|
|
243
|
+
]
|
|
244
|
+
const builder = resourceBuilder().addResources(resources)
|
|
245
|
+
expect(builder.length).toBe(2)
|
|
246
|
+
expect(builder.toString().split(',').sort()).toEqual(['abc', 'def@ver'].sort())
|
|
247
|
+
})
|
|
248
|
+
|
|
249
|
+
it('can clear resources', () => {
|
|
250
|
+
const builder = resourceBuilder().addModel('abc').addModel('def')
|
|
251
|
+
expect(builder.length).toBe(2)
|
|
252
|
+
builder.clear()
|
|
253
|
+
expect(builder.length).toBe(0)
|
|
254
|
+
expect(builder.toString()).toBe('')
|
|
255
|
+
})
|
|
256
|
+
|
|
257
|
+
it('can clone builder', () => {
|
|
258
|
+
const builder = resourceBuilder().addModel('abc').addModel('def')
|
|
259
|
+
const clone = builder.clone()
|
|
260
|
+
expect(clone).not.toBe(builder)
|
|
261
|
+
expect(clone.toString()).toBe(builder.toString())
|
|
262
|
+
clone.addModel('xyz')
|
|
263
|
+
expect(clone.length).toBe(3)
|
|
264
|
+
expect(builder.length).toBe(2)
|
|
265
|
+
})
|
|
266
|
+
|
|
267
|
+
it('can iterate over resources', () => {
|
|
268
|
+
const builder = resourceBuilder().addModel('abc').addModel('def')
|
|
269
|
+
const ids = []
|
|
270
|
+
for (const r of builder) {
|
|
271
|
+
ids.push(r.toString())
|
|
272
|
+
}
|
|
273
|
+
expect(ids.sort()).toEqual(['abc', 'def'].sort())
|
|
274
|
+
})
|
|
275
|
+
|
|
276
|
+
it('can use forEach', () => {
|
|
277
|
+
const builder = resourceBuilder().addModel('abc').addModel('def')
|
|
278
|
+
const ids: string[] = []
|
|
279
|
+
builder.forEach((r) => ids.push(r.toString()))
|
|
280
|
+
expect(ids.sort()).toEqual(['abc', 'def'].sort())
|
|
281
|
+
})
|
|
282
|
+
|
|
283
|
+
it('can use filter', () => {
|
|
284
|
+
const builder = resourceBuilder().addModel('abc').addModel('def')
|
|
285
|
+
const res = builder.filter((r) => r.toString() === 'abc')
|
|
286
|
+
expect(res.length).toBe(1)
|
|
287
|
+
expect(res[0].toString()).toBe('abc')
|
|
288
|
+
})
|
|
289
|
+
|
|
290
|
+
it('can use map', () => {
|
|
291
|
+
const builder = resourceBuilder().addModel('abc').addModel('def')
|
|
292
|
+
const types = builder.map((r) => r.type)
|
|
293
|
+
expect(types.sort()).toEqual(['Model', 'Model'].sort())
|
|
294
|
+
})
|
|
295
|
+
|
|
296
|
+
it('toResources returns a copy', () => {
|
|
297
|
+
const builder = resourceBuilder().addModel('abc')
|
|
298
|
+
const arr = builder.toResources()
|
|
299
|
+
expect(arr).toHaveLength(1)
|
|
300
|
+
arr.push(parseResourceFromString('def'))
|
|
301
|
+
expect(builder.length).toBe(1)
|
|
302
|
+
})
|
|
303
|
+
|
|
304
|
+
it('can find an item', () => {
|
|
305
|
+
const builder = resourceBuilder().addModel('abc').addModel('def')
|
|
306
|
+
const found = builder.find((r) => r.toString() === 'def')
|
|
307
|
+
expect(found).toBeDefined()
|
|
308
|
+
expect(found?.toString()).toBe('def')
|
|
309
|
+
})
|
|
310
|
+
|
|
311
|
+
it('addNew only adds new resources', () => {
|
|
312
|
+
const builder = resourceBuilder().addModel('abc').addModel('def')
|
|
313
|
+
builder.addNew('abc') // should not add
|
|
314
|
+
expect(builder.length).toBe(2)
|
|
315
|
+
builder.addNew('abc@yaya') // should not add
|
|
316
|
+
expect(builder.length).toBe(2)
|
|
317
|
+
builder.addNew('xyz') // should add
|
|
318
|
+
expect(builder.length).toBe(3)
|
|
319
|
+
builder.addNew('$newFolder') // should add
|
|
320
|
+
expect(builder.length).toBe(4)
|
|
321
|
+
expect(builder.toString()).toBe('$newFolder,abc,def,xyz') // $newFolder should keep casing
|
|
322
|
+
})
|
|
323
|
+
|
|
324
|
+
it('addResources can add any kind of ViewerResources', () => {
|
|
325
|
+
const resources = [
|
|
326
|
+
'abc',
|
|
327
|
+
['def@ver', '$folder'],
|
|
328
|
+
parseResourceFromString('abc2'),
|
|
329
|
+
parseResourceFromString('def2@ver'),
|
|
330
|
+
parseResourceFromString('$2folder'),
|
|
331
|
+
resourceBuilder().addModel('nestedModel')
|
|
332
|
+
]
|
|
333
|
+
|
|
334
|
+
const builder = resourceBuilder()
|
|
335
|
+
for (const res of resources) {
|
|
336
|
+
builder.addResources(res)
|
|
337
|
+
}
|
|
338
|
+
|
|
339
|
+
expect(builder.length).toBe(7)
|
|
340
|
+
expect(builder.toString().split(',').sort()).toEqual(
|
|
341
|
+
[
|
|
342
|
+
'abc',
|
|
343
|
+
'abc2',
|
|
344
|
+
'def@ver',
|
|
345
|
+
'def2@ver',
|
|
346
|
+
'nestedmodel',
|
|
347
|
+
'$2folder',
|
|
348
|
+
'$folder'
|
|
349
|
+
].sort()
|
|
350
|
+
)
|
|
351
|
+
})
|
|
352
|
+
})
|
|
353
|
+
})
|
|
@@ -1,11 +1,13 @@
|
|
|
1
|
-
import { uniq, uniqBy } from '#lodash'
|
|
1
|
+
import { isString, uniq, uniqBy } from '#lodash'
|
|
2
2
|
|
|
3
|
-
export
|
|
4
|
-
Model
|
|
5
|
-
Object
|
|
6
|
-
ModelFolder
|
|
7
|
-
AllModels
|
|
3
|
+
export const ViewerResourceType = <const>{
|
|
4
|
+
Model: 'Model',
|
|
5
|
+
Object: 'Object',
|
|
6
|
+
ModelFolder: 'ModelFolder',
|
|
7
|
+
AllModels: 'all-models'
|
|
8
8
|
}
|
|
9
|
+
export type ViewerResourceType =
|
|
10
|
+
(typeof ViewerResourceType)[keyof typeof ViewerResourceType]
|
|
9
11
|
|
|
10
12
|
export interface ViewerResource {
|
|
11
13
|
type: ViewerResourceType
|
|
@@ -27,8 +29,8 @@ export class ViewerModelResource implements ViewerResource {
|
|
|
27
29
|
|
|
28
30
|
constructor(modelId: string, versionId?: string) {
|
|
29
31
|
this.type = ViewerResourceType.Model
|
|
30
|
-
this.modelId = modelId
|
|
31
|
-
this.versionId = versionId
|
|
32
|
+
this.modelId = modelId.toLowerCase()
|
|
33
|
+
this.versionId = versionId?.toLowerCase()
|
|
32
34
|
}
|
|
33
35
|
|
|
34
36
|
toString(): string {
|
|
@@ -43,7 +45,7 @@ export class ViewerVersionResource extends ViewerModelResource {
|
|
|
43
45
|
|
|
44
46
|
constructor(modelId: string, versionId: string) {
|
|
45
47
|
super(modelId, versionId)
|
|
46
|
-
this.versionId = versionId
|
|
48
|
+
this.versionId = versionId?.toLowerCase()
|
|
47
49
|
}
|
|
48
50
|
|
|
49
51
|
toJSON() {
|
|
@@ -57,7 +59,7 @@ export class ViewerObjectResource implements ViewerResource {
|
|
|
57
59
|
|
|
58
60
|
constructor(objectId: string) {
|
|
59
61
|
this.type = ViewerResourceType.Object
|
|
60
|
-
this.objectId = objectId
|
|
62
|
+
this.objectId = objectId.toLowerCase()
|
|
61
63
|
}
|
|
62
64
|
|
|
63
65
|
toString(): string {
|
|
@@ -75,26 +77,36 @@ export class ViewerModelFolderResource implements ViewerResource {
|
|
|
75
77
|
}
|
|
76
78
|
|
|
77
79
|
toString(): string {
|
|
78
|
-
return
|
|
80
|
+
return '$' + this.folderName
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
export const parseResourceFromString = (resourceId: string): ViewerResource => {
|
|
85
|
+
if (resourceId === 'all') {
|
|
86
|
+
return new ViewerAllModelsResource()
|
|
87
|
+
} else if (resourceId.includes('@')) {
|
|
88
|
+
const [modelId, versionId] = resourceId.split('@')
|
|
89
|
+
return new ViewerVersionResource(modelId, versionId)
|
|
90
|
+
} else if (resourceId.startsWith('$')) {
|
|
91
|
+
return new ViewerModelFolderResource(resourceId.substring(1))
|
|
92
|
+
} else if (resourceId.length === 32) {
|
|
93
|
+
return new ViewerObjectResource(resourceId)
|
|
94
|
+
} else {
|
|
95
|
+
return new ViewerModelResource(resourceId)
|
|
79
96
|
}
|
|
80
97
|
}
|
|
81
98
|
|
|
82
99
|
export function parseUrlParameters(resourceGetParam: string) {
|
|
83
100
|
if (!resourceGetParam?.length) return []
|
|
84
|
-
const parts = resourceGetParam
|
|
101
|
+
const parts = resourceGetParam
|
|
102
|
+
.split(',')
|
|
103
|
+
.filter((i) => i.trim().length)
|
|
104
|
+
.sort()
|
|
85
105
|
const resources: ViewerResource[] = []
|
|
86
106
|
for (const part of parts) {
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
const [modelId, versionId] = part.split('@')
|
|
91
|
-
resources.push(new ViewerModelResource(modelId, versionId))
|
|
92
|
-
} else if (part.startsWith('$')) {
|
|
93
|
-
resources.push(new ViewerModelFolderResource(part.substring(1)))
|
|
94
|
-
} else if (part.length === 32) {
|
|
95
|
-
resources.push(new ViewerObjectResource(part))
|
|
96
|
-
} else {
|
|
97
|
-
resources.push(new ViewerModelResource(part))
|
|
107
|
+
const resource = parseResourceFromString(part)
|
|
108
|
+
if (resource) {
|
|
109
|
+
resources.push(resource)
|
|
98
110
|
}
|
|
99
111
|
}
|
|
100
112
|
|
|
@@ -103,7 +115,7 @@ export function parseUrlParameters(resourceGetParam: string) {
|
|
|
103
115
|
}
|
|
104
116
|
|
|
105
117
|
export function createGetParamFromResources(resources: ViewerResource[]) {
|
|
106
|
-
const resourceParts = uniq(resources.map((r) => r.toString()
|
|
118
|
+
const resourceParts = uniq(resources.map((r) => r.toString())).sort()
|
|
107
119
|
return resourceParts.join(',')
|
|
108
120
|
}
|
|
109
121
|
|
|
@@ -120,35 +132,176 @@ export const isModelFolderResource = (
|
|
|
120
132
|
r: ViewerResource
|
|
121
133
|
): r is ViewerModelFolderResource => r.type === ViewerResourceType.ModelFolder
|
|
122
134
|
|
|
123
|
-
|
|
135
|
+
type StringViewerResourcesTarget = string | string[]
|
|
136
|
+
export type ViewerResourcesTarget =
|
|
137
|
+
| ViewerResourceBuilder
|
|
138
|
+
| ViewerResource[]
|
|
139
|
+
| ViewerResource
|
|
140
|
+
| StringViewerResourcesTarget
|
|
141
|
+
|
|
142
|
+
const toViewerResourceArray = (res: ViewerResourcesTarget): ViewerResource[] => {
|
|
143
|
+
if (res instanceof ViewerResourceBuilder) {
|
|
144
|
+
return res.toResources()
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
const fixString = (r: string | ViewerResource): ViewerResource[] =>
|
|
148
|
+
isString(r) ? parseUrlParameters(r) : [r]
|
|
149
|
+
|
|
150
|
+
if (Array.isArray(res)) {
|
|
151
|
+
return res.flatMap(fixString)
|
|
152
|
+
} else {
|
|
153
|
+
return fixString(res)
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
class ViewerResourceBuilder implements Iterable<ViewerResource> {
|
|
124
158
|
#resources: ViewerResource[] = []
|
|
125
159
|
|
|
160
|
+
#order() {
|
|
161
|
+
this.#resources = uniq(this.#resources).sort()
|
|
162
|
+
}
|
|
163
|
+
|
|
126
164
|
addAllModels() {
|
|
127
165
|
this.#resources.push(new ViewerAllModelsResource())
|
|
166
|
+
this.#order()
|
|
128
167
|
return this
|
|
129
168
|
}
|
|
130
169
|
addModel(modelId: string, versionId?: string) {
|
|
131
170
|
this.#resources.push(new ViewerModelResource(modelId, versionId))
|
|
171
|
+
this.#order()
|
|
132
172
|
return this
|
|
133
173
|
}
|
|
134
174
|
addModelFolder(folderName: string) {
|
|
135
175
|
this.#resources.push(new ViewerModelFolderResource(folderName))
|
|
176
|
+
this.#order()
|
|
136
177
|
return this
|
|
137
178
|
}
|
|
138
179
|
addObject(objectId: string) {
|
|
139
180
|
this.#resources.push(new ViewerObjectResource(objectId))
|
|
181
|
+
this.#order()
|
|
140
182
|
return this
|
|
141
183
|
}
|
|
184
|
+
/**
|
|
185
|
+
* @deprecated Use 'addResources' or 'addNew' instead
|
|
186
|
+
*/
|
|
187
|
+
addFromString(stringResources: StringViewerResourcesTarget) {
|
|
188
|
+
const strings = Array.isArray(stringResources) ? stringResources : [stringResources]
|
|
189
|
+
for (const resourceIdString of strings) {
|
|
190
|
+
const resources = parseUrlParameters(resourceIdString.toLowerCase())
|
|
191
|
+
this.#resources.push(...resources)
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
this.#order()
|
|
195
|
+
return this
|
|
196
|
+
}
|
|
197
|
+
addResources(res: ViewerResourcesTarget) {
|
|
198
|
+
this.#resources.push(...toViewerResourceArray(res))
|
|
199
|
+
this.#order()
|
|
200
|
+
return this
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
/**
|
|
204
|
+
* Only add those resources that are not already in the builder.
|
|
205
|
+
*/
|
|
206
|
+
addNew(
|
|
207
|
+
incoming: ViewerResourcesTarget,
|
|
208
|
+
options?: {
|
|
209
|
+
/**
|
|
210
|
+
* If true, will require exact version matches for model resources
|
|
211
|
+
* Default: false
|
|
212
|
+
*/
|
|
213
|
+
requireExactMatch?: boolean
|
|
214
|
+
}
|
|
215
|
+
) {
|
|
216
|
+
const { requireExactMatch = false } = options || {}
|
|
217
|
+
const resources = toViewerResourceArray(incoming)
|
|
218
|
+
|
|
219
|
+
const newResources: ViewerResource[] = this.#resources.slice()
|
|
220
|
+
for (const resource of resources) {
|
|
221
|
+
// check if newResources has a resource w/ same modelId (check w/ isModelResource)
|
|
222
|
+
if (isModelResource(resource) && !requireExactMatch) {
|
|
223
|
+
const existing = newResources.find(
|
|
224
|
+
(r) => isModelResource(r) && r.modelId === resource.modelId
|
|
225
|
+
)
|
|
226
|
+
if (!existing) {
|
|
227
|
+
newResources.push(resource)
|
|
228
|
+
}
|
|
229
|
+
} else if (!newResources.some((r) => r.toString() === resource.toString())) {
|
|
230
|
+
newResources.push(resource)
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
this.#resources = newResources
|
|
235
|
+
this.#order()
|
|
236
|
+
|
|
237
|
+
return this
|
|
238
|
+
}
|
|
239
|
+
|
|
142
240
|
toString() {
|
|
143
241
|
return createGetParamFromResources(this.#resources)
|
|
144
242
|
}
|
|
145
243
|
toResources() {
|
|
146
244
|
return this.#resources.slice()
|
|
147
245
|
}
|
|
246
|
+
toResourceIds() {
|
|
247
|
+
return this.toResources().map((r) => r.toString())
|
|
248
|
+
}
|
|
148
249
|
clear() {
|
|
149
250
|
this.#resources = []
|
|
150
251
|
return this
|
|
151
252
|
}
|
|
253
|
+
clone() {
|
|
254
|
+
const clone = new ViewerResourceBuilder()
|
|
255
|
+
const resources = this.toString()
|
|
256
|
+
clone.addResources(resources)
|
|
257
|
+
return clone
|
|
258
|
+
}
|
|
259
|
+
get length() {
|
|
260
|
+
return this.#resources.length
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
/**
|
|
264
|
+
* Remove specified versionIds from any model resources
|
|
265
|
+
*/
|
|
266
|
+
clearVersions() {
|
|
267
|
+
this.#resources.forEach((r) => {
|
|
268
|
+
if (!isModelResource(r)) return
|
|
269
|
+
r.versionId = undefined
|
|
270
|
+
})
|
|
271
|
+
return this
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
isEqualTo(resource: ViewerResourcesTarget) {
|
|
275
|
+
const incomingBuilder = resourceBuilder().addResources(resource)
|
|
276
|
+
return this.toString() === incomingBuilder.toString()
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
forEach(callback: (resource: ViewerResource) => void) {
|
|
280
|
+
this.#resources.forEach(callback)
|
|
281
|
+
return this
|
|
282
|
+
}
|
|
283
|
+
|
|
284
|
+
filter<Res extends ViewerResource>(
|
|
285
|
+
callback: (resource: ViewerResource) => resource is Res
|
|
286
|
+
): Res[]
|
|
287
|
+
filter(callback: (resource: ViewerResource) => boolean): ViewerResource[]
|
|
288
|
+
filter(callback: (resource: ViewerResource) => boolean) {
|
|
289
|
+
return this.#resources.filter(callback)
|
|
290
|
+
}
|
|
291
|
+
|
|
292
|
+
find<Res extends ViewerResource>(
|
|
293
|
+
callback: (resource: ViewerResource) => resource is Res
|
|
294
|
+
): Res | undefined
|
|
295
|
+
find(callback: (resource: ViewerResource) => boolean): ViewerResource | undefined
|
|
296
|
+
find(callback: (resource: ViewerResource) => boolean) {
|
|
297
|
+
return this.#resources.find(callback)
|
|
298
|
+
}
|
|
299
|
+
map<T>(callback: (resource: ViewerResource) => T): T[] {
|
|
300
|
+
return this.#resources.map(callback)
|
|
301
|
+
}
|
|
302
|
+
[Symbol.iterator](): Iterator<ViewerResource> {
|
|
303
|
+
return this.#resources[Symbol.iterator]()
|
|
304
|
+
}
|
|
152
305
|
}
|
|
153
306
|
|
|
154
307
|
/**
|
|
@@ -157,3 +310,5 @@ class ViewerResourceBuilder {
|
|
|
157
310
|
export function resourceBuilder() {
|
|
158
311
|
return new ViewerResourceBuilder()
|
|
159
312
|
}
|
|
313
|
+
|
|
314
|
+
export type ResourceBuilder = ReturnType<typeof resourceBuilder>
|