@rancher/shell 3.0.12-rc.1 → 3.0.12-rc.3
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/apis/impl/apis.ts +6 -0
- package/apis/index.ts +26 -0
- package/apis/intf/resources-api/cluster-api.ts +18 -0
- package/apis/intf/resources-api/mgmt-api.ts +15 -0
- package/apis/intf/resources-api/resource-base.ts +107 -0
- package/apis/intf/resources-api/resource-constants.ts +147 -0
- package/apis/intf/resources-api/resources-api.ts +143 -0
- package/apis/intf/resources.ts +49 -0
- package/apis/intf/{modal.ts → shell-api/modal.ts} +21 -26
- package/apis/intf/shell-api/proxy.ts +216 -0
- package/apis/intf/{slide-in.ts → shell-api/slide-in.ts} +4 -3
- package/apis/intf/{system.ts → shell-api/system.ts} +4 -1
- package/apis/intf/shell.ts +12 -6
- package/apis/resources/__tests__/resources-api-class.test.ts +550 -0
- package/apis/resources/index.ts +22 -0
- package/apis/resources/resources-api-class.ts +187 -0
- package/apis/shell/__tests__/proxy.test.ts +369 -0
- package/apis/shell/index.ts +8 -1
- package/apis/shell/modal.ts +4 -1
- package/apis/shell/notifications.ts +9 -6
- package/apis/shell/proxy.ts +256 -0
- package/apis/shell/slide-in.ts +4 -1
- package/apis/vue-shim.d.ts +2 -1
- package/assets/data/aws-regions.json +4 -0
- package/assets/fonts/lato/LatoLatin-Black.woff +0 -0
- package/assets/fonts/lato/LatoLatin-Black.woff2 +0 -0
- package/assets/fonts/lato/LatoLatin-BlackItalic.woff +0 -0
- package/assets/fonts/lato/LatoLatin-BlackItalic.woff2 +0 -0
- package/assets/fonts/lato/LatoLatin-Bold.woff +0 -0
- package/assets/fonts/lato/LatoLatin-Bold.woff2 +0 -0
- package/assets/fonts/lato/LatoLatin-BoldItalic.woff +0 -0
- package/assets/fonts/lato/LatoLatin-BoldItalic.woff2 +0 -0
- package/assets/fonts/lato/LatoLatin-Heavy.woff +0 -0
- package/assets/fonts/lato/LatoLatin-Heavy.woff2 +0 -0
- package/assets/fonts/lato/LatoLatin-HeavyItalic.woff +0 -0
- package/assets/fonts/lato/LatoLatin-HeavyItalic.woff2 +0 -0
- package/assets/fonts/lato/LatoLatin-Italic.woff +0 -0
- package/assets/fonts/lato/LatoLatin-Italic.woff2 +0 -0
- package/assets/fonts/lato/LatoLatin-Light.woff +0 -0
- package/assets/fonts/lato/LatoLatin-Light.woff2 +0 -0
- package/assets/fonts/lato/LatoLatin-LightItalic.woff +0 -0
- package/assets/fonts/lato/LatoLatin-LightItalic.woff2 +0 -0
- package/assets/fonts/lato/LatoLatin-Medium.woff +0 -0
- package/assets/fonts/lato/LatoLatin-Medium.woff2 +0 -0
- package/assets/fonts/lato/LatoLatin-MediumItalic.woff +0 -0
- package/assets/fonts/lato/LatoLatin-MediumItalic.woff2 +0 -0
- package/assets/fonts/lato/LatoLatin-Regular.woff +0 -0
- package/assets/fonts/lato/LatoLatin-Regular.woff2 +0 -0
- package/assets/fonts/lato/LatoLatin-Semibold.woff +0 -0
- package/assets/fonts/lato/LatoLatin-Semibold.woff2 +0 -0
- package/assets/fonts/lato/LatoLatin-SemiboldItalic.woff +0 -0
- package/assets/fonts/lato/LatoLatin-SemiboldItalic.woff2 +0 -0
- package/assets/images/providers/entraid-black.svg +4 -0
- package/assets/images/providers/entraid.svg +9 -0
- package/assets/images/vendor/entraid.svg +9 -0
- package/assets/styles/app.scss +0 -1
- package/assets/styles/base/_variables.scss +2 -0
- package/assets/styles/fonts/_fontstack.scss +132 -8
- package/assets/translations/en-us.yaml +41 -22
- package/assets/translations/zh-hans.yaml +4 -8
- package/chart/__tests__/S3.test.ts +10 -3
- package/chart/monitoring/index.vue +10 -1
- package/components/ActionDropdownShell.vue +2 -1
- package/components/CountBox.vue +20 -0
- package/components/CreateDriver.vue +0 -12
- package/components/CruResourceFooter.vue +9 -5
- package/components/DetailText.vue +12 -3
- package/components/ExplorerProjectsNamespaces.vue +1 -1
- package/components/InstallHelmCharts.vue +2 -2
- package/components/LandingPagePreference.vue +14 -5
- package/components/Resource/Detail/Metadata/IdentifyingInformation/index.vue +15 -1
- package/components/Resource/Detail/Metadata/index.vue +6 -0
- package/components/Resource/Detail/ResourcePopover/index.vue +12 -1
- package/components/Resource/Detail/SpacedRow.vue +3 -1
- package/components/Resource/Detail/TitleBar/index.vue +10 -11
- package/components/ResourceList/Masthead.vue +12 -8
- package/components/SelectIconGrid.vue +5 -10
- package/components/SingleClusterInfo.vue +1 -0
- package/components/SortableTable/__tests__/sorting.test.ts +126 -0
- package/components/SortableTable/index.vue +6 -9
- package/components/SortableTable/selection.js +23 -5
- package/components/SortableTable/sorting.js +6 -3
- package/components/Wizard.vue +14 -13
- package/components/__tests__/CountBox.test.ts +72 -0
- package/components/__tests__/DetailText.test.ts +113 -0
- package/components/fleet/FleetBundles.vue +100 -12
- package/components/fleet/FleetClusterTargets/index.vue +54 -15
- package/components/fleet/__tests__/FleetClusterTargets.test.ts +149 -115
- package/components/fleet/__tests__/FleetClusters.test.ts +12 -12
- package/components/form/InputWithSelect.vue +18 -10
- package/components/form/KeyValue.vue +17 -1
- package/components/form/LabeledSelect.vue +101 -26
- package/components/form/NameNsDescription.vue +11 -0
- package/components/form/Security.vue +6 -2
- package/components/form/Select.vue +73 -56
- package/components/form/ServiceNameSelect.vue +13 -11
- package/components/form/WorkloadPorts.vue +2 -7
- package/components/form/__tests__/KeyValue.test.ts +66 -0
- package/components/form/__tests__/NodeScheduling.test.ts +9 -0
- package/components/form/__tests__/Security.test.ts +76 -0
- package/components/form/labeled-select-utils/useLabeledSelectPagination.ts +138 -0
- package/components/formatter/Autoscaler.vue +4 -4
- package/components/formatter/ClusterKubeVersion.vue +27 -0
- package/components/formatter/ClusterLink.vue +1 -7
- package/components/formatter/ClusterProvider.vue +6 -10
- package/components/formatter/FleetSummaryGraph.vue +0 -3
- package/components/formatter/MachineSummaryGraph.vue +1 -1
- package/components/formatter/PodsUsage.vue +2 -2
- package/components/formatter/__tests__/Autoscaler.test.ts +19 -22
- package/components/formatter/__tests__/FleetSummaryGraph.test.ts +216 -0
- package/components/formatter/__tests__/PodsUsage.test.ts +6 -10
- package/components/nav/Group.vue +7 -6
- package/components/nav/Header.vue +24 -3
- package/components/nav/NamespaceFilter.vue +2 -2
- package/components/nav/NotificationCenter/Notification.vue +4 -1
- package/components/nav/NotificationCenter/NotificationHeader.vue +20 -8
- package/components/nav/NotificationCenter/__tests__/NotificationHeader.test.ts +80 -0
- package/components/nav/TopLevelMenu.helper.ts +15 -3
- package/components/nav/TopLevelMenu.vue +16 -5
- package/components/nav/Type.vue +8 -7
- package/components/nav/WindowManager/index.vue +2 -1
- package/components/nav/WorkspaceSwitcher.vue +13 -0
- package/components/nav/__tests__/Group.test.ts +67 -0
- package/components/nav/__tests__/Header.test.ts +235 -0
- package/components/nav/__tests__/TopLevelMenu.test.ts +145 -21
- package/components/nav/__tests__/Type.test.ts +20 -3
- package/components/templates/default.vue +34 -4
- package/components/templates/home.vue +30 -25
- package/components/templates/plain.vue +31 -26
- package/components/templates/standalone.vue +17 -0
- package/composables/useFormValidation.ts +93 -0
- package/composables/useLabeledFormElement.ts +10 -2
- package/composables/useLabeledSelect.ts +60 -0
- package/composables/useUserRetentionValidation.ts +1 -49
- package/composables/useVeeValidateField.test.ts +159 -0
- package/composables/useVeeValidateField.ts +67 -0
- package/config/cookies.js +0 -1
- package/config/labels-annotations.js +1 -0
- package/config/pagination-table-headers.js +18 -1
- package/config/product/manager.js +82 -21
- package/config/query-params.js +1 -0
- package/config/router/routes.js +6 -8
- package/config/table-headers.js +20 -1
- package/config/types.js +2 -1
- package/core/__tests__/plugin-products.test.ts +1505 -30
- package/core/plugin-products-base.ts +137 -20
- package/core/plugin-products-helpers.ts +5 -4
- package/core/plugin-products.ts +4 -0
- package/core/plugin-types.ts +129 -4
- package/core/plugin.ts +15 -7
- package/core/productDebugger.js +9 -4
- package/core/types-provisioning.ts +43 -30
- package/core/types.ts +58 -19
- package/detail/__tests__/management.cattle.io.fleetworkspace.test.ts +128 -0
- package/detail/__tests__/pod.test.ts +41 -0
- package/detail/harvesterhci.io.management.cluster.vue +6 -2
- package/detail/management.cattle.io.fleetworkspace.vue +49 -0
- package/detail/pod.vue +1 -1
- package/detail/provisioning.cattle.io.cluster.vue +4 -10
- package/edit/__tests__/fleet.cattle.io.helmop.test.ts +9 -0
- package/edit/__tests__/kontainerDriver.test.ts +0 -13
- package/edit/__tests__/nodeDriver.test.ts +5 -11
- package/edit/__tests__/resources.cattle.io.restore.test.ts +9 -0
- package/edit/auditlog.cattle.io.auditpolicy/__tests__/__snapshots__/General.test.ts.snap +6 -0
- package/edit/auth/__tests__/azuread.test.ts +217 -34
- package/edit/auth/__tests__/oidc.test.ts +54 -0
- package/edit/auth/azuread.vue +123 -15
- package/edit/auth/oidc.vue +10 -2
- package/edit/kontainerDriver.vue +1 -2
- package/edit/networking.k8s.io.ingress/DefaultBackend.vue +13 -4
- package/edit/networking.k8s.io.ingress/RulePath.vue +8 -4
- package/edit/networking.k8s.io.ingress/index.vue +75 -20
- package/edit/nodeDriver.vue +0 -2
- package/edit/provisioning.cattle.io.cluster/AgentEnv.vue +1 -0
- package/edit/provisioning.cattle.io.cluster/__tests__/AgentEnv.test.ts +25 -0
- package/edit/provisioning.cattle.io.cluster/__tests__/MachinePool.test.ts +104 -0
- package/edit/provisioning.cattle.io.cluster/index.vue +81 -106
- package/edit/provisioning.cattle.io.cluster/rke2.vue +8 -4
- package/edit/provisioning.cattle.io.cluster/tabs/MachinePool.vue +11 -0
- package/edit/provisioning.cattle.io.cluster/tabs/registries/RegistryConfigs.vue +37 -4
- package/edit/provisioning.cattle.io.cluster/tabs/registries/__tests__/RegistryConfigs.test.ts +132 -7
- package/edit/provisioning.cattle.io.cluster/tabs/registries/index.vue +2 -1
- package/edit/secret/__tests__/ssh.test.ts +5 -6
- package/edit/secret/basic.vue +31 -0
- package/edit/secret/index.vue +68 -17
- package/edit/secret/registry.vue +38 -0
- package/edit/secret/ssh.vue +29 -0
- package/edit/secret/tls.vue +30 -0
- package/edit/service.vue +4 -4
- package/edit/workload/Upgrading.vue +3 -3
- package/edit/workload/__tests__/Upgrading.test.ts +6 -9
- package/edit/workload/mixins/workload.js +2 -1
- package/initialize/App.vue +29 -2
- package/initialize/install-plugins.js +0 -2
- package/list/__tests__/management.cattle.io.feature.test.ts +105 -0
- package/list/catalog.cattle.io.app.vue +25 -5
- package/list/fleet.cattle.io.bundle.vue +7 -104
- package/list/fleet.cattle.io.clusterregistrationtoken.vue +20 -0
- package/list/management.cattle.io.feature.vue +1 -1
- package/list/management.cattle.io.fleetworkspace.vue +8 -0
- package/list/provisioning.cattle.io.cluster.vue +262 -180
- package/list/utils/management.cattle.io.cluster.utils.ts +128 -0
- package/machine-config/amazonec2.vue +1 -0
- package/mixins/__tests__/chart.test.ts +112 -0
- package/mixins/brand.js +2 -1
- package/mixins/chart.js +50 -15
- package/mixins/resource-fetch-api-pagination.js +41 -5
- package/models/__tests__/catalog.cattle.io.app.test.ts +15 -1
- package/models/__tests__/catalog.cattle.io.clusterrepo.test.ts +84 -0
- package/models/__tests__/chart.test.ts +99 -6
- package/models/__tests__/ext.cattle.io.kubeconfig.test.ts +67 -67
- package/models/__tests__/management.cattle.io.cluster.test.ts +1 -1
- package/models/__tests__/management.cattle.io.feature.test.ts +131 -0
- package/models/__tests__/management.cattle.io.node.ts +6 -5
- package/models/__tests__/management.cattle.io.nodepool.ts +5 -4
- package/models/__tests__/monitoring.coreos.com.alertmanagerconfig.test.ts +98 -0
- package/models/__tests__/provisioning.cattle.io.cluster.test.ts +32 -11
- package/models/base-cluster.x-k8s.io.js +26 -0
- package/models/catalog.cattle.io.app.js +21 -17
- package/models/catalog.cattle.io.clusterrepo.js +39 -11
- package/models/chart.js +33 -19
- package/models/cluster.js +1 -1
- package/models/cluster.x-k8s.io.machine.js +4 -22
- package/models/cluster.x-k8s.io.machinedeployment.js +2 -20
- package/models/cluster.x-k8s.io.machineset.js +2 -20
- package/models/compliance.cattle.io.clusterscan.js +130 -2
- package/models/ext.cattle.io.kubeconfig.ts +4 -7
- package/models/fleet-application.js +4 -2
- package/models/fleet.cattle.io.bundle.js +1 -1
- package/models/kontainerdriver.js +11 -0
- package/models/management.cattle.io.authconfig.js +5 -1
- package/models/management.cattle.io.cluster.js +402 -78
- package/models/management.cattle.io.feature.js +3 -3
- package/models/management.cattle.io.kontainerdriver.js +1 -26
- package/models/management.cattle.io.node.js +6 -4
- package/models/management.cattle.io.nodepool.js +1 -1
- package/models/monitoring.coreos.com.alertmanagerconfig.js +31 -17
- package/models/networking.k8s.io.ingress.js +12 -4
- package/models/nodedriver.js +7 -0
- package/models/provisioning.cattle.io.cluster.js +47 -330
- package/models/rke.cattle.io.etcdsnapshot.js +1 -2
- package/package.json +20 -37
- package/pages/__tests__/readme.test.ts +49 -0
- package/pages/auth/setup.vue +2 -3
- package/pages/c/_cluster/apps/charts/__tests__/chart.test.ts +265 -0
- package/pages/c/_cluster/apps/charts/__tests__/index.test.ts +55 -0
- package/pages/c/_cluster/apps/charts/__tests__/install.test.ts +53 -0
- package/pages/c/_cluster/apps/charts/chart.vue +275 -39
- package/pages/c/_cluster/apps/charts/index.vue +2 -2
- package/pages/c/_cluster/apps/charts/install.vue +18 -10
- package/pages/c/_cluster/auth/user.retention/index.vue +55 -22
- package/pages/c/_cluster/explorer/__tests__/index.test.ts +23 -25
- package/pages/c/_cluster/explorer/index.vue +5 -49
- package/pages/c/_cluster/istio/__tests__/istio.index.test.ts +194 -0
- package/pages/c/_cluster/istio/index.vue +21 -6
- package/pages/c/_cluster/manager/drivers/kontainerDriver/index.vue +5 -7
- package/pages/c/_cluster/uiplugins/PluginInfoPanel.vue +40 -2
- package/pages/c/_cluster/uiplugins/__tests__/PluginInfoPanel.test.ts +61 -0
- package/pages/c/_cluster/uiplugins/__tests__/index.test.ts +735 -13
- package/pages/c/_cluster/uiplugins/index.vue +226 -222
- package/pages/diagnostic.vue +13 -17
- package/pages/fail-whale.vue +18 -0
- package/pages/home.vue +77 -260
- package/pages/readme.vue +88 -0
- package/plugins/dashboard-store/__tests__/resource-class.test.ts +88 -0
- package/plugins/dashboard-store/actions.js +40 -18
- package/plugins/dashboard-store/resource-class.js +5 -2
- package/plugins/steve/__tests__/subscribe.spec.ts +6 -3
- package/plugins/steve/steve-pagination-utils.ts +11 -3
- package/plugins/steve/subscribe.js +35 -5
- package/rancher-components/Form/LabeledInput/LabeledInput.test.ts +211 -1
- package/rancher-components/Form/LabeledInput/LabeledInput.vue +37 -4
- package/rancher-components/Form/ToggleSwitch/ToggleSwitch.vue +1 -1
- package/rancher-components/RcButton/RcButton.test.ts +37 -1
- package/rancher-components/RcButton/RcButton.vue +38 -8
- package/rancher-components/RcDropdown/RcDropdownTrigger.vue +10 -8
- package/scripts/test-plugins-build.sh +5 -2
- package/server/server-middleware.js +2 -2
- package/static/humans.txt +1 -0
- package/static/robots.txt +34 -0
- package/static/welcome-cow.svg +18 -0
- package/store/__tests__/catalog.test.ts +276 -12
- package/store/__tests__/type-map.test.ts +556 -1
- package/store/action-menu.js +8 -3
- package/store/auth.js +1 -4
- package/store/aws.js +27 -16
- package/store/catalog.js +87 -11
- package/store/digitalocean.js +20 -38
- package/store/index.js +2 -0
- package/store/linode.js +25 -40
- package/store/pnap.js +1 -0
- package/store/type-map.js +111 -29
- package/tsconfig.paths.json +8 -8
- package/types/kube/kube-api.ts +14 -1
- package/types/rancher/steve.api.ts +12 -12
- package/types/resources/settings.d.ts +2 -1
- package/types/shell/index.d.ts +128 -24
- package/types/store/dashboard-store.types.ts +108 -11
- package/types/store/pagination.types.ts +6 -3
- package/utils/__tests__/alertmanagerconfig.test.ts +117 -0
- package/utils/__tests__/async.test.ts +87 -0
- package/utils/__tests__/aws.test.ts +140 -0
- package/utils/__tests__/banners.test.ts +176 -0
- package/utils/__tests__/chart.test.ts +64 -1
- package/utils/__tests__/color.test.ts +226 -0
- package/utils/__tests__/duration.test.ts +140 -0
- package/utils/__tests__/fleet.test.ts +340 -0
- package/utils/__tests__/git.test.ts +270 -0
- package/utils/__tests__/inactivity.test.ts +316 -0
- package/utils/__tests__/ingress.test.ts +553 -0
- package/utils/__tests__/kube.test.ts +68 -0
- package/utils/__tests__/namespace-filter.test.ts +109 -0
- package/utils/__tests__/object.test.ts +77 -0
- package/utils/__tests__/pagination-utils.test.ts +361 -0
- package/utils/__tests__/parse-externalid.test.ts +137 -0
- package/utils/__tests__/perf-setting.utils.test.ts +98 -0
- package/utils/__tests__/poller-sequential.test.ts +177 -0
- package/utils/__tests__/poller.test.ts +170 -0
- package/utils/__tests__/promise.test.ts +346 -0
- package/utils/__tests__/settings.test.ts +140 -0
- package/utils/__tests__/sort-utils.test.ts +301 -0
- package/utils/__tests__/string-utils.test.ts +798 -0
- package/utils/__tests__/string.test.ts +23 -1
- package/utils/__tests__/style.test.ts +154 -0
- package/utils/__tests__/svg-filter.test.ts +184 -0
- package/utils/__tests__/time.test.ts +14 -1
- package/utils/__tests__/units.test.ts +417 -0
- package/utils/__tests__/url.test.ts +246 -0
- package/utils/__tests__/versions.test.ts +128 -0
- package/utils/__tests__/xccdf.test.ts +391 -0
- package/utils/chart.js +36 -0
- package/utils/fleet.ts +13 -3
- package/utils/gatekeeper/__tests__/util.test.ts +174 -0
- package/utils/gc/__tests__/gc-interval.test.ts +119 -0
- package/utils/gc/__tests__/gc-root-store.test.ts +225 -0
- package/utils/gc/__tests__/gc-route-changed.test.ts +96 -0
- package/utils/gc/__tests__/gc.test.ts +487 -0
- package/utils/ingress.ts +9 -1
- package/utils/object.js +33 -2
- package/utils/pagination-utils.ts +2 -1
- package/utils/string.js +25 -2
- package/utils/time.ts +5 -0
- package/utils/uiplugins.ts +5 -5
- package/utils/validators/__tests__/cluster-name.test.ts +110 -0
- package/utils/validators/__tests__/cron-schedule.test.ts +79 -0
- package/utils/validators/__tests__/index.test.ts +481 -0
- package/utils/validators/__tests__/kubernetes-name.test.ts +163 -0
- package/utils/validators/__tests__/misc-validators.test.ts +246 -0
- package/utils/validators/__tests__/pod-affinity.test.ts +382 -0
- package/utils/validators/__tests__/prometheusrule.test.ts +211 -0
- package/utils/validators/__tests__/role-template.test.ts +149 -0
- package/utils/validators/__tests__/service.test.ts +283 -0
- package/utils/validators/__tests__/setting.test.js +32 -0
- package/utils/validators/formRules/__tests__/index.test.ts +50 -0
- package/utils/validators/formRules/index.ts +5 -5
- package/utils/validators/machine-pool.ts +1 -1
- package/utils/validators/setting.js +18 -3
- package/utils/xccdf.ts +418 -0
- package/vue.config.js +0 -9
- package/assets/fonts/lato/lato-v17-latin-700.woff +0 -0
- package/assets/fonts/lato/lato-v17-latin-700.woff2 +0 -0
- package/assets/fonts/lato/lato-v17-latin-regular.woff +0 -0
- package/assets/fonts/lato/lato-v17-latin-regular.woff2 +0 -0
- package/assets/images/providers/azuread-black.svg +0 -22
- package/assets/images/providers/azuread.svg +0 -25
- package/assets/images/vendor/azuread.svg +0 -18
- package/assets/styles/fonts/_dots.scss +0 -18
- package/components/EmberPage.vue +0 -622
- package/components/EmberPageView.vue +0 -39
- package/components/form/labeled-select-utils/labeled-select-pagination.ts +0 -116
- package/mixins/labeled-form-element.ts +0 -225
- package/pages/c/_cluster/explorer/tools/pages/_page.vue +0 -28
- package/pages/c/_cluster/manager/pages/_page.vue +0 -22
- package/pages/c/_cluster/mcapps/pages/_page.vue +0 -22
- package/plugins/ember-cookie.js +0 -17
- package/utils/ember-page.js +0 -30
package/store/aws.js
CHANGED
|
@@ -12,9 +12,10 @@ export const state = () => {
|
|
|
12
12
|
};
|
|
13
13
|
|
|
14
14
|
class Handler {
|
|
15
|
-
constructor(cloudCredentialId, options) {
|
|
15
|
+
constructor(cloudCredentialId, options, proxyApi) {
|
|
16
16
|
this.cloudCredentialId = (cloudCredentialId || '');
|
|
17
17
|
this.fetchHandler = new FetchHttpHandler(options);
|
|
18
|
+
this.proxyApi = proxyApi;
|
|
18
19
|
}
|
|
19
20
|
|
|
20
21
|
async handle(httpRequest, options = {}) {
|
|
@@ -24,24 +25,34 @@ class Handler {
|
|
|
24
25
|
|
|
25
26
|
httpRequest.headers['x-api-headers-restrict'] = 'Content-Length';
|
|
26
27
|
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
28
|
+
// Build proxy options: use awsv4 credential signing when a cloud credential
|
|
29
|
+
// is available, otherwise forward the SDK-generated Authorization header
|
|
30
|
+
// directly via x-api-auth-header.
|
|
31
|
+
const upstreamUrl = new URL(`https://${ httpRequest.hostname }${ httpRequest.path }`);
|
|
32
|
+
const proxyOptions = this.cloudCredentialId ? {
|
|
33
|
+
url: upstreamUrl,
|
|
34
|
+
authentication: {
|
|
35
|
+
id: this.cloudCredentialId,
|
|
36
|
+
authSigner: 'awsv4',
|
|
37
|
+
},
|
|
38
|
+
} : {
|
|
39
|
+
url: upstreamUrl,
|
|
40
|
+
headers: httpRequest?.headers['authorization'] ? { 'x-api-auth-header': httpRequest.headers['authorization'] } : {},
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
const { url: proxyPath, headers: proxyHeaders } = this.proxyApi.prepareRequest(proxyOptions);
|
|
32
44
|
|
|
45
|
+
// Merge proxy auth headers; remove the upstream Authorization and the
|
|
46
|
+
// Accept header added by prepareRequest (AWS SDK manages its own Accept).
|
|
47
|
+
Object.assign(httpRequest.headers, proxyHeaders);
|
|
33
48
|
delete httpRequest.headers['authorization'];
|
|
49
|
+
delete httpRequest.headers['Accept'];
|
|
34
50
|
|
|
35
51
|
const originalContentType = httpRequest.headers['content-type'] ?? '';
|
|
36
52
|
|
|
37
53
|
httpRequest.headers['content-type'] = originalContentType ? `rancher:${ originalContentType }` : 'rancher:';
|
|
38
54
|
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
if (!httpRequest.path.startsWith(endpoint)) {
|
|
42
|
-
httpRequest.path = endpoint + httpRequest.hostname + httpRequest.path;
|
|
43
|
-
}
|
|
44
|
-
|
|
55
|
+
httpRequest.path = proxyPath;
|
|
45
56
|
httpRequest.protocol = window.location.protocol;
|
|
46
57
|
httpRequest.hostname = window.location.hostname;
|
|
47
58
|
httpRequest.port = window.location.port;
|
|
@@ -114,7 +125,7 @@ export const actions = {
|
|
|
114
125
|
const client = new lib.EC2({
|
|
115
126
|
region,
|
|
116
127
|
credentialDefaultProvider: credentialDefaultProvider(accessKey, secretKey),
|
|
117
|
-
requestHandler: new Handler(cloudCredentialId),
|
|
128
|
+
requestHandler: new Handler(cloudCredentialId, undefined, this.$shell.proxy),
|
|
118
129
|
useDualstackEndpoint: true,
|
|
119
130
|
});
|
|
120
131
|
|
|
@@ -129,7 +140,7 @@ export const actions = {
|
|
|
129
140
|
const client = new lib.EKS({
|
|
130
141
|
region,
|
|
131
142
|
credentialDefaultProvider: credentialDefaultProvider(accessKey, secretKey),
|
|
132
|
-
requestHandler: new Handler(cloudCredentialId),
|
|
143
|
+
requestHandler: new Handler(cloudCredentialId, undefined, this.$shell.proxy),
|
|
133
144
|
useDualstackEndpoint: true,
|
|
134
145
|
});
|
|
135
146
|
|
|
@@ -144,7 +155,7 @@ export const actions = {
|
|
|
144
155
|
const client = new lib.KMS({
|
|
145
156
|
region,
|
|
146
157
|
credentialDefaultProvider: credentialDefaultProvider(accessKey, secretKey),
|
|
147
|
-
requestHandler: new Handler(cloudCredentialId),
|
|
158
|
+
requestHandler: new Handler(cloudCredentialId, undefined, this.$shell.proxy),
|
|
148
159
|
useDualstackEndpoint: true,
|
|
149
160
|
});
|
|
150
161
|
|
|
@@ -159,7 +170,7 @@ export const actions = {
|
|
|
159
170
|
const client = new lib.IAM({
|
|
160
171
|
region,
|
|
161
172
|
credentialDefaultProvider: credentialDefaultProvider(accessKey, secretKey),
|
|
162
|
-
requestHandler: new Handler(cloudCredentialId),
|
|
173
|
+
requestHandler: new Handler(cloudCredentialId, undefined, this.$shell.proxy),
|
|
163
174
|
useDualstackEndpoint: true,
|
|
164
175
|
});
|
|
165
176
|
|
package/store/catalog.js
CHANGED
|
@@ -325,8 +325,12 @@ export const actions = {
|
|
|
325
325
|
* force: Always refresh catalog's helm repo by re-fetching index.yaml
|
|
326
326
|
*
|
|
327
327
|
* reset: clear existing charts and version cache
|
|
328
|
+
*
|
|
329
|
+
* repoKeys: Optional array of specific repo keys (IDs) to refresh. When provided, only these specific
|
|
330
|
+
* repos will be fetched, and only their existing charts will be cleared from the cache to avoid
|
|
331
|
+
* duplicate chart entries or wiping out unrelated chart data.
|
|
328
332
|
*/
|
|
329
|
-
async load(ctx, { force, reset } = {}) {
|
|
333
|
+
async load(ctx, { force, reset, repoKeys = [] } = {}) {
|
|
330
334
|
const {
|
|
331
335
|
state, getters, rootGetters, commit, dispatch
|
|
332
336
|
} = ctx;
|
|
@@ -360,14 +364,34 @@ export const actions = {
|
|
|
360
364
|
promises = {};
|
|
361
365
|
|
|
362
366
|
for ( const repo of repos ) {
|
|
363
|
-
|
|
367
|
+
let shouldLoad = false;
|
|
368
|
+
|
|
369
|
+
if (repoKeys.length) {
|
|
370
|
+
// If repoKeys are explicitly provided (e.g. refreshing a single repo from the UI),
|
|
371
|
+
// we ONLY want to load the repos in that array. We intentionally ignore `!getters.isLoaded(repo)`
|
|
372
|
+
// here so we don't accidentally fetch other unrelated repos just because they haven't loaded yet.
|
|
373
|
+
shouldLoad = repoKeys.includes(repo._key);
|
|
374
|
+
} else {
|
|
375
|
+
// Default behavior: load if explicitly forced, OR if the repo hasn't been loaded into state yet.
|
|
376
|
+
shouldLoad = force === true || !getters.isLoaded(repo);
|
|
377
|
+
}
|
|
378
|
+
|
|
379
|
+
if ( shouldLoad && repo.canLoad ) {
|
|
364
380
|
console.info('Loading index for repo', repo.name, `(${ repo._key })`); // eslint-disable-line no-console
|
|
365
381
|
promises[repo._key] = repo.followLink('index');
|
|
366
382
|
}
|
|
367
383
|
}
|
|
368
384
|
|
|
369
385
|
const res = await allHashSettled(promises);
|
|
370
|
-
const charts = reset ? {} : state.charts;
|
|
386
|
+
const charts = reset ? {} : { ...state.charts };
|
|
387
|
+
let versionInfos = null;
|
|
388
|
+
|
|
389
|
+
if (reset) {
|
|
390
|
+
versionInfos = {};
|
|
391
|
+
} else if (repoKeys.length) {
|
|
392
|
+
versionInfos = { ...state.versionInfos };
|
|
393
|
+
}
|
|
394
|
+
|
|
371
395
|
const errors = [];
|
|
372
396
|
|
|
373
397
|
for ( const key of Object.keys(res) ) {
|
|
@@ -379,6 +403,28 @@ export const actions = {
|
|
|
379
403
|
continue;
|
|
380
404
|
}
|
|
381
405
|
|
|
406
|
+
// We are targeting specific repos. To prevent duplicate chart versions from appearing,
|
|
407
|
+
// we must remove the old charts for this specific repo before appending the newly fetched ones,
|
|
408
|
+
// but ONLY if the fetch was successful.
|
|
409
|
+
if (repoKeys.length && repoKeys.includes(key)) {
|
|
410
|
+
for (const chartKey in charts) {
|
|
411
|
+
if (charts[chartKey].repoKey === key) {
|
|
412
|
+
delete charts[chartKey];
|
|
413
|
+
}
|
|
414
|
+
}
|
|
415
|
+
|
|
416
|
+
// Also clear out cached version info for this repo so we don't display stale READMEs/values
|
|
417
|
+
const repoType = repo.type === CATALOG.CLUSTER_REPO ? 'cluster' : 'namespace';
|
|
418
|
+
const repoName = repo.metadata.name;
|
|
419
|
+
const versionPrefix = `${ repoType }/${ repoName }/`;
|
|
420
|
+
|
|
421
|
+
for (const versionKey in versionInfos) {
|
|
422
|
+
if (versionKey.startsWith(versionPrefix)) {
|
|
423
|
+
delete versionInfos[versionKey];
|
|
424
|
+
}
|
|
425
|
+
}
|
|
426
|
+
}
|
|
427
|
+
|
|
382
428
|
for ( const k in obj.value.entries ) {
|
|
383
429
|
for ( const entry of obj.value.entries[k] ) {
|
|
384
430
|
addChart(ctx, charts, entry, repo);
|
|
@@ -394,13 +440,17 @@ export const actions = {
|
|
|
394
440
|
loaded,
|
|
395
441
|
});
|
|
396
442
|
|
|
397
|
-
if (
|
|
398
|
-
commit('setVersions',
|
|
443
|
+
if (versionInfos) {
|
|
444
|
+
commit('setVersions', versionInfos);
|
|
399
445
|
}
|
|
400
446
|
},
|
|
401
447
|
|
|
448
|
+
/**
|
|
449
|
+
* Globally refreshes all loaded repositories by triggering their refresh actions concurrently,
|
|
450
|
+
* bypassing individual catalog loads, and then performs a single, global catalog/load.
|
|
451
|
+
*/
|
|
402
452
|
async refresh({ getters, commit, dispatch }) {
|
|
403
|
-
const promises = getters.repos.map((x) => x.refresh());
|
|
453
|
+
const promises = getters.repos.map((x) => x.refresh(false));
|
|
404
454
|
|
|
405
455
|
// @TODO wait for repo state to indicate they're done once the API has that
|
|
406
456
|
|
|
@@ -488,7 +538,9 @@ function addChart(ctx, map, chart, repo) {
|
|
|
488
538
|
certified = CATALOG_ANNOTATIONS._OTHER;
|
|
489
539
|
}
|
|
490
540
|
|
|
491
|
-
|
|
541
|
+
const isDeprecated = !!chart.deprecated || chart.annotations?.[CATALOG_ANNOTATIONS.DEPRECATED] === 'true';
|
|
542
|
+
|
|
543
|
+
if ( isDeprecated ) {
|
|
492
544
|
sideLabel = DEPRECATED;
|
|
493
545
|
} else if ( chart.annotations?.[CATALOG_ANNOTATIONS.EXPERIMENTAL] ) {
|
|
494
546
|
sideLabel = EXPERIMENTAL;
|
|
@@ -507,7 +559,10 @@ function addChart(ctx, map, chart, repo) {
|
|
|
507
559
|
|
|
508
560
|
const primeOnly = chart.annotations?.[CATALOG_ANNOTATIONS.PRIME_ONLY] === 'true';
|
|
509
561
|
const experimental = !!chart.annotations?.[CATALOG_ANNOTATIONS.EXPERIMENTAL];
|
|
510
|
-
|
|
562
|
+
|
|
563
|
+
const isRancherRepoFlag = isRancherRepo(repo, chart);
|
|
564
|
+
const permittedSystems = getPermittedOSs(chart.annotations, isRancherRepoFlag);
|
|
565
|
+
const windowsIncompatible = permittedSystems.length > 0 && !permittedSystems.includes('windows');
|
|
511
566
|
const deploysOnWindows = (chart.annotations?.[CATALOG_ANNOTATIONS.DEPLOYED_OS] || '').includes('windows');
|
|
512
567
|
const tags = [];
|
|
513
568
|
|
|
@@ -546,7 +601,7 @@ function addChart(ctx, map, chart, repo) {
|
|
|
546
601
|
versions: [],
|
|
547
602
|
keywords: chart.keywords || [],
|
|
548
603
|
categories: filterCategories(chart.keywords),
|
|
549
|
-
deprecated:
|
|
604
|
+
deprecated: isDeprecated,
|
|
550
605
|
primeOnly,
|
|
551
606
|
experimental,
|
|
552
607
|
hidden: !!chart.annotations?.[CATALOG_ANNOTATIONS.HIDDEN],
|
|
@@ -556,6 +611,7 @@ function addChart(ctx, map, chart, repo) {
|
|
|
556
611
|
provides: [],
|
|
557
612
|
windowsIncompatible,
|
|
558
613
|
deploysOnWindows,
|
|
614
|
+
isRancherRepo: isRancherRepoFlag,
|
|
559
615
|
tags
|
|
560
616
|
});
|
|
561
617
|
|
|
@@ -640,13 +696,13 @@ export function compatibleVersionsFor(chart, os, includePrerelease = true) {
|
|
|
640
696
|
}
|
|
641
697
|
|
|
642
698
|
return versions.filter((ver) => {
|
|
643
|
-
const osPermitted = (ver?.annotations?.
|
|
699
|
+
const osPermitted = getPermittedOSs(ver?.annotations, chart?.isRancherRepo);
|
|
644
700
|
|
|
645
701
|
if ( !includePrerelease && isPrerelease(ver.version) ) {
|
|
646
702
|
return false;
|
|
647
703
|
}
|
|
648
704
|
|
|
649
|
-
if ( !os || difference(os, osPermitted).length === 0) {
|
|
705
|
+
if ( !os || osPermitted.length === 0 || difference(os, osPermitted).length === 0) {
|
|
650
706
|
return true;
|
|
651
707
|
}
|
|
652
708
|
|
|
@@ -735,3 +791,23 @@ export function filterAndArrangeCharts(charts, {
|
|
|
735
791
|
|
|
736
792
|
return sortBy(out, ['certifiedSort', 'repoName', 'chartNameDisplay']);
|
|
737
793
|
}
|
|
794
|
+
|
|
795
|
+
/**
|
|
796
|
+
* Detects if a repository is a Rancher repository.
|
|
797
|
+
*/
|
|
798
|
+
export function isRancherRepo(repo, chart) {
|
|
799
|
+
return !!(chart?.isRancherRepo || repo?.isRancherSource);
|
|
800
|
+
}
|
|
801
|
+
|
|
802
|
+
/**
|
|
803
|
+
* Returns an array of permitted operating systems for a given chart or version.
|
|
804
|
+
* If the chart explicitly defines permitted OSs via annotation, those are returned.
|
|
805
|
+
* Otherwise, if the chart is from a Rancher repository, it defaults to Linux.
|
|
806
|
+
* External charts with no annotations have no OS restrictions (returns empty array).
|
|
807
|
+
*/
|
|
808
|
+
export function getPermittedOSs(annotations, isRancher) {
|
|
809
|
+
const permittedOs = annotations?.[CATALOG_ANNOTATIONS.PERMITTED_OS];
|
|
810
|
+
const fallbackOs = isRancher ? LINUX : '';
|
|
811
|
+
|
|
812
|
+
return (permittedOs || fallbackOs).split(',').filter(Boolean);
|
|
813
|
+
}
|
package/store/digitalocean.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { sortBy } from '@shell/utils/sort';
|
|
2
|
-
import {
|
|
2
|
+
import { createDepaginator } from '@shell/apis/shell/proxy';
|
|
3
3
|
|
|
4
4
|
const ENDPOINT = 'api.digitalocean.com/v2';
|
|
5
5
|
|
|
@@ -149,50 +149,32 @@ export const actions = {
|
|
|
149
149
|
return out;
|
|
150
150
|
},
|
|
151
151
|
|
|
152
|
-
async request(
|
|
153
|
-
token, credentialId, command, opt
|
|
152
|
+
async request(_, {
|
|
153
|
+
token, credentialId, command, opt
|
|
154
154
|
}) {
|
|
155
155
|
opt = opt || {};
|
|
156
156
|
|
|
157
|
-
|
|
157
|
+
const url = new URL(opt.url || `https://${ ENDPOINT }/${ command }`);
|
|
158
158
|
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
url = addParams(url, opt.params || {});
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
const headers = { Accept: 'application/json' };
|
|
168
|
-
|
|
169
|
-
if ( credentialId ) {
|
|
170
|
-
headers['x-api-cattleauth-header'] = `Bearer credID=${ credentialId } passwordField=accessToken`;
|
|
171
|
-
} else if ( token ) {
|
|
172
|
-
headers['x-api-auth-header'] = `Bearer ${ token }`;
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
const res = await dispatch('management/request', {
|
|
176
|
-
url,
|
|
177
|
-
headers,
|
|
178
|
-
redirectUnauthorized: false,
|
|
179
|
-
}, { root: true });
|
|
180
|
-
|
|
181
|
-
if ( out ) {
|
|
182
|
-
out[command] = out[command].concat(res[command]);
|
|
183
|
-
} else {
|
|
184
|
-
out = res;
|
|
159
|
+
url.searchParams.set('per_page', `${ opt.per_page || 1000 }`);
|
|
160
|
+
if (opt.params) {
|
|
161
|
+
for (const [key, value] of Object.entries(opt.params)) {
|
|
162
|
+
url.searchParams.set(key, value);
|
|
163
|
+
}
|
|
185
164
|
}
|
|
186
165
|
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
166
|
+
const authentication = credentialId ? {
|
|
167
|
+
id: credentialId,
|
|
168
|
+
authSigner: 'bearer',
|
|
169
|
+
passwordField: 'accessToken',
|
|
170
|
+
} : { token };
|
|
190
171
|
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
});
|
|
194
|
-
}
|
|
172
|
+
const proxy = this.$shell?.proxy;
|
|
173
|
+
const requestOptions = { url, authentication };
|
|
195
174
|
|
|
196
|
-
return
|
|
175
|
+
return proxy.request({
|
|
176
|
+
...requestOptions,
|
|
177
|
+
postProcess: createDepaginator(proxy, requestOptions, { mergeKey: command }),
|
|
178
|
+
});
|
|
197
179
|
},
|
|
198
180
|
};
|
package/store/index.js
CHANGED
|
@@ -1041,6 +1041,8 @@ export const actions = {
|
|
|
1041
1041
|
// This is a workaround for a timing issue where the mgmt cluster schema may not be available
|
|
1042
1042
|
// Try and wait until the schema exists before proceeding
|
|
1043
1043
|
await dispatch('management/waitForSchema', { type: MANAGEMENT.CLUSTER });
|
|
1044
|
+
// Similarly to above, we somehow get here without everything in management land being ready. FF needed to determine pagination state
|
|
1045
|
+
await dispatch('management/waitForHaveAll', { type: MANAGEMENT.FEATURE });
|
|
1044
1046
|
|
|
1045
1047
|
// If SSP is on we won't have requested all clusters
|
|
1046
1048
|
if (!paginateClusters({ rootGetters, state })) {
|
package/store/linode.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { sortBy } from '@shell/utils/sort';
|
|
2
|
-
import {
|
|
2
|
+
import { createDepaginator } from '@shell/apis/shell/proxy';
|
|
3
3
|
|
|
4
4
|
const ENDPOINT = 'api.linode.com/v4';
|
|
5
5
|
|
|
@@ -93,50 +93,35 @@ export const actions = {
|
|
|
93
93
|
return out;
|
|
94
94
|
},
|
|
95
95
|
|
|
96
|
-
async request(
|
|
97
|
-
token, credentialId, command, opt
|
|
96
|
+
async request(_, {
|
|
97
|
+
token, credentialId, command, opt
|
|
98
98
|
}) {
|
|
99
99
|
opt = opt || {};
|
|
100
100
|
|
|
101
|
-
|
|
101
|
+
const url = new URL(opt.url || `https://${ ENDPOINT }/${ command }`);
|
|
102
102
|
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
url = addParams(url, opt.params || {});
|
|
103
|
+
url.searchParams.set('per_page', `${ opt.per_page || 1000 }`);
|
|
104
|
+
if (opt.params) {
|
|
105
|
+
for (const [key, value] of Object.entries(opt.params)) {
|
|
106
|
+
url.searchParams.set(key, value);
|
|
107
|
+
}
|
|
109
108
|
}
|
|
110
109
|
|
|
111
|
-
const
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
} else {
|
|
128
|
-
out = res;
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
// De-pagination
|
|
132
|
-
if ( res?.links?.pages?.next ) {
|
|
133
|
-
opt.url = res.links.pages.next;
|
|
134
|
-
|
|
135
|
-
return dispatch('request', {
|
|
136
|
-
token, credentialId, command, opt, out
|
|
137
|
-
});
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
return out;
|
|
110
|
+
const authentication = credentialId ? {
|
|
111
|
+
id: credentialId,
|
|
112
|
+
authSigner: 'bearer',
|
|
113
|
+
passwordField: 'token',
|
|
114
|
+
} : { token };
|
|
115
|
+
|
|
116
|
+
const proxy = this.$shell.proxy;
|
|
117
|
+
const requestOptions = { url, authentication };
|
|
118
|
+
|
|
119
|
+
return proxy.request({
|
|
120
|
+
...requestOptions,
|
|
121
|
+
postProcess: createDepaginator(proxy, requestOptions, {
|
|
122
|
+
nextUrlPath: 'links.pages.next',
|
|
123
|
+
mergeKey: command,
|
|
124
|
+
}),
|
|
125
|
+
});
|
|
141
126
|
}
|
|
142
127
|
};
|
package/store/pnap.js
CHANGED
package/store/type-map.js
CHANGED
|
@@ -20,7 +20,7 @@
|
|
|
20
20
|
// importList(type) Returns a promise that resolves to the list component for type
|
|
21
21
|
// importDetail(type[,subType]) Returns a promise that resolves to the detail component for type
|
|
22
22
|
// importEdit(type[,subType]) Returns a promise that resolves to the edit component for type
|
|
23
|
-
// optionsFor(schemaOrType)
|
|
23
|
+
// optionsFor(schemaOrType, pagination(bool), product(string)) Return the configured options for a type (from configureType) - additional product param can be passed if "optionsFor" needed isn't the current product
|
|
24
24
|
//
|
|
25
25
|
// 3) Changing specialization info about a type
|
|
26
26
|
// For all:
|
|
@@ -107,6 +107,7 @@
|
|
|
107
107
|
// notFilterNamespace: undefined -- Define namespaces that do not need to be filtered
|
|
108
108
|
// localOnly: False -- Hide this type from the nav/search bar on downstream clusters
|
|
109
109
|
// custom: any - Custom options for a given type
|
|
110
|
+
// product: string - If set, this type's options will only apply when that product is active
|
|
110
111
|
// }
|
|
111
112
|
// )
|
|
112
113
|
// ignoreGroup(group): Never show group or any types in it
|
|
@@ -269,20 +270,25 @@ export function DSL(store, product, module = 'type-map') {
|
|
|
269
270
|
store.commit(`${ module }/groupBy`, { type, field });
|
|
270
271
|
},
|
|
271
272
|
|
|
272
|
-
headers(type, headers, paginationHeaders = []) {
|
|
273
|
-
headers.
|
|
273
|
+
headers(type, headers = [], paginationHeaders = []) {
|
|
274
|
+
if (headers.length) {
|
|
275
|
+
headers.forEach((header) => {
|
|
274
276
|
// If on the client, then use the value getter if there is one
|
|
275
|
-
|
|
277
|
+
if (header.getValue) {
|
|
276
278
|
// we need to store the .value prop for the advanced filtering
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
279
|
+
header.valueProp = header.value;
|
|
280
|
+
header.value = header.getValue;
|
|
281
|
+
}
|
|
280
282
|
|
|
281
|
-
|
|
282
|
-
|
|
283
|
+
delete header.getValue;
|
|
284
|
+
});
|
|
283
285
|
|
|
284
|
-
|
|
285
|
-
|
|
286
|
+
store.commit(`${ module }/headers`, { type, headers });
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
if (paginationHeaders.length) {
|
|
290
|
+
store.commit(`${ module }/paginationHeaders`, { type, paginationHeaders });
|
|
291
|
+
}
|
|
286
292
|
},
|
|
287
293
|
|
|
288
294
|
hideBulkActions(type, field) {
|
|
@@ -290,7 +296,9 @@ export function DSL(store, product, module = 'type-map') {
|
|
|
290
296
|
},
|
|
291
297
|
|
|
292
298
|
configureType(match, options) {
|
|
293
|
-
store.commit(`${ module }/configureType`, {
|
|
299
|
+
store.commit(`${ module }/configureType`, {
|
|
300
|
+
...options, match, product
|
|
301
|
+
});
|
|
294
302
|
},
|
|
295
303
|
|
|
296
304
|
componentForType(match, replace) {
|
|
@@ -371,6 +379,18 @@ export function DSL(store, product, module = 'type-map') {
|
|
|
371
379
|
};
|
|
372
380
|
}
|
|
373
381
|
|
|
382
|
+
const LEGACY_COMPATIBILITY_BUCKET = 'legacyCompatibilityProdRegistration';
|
|
383
|
+
|
|
384
|
+
function validateProductName(product) {
|
|
385
|
+
if (!product || typeof product !== 'string' || product.trim() === '') {
|
|
386
|
+
throw new Error(`Product name must be a non-empty string, got: ${ JSON.stringify(product) }`);
|
|
387
|
+
}
|
|
388
|
+
|
|
389
|
+
if (product === LEGACY_COMPATIBILITY_BUCKET) {
|
|
390
|
+
throw new Error(`Product name cannot be "${ LEGACY_COMPATIBILITY_BUCKET }" as it is reserved for backward compatibility`);
|
|
391
|
+
}
|
|
392
|
+
}
|
|
393
|
+
|
|
374
394
|
let called = false;
|
|
375
395
|
|
|
376
396
|
export async function applyProducts(store, $extension) {
|
|
@@ -412,7 +432,7 @@ export const state = function() {
|
|
|
412
432
|
typeMappings: [],
|
|
413
433
|
typeMoveMappings: [],
|
|
414
434
|
typeToComponentMappings: [],
|
|
415
|
-
typeOptions:
|
|
435
|
+
typeOptions: {},
|
|
416
436
|
groupBy: {},
|
|
417
437
|
headers: {},
|
|
418
438
|
paginationHeaders: {},
|
|
@@ -549,15 +569,37 @@ export const getters = {
|
|
|
549
569
|
subTypes: [],
|
|
550
570
|
};
|
|
551
571
|
|
|
552
|
-
return (schemaOrType, pagination) => {
|
|
572
|
+
return (schemaOrType, pagination, product) => {
|
|
553
573
|
// Note - This can run a LOT so needs to be performant
|
|
554
574
|
|
|
555
575
|
if (!schemaOrType) {
|
|
556
576
|
return {};
|
|
557
577
|
}
|
|
558
578
|
|
|
579
|
+
if (product) {
|
|
580
|
+
validateProductName(product);
|
|
581
|
+
}
|
|
582
|
+
|
|
559
583
|
const type = (typeof schemaOrType === 'object' ? schemaOrType.id : schemaOrType);
|
|
560
|
-
const
|
|
584
|
+
const productToUse = product || rootGetters['productId'];
|
|
585
|
+
|
|
586
|
+
// Handle both array (pre-2.15) and object (2.15+) state.typeOptions formats for backwards compatibility
|
|
587
|
+
let productTypeOptions = [];
|
|
588
|
+
|
|
589
|
+
if (Array.isArray(state.typeOptions)) {
|
|
590
|
+
// Legacy format: filter the flat array for entries matching the product or entries without a product field
|
|
591
|
+
productTypeOptions = state.typeOptions.filter((entry) => entry.product === productToUse || !entry.product
|
|
592
|
+
);
|
|
593
|
+
} else {
|
|
594
|
+
// New format: direct object lookup by product, with fallback to legacy compatibility bucket for unscoped entries
|
|
595
|
+
// (e.g., extensions compiled with pre-2.15 shell that don't send product parameter)
|
|
596
|
+
productTypeOptions = [
|
|
597
|
+
...(state.typeOptions[productToUse] || []),
|
|
598
|
+
...(state.typeOptions[LEGACY_COMPATIBILITY_BUCKET] || [])
|
|
599
|
+
];
|
|
600
|
+
}
|
|
601
|
+
|
|
602
|
+
const found = productTypeOptions.find((entry) => {
|
|
561
603
|
const re = stringToRegex(entry.match);
|
|
562
604
|
|
|
563
605
|
return re.test(type);
|
|
@@ -944,7 +986,7 @@ export const getters = {
|
|
|
944
986
|
});
|
|
945
987
|
|
|
946
988
|
const attrs = schema.attributes || {};
|
|
947
|
-
const typeOptions = getters['optionsFor'](schema);
|
|
989
|
+
const typeOptions = getters['optionsFor'](schema, undefined, product);
|
|
948
990
|
|
|
949
991
|
schemaModes[TYPE_MODES.BASIC] = schemaModes[TYPE_MODES.BASIC] && getters.groupForBasicType(product, schema.id);
|
|
950
992
|
|
|
@@ -1522,6 +1564,10 @@ export const mutations = {
|
|
|
1522
1564
|
delete state.virtualTypes[product];
|
|
1523
1565
|
}
|
|
1524
1566
|
|
|
1567
|
+
if (state.typeOptions[product]) {
|
|
1568
|
+
delete state.typeOptions[product];
|
|
1569
|
+
}
|
|
1570
|
+
|
|
1525
1571
|
if (state.basicTypes[product]) {
|
|
1526
1572
|
// Remove table header configuration
|
|
1527
1573
|
Object.keys(state.basicTypes[product]).forEach((type) => {
|
|
@@ -1784,20 +1830,54 @@ export const mutations = {
|
|
|
1784
1830
|
},
|
|
1785
1831
|
|
|
1786
1832
|
configureType(state, options) {
|
|
1787
|
-
const
|
|
1833
|
+
const { product, ...typeOptions } = options;
|
|
1834
|
+
const match = regexToString(ensureRegex(typeOptions.match));
|
|
1835
|
+
|
|
1836
|
+
// Handle both old (array) and new (object) state.typeOptions formats for backwards compatibility
|
|
1837
|
+
// Old format (pre-2.15): state.typeOptions = []
|
|
1838
|
+
// New format (2.15+): state.typeOptions = { productName: [...] }
|
|
1839
|
+
if (Array.isArray(state.typeOptions)) {
|
|
1840
|
+
// Legacy path: old format for extensions compiled with pre-2.15 shell
|
|
1841
|
+
// In 2.14, product parameter is not validated/enforced
|
|
1842
|
+
const idx = state.typeOptions.findIndex((obj) => obj.match === match);
|
|
1843
|
+
let obj = { ...options, match };
|
|
1844
|
+
|
|
1845
|
+
if ( idx >= 0 ) {
|
|
1846
|
+
// Merge the custom data object - multiple configures will update existing rather than overwrite
|
|
1847
|
+
obj.custom = Object.assign(state.typeOptions[idx].custom || {}, obj.custom || {});
|
|
1848
|
+
obj = Object.assign(state.typeOptions[idx], obj);
|
|
1849
|
+
state.typeOptions.splice(idx, 1, obj);
|
|
1850
|
+
} else {
|
|
1851
|
+
state.typeOptions.push(obj);
|
|
1852
|
+
}
|
|
1853
|
+
} else {
|
|
1854
|
+
// New path: object format with product scoping (2.15+)
|
|
1855
|
+
// Product is required in new format
|
|
1856
|
+
if (!product) {
|
|
1857
|
+
throw new Error(`configureType: product parameter is required in Rancher 2.15+, not provided for type "${ match }"`);
|
|
1858
|
+
}
|
|
1788
1859
|
|
|
1789
|
-
|
|
1790
|
-
let obj = { ...options, match };
|
|
1860
|
+
validateProductName(product);
|
|
1791
1861
|
|
|
1792
|
-
|
|
1793
|
-
|
|
1794
|
-
|
|
1795
|
-
|
|
1796
|
-
|
|
1797
|
-
|
|
1798
|
-
const
|
|
1862
|
+
// Initialize product's typeOptions array if needed
|
|
1863
|
+
if (!state.typeOptions[product]) {
|
|
1864
|
+
state.typeOptions[product] = [];
|
|
1865
|
+
}
|
|
1866
|
+
|
|
1867
|
+
const productTypeOptions = state.typeOptions[product];
|
|
1868
|
+
const idx = productTypeOptions.findIndex((obj) => obj.match === match);
|
|
1869
|
+
let obj = { ...typeOptions, match };
|
|
1799
1870
|
|
|
1800
|
-
|
|
1871
|
+
if ( idx >= 0 ) {
|
|
1872
|
+
// Merge the custom data object - multiple configures will update existing rather than overwrite
|
|
1873
|
+
obj.custom = Object.assign(productTypeOptions[idx].custom || {}, obj.custom || {});
|
|
1874
|
+
obj = Object.assign(productTypeOptions[idx], obj);
|
|
1875
|
+
productTypeOptions.splice(idx, 1, obj);
|
|
1876
|
+
} else {
|
|
1877
|
+
const obj = Object.assign({}, typeOptions, { match });
|
|
1878
|
+
|
|
1879
|
+
productTypeOptions.push(obj);
|
|
1880
|
+
}
|
|
1801
1881
|
}
|
|
1802
1882
|
},
|
|
1803
1883
|
|
|
@@ -1836,8 +1916,10 @@ export const actions = {
|
|
|
1836
1916
|
dispatch('prefs/set', { key: EXPANDED_GROUPS, value: groups }, { root: true });
|
|
1837
1917
|
},
|
|
1838
1918
|
|
|
1839
|
-
configureType({ commit }, options) {
|
|
1840
|
-
|
|
1919
|
+
configureType({ commit, rootGetters }, options) {
|
|
1920
|
+
const product = options.product || rootGetters['productId'];
|
|
1921
|
+
|
|
1922
|
+
commit('configureType', { ...options, product });
|
|
1841
1923
|
}
|
|
1842
1924
|
};
|
|
1843
1925
|
|