dashboard-shell-shell 0.0.1
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/.DS_Store +0 -0
- package/assets/brand/csp/dark/rancher-logo.svg +148 -0
- package/assets/brand/csp/favicon.png +0 -0
- package/assets/brand/csp/metadata.json +3 -0
- package/assets/brand/csp/rancher-logo.svg +130 -0
- package/assets/brand/federal/dark/rancher-logo.svg +104 -0
- package/assets/brand/federal/metadata.json +3 -0
- package/assets/brand/federal/rancher-logo.svg +1 -0
- package/assets/brand/harvester/favicon.png +0 -0
- package/assets/brand/harvester/metadata.json +3 -0
- package/assets/brand/rgs/dark/rancher-logo.svg +1 -0
- package/assets/brand/rgs/metadata.json +3 -0
- package/assets/brand/rgs/rancher-logo.svg +1 -0
- package/assets/brand/suse/dark/rancher-logo.svg +1 -0
- package/assets/brand/suse/favicon.png +0 -0
- package/assets/brand/suse/metadata.json +3 -0
- package/assets/brand/suse/rancher-logo.svg +1 -0
- package/assets/data/aws-regions.json +39 -0
- package/assets/data/ec2-instance-groups.json +85 -0
- 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/fonts/poppins/poppins-v15-latin-300.woff +0 -0
- package/assets/fonts/poppins/poppins-v15-latin-300.woff2 +0 -0
- package/assets/fonts/poppins/poppins-v15-latin-500.woff +0 -0
- package/assets/fonts/poppins/poppins-v15-latin-500.woff2 +0 -0
- package/assets/fonts/roboto-mono/roboto-mono-v13-latin-regular.woff +0 -0
- package/assets/fonts/roboto-mono/roboto-mono-v13-latin-regular.woff2 +0 -0
- package/assets/icons/demo.css +539 -0
- package/assets/icons/demo_index.html +1131 -0
- package/assets/icons/iconfont.css +216 -0
- package/assets/icons/iconfont.js +1 -0
- package/assets/icons/iconfont.json +324 -0
- package/assets/icons/iconfont.ttf +0 -0
- package/assets/icons/iconfont.woff +0 -0
- package/assets/icons/iconfont.woff2 +0 -0
- package/assets/images/API.svg +3 -0
- package/assets/images/featured/img1.jpg +0 -0
- package/assets/images/featured.jpg +0 -0
- package/assets/images/field-valid.svg +16 -0
- package/assets/images/generic-catalog.svg +15 -0
- package/assets/images/generic-driver.svg +17 -0
- package/assets/images/generic-plugin.svg +1 -0
- package/assets/images/login/password.svg +20 -0
- package/assets/images/login/user.svg +6 -0
- package/assets/images/login-bg.png +0 -0
- package/assets/images/login-left.png +0 -0
- package/assets/images/login-logo.svg +19 -0
- package/assets/images/logo.png +0 -0
- package/assets/images/pl/README.md +13 -0
- package/assets/images/pl/banner.svg +241 -0
- package/assets/images/pl/dark/banner.svg +242 -0
- package/assets/images/pl/dark/login-landscape.svg +291 -0
- package/assets/images/pl/dark/rancher-logo.svg +51 -0
- package/assets/images/pl/decoration-cloud-big-white.svg +1 -0
- package/assets/images/pl/decoration-ground.svg +1 -0
- package/assets/images/pl/error-desert-landscape.svg +217 -0
- package/assets/images/pl/half-logo.svg +2 -0
- package/assets/images/pl/harvester.png +0 -0
- package/assets/images/pl/harvester.svg +1 -0
- package/assets/images/pl/login-landscape.svg +496 -0
- package/assets/images/pl/rancher-logo.svg +51 -0
- package/assets/images/pl/setup-step-one.svg +612 -0
- package/assets/images/pl/sunglasses.svg +20 -0
- package/assets/images/promp-yellow.svg +5 -0
- package/assets/images/providers/aliyun-black.svg +14 -0
- package/assets/images/providers/aliyun.svg +17 -0
- package/assets/images/providers/aliyunecs-black.svg +13 -0
- package/assets/images/providers/aliyunecs.svg +21 -0
- package/assets/images/providers/amazonec2-black.svg +8 -0
- package/assets/images/providers/amazonec2.svg +19 -0
- package/assets/images/providers/amazoneks-black.svg +10 -0
- package/assets/images/providers/amazoneks.svg +14 -0
- package/assets/images/providers/aws.svg +38 -0
- package/assets/images/providers/azure-black.svg +29 -0
- package/assets/images/providers/azure.svg +32 -0
- package/assets/images/providers/azuread-black.svg +22 -0
- package/assets/images/providers/azuread.svg +25 -0
- package/assets/images/providers/azureaks-black.svg +28 -0
- package/assets/images/providers/azureaks.svg +31 -0
- package/assets/images/providers/baidu-black.svg +19 -0
- package/assets/images/providers/baidu.svg +25 -0
- package/assets/images/providers/cloudca-black.svg +45 -0
- package/assets/images/providers/cloudca.svg +49 -0
- package/assets/images/providers/cloudscale-black.svg +24 -0
- package/assets/images/providers/cloudscale.svg +28 -0
- package/assets/images/providers/custom.svg +85 -0
- package/assets/images/providers/digitalocean-black.svg +21 -0
- package/assets/images/providers/digitalocean.svg +24 -0
- package/assets/images/providers/equinix-black.svg +13 -0
- package/assets/images/providers/equinix.svg +13 -0
- package/assets/images/providers/exoscale.svg +1 -0
- package/assets/images/providers/gcp.svg +6 -0
- package/assets/images/providers/gke-black.svg +10 -0
- package/assets/images/providers/gke.svg +28 -0
- package/assets/images/providers/google.svg +29 -0
- package/assets/images/providers/googlegke-black.svg +10 -0
- package/assets/images/providers/googlegke.svg +28 -0
- package/assets/images/providers/harvester.svg +1 -0
- package/assets/images/providers/huaweicce-black.svg +109 -0
- package/assets/images/providers/huaweicce.svg +184 -0
- package/assets/images/providers/import.svg +99 -0
- package/assets/images/providers/k3s-black.svg +10 -0
- package/assets/images/providers/k3s.svg +15 -0
- package/assets/images/providers/kubernetes-black.svg +37 -0
- package/assets/images/providers/kubernetes.svg +99 -0
- package/assets/images/providers/linode.svg +54 -0
- package/assets/images/providers/linodelke-black.svg +40 -0
- package/assets/images/providers/linodelke.svg +54 -0
- package/assets/images/providers/local-cluster.svg +20 -0
- package/assets/images/providers/minikube-black.svg +25 -0
- package/assets/images/providers/minikube.svg +36 -0
- package/assets/images/providers/nutanix.svg +12 -0
- package/assets/images/providers/oci-black.svg +41 -0
- package/assets/images/providers/oci.svg +44 -0
- package/assets/images/providers/openstack-black.svg +16 -0
- package/assets/images/providers/openstack.svg +20 -0
- package/assets/images/providers/oracle.svg +66 -0
- package/assets/images/providers/oracleoke-black.svg +51 -0
- package/assets/images/providers/oracleoke.svg +55 -0
- package/assets/images/providers/otc-black.svg +15 -0
- package/assets/images/providers/otc.svg +33 -0
- package/assets/images/providers/otccce.svg +33 -0
- package/assets/images/providers/outscale.svg +19 -0
- package/assets/images/providers/ovhcloudmks.svg +122 -0
- package/assets/images/providers/ovhcloudpubliccloud.svg +122 -0
- package/assets/images/providers/packet-black.svg +15 -0
- package/assets/images/providers/packet.svg +16 -0
- package/assets/images/providers/pinganyunecs-black.svg +26 -0
- package/assets/images/providers/pinganyunecs.svg +26 -0
- package/assets/images/providers/pnap-black.svg +43 -0
- package/assets/images/providers/pnap.svg +48 -0
- package/assets/images/providers/rackspace-black.svg +14 -0
- package/assets/images/providers/rackspace.svg +18 -0
- package/assets/images/providers/rke.svg +26 -0
- package/assets/images/providers/rke2.svg +26 -0
- package/assets/images/providers/softlayer.svg +27 -0
- package/assets/images/providers/tencenttke-black.svg +22 -0
- package/assets/images/providers/tencenttke.svg +39 -0
- package/assets/images/providers/vmwarevsphere-black.svg +60 -0
- package/assets/images/providers/vmwarevsphere.svg +51 -0
- package/assets/images/user.png +0 -0
- package/assets/images/vendor/activedirectory.svg +20 -0
- package/assets/images/vendor/adfs.svg +19 -0
- package/assets/images/vendor/azuread.svg +18 -0
- package/assets/images/vendor/custom.svg +42 -0
- package/assets/images/vendor/email.svg +22 -0
- package/assets/images/vendor/freeipa.svg +26 -0
- package/assets/images/vendor/github.svg +13 -0
- package/assets/images/vendor/googleoauth.svg +9 -0
- package/assets/images/vendor/grafana.svg +48 -0
- package/assets/images/vendor/jaeger.svg +1 -0
- package/assets/images/vendor/keycloak.svg +30 -0
- package/assets/images/vendor/kiali.svg +23 -0
- package/assets/images/vendor/linux.svg +23 -0
- package/assets/images/vendor/longhorn.svg +25 -0
- package/assets/images/vendor/neuvector.svg +1 -0
- package/assets/images/vendor/okta.svg +31 -0
- package/assets/images/vendor/openid.svg +18 -0
- package/assets/images/vendor/openldap.svg +34 -0
- package/assets/images/vendor/pagerduty.svg +26 -0
- package/assets/images/vendor/ping.svg +58 -0
- package/assets/images/vendor/prometheus.svg +14 -0
- package/assets/images/vendor/shibboleth.svg +481 -0
- package/assets/images/vendor/slack.svg +38 -0
- package/assets/images/vendor/webhook.svg +23 -0
- package/assets/images/vendor/windows.svg +13 -0
- package/assets/images/wechat-qr-code.jpg +0 -0
- package/assets/styles/all.scss +63 -0
- package/assets/styles/app.scss +36 -0
- package/assets/styles/base/_basic.scss +152 -0
- package/assets/styles/base/_color.scss +11 -0
- package/assets/styles/base/_functions.scss +134 -0
- package/assets/styles/base/_helpers.scss +271 -0
- package/assets/styles/base/_mixins.scss +163 -0
- package/assets/styles/base/_typography.scss +70 -0
- package/assets/styles/base/_variables.scss +78 -0
- package/assets/styles/fonts/_dots.scss +18 -0
- package/assets/styles/fonts/_fontstack.scss +49 -0
- package/assets/styles/fonts/_icons.scss +101 -0
- package/assets/styles/fonts/_zerowidthspace.scss +8 -0
- package/assets/styles/global/_button.scss +234 -0
- package/assets/styles/global/_cards.scss +94 -0
- package/assets/styles/global/_columns.scss +128 -0
- package/assets/styles/global/_form.scss +178 -0
- package/assets/styles/global/_gauges.scss +55 -0
- package/assets/styles/global/_labeled-input.scss +165 -0
- package/assets/styles/global/_layout.scss +171 -0
- package/assets/styles/global/_resource.scss +89 -0
- package/assets/styles/global/_select.scss +202 -0
- package/assets/styles/global/_table.scss +106 -0
- package/assets/styles/global/_tooltip.scss +206 -0
- package/assets/styles/themes/_csp.scss +25 -0
- package/assets/styles/themes/_dark.scss +233 -0
- package/assets/styles/themes/_light.scss +569 -0
- package/assets/styles/themes/_suse.scss +27 -0
- package/assets/styles/vendor/_code-mirror.scss +3 -0
- package/assets/styles/vendor/normalize.scss +349 -0
- package/assets/styles/vendor/vue-select.scss +403 -0
- package/assets/translations/en-us.yaml +8184 -0
- package/assets/translations/zh-hans.yaml +7825 -0
- package/babel.config.js +35 -0
- package/chart/__tests__/S3.test.ts +64 -0
- package/chart/example.vue +18 -0
- package/chart/gatekeeper.vue +69 -0
- package/chart/istio.vue +284 -0
- package/chart/logging/index.vue +84 -0
- package/chart/monitoring/ClusterSelector.vue +215 -0
- package/chart/monitoring/StorageClassSelector.vue +49 -0
- package/chart/monitoring/alerting/index.vue +188 -0
- package/chart/monitoring/grafana/index.vue +378 -0
- package/chart/monitoring/index.vue +366 -0
- package/chart/monitoring/prometheus/index.vue +376 -0
- package/chart/rancher-backup/S3.vue +190 -0
- package/chart/rancher-backup/index.vue +260 -0
- package/cloud-credential/__tests__/azure.test.ts +43 -0
- package/cloud-credential/__tests__/harvester.test.ts +18 -0
- package/cloud-credential/aws.vue +111 -0
- package/cloud-credential/azure.vue +132 -0
- package/cloud-credential/digitalocean.vue +55 -0
- package/cloud-credential/gcp.vue +82 -0
- package/cloud-credential/generic.vue +100 -0
- package/cloud-credential/harvester.vue +125 -0
- package/cloud-credential/linode.vue +58 -0
- package/cloud-credential/pnap.vue +92 -0
- package/cloud-credential/s3.vue +143 -0
- package/cloud-credential/vmwarevsphere.vue +109 -0
- package/components/ActionDropdown.vue +248 -0
- package/components/ActionDropdownShell.vue +71 -0
- package/components/ActionMenu.vue +366 -0
- package/components/ActionMenuShell.vue +106 -0
- package/components/AdvancedSection.vue +40 -0
- package/components/Alert.vue +55 -0
- package/components/AlertTable.vue +123 -0
- package/components/AppModal.vue +307 -0
- package/components/AssignTo.vue +199 -0
- package/components/AsyncButton.vue +332 -0
- package/components/AwsComplianceBanner.vue +47 -0
- package/components/BackLink.vue +44 -0
- package/components/BannerGraphic.vue +95 -0
- package/components/BrandImage.vue +135 -0
- package/components/ButtonDropdown.vue +340 -0
- package/components/ButtonGroup.vue +124 -0
- package/components/ButtonMultiAction.vue +52 -0
- package/components/Carousel.vue +397 -0
- package/components/Certificates.vue +161 -0
- package/components/ChartHeading.vue +25 -0
- package/components/ChartReadme.vue +100 -0
- package/components/ClusterBadge.vue +48 -0
- package/components/ClusterIconMenu.vue +189 -0
- package/components/ClusterProviderIcon.vue +131 -0
- package/components/CodeMirror.vue +501 -0
- package/components/Collapse.vue +87 -0
- package/components/CollapsibleCard.vue +121 -0
- package/components/CommunityLinks.vue +216 -0
- package/components/CompoundStatusBadge.vue +53 -0
- package/components/ConsumptionGauge.vue +167 -0
- package/components/ContainerResourceLimit.vue +254 -0
- package/components/CopyCode.vue +74 -0
- package/components/CopyToClipboard.vue +44 -0
- package/components/CopyToClipboardText.vue +83 -0
- package/components/CountBox.vue +114 -0
- package/components/CountGauge.vue +180 -0
- package/components/CreateDriver.vue +81 -0
- package/components/CruResource.vue +936 -0
- package/components/CruResourceFooter.vue +127 -0
- package/components/DashboardMetrics.vue +125 -0
- package/components/DashboardOptions.vue +159 -0
- package/components/DetailText.vue +220 -0
- package/components/DetailTop.vue +374 -0
- package/components/Dialog.vue +136 -0
- package/components/DisableAuthProviderModal.vue +115 -0
- package/components/DotState.vue +84 -0
- package/components/DraggableZone.vue +181 -0
- package/components/EmberPage.vue +622 -0
- package/components/EmberPageView.vue +39 -0
- package/components/EtcdInfoBanner.vue +76 -0
- package/components/ExplorerMembers.vue +453 -0
- package/components/ExplorerProjectsNamespaces.vue +654 -0
- package/components/ExtensionPanel.vue +42 -0
- package/components/FileDiff.vue +184 -0
- package/components/FixedBanner.vue +284 -0
- package/components/Flag.vue +83 -0
- package/components/Glance.vue +79 -0
- package/components/GlobalRoleBindings.vue +429 -0
- package/components/GradientBox.vue +82 -0
- package/components/GrafanaDashboard.vue +321 -0
- package/components/GroupPanel.vue +57 -0
- package/components/GrowlManager.vue +215 -0
- package/components/HardwareResourceGauge.vue +206 -0
- package/components/HarvesterServiceAddOnConfig.vue +207 -0
- package/components/IconMessage.vue +101 -0
- package/components/IconOrSvg.vue +184 -0
- package/components/Import.vue +260 -0
- package/components/Inactivity.vue +236 -0
- package/components/IndentedPanel.vue +26 -0
- package/components/InfoBox.vue +84 -0
- package/components/InputOrDisplay.vue +91 -0
- package/components/KeyValueView.vue +283 -0
- package/components/LabelValue.vue +61 -0
- package/components/LandingPagePreference.vue +154 -0
- package/components/LazyImage.vue +70 -0
- package/components/Loading.vue +85 -0
- package/components/LocaleSelector.vue +121 -0
- package/components/LogItem.vue +69 -0
- package/components/Markdown.vue +138 -0
- package/components/MessageLink.vue +79 -0
- package/components/ModalManager.vue +55 -0
- package/components/ModalWithCard.vue +147 -0
- package/components/MoveModal.vue +167 -0
- package/components/PaginatedResourceTable.vue +133 -0
- package/components/PercentageBar.vue +127 -0
- package/components/PodSecurityAdmission.vue +306 -0
- package/components/ProgressBarMulti.vue +173 -0
- package/components/PromptChangePassword.vue +123 -0
- package/components/PromptModal.vue +122 -0
- package/components/PromptRemove.vue +491 -0
- package/components/PromptRestore.vue +328 -0
- package/components/Questions/Array.vue +38 -0
- package/components/Questions/Boolean.vue +37 -0
- package/components/Questions/CloudCredential.vue +54 -0
- package/components/Questions/Enum.vue +53 -0
- package/components/Questions/Float.vue +41 -0
- package/components/Questions/Int.vue +41 -0
- package/components/Questions/Question.js +145 -0
- package/components/Questions/QuestionMap.vue +45 -0
- package/components/Questions/Radio.vue +35 -0
- package/components/Questions/Reference.vue +167 -0
- package/components/Questions/String.vue +51 -0
- package/components/Questions/Yaml.vue +48 -0
- package/components/Questions/__tests__/Boolean.test.ts +125 -0
- package/components/Questions/__tests__/Float.test.ts +125 -0
- package/components/Questions/__tests__/Int.test.ts +125 -0
- package/components/Questions/__tests__/String.test.ts +125 -0
- package/components/Questions/__tests__/Yaml.test.ts +125 -0
- package/components/Questions/__tests__/utils/questions-defaults.ts +20 -0
- package/components/Questions/index.vue +522 -0
- package/components/Random.vue +100 -0
- package/components/RelatedResources.vue +187 -0
- package/components/ResourceCancelModal.vue +128 -0
- package/components/ResourceDetail/Masthead.vue +838 -0
- package/components/ResourceDetail/__tests__/Masthead.test.ts +65 -0
- package/components/ResourceDetail/index.vue +572 -0
- package/components/ResourceList/Masthead.vue +311 -0
- package/components/ResourceList/ResourceLoadingIndicator.vue +137 -0
- package/components/ResourceList/index.vue +307 -0
- package/components/ResourceList/resource-list.config.js +7 -0
- package/components/ResourceSummary.vue +173 -0
- package/components/ResourceTable.vue +708 -0
- package/components/ResourceYaml.vue +403 -0
- package/components/RoleBindings.vue +470 -0
- package/components/SelectIconGrid.vue +414 -0
- package/components/Setting.vue +115 -0
- package/components/SideNav.vue +589 -0
- package/components/SimpleBox.vue +121 -0
- package/components/SingleClusterInfo.vue +199 -0
- package/components/SlideInPanelManager.vue +126 -0
- package/components/SortableTable/THead.vue +555 -0
- package/components/SortableTable/actions.js +153 -0
- package/components/SortableTable/advanced-filtering.js +272 -0
- package/components/SortableTable/debug.js +117 -0
- package/components/SortableTable/filtering.js +290 -0
- package/components/SortableTable/grouping.js +48 -0
- package/components/SortableTable/index.vue +2604 -0
- package/components/SortableTable/paging.js +155 -0
- package/components/SortableTable/selection.js +629 -0
- package/components/SortableTable/sortable-config.ts +4 -0
- package/components/SortableTable/sorting.js +129 -0
- package/components/StatusBadge.vue +77 -0
- package/components/StatusTable.vue +61 -0
- package/components/TabTitle.vue +78 -0
- package/components/Tabbed/Tab.vue +129 -0
- package/components/Tabbed/index.vue +587 -0
- package/components/TableDataUserIcon.vue +47 -0
- package/components/TableSparkLine.vue +108 -0
- package/components/Tag.vue +19 -0
- package/components/Tip.vue +43 -0
- package/components/TypeDescription.vue +65 -0
- package/components/Wizard.vue +704 -0
- package/components/YamlEditor.vue +296 -0
- package/components/__tests__/AppModal.test.ts +106 -0
- package/components/__tests__/ApplicationCard.test.ts +27 -0
- package/components/__tests__/AsyncButton.test.ts +148 -0
- package/components/__tests__/BackLink.test.ts +33 -0
- package/components/__tests__/ButtonGroup.test.ts +121 -0
- package/components/__tests__/ButtonMultiAction.test.ts +31 -0
- package/components/__tests__/Carousel.test.ts +72 -0
- package/components/__tests__/Certificates.test.ts +31 -0
- package/components/__tests__/ClusterBadge.test.ts +32 -0
- package/components/__tests__/CodeMirror.test.ts +93 -0
- package/components/__tests__/Collapse.test.ts +44 -0
- package/components/__tests__/CollapsibleCard.test.ts +64 -0
- package/components/__tests__/ConsumptionGauge.test.ts +88 -0
- package/components/__tests__/ContainerResourceLimit.test.ts +35 -0
- package/components/__tests__/CopyCode.test.ts +16 -0
- package/components/__tests__/CruResource.test.ts +155 -0
- package/components/__tests__/EtcdInfoBanner.test.ts +39 -0
- package/components/__tests__/FixedBanner.test.ts +114 -0
- package/components/__tests__/GrowlManager.test.ts +146 -0
- package/components/__tests__/ModalManager.spec.ts +176 -0
- package/components/__tests__/NamespaceFilter.test.ts +247 -0
- package/components/__tests__/PercentageBar.test.ts +32 -0
- package/components/__tests__/PodSecurityAdmission.test.ts +440 -0
- package/components/__tests__/ProjectRow.test.ts +59 -0
- package/components/__tests__/PromptRestore.test.ts +139 -0
- package/components/__tests__/SimpleBox.spec.ts +28 -0
- package/components/__tests__/SlideInPanelManager.spec.ts +166 -0
- package/components/__tests__/TabTitle.test.ts +136 -0
- package/components/auth/AllowedPrincipals.vue +122 -0
- package/components/auth/AuthBanner.vue +104 -0
- package/components/auth/AzureWarning.vue +77 -0
- package/components/auth/Principal.vue +219 -0
- package/components/auth/RoleDetailEdit.vue +808 -0
- package/components/auth/SelectPrincipal.vue +260 -0
- package/components/auth/__tests__/Principal.test.ts +40 -0
- package/components/auth/__tests__/RoleDetailEdit.test.ts +84 -0
- package/components/auth/login/github.vue +23 -0
- package/components/auth/login/ldap.vue +106 -0
- package/components/auth/login/oauth.vue +26 -0
- package/components/auth/login/oidc.vue +32 -0
- package/components/auth/login/saml.vue +39 -0
- package/components/cards/ApplicationCard.vue +145 -0
- package/components/fleet/FleetBundleResources.vue +86 -0
- package/components/fleet/FleetBundles.vue +136 -0
- package/components/fleet/FleetClusters.vue +208 -0
- package/components/fleet/FleetIntro.vue +65 -0
- package/components/fleet/FleetNoWorkspaces.vue +62 -0
- package/components/fleet/FleetRepos.vue +184 -0
- package/components/fleet/FleetResources.vue +83 -0
- package/components/fleet/FleetStatus.vue +301 -0
- package/components/fleet/FleetSummary.vue +210 -0
- package/components/fleet/ForceDirectedTreeChart/chartIcons.js +17 -0
- package/components/fleet/ForceDirectedTreeChart/index.vue +565 -0
- package/components/fleet/ResourcesSummary.vue +93 -0
- package/components/fleet/__tests__/FleetSummary.test.ts +362 -0
- package/components/form/ArrayList.vue +456 -0
- package/components/form/ArrayListGrouped.vue +149 -0
- package/components/form/ArrayListSelect.vue +103 -0
- package/components/form/BannerSettings.vue +220 -0
- package/components/form/ChangePassword.vue +461 -0
- package/components/form/ClusterAppearance.vue +132 -0
- package/components/form/ColorInput.vue +200 -0
- package/components/form/Command.vue +204 -0
- package/components/form/Conditions.vue +93 -0
- package/components/form/EnvVars.vue +162 -0
- package/components/form/Error.vue +66 -0
- package/components/form/FileImageSelector.vue +140 -0
- package/components/form/FileSelector.vue +169 -0
- package/components/form/Footer.vue +119 -0
- package/components/form/GitPicker.vue +590 -0
- package/components/form/HealthCheck.vue +86 -0
- package/components/form/HookOption.vue +253 -0
- package/components/form/InputWithSelect.vue +330 -0
- package/components/form/KeyValue.vue +991 -0
- package/components/form/LabeledSelect.vue +719 -0
- package/components/form/Labels.vue +154 -0
- package/components/form/LifecycleHooks.vue +87 -0
- package/components/form/MatchExpressions.vue +471 -0
- package/components/form/Members/ClusterMembershipEditor.vue +61 -0
- package/components/form/Members/ClusterPermissionsEditor.vue +314 -0
- package/components/form/Members/MembershipEditor.vue +230 -0
- package/components/form/Members/ProjectMembershipEditor.vue +63 -0
- package/components/form/Members/__tests__/MembershipEditor.test.ts +62 -0
- package/components/form/NameNsDescription.vue +601 -0
- package/components/form/Networking.vue +281 -0
- package/components/form/NodeAffinity.vue +258 -0
- package/components/form/NodeScheduling.vue +212 -0
- package/components/form/NotificationSettings.vue +71 -0
- package/components/form/Password.vue +191 -0
- package/components/form/PlusMinus.vue +109 -0
- package/components/form/PodAffinity.vue +496 -0
- package/components/form/Ports.vue +310 -0
- package/components/form/Probe.vue +376 -0
- package/components/form/ProjectMemberEditor.vue +342 -0
- package/components/form/ResourceLabeledSelect.vue +154 -0
- package/components/form/ResourceQuota/Namespace.vue +117 -0
- package/components/form/ResourceQuota/NamespaceRow.vue +220 -0
- package/components/form/ResourceQuota/Project.vue +107 -0
- package/components/form/ResourceQuota/ProjectRow.vue +115 -0
- package/components/form/ResourceQuota/shared.js +147 -0
- package/components/form/ResourceSelector.vue +144 -0
- package/components/form/ResourceTabs/index.vue +292 -0
- package/components/form/RuleSelector.vue +184 -0
- package/components/form/SSHKnownHosts/KnownHostsEditDialog.vue +196 -0
- package/components/form/SSHKnownHosts/__tests__/KnownHostsEditDialog.test.ts +115 -0
- package/components/form/SSHKnownHosts/index.vue +115 -0
- package/components/form/SchedulingCustomization.vue +85 -0
- package/components/form/SecretSelector.vue +269 -0
- package/components/form/Security.vue +245 -0
- package/components/form/Select.vue +407 -0
- package/components/form/SelectOrCreateAuthSecret.vue +693 -0
- package/components/form/ServiceNameSelect.vue +168 -0
- package/components/form/ServicePorts.vue +340 -0
- package/components/form/ShellInput.vue +95 -0
- package/components/form/SimpleSecretSelector.vue +278 -0
- package/components/form/Taints.vue +98 -0
- package/components/form/Tolerations.vue +319 -0
- package/components/form/UnitInput.vue +257 -0
- package/components/form/ValueFromResource.vue +407 -0
- package/components/form/WorkloadPorts.vue +514 -0
- package/components/form/__tests__/ArrayList.test.ts +127 -0
- package/components/form/__tests__/ArrayListGrouped.test.ts +41 -0
- package/components/form/__tests__/BannerSettings.test.ts +54 -0
- package/components/form/__tests__/ColorInput.test.ts +27 -0
- package/components/form/__tests__/Command.test.ts +64 -0
- package/components/form/__tests__/Error.test.ts +56 -0
- package/components/form/__tests__/FileImageSelector.test.ts +42 -0
- package/components/form/__tests__/FileSelector.test.ts +76 -0
- package/components/form/__tests__/HookOption.test.ts +28 -0
- package/components/form/__tests__/InputWithSelect.test.ts +42 -0
- package/components/form/__tests__/KeyValue.test.ts +179 -0
- package/components/form/__tests__/LabeledSelect.test.ts +217 -0
- package/components/form/__tests__/MatchExpressions.test.ts +78 -0
- package/components/form/__tests__/NameNsDescription.test.ts +173 -0
- package/components/form/__tests__/NodeAffinity.test.ts +39 -0
- package/components/form/__tests__/NodeScheduling.test.ts +44 -0
- package/components/form/__tests__/PodAffinity.test.ts +47 -0
- package/components/form/__tests__/Probe.test.ts +78 -0
- package/components/form/__tests__/SSHKnownHosts.test.ts +70 -0
- package/components/form/__tests__/Security.test.ts +55 -0
- package/components/form/__tests__/Select.test.ts +67 -0
- package/components/form/__tests__/SelectOrCreateAuthSecret.test.ts +34 -0
- package/components/form/__tests__/ServiceNameSelect.test.ts +42 -0
- package/components/form/__tests__/Taints.test.ts +71 -0
- package/components/form/__tests__/UnitInput.test.ts +255 -0
- package/components/form/labeled-select-utils/labeled-select-pagination.ts +151 -0
- package/components/form/labeled-select-utils/labeled-select.utils.ts +122 -0
- package/components/formatter/AppSummaryGraph.vue +154 -0
- package/components/formatter/BadgeStateFormatter.vue +66 -0
- package/components/formatter/Capitalize.vue +28 -0
- package/components/formatter/Checked.vue +31 -0
- package/components/formatter/CloudCredExpired.vue +69 -0
- package/components/formatter/CloudCredPublicData.vue +30 -0
- package/components/formatter/ClusterLink.vue +117 -0
- package/components/formatter/ClusterProvider.vue +38 -0
- package/components/formatter/CopyToClipboard.vue +18 -0
- package/components/formatter/Date.vue +74 -0
- package/components/formatter/DelayedValue.vue +46 -0
- package/components/formatter/Endpoints.vue +106 -0
- package/components/formatter/ExternalLink.vue +11 -0
- package/components/formatter/FleetClusterSummaryGraph.vue +27 -0
- package/components/formatter/FleetSummaryGraph.vue +122 -0
- package/components/formatter/IconIsDefault.vue +34 -0
- package/components/formatter/IconText.vue +49 -0
- package/components/formatter/ImageName.vue +23 -0
- package/components/formatter/ImagePercentageBar.vue +86 -0
- package/components/formatter/IngressFullPath.vue +22 -0
- package/components/formatter/IngressTarget.vue +96 -0
- package/components/formatter/InternalExternalIP.vue +64 -0
- package/components/formatter/InvolvedObjectLink.vue +54 -0
- package/components/formatter/KeyValue.vue +78 -0
- package/components/formatter/Link.vue +189 -0
- package/components/formatter/LinkDetail.vue +58 -0
- package/components/formatter/LinkDetailImage.vue +31 -0
- package/components/formatter/LinkName.vue +66 -0
- package/components/formatter/List.vue +22 -0
- package/components/formatter/ListLink.vue +37 -0
- package/components/formatter/ListLinkDetail.vue +30 -0
- package/components/formatter/LiveDate.vue +167 -0
- package/components/formatter/LiveDuration.vue +78 -0
- package/components/formatter/LiveExpiryBadgeState.vue +79 -0
- package/components/formatter/LiveExpiryDate.vue +87 -0
- package/components/formatter/LivePodRestarts.vue +50 -0
- package/components/formatter/MachineSummaryGraph.vue +108 -0
- package/components/formatter/Number.vue +34 -0
- package/components/formatter/Percentage.vue +25 -0
- package/components/formatter/PercentageBar.vue +41 -0
- package/components/formatter/PodImages.vue +72 -0
- package/components/formatter/PodsUsage.vue +29 -0
- package/components/formatter/Principal.vue +22 -0
- package/components/formatter/PrincipalGroupBindings.vue +59 -0
- package/components/formatter/QualityText.vue +21 -0
- package/components/formatter/RKETemplateName.vue +37 -0
- package/components/formatter/ReceiverIcons.vue +132 -0
- package/components/formatter/RunBookLink.vue +20 -0
- package/components/formatter/Scale.vue +143 -0
- package/components/formatter/ScanResult.vue +33 -0
- package/components/formatter/SecretData.vue +68 -0
- package/components/formatter/ServiceTargets.vue +121 -0
- package/components/formatter/ServiceType.vue +54 -0
- package/components/formatter/Shortened.vue +55 -0
- package/components/formatter/Si.vue +46 -0
- package/components/formatter/Translate.vue +32 -0
- package/components/formatter/VerticalScroll.vue +17 -0
- package/components/formatter/VirtualServiceGateways.vue +111 -0
- package/components/formatter/WorkloadDetailEndpoints.vue +107 -0
- package/components/formatter/WorkloadHealthScale.vue +339 -0
- package/components/formatter/__tests__/Checked.test.ts +19 -0
- package/components/formatter/__tests__/ClusterLink.test.ts +101 -0
- package/components/formatter/__tests__/Date.test.ts +60 -0
- package/components/formatter/__tests__/LinkDetail.test.ts +72 -0
- package/components/formatter/__tests__/LiveDate.test.ts +90 -0
- package/components/formatter/__tests__/PodsUsage.test.ts +55 -0
- package/components/formatter/__tests__/Si.test.ts +35 -0
- package/components/formatter/__tests__/WorkloadDetailEndpoints.test.ts +81 -0
- package/components/graph/AspectPreserver.vue +79 -0
- package/components/graph/Bar.vue +81 -0
- package/components/graph/Circle.vue +164 -0
- package/components/graph/HalfCircle.vue +46 -0
- package/components/graph/LinePlot.vue +189 -0
- package/components/graph/ProgressArc.vue +94 -0
- package/components/nav/Favorite.vue +60 -0
- package/components/nav/GlobalLoading.vue +25 -0
- package/components/nav/Group.vue +496 -0
- package/components/nav/Header.vue +1182 -0
- package/components/nav/HeaderPageActionMenu.vue +22 -0
- package/components/nav/Jump.vue +135 -0
- package/components/nav/NamespaceFilter.vue +1165 -0
- package/components/nav/Pinned.vue +52 -0
- package/components/nav/TopLevelMenu.helper.ts +562 -0
- package/components/nav/TopLevelMenu.vue +1590 -0
- package/components/nav/Type.vue +289 -0
- package/components/nav/WindowManager/ChartReadme.vue +48 -0
- package/components/nav/WindowManager/ContainerLogs.vue +877 -0
- package/components/nav/WindowManager/ContainerShell.vue +585 -0
- package/components/nav/WindowManager/KubectlShell.vue +42 -0
- package/components/nav/WindowManager/MachineSsh.vue +21 -0
- package/components/nav/WindowManager/Window.vue +105 -0
- package/components/nav/WindowManager/__tests__/ContainerLogs.test.ts +197 -0
- package/components/nav/WindowManager/__tests__/ContainerShell.test.ts +571 -0
- package/components/nav/WindowManager/index.vue +587 -0
- package/components/nav/WorkspaceSwitcher.vue +190 -0
- package/components/nav/__tests__/TopLevelMenu.test.ts +558 -0
- package/components/nav/__tests__/Type.test.ts +491 -0
- package/components/templates/blank.vue +23 -0
- package/components/templates/default.vue +271 -0
- package/components/templates/home.vue +135 -0
- package/components/templates/plain.vue +143 -0
- package/components/templates/standalone.vue +9 -0
- package/components/templates/unauthenticated.vue +26 -0
- package/components/user.retention/user-retention-header.vue +34 -0
- package/composables/focusTrap.ts +76 -0
- package/composables/useClickOutside.ts +81 -0
- package/composables/useCompactInput.test.ts +36 -0
- package/composables/useCompactInput.ts +20 -0
- package/composables/useI18n.ts +26 -0
- package/composables/useLabeledFormElement.test.ts +135 -0
- package/composables/useLabeledFormElement.ts +153 -0
- package/composables/useRuntimeFlag.ts +29 -0
- package/composables/useUserRetentionValidation.test.ts +178 -0
- package/composables/useUserRetentionValidation.ts +201 -0
- package/config/__test__/home-links.test.ts +57 -0
- package/config/cookies.js +4 -0
- package/config/elemental-types.js +9 -0
- package/config/features.js +6 -0
- package/config/harvester-manager-types.js +3 -0
- package/config/home-links.js +209 -0
- package/config/labels-annotations.js +192 -0
- package/config/local-storage.js +6 -0
- package/config/page-actions.js +4 -0
- package/config/pagination-table-headers.js +80 -0
- package/config/persistentVolume.ts +108 -0
- package/config/pod-security-admission.ts +82 -0
- package/config/private-label.js +99 -0
- package/config/product/apps.js +148 -0
- package/config/product/auth.js +218 -0
- package/config/product/backup.js +61 -0
- package/config/product/cis.js +158 -0
- package/config/product/explorer.js +632 -0
- package/config/product/fleet.js +100 -0
- package/config/product/gatekeeper.js +119 -0
- package/config/product/istio.js +89 -0
- package/config/product/legacy.js +62 -0
- package/config/product/logging.js +377 -0
- package/config/product/longhorn.js +49 -0
- package/config/product/manager.js +217 -0
- package/config/product/monitoring.js +287 -0
- package/config/product/navlinks.js +32 -0
- package/config/product/neuvector.js +30 -0
- package/config/product/settings.js +161 -0
- package/config/product/uiplugins.js +18 -0
- package/config/query-params.js +79 -0
- package/config/roles.ts +409 -0
- package/config/router/index.js +26 -0
- package/config/router/navigation-guards/attempt-first-login.js +73 -0
- package/config/router/navigation-guards/authentication.js +64 -0
- package/config/router/navigation-guards/clusters.js +132 -0
- package/config/router/navigation-guards/i18n.js +13 -0
- package/config/router/navigation-guards/index.js +23 -0
- package/config/router/navigation-guards/install-redirect.js +95 -0
- package/config/router/navigation-guards/load-initial-settings.js +15 -0
- package/config/router/navigation-guards/page-title.js +12 -0
- package/config/router/navigation-guards/products.js +15 -0
- package/config/router/navigation-guards/record-last-route.js +24 -0
- package/config/router/navigation-guards/runtime-extension-route.js +31 -0
- package/config/router/navigation-guards/server-upgrade-growl.js +19 -0
- package/config/router/routes.js +496 -0
- package/config/schema.js +32 -0
- package/config/secret.js +14 -0
- package/config/settings.ts +258 -0
- package/config/store.js +188 -0
- package/config/system-namespaces.js +18 -0
- package/config/table-headers.js +1116 -0
- package/config/types.js +353 -0
- package/config/uiplugins.js +276 -0
- package/config/version.js +33 -0
- package/config/workload.ts +1 -0
- package/core/plugin-helpers.ts +220 -0
- package/core/plugin-routes.ts +34 -0
- package/core/plugin.ts +367 -0
- package/core/plugins-loader.js +31 -0
- package/core/plugins.js +471 -0
- package/core/types-provisioning.ts +361 -0
- package/core/types.ts +682 -0
- package/detail/__tests__/autoscaling.horizontalpodautoscaler.test.ts +196 -0
- package/detail/__tests__/provisioning.cattle.io.cluster.test.ts +119 -0
- package/detail/__tests__/service.test.ts +62 -0
- package/detail/autoscaling.horizontalpodautoscaler/index.vue +264 -0
- package/detail/catalog.cattle.io.app.vue +181 -0
- package/detail/catalog.cattle.io.clusterrepo.vue +35 -0
- package/detail/cis.cattle.io.clusterscan.vue +372 -0
- package/detail/configmap.vue +81 -0
- package/detail/constraints.gatekeeper.sh.constraint.vue +66 -0
- package/detail/fleet.cattle.io.bundle.vue +63 -0
- package/detail/fleet.cattle.io.cluster.vue +99 -0
- package/detail/fleet.cattle.io.clustergroup.vue +76 -0
- package/detail/fleet.cattle.io.gitrepo.vue +148 -0
- package/detail/harvesterhci.io.management.cluster.vue +104 -0
- package/detail/helm.cattle.io.projecthelmchart.vue +249 -0
- package/detail/management.cattle.io.fleetworkspace.vue +100 -0
- package/detail/management.cattle.io.globalrole.vue +8 -0
- package/detail/management.cattle.io.roletemplate.vue +11 -0
- package/detail/management.cattle.io.user.vue +312 -0
- package/detail/namespace.vue +269 -0
- package/detail/networking.k8s.io.ingress.vue +74 -0
- package/detail/node.vue +330 -0
- package/detail/pod.vue +255 -0
- package/detail/provisioning.cattle.io.cluster.vue +1200 -0
- package/detail/rbac.authorization.k8s.io.clusterrole.vue +8 -0
- package/detail/rbac.authorization.k8s.io.role.vue +8 -0
- package/detail/secret.vue +313 -0
- package/detail/service.vue +202 -0
- package/detail/workload/index.vue +541 -0
- package/dialog/AddClusterMemberDialog.vue +86 -0
- package/dialog/AddCustomBadgeDialog.vue +466 -0
- package/dialog/AddProjectMemberDialog.vue +181 -0
- package/dialog/AddonConfigConfirmationDialog.vue +101 -0
- package/dialog/DeactivateDriverDialog.vue +139 -0
- package/dialog/DiagnosticTimingsDialog.vue +141 -0
- package/dialog/DrainNode.vue +247 -0
- package/dialog/ForceMachineRemoveDialog.vue +134 -0
- package/dialog/GenericPrompt.vue +135 -0
- package/dialog/GitRepoForceUpdateDialog.vue +132 -0
- package/dialog/RollbackWorkloadDialog.vue +308 -0
- package/dialog/RotateCertificatesDialog.vue +205 -0
- package/dialog/RotateEncryptionKeyDialog.vue +191 -0
- package/dialog/SaveAsRKETemplateDialog.vue +139 -0
- package/dialog/ScaleMachineDownDialog.vue +156 -0
- package/dialog/ScalePoolDownDialog.vue +121 -0
- package/dialog/SloDialog.vue +97 -0
- package/directives/clean-html.js +15 -0
- package/directives/clean-tooltip.js +32 -0
- package/directives/focus.js +47 -0
- package/directives/int-number.js +21 -0
- package/directives/positive-int-number.js +19 -0
- package/directives/strip-html-aria-label.js +19 -0
- package/directives/trim-whitespace.js +19 -0
- package/edit/__tests__/cis.cattle.io.clusterscan.test.ts +87 -0
- package/edit/__tests__/fleet.cattle.io.gitrepo.test.ts +246 -0
- package/edit/__tests__/kontainerDriver.test.ts +110 -0
- package/edit/__tests__/management.cattle.io.clusterroletemplatebinding.test.ts +71 -0
- package/edit/__tests__/management.cattle.io.setting.test.ts +109 -0
- package/edit/__tests__/monitoring.coreos.com.prometheusrule.test.ts +70 -0
- package/edit/__tests__/namespace.test.ts +49 -0
- package/edit/__tests__/nodeDriver.test.ts +89 -0
- package/edit/__tests__/service.test.ts +100 -0
- package/edit/__tests__/ui.cattle.io.navlink.test.ts +114 -0
- package/edit/auth/AuthProviderWarningBanners.vue +34 -0
- package/edit/auth/__tests__/AuthProviderWarningBanners.test.ts +19 -0
- package/edit/auth/__tests__/azuread.test.ts +238 -0
- package/edit/auth/__tests__/oidc.test.ts +225 -0
- package/edit/auth/azuread.vue +538 -0
- package/edit/auth/github.vue +269 -0
- package/edit/auth/googleoauth.vue +260 -0
- package/edit/auth/ldap/__tests__/config.test.ts +44 -0
- package/edit/auth/ldap/config.vue +379 -0
- package/edit/auth/ldap/index.vue +156 -0
- package/edit/auth/oidc.vue +445 -0
- package/edit/auth/saml.vue +432 -0
- package/edit/autoscaling.horizontalpodautoscaler/external-metric.vue +58 -0
- package/edit/autoscaling.horizontalpodautoscaler/hpa-scaling-rule.vue +130 -0
- package/edit/autoscaling.horizontalpodautoscaler/index.vue +343 -0
- package/edit/autoscaling.horizontalpodautoscaler/metric-identifier.vue +82 -0
- package/edit/autoscaling.horizontalpodautoscaler/metric-object-reference.vue +60 -0
- package/edit/autoscaling.horizontalpodautoscaler/metric-target.vue +220 -0
- package/edit/autoscaling.horizontalpodautoscaler/metrics-row.vue +198 -0
- package/edit/autoscaling.horizontalpodautoscaler/object-metric.vue +71 -0
- package/edit/autoscaling.horizontalpodautoscaler/pod-metric.vue +58 -0
- package/edit/autoscaling.horizontalpodautoscaler/resource-metric.vue +65 -0
- package/edit/catalog.cattle.io.clusterrepo.vue +336 -0
- package/edit/cis.cattle.io.clusterscan.vue +377 -0
- package/edit/cis.cattle.io.clusterscanbenchmark.vue +153 -0
- package/edit/cis.cattle.io.clusterscanprofile.vue +150 -0
- package/edit/cloudcredential.vue +334 -0
- package/edit/configmap.vue +163 -0
- package/edit/constraints.gatekeeper.sh.constraint/MatchKinds.vue +72 -0
- package/edit/constraints.gatekeeper.sh.constraint/NamespaceList.vue +78 -0
- package/edit/constraints.gatekeeper.sh.constraint/Scope.vue +52 -0
- package/edit/constraints.gatekeeper.sh.constraint/index.vue +368 -0
- package/edit/fleet.cattle.io.cluster.vue +105 -0
- package/edit/fleet.cattle.io.clustergroup.vue +189 -0
- package/edit/fleet.cattle.io.gitrepo.vue +912 -0
- package/edit/group.principal.vue +65 -0
- package/edit/helm.cattle.io.projecthelmchart.vue +163 -0
- package/edit/k8s.cni.cncf.io.networkattachmentdefinition.vue +94 -0
- package/edit/kontainerDriver.vue +67 -0
- package/edit/logging-flow/Match.vue +142 -0
- package/edit/logging-flow/index.vue +549 -0
- package/edit/logging.banzaicloud.io.clusterflow.vue +7 -0
- package/edit/logging.banzaicloud.io.clusteroutput.vue +12 -0
- package/edit/logging.banzaicloud.io.flow.vue +7 -0
- package/edit/logging.banzaicloud.io.output/__tests__/logging.banzaicloud.io.output.test.ts +310 -0
- package/edit/logging.banzaicloud.io.output/index.vue +386 -0
- package/edit/logging.banzaicloud.io.output/providers/__tests__/loki.test.ts +13 -0
- package/edit/logging.banzaicloud.io.output/providers/awsElasticsearch.vue +77 -0
- package/edit/logging.banzaicloud.io.output/providers/azurestorage.vue +94 -0
- package/edit/logging.banzaicloud.io.output/providers/cloudwatch.vue +112 -0
- package/edit/logging.banzaicloud.io.output/providers/datadog.vue +95 -0
- package/edit/logging.banzaicloud.io.output/providers/elasticsearch.vue +234 -0
- package/edit/logging.banzaicloud.io.output/providers/file.vue +47 -0
- package/edit/logging.banzaicloud.io.output/providers/forward.vue +152 -0
- package/edit/logging.banzaicloud.io.output/providers/gcs.vue +102 -0
- package/edit/logging.banzaicloud.io.output/providers/gelf.vue +167 -0
- package/edit/logging.banzaicloud.io.output/providers/kafka.vue +166 -0
- package/edit/logging.banzaicloud.io.output/providers/kinesisStream.vue +76 -0
- package/edit/logging.banzaicloud.io.output/providers/logdna.vue +72 -0
- package/edit/logging.banzaicloud.io.output/providers/logz.vue +107 -0
- package/edit/logging.banzaicloud.io.output/providers/loki.vue +172 -0
- package/edit/logging.banzaicloud.io.output/providers/newrelic.vue +71 -0
- package/edit/logging.banzaicloud.io.output/providers/opensearch.vue +225 -0
- package/edit/logging.banzaicloud.io.output/providers/redis.vue +142 -0
- package/edit/logging.banzaicloud.io.output/providers/s3.vue +122 -0
- package/edit/logging.banzaicloud.io.output/providers/splunkHec.vue +180 -0
- package/edit/logging.banzaicloud.io.output/providers/sumologic.vue +59 -0
- package/edit/logging.banzaicloud.io.output/providers/syslog.vue +234 -0
- package/edit/logging.banzaicloud.io.output/providers/utils.js +27 -0
- package/edit/management.cattle.io.clusterroletemplatebinding.vue +71 -0
- package/edit/management.cattle.io.fleetworkspace.vue +245 -0
- package/edit/management.cattle.io.globalrole.vue +8 -0
- package/edit/management.cattle.io.node.vue +72 -0
- package/edit/management.cattle.io.podsecurityadmissionconfigurationtemplate.vue +111 -0
- package/edit/management.cattle.io.project.vue +255 -0
- package/edit/management.cattle.io.projectroletemplatebinding.vue +96 -0
- package/edit/management.cattle.io.roletemplate.vue +11 -0
- package/edit/management.cattle.io.setting.vue +264 -0
- package/edit/management.cattle.io.user.vue +289 -0
- package/edit/monitoring.coreos.com.alertmanagerconfig/auth.vue +324 -0
- package/edit/monitoring.coreos.com.alertmanagerconfig/index.vue +287 -0
- package/edit/monitoring.coreos.com.alertmanagerconfig/receiverConfig.vue +423 -0
- package/edit/monitoring.coreos.com.alertmanagerconfig/routeConfig.vue +176 -0
- package/edit/monitoring.coreos.com.alertmanagerconfig/tls.vue +272 -0
- package/edit/monitoring.coreos.com.alertmanagerconfig/types/email.vue +175 -0
- package/edit/monitoring.coreos.com.alertmanagerconfig/types/opsgenie.vue +282 -0
- package/edit/monitoring.coreos.com.alertmanagerconfig/types/pagerduty.vue +203 -0
- package/edit/monitoring.coreos.com.alertmanagerconfig/types/slack.vue +140 -0
- package/edit/monitoring.coreos.com.alertmanagerconfig/types/webhook.vue +230 -0
- package/edit/monitoring.coreos.com.prometheusrule/AlertingRule.vue +534 -0
- package/edit/monitoring.coreos.com.prometheusrule/GroupRules.vue +229 -0
- package/edit/monitoring.coreos.com.prometheusrule/RecordingRule.vue +112 -0
- package/edit/monitoring.coreos.com.prometheusrule/index.vue +223 -0
- package/edit/monitoring.coreos.com.receiver/auth.vue +142 -0
- package/edit/monitoring.coreos.com.receiver/index.vue +357 -0
- package/edit/monitoring.coreos.com.receiver/tls.vue +72 -0
- package/edit/monitoring.coreos.com.receiver/types/__tests__/email.test.ts +57 -0
- package/edit/monitoring.coreos.com.receiver/types/email.vue +130 -0
- package/edit/monitoring.coreos.com.receiver/types/opsgenie.vue +237 -0
- package/edit/monitoring.coreos.com.receiver/types/pagerduty.vue +97 -0
- package/edit/monitoring.coreos.com.receiver/types/slack.vue +88 -0
- package/edit/monitoring.coreos.com.receiver/types/webhook.add.vue +65 -0
- package/edit/monitoring.coreos.com.receiver/types/webhook.banner.vue +28 -0
- package/edit/monitoring.coreos.com.receiver/types/webhook.vue +93 -0
- package/edit/monitoring.coreos.com.route.vue +237 -0
- package/edit/namespace.vue +281 -0
- package/edit/networking.istio.io.destinationrule/LoadBalancer.vue +194 -0
- package/edit/networking.istio.io.destinationrule/index.vue +237 -0
- package/edit/networking.k8s.io.ingress/Certificate.vue +134 -0
- package/edit/networking.k8s.io.ingress/Certificates.vue +111 -0
- package/edit/networking.k8s.io.ingress/DefaultBackend.vue +145 -0
- package/edit/networking.k8s.io.ingress/IngressClass.vue +69 -0
- package/edit/networking.k8s.io.ingress/Rule.vue +188 -0
- package/edit/networking.k8s.io.ingress/RulePath.vue +224 -0
- package/edit/networking.k8s.io.ingress/Rules.vue +155 -0
- package/edit/networking.k8s.io.ingress/__tests__/IngressClass.test.ts +58 -0
- package/edit/networking.k8s.io.ingress/index.vue +300 -0
- package/edit/networking.k8s.io.networkpolicy/PolicyRule.vue +108 -0
- package/edit/networking.k8s.io.networkpolicy/PolicyRulePort.vue +50 -0
- package/edit/networking.k8s.io.networkpolicy/PolicyRuleTarget.vue +401 -0
- package/edit/networking.k8s.io.networkpolicy/PolicyRules.vue +93 -0
- package/edit/networking.k8s.io.networkpolicy/__tests__/PolicyRuleTarget.test.ts +180 -0
- package/edit/networking.k8s.io.networkpolicy/__tests__/utils/mock.json +158 -0
- package/edit/networking.k8s.io.networkpolicy/__tests__/utils/selectors.test.ts +45 -0
- package/edit/networking.k8s.io.networkpolicy/index.vue +299 -0
- package/edit/node.vue +82 -0
- package/edit/nodeDriver.vue +72 -0
- package/edit/persistentvolume/__tests__/persistentvolume.test.ts +105 -0
- package/edit/persistentvolume/index.vue +380 -0
- package/edit/persistentvolume/plugins/awsElasticBlockStore.vue +90 -0
- package/edit/persistentvolume/plugins/azureDisk.vue +136 -0
- package/edit/persistentvolume/plugins/azureFile.vue +78 -0
- package/edit/persistentvolume/plugins/cephfs.vue +109 -0
- package/edit/persistentvolume/plugins/cinder.vue +89 -0
- package/edit/persistentvolume/plugins/csi.vue +209 -0
- package/edit/persistentvolume/plugins/fc.vue +101 -0
- package/edit/persistentvolume/plugins/flexVolume.vue +102 -0
- package/edit/persistentvolume/plugins/flocker.vue +45 -0
- package/edit/persistentvolume/plugins/gcePersistentDisk.vue +90 -0
- package/edit/persistentvolume/plugins/glusterfs.vue +70 -0
- package/edit/persistentvolume/plugins/hostPath.vue +82 -0
- package/edit/persistentvolume/plugins/iscsi.vue +170 -0
- package/edit/persistentvolume/plugins/local.vue +37 -0
- package/edit/persistentvolume/plugins/longhorn.vue +99 -0
- package/edit/persistentvolume/plugins/nfs.vue +70 -0
- package/edit/persistentvolume/plugins/photonPersistentDisk.vue +58 -0
- package/edit/persistentvolume/plugins/portworxVolume.vue +71 -0
- package/edit/persistentvolume/plugins/quobyte.vue +88 -0
- package/edit/persistentvolume/plugins/rbd.vue +127 -0
- package/edit/persistentvolume/plugins/scaleIO.vue +146 -0
- package/edit/persistentvolume/plugins/storageos.vue +98 -0
- package/edit/persistentvolume/plugins/vsphereVolume.vue +63 -0
- package/edit/persistentvolumeclaim.vue +395 -0
- package/edit/pod.vue +27 -0
- package/edit/policy.poddisruptionbudget.vue +152 -0
- package/edit/provisioning.cattle.io.cluster/AgentEnv.vue +40 -0
- package/edit/provisioning.cattle.io.cluster/CustomCommand.vue +306 -0
- package/edit/provisioning.cattle.io.cluster/Labels.vue +46 -0
- package/edit/provisioning.cattle.io.cluster/SelectCredential.vue +341 -0
- package/edit/provisioning.cattle.io.cluster/__tests__/Advanced.test.ts +304 -0
- package/edit/provisioning.cattle.io.cluster/__tests__/Basics.test.ts +564 -0
- package/edit/provisioning.cattle.io.cluster/__tests__/CustomCommand.test.ts +129 -0
- package/edit/provisioning.cattle.io.cluster/__tests__/DirectoryConfig.test.ts +182 -0
- package/edit/provisioning.cattle.io.cluster/__tests__/DrainOptions.test.ts +54 -0
- package/edit/provisioning.cattle.io.cluster/__tests__/index.test.ts +72 -0
- package/edit/provisioning.cattle.io.cluster/__tests__/rke2.test.ts +546 -0
- package/edit/provisioning.cattle.io.cluster/__tests__/utils/cluster.ts +391 -0
- package/edit/provisioning.cattle.io.cluster/index.vue +733 -0
- package/edit/provisioning.cattle.io.cluster/rke2.vue +2538 -0
- package/edit/provisioning.cattle.io.cluster/tabs/AddOnAdditionalManifest.vue +49 -0
- package/edit/provisioning.cattle.io.cluster/tabs/AddOnConfig.vue +112 -0
- package/edit/provisioning.cattle.io.cluster/tabs/Advanced.vue +224 -0
- package/edit/provisioning.cattle.io.cluster/tabs/AgentConfiguration.vue +340 -0
- package/edit/provisioning.cattle.io.cluster/tabs/Basics.vue +700 -0
- package/edit/provisioning.cattle.io.cluster/tabs/DirectoryConfig.vue +219 -0
- package/edit/provisioning.cattle.io.cluster/tabs/MachinePool.vue +405 -0
- package/edit/provisioning.cattle.io.cluster/tabs/MemberRoles.vue +40 -0
- package/edit/provisioning.cattle.io.cluster/tabs/etcd/S3Config.vue +153 -0
- package/edit/provisioning.cattle.io.cluster/tabs/etcd/index.vue +138 -0
- package/edit/provisioning.cattle.io.cluster/tabs/networking/ACE.vue +73 -0
- package/edit/provisioning.cattle.io.cluster/tabs/networking/index.vue +214 -0
- package/edit/provisioning.cattle.io.cluster/tabs/registries/RegistryConfigs.vue +211 -0
- package/edit/provisioning.cattle.io.cluster/tabs/registries/RegistryMirrors.vue +138 -0
- package/edit/provisioning.cattle.io.cluster/tabs/registries/__tests__/RegistryConfigs.test.ts +66 -0
- package/edit/provisioning.cattle.io.cluster/tabs/registries/index.vue +149 -0
- package/edit/provisioning.cattle.io.cluster/tabs/upgrade/DrainOptions.vue +155 -0
- package/edit/provisioning.cattle.io.cluster/tabs/upgrade/index.vue +76 -0
- package/edit/rbac.authorization.k8s.io.clusterrole.vue +8 -0
- package/edit/rbac.authorization.k8s.io.role.vue +8 -0
- package/edit/resources.cattle.io.backup.vue +454 -0
- package/edit/resources.cattle.io.restore.vue +326 -0
- package/edit/secret/__tests__/ssh.test.ts +79 -0
- package/edit/secret/basic.vue +64 -0
- package/edit/secret/generic.vue +64 -0
- package/edit/secret/index.vue +407 -0
- package/edit/secret/registry.vue +145 -0
- package/edit/secret/ssh.vue +106 -0
- package/edit/secret/tls.vue +94 -0
- package/edit/service.vue +546 -0
- package/edit/serviceaccount.vue +193 -0
- package/edit/storage.k8s.io.storageclass/index.vue +307 -0
- package/edit/storage.k8s.io.storageclass/provisioners/custom.vue +25 -0
- package/edit/storage.k8s.io.storageclass/provisioners/driver.harvesterhci.io.vue +114 -0
- package/edit/storage.k8s.io.storageclass/provisioners/driver.longhorn.io.vue +40 -0
- package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/aws-ebs.vue +180 -0
- package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/azure-disk.vue +75 -0
- package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/azure-file.vue +47 -0
- package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/cinder.vue +69 -0
- package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/gce-pd.vue +117 -0
- package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/glusterfs.vue +99 -0
- package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/no-provisioner.vue +21 -0
- package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/portworx-volume.vue +83 -0
- package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/quobyte.vue +91 -0
- package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/rbd.vue +117 -0
- package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/scaleio.vue +116 -0
- package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/storageos.vue +65 -0
- package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/vsphere-volume.vue +97 -0
- package/edit/token.vue +337 -0
- package/edit/ui.cattle.io.navlink.vue +461 -0
- package/edit/workload/Job.vue +339 -0
- package/edit/workload/Upgrading.vue +372 -0
- package/edit/workload/VolumeClaimTemplate.vue +136 -0
- package/edit/workload/__tests__/Job.test.ts +71 -0
- package/edit/workload/__tests__/Upgrading.test.ts +61 -0
- package/edit/workload/__tests__/index.test.ts +103 -0
- package/edit/workload/index.vue +677 -0
- package/edit/workload/mixins/workload.js +1067 -0
- package/edit/workload/storage/ContainerMountPaths.vue +171 -0
- package/edit/workload/storage/Mount.vue +157 -0
- package/edit/workload/storage/__tests__/Mount.test.ts +102 -0
- package/edit/workload/storage/__tests__/Storage.test.ts +106 -0
- package/edit/workload/storage/awsElasticBlockStore.vue +73 -0
- package/edit/workload/storage/azureDisk.vue +104 -0
- package/edit/workload/storage/azureFile.vue +74 -0
- package/edit/workload/storage/csi/driver.longhorn.io.vue +48 -0
- package/edit/workload/storage/csi/index.vue +122 -0
- package/edit/workload/storage/emptyDir.vue +88 -0
- package/edit/workload/storage/ephemeralVolume/index.vue +108 -0
- package/edit/workload/storage/gcePersistentDisk.vue +73 -0
- package/edit/workload/storage/hostPath.vue +115 -0
- package/edit/workload/storage/index.vue +339 -0
- package/edit/workload/storage/nfs.vue +78 -0
- package/edit/workload/storage/persistentVolumeClaim/__tests__/persistentvolumeclaim.test.ts +38 -0
- package/edit/workload/storage/persistentVolumeClaim/index.vue +154 -0
- package/edit/workload/storage/persistentVolumeClaim/persistentvolumeclaim.vue +256 -0
- package/edit/workload/storage/secret.vue +186 -0
- package/edit/workload/storage/vsphereVolume.vue +73 -0
- package/initialize/App.vue +70 -0
- package/initialize/app-extended.js +112 -0
- package/initialize/entry-helpers.js +147 -0
- package/initialize/entry.js +33 -0
- package/initialize/install-components.js +11 -0
- package/initialize/install-directives.js +61 -0
- package/initialize/install-plugins.js +129 -0
- package/list/__tests__/workload.test.ts +55 -0
- package/list/catalog.cattle.io.app.vue +76 -0
- package/list/catalog.cattle.io.clusterrepo.vue +83 -0
- package/list/cis.cattle.io.clusterscan.vue +76 -0
- package/list/fleet.cattle.io.bundle.vue +127 -0
- package/list/fleet.cattle.io.cluster.vue +95 -0
- package/list/fleet.cattle.io.clustergroup.vue +88 -0
- package/list/fleet.cattle.io.clusterregistrationtoken.vue +94 -0
- package/list/fleet.cattle.io.gitrepo.vue +108 -0
- package/list/group.principal.vue +153 -0
- package/list/harvesterhci.io.management.cluster.vue +247 -0
- package/list/helm.cattle.io.projecthelmchart.vue +157 -0
- package/list/logging.banzaicloud.io.clusterflow.vue +44 -0
- package/list/logging.banzaicloud.io.flow.vue +45 -0
- package/list/management.cattle.io.cluster.vue +54 -0
- package/list/management.cattle.io.feature.vue +368 -0
- package/list/management.cattle.io.fleetworkspace.vue +44 -0
- package/list/management.cattle.io.podsecurityadmissionconfigurationtemplate.vue +51 -0
- package/list/management.cattle.io.setting.vue +117 -0
- package/list/management.cattle.io.user.vue +178 -0
- package/list/monitoring.coreos.com.alertmanagerconfig.vue +83 -0
- package/list/namespace.vue +81 -0
- package/list/networking.k8s.io.ingress.vue +39 -0
- package/list/node.vue +418 -0
- package/list/persistentvolume.vue +89 -0
- package/list/persistentvolumeclaim.vue +32 -0
- package/list/provisioning.cattle.io.cluster.vue +326 -0
- package/list/rbac.authorization.k8s.io.clusterrolebinding.vue +47 -0
- package/list/service.vue +48 -0
- package/list/ui.cattle.io.navlink.vue +72 -0
- package/list/workload.vue +188 -0
- package/machine-config/__tests__/vmwarevsphere.test.ts +302 -0
- package/machine-config/amazonec2.vue +702 -0
- package/machine-config/azure.vue +913 -0
- package/machine-config/digitalocean.vue +231 -0
- package/machine-config/generic.vue +103 -0
- package/machine-config/linode.vue +189 -0
- package/machine-config/pnap.vue +288 -0
- package/machine-config/vmwarevsphere-config.ts +17 -0
- package/machine-config/vmwarevsphere.vue +1268 -0
- package/mixins/__tests__/auth-config.test.ts +74 -0
- package/mixins/__tests__/chart.test.ts +104 -0
- package/mixins/__tests__/create-edit-view.test.ts +56 -0
- package/mixins/auth-config.js +332 -0
- package/mixins/back-link.js +15 -0
- package/mixins/brand.js +211 -0
- package/mixins/browser-tab-visibility.js +31 -0
- package/mixins/chart.js +557 -0
- package/mixins/child-hook.js +82 -0
- package/mixins/closeable.js +47 -0
- package/mixins/compact-input.ts +25 -0
- package/mixins/create-edit-view/impl.js +201 -0
- package/mixins/create-edit-view/index.js +48 -0
- package/mixins/fetch.client.js +90 -0
- package/mixins/form-validation.js +197 -0
- package/mixins/labeled-form-element.ts +225 -0
- package/mixins/login.js +31 -0
- package/mixins/metric-poller.js +19 -0
- package/mixins/page-actions.js +36 -0
- package/mixins/resource-fetch-api-pagination.js +339 -0
- package/mixins/resource-fetch-namespaced.js +90 -0
- package/mixins/resource-fetch.js +291 -0
- package/mixins/resource-manager.js +109 -0
- package/mixins/vue-select-overrides.js +102 -0
- package/models/__tests__/apps.deployment.test.ts +93 -0
- package/models/__tests__/batch.cronjob.test.ts +88 -0
- package/models/__tests__/catalog.cattle.io.app.test.ts +148 -0
- package/models/__tests__/cluster.test.ts +44 -0
- package/models/__tests__/fleet.cattle.io.cluster.test.ts +36 -0
- package/models/__tests__/fleet.cattle.io.gitrepo.test.ts +157 -0
- package/models/__tests__/logging.banzaicloud.io.flow.test.ts +88 -0
- package/models/__tests__/management.cattle.io.cluster.test.ts +23 -0
- package/models/__tests__/management.cattle.io.node.ts +181 -0
- package/models/__tests__/management.cattle.io.nodepool.ts +83 -0
- package/models/__tests__/namespace.test.ts +189 -0
- package/models/__tests__/node.test.ts +74 -0
- package/models/__tests__/provisioning.cattle.io.cluster.test.ts +155 -0
- package/models/__tests__/schema.tests.ts +24 -0
- package/models/__tests__/secret.test.ts +80 -0
- package/models/__tests__/steve-schema.test.ts +73 -0
- package/models/__tests__/storage.k8s.io.storageclass.test.ts +22 -0
- package/models/__tests__/workload.test.ts +91 -0
- package/models/app.js +25 -0
- package/models/apps.controllerrevision.js +7 -0
- package/models/apps.daemonset.js +22 -0
- package/models/apps.deployment.js +71 -0
- package/models/apps.replicaset.js +11 -0
- package/models/apps.statefulset.js +49 -0
- package/models/autoscaling.horizontalpodautoscaler.js +44 -0
- package/models/batch.cronjob.js +85 -0
- package/models/batch.job.js +19 -0
- package/models/catalog.cattle.io.app.js +488 -0
- package/models/catalog.cattle.io.clusterrepo.js +223 -0
- package/models/catalog.cattle.io.operation.js +43 -0
- package/models/catalog.cattle.io.repo.js +4 -0
- package/models/catalog.cattle.io.uiplugin.js +37 -0
- package/models/chart.js +50 -0
- package/models/chartinstallaction.js +17 -0
- package/models/chartupgradeaction.js +12 -0
- package/models/cis.cattle.io.clusterscan.js +179 -0
- package/models/cis.cattle.io.clusterscanbenchmark.js +18 -0
- package/models/cis.cattle.io.clusterscanprofile.js +31 -0
- package/models/cis.cattle.io.clusterscanreport.js +62 -0
- package/models/cloudcredential.js +341 -0
- package/models/cluster/node.js +487 -0
- package/models/cluster/schema.js +6 -0
- package/models/cluster.js +44 -0
- package/models/cluster.x-k8s.io.machine.js +272 -0
- package/models/cluster.x-k8s.io.machinedeployment.js +228 -0
- package/models/cluster.x-k8s.io.machineset.js +23 -0
- package/models/clusterroletemplatebinding.js +31 -0
- package/models/configmap.js +20 -0
- package/models/constraints.gatekeeper.sh.constraint.js +121 -0
- package/models/driver.js +63 -0
- package/models/etcdbackup.js +45 -0
- package/models/event.js +34 -0
- package/models/fleet.cattle.io.bundle.js +168 -0
- package/models/fleet.cattle.io.cluster.js +221 -0
- package/models/fleet.cattle.io.clustergroup.js +62 -0
- package/models/fleet.cattle.io.clusterregistrationtoken.js +14 -0
- package/models/fleet.cattle.io.gitrepo.js +548 -0
- package/models/group.principal.js +71 -0
- package/models/helm.cattle.io.projecthelmchart.js +38 -0
- package/models/k8s.cni.cncf.io.networkattachmentdefinition.js +88 -0
- package/models/kontainerdriver.js +88 -0
- package/models/logging.banzaicloud.io.clusterflow.js +36 -0
- package/models/logging.banzaicloud.io.clusteroutput.js +4 -0
- package/models/logging.banzaicloud.io.flow.js +115 -0
- package/models/logging.banzaicloud.io.output.js +173 -0
- package/models/management/schema.js +6 -0
- package/models/management.cattle.io.authconfig.js +70 -0
- package/models/management.cattle.io.cluster.js +501 -0
- package/models/management.cattle.io.clusterroletemplatebinding.js +143 -0
- package/models/management.cattle.io.feature.js +56 -0
- package/models/management.cattle.io.fleetworkspace.js +90 -0
- package/models/management.cattle.io.gitreporestriction.js +5 -0
- package/models/management.cattle.io.globalrole.js +172 -0
- package/models/management.cattle.io.globalrolebinding.js +59 -0
- package/models/management.cattle.io.kontainerdriver.js +90 -0
- package/models/management.cattle.io.node.js +179 -0
- package/models/management.cattle.io.nodepool.js +185 -0
- package/models/management.cattle.io.nodetemplate.js +139 -0
- package/models/management.cattle.io.podsecurityadmissionconfigurationtemplate.js +3 -0
- package/models/management.cattle.io.project.js +182 -0
- package/models/management.cattle.io.projectroletemplatebinding.js +150 -0
- package/models/management.cattle.io.roletemplate.js +216 -0
- package/models/management.cattle.io.setting.js +72 -0
- package/models/management.cattle.io.user.js +302 -0
- package/models/metrics.k8s.io.nodemetrics.js +41 -0
- package/models/monitoring.coreos.com.alertmanagerconfig.js +126 -0
- package/models/monitoring.coreos.com.podmonitor.js +23 -0
- package/models/monitoring.coreos.com.prometheusrule.js +38 -0
- package/models/monitoring.coreos.com.receiver.js +197 -0
- package/models/monitoring.coreos.com.route.js +162 -0
- package/models/monitoring.coreos.com.servicemonitor.js +23 -0
- package/models/namespace.js +261 -0
- package/models/networking.istio.io.destinationrule.js +19 -0
- package/models/networking.k8s.io.ingress.js +209 -0
- package/models/nodedriver.js +96 -0
- package/models/persistentvolume.js +43 -0
- package/models/persistentvolumeclaim.js +63 -0
- package/models/pod.js +279 -0
- package/models/principal.js +42 -0
- package/models/projectroletemplatebinding.js +35 -0
- package/models/provisioning.cattle.io.cluster.js +1091 -0
- package/models/rbac.authorization.k8s.io.clusterrole.js +17 -0
- package/models/rbac.authorization.k8s.io.clusterrolebinding.js +16 -0
- package/models/rbac.authorization.k8s.io.role.js +52 -0
- package/models/rbac.authorization.k8s.io.rolebinding.js +16 -0
- package/models/replicationcontroller.js +4 -0
- package/models/resources.cattle.io.backup.js +29 -0
- package/models/resources.cattle.io.restore.js +33 -0
- package/models/rke-machine-config.cattle.io.harvesterconfig.js +19 -0
- package/models/rke-machine.cattle.io.amazonec2machinetemplate.js +15 -0
- package/models/rke-machine.cattle.io.azuremachinetemplate.js +15 -0
- package/models/rke-machine.cattle.io.digitaloceanmachinetemplate.js +15 -0
- package/models/rke-machine.cattle.io.linodemachinetemplate.js +15 -0
- package/models/rke-machine.cattle.io.machinetemplate.js +22 -0
- package/models/rke-machine.cattle.io.pnapmachinetemplate.js +15 -0
- package/models/rke-machine.cattle.io.vmwarevspheremachinetemplate.js +14 -0
- package/models/rke.cattle.io.etcdsnapshot.js +76 -0
- package/models/schema.js +38 -0
- package/models/secret.js +473 -0
- package/models/service.js +193 -0
- package/models/steve-schema.ts +254 -0
- package/models/storage.k8s.io.storageclass.js +164 -0
- package/models/templates.gatekeeper.sh.constrainttemplate.js +23 -0
- package/models/token.js +19 -0
- package/models/ui.cattle.io.navlink.js +38 -0
- package/models/workload.js +691 -0
- package/models/workload.service.js +341 -0
- package/package.json +173 -0
- package/pages/404.vue +15 -0
- package/pages/__tests__/prefs.test.ts +96 -0
- package/pages/about.vue +311 -0
- package/pages/account/create-key.vue +16 -0
- package/pages/account/index.vue +308 -0
- package/pages/account/pri.vue +229 -0
- package/pages/auth/login.vue +742 -0
- package/pages/auth/logout.vue +47 -0
- package/pages/auth/setup.vue +646 -0
- package/pages/auth/verify.vue +203 -0
- package/pages/auth copy/login.vue +595 -0
- package/pages/auth copy/logout.vue +47 -0
- package/pages/auth copy/setup.vue +523 -0
- package/pages/auth copy/verify.vue +203 -0
- package/pages/c/_cluster/_product/_resource/_id.vue +12 -0
- package/pages/c/_cluster/_product/_resource/_namespace/_id.vue +12 -0
- package/pages/c/_cluster/_product/_resource/create.vue +12 -0
- package/pages/c/_cluster/_product/_resource/index.vue +12 -0
- package/pages/c/_cluster/_product/index.vue +15 -0
- package/pages/c/_cluster/_product/members/index.vue +8 -0
- package/pages/c/_cluster/_product/namespaces.vue +77 -0
- package/pages/c/_cluster/_product/projectsnamespaces.vue +6 -0
- package/pages/c/_cluster/apps/charts/__tests__/install.helper.test.ts +18 -0
- package/pages/c/_cluster/apps/charts/chart.vue +452 -0
- package/pages/c/_cluster/apps/charts/index.vue +718 -0
- package/pages/c/_cluster/apps/charts/install.helpers.js +15 -0
- package/pages/c/_cluster/apps/charts/install.vue +2050 -0
- package/pages/c/_cluster/auth/config/_id.vue +35 -0
- package/pages/c/_cluster/auth/config/index.vue +114 -0
- package/pages/c/_cluster/auth/group.principal/assign-edit.vue +138 -0
- package/pages/c/_cluster/auth/roles/_resource/_id.vue +12 -0
- package/pages/c/_cluster/auth/roles/_resource/create.vue +12 -0
- package/pages/c/_cluster/auth/roles/index.vue +215 -0
- package/pages/c/_cluster/auth/user.retention/index.vue +323 -0
- package/pages/c/_cluster/ecm/index.vue +14 -0
- package/pages/c/_cluster/explorer/ConfigBadge.vue +64 -0
- package/pages/c/_cluster/explorer/EventsTable.vue +126 -0
- package/pages/c/_cluster/explorer/__tests__/index.test.ts +264 -0
- package/pages/c/_cluster/explorer/explorer-utils.js +17 -0
- package/pages/c/_cluster/explorer/index.vue +1004 -0
- package/pages/c/_cluster/explorer/tools/__tests__/index.test.ts +71 -0
- package/pages/c/_cluster/explorer/tools/index.vue +397 -0
- package/pages/c/_cluster/explorer/tools/pages/_page.vue +29 -0
- package/pages/c/_cluster/fleet/GitRepoGraphConfig.js +249 -0
- package/pages/c/_cluster/fleet/index.vue +506 -0
- package/pages/c/_cluster/gatekeeper/constraints/index.vue +90 -0
- package/pages/c/_cluster/gatekeeper/index.vue +78 -0
- package/pages/c/_cluster/istio/index.vue +149 -0
- package/pages/c/_cluster/legacy/pages/_page.vue +29 -0
- package/pages/c/_cluster/legacy/project/_page.vue +57 -0
- package/pages/c/_cluster/legacy/project/index.vue +32 -0
- package/pages/c/_cluster/legacy/project/pipelines.vue +96 -0
- package/pages/c/_cluster/logging/index.vue +94 -0
- package/pages/c/_cluster/longhorn/__tests__/longhorn.index.test.ts +92 -0
- package/pages/c/_cluster/longhorn/index.vue +107 -0
- package/pages/c/_cluster/manager/cloudCredential/_id.vue +15 -0
- package/pages/c/_cluster/manager/cloudCredential/create.vue +15 -0
- package/pages/c/_cluster/manager/cloudCredential/index.vue +158 -0
- package/pages/c/_cluster/manager/drivers/kontainerDriver/_id.vue +12 -0
- package/pages/c/_cluster/manager/drivers/kontainerDriver/create.vue +15 -0
- package/pages/c/_cluster/manager/drivers/kontainerDriver/index.vue +91 -0
- package/pages/c/_cluster/manager/drivers/nodeDriver/_id.vue +12 -0
- package/pages/c/_cluster/manager/drivers/nodeDriver/create.vue +15 -0
- package/pages/c/_cluster/manager/drivers/nodeDriver/index.vue +60 -0
- package/pages/c/_cluster/manager/jwt.authentication/index.vue +244 -0
- package/pages/c/_cluster/manager/pages/_page.vue +22 -0
- package/pages/c/_cluster/mcapps/pages/_page.vue +22 -0
- package/pages/c/_cluster/monitoring/alertmanagerconfig/_alertmanagerconfigid/index.vue +12 -0
- package/pages/c/_cluster/monitoring/alertmanagerconfig/_alertmanagerconfigid/receiver.vue +320 -0
- package/pages/c/_cluster/monitoring/alertmanagerconfig/index.vue +24 -0
- package/pages/c/_cluster/monitoring/index.vue +202 -0
- package/pages/c/_cluster/monitoring/monitor/_namespace/_id.vue +21 -0
- package/pages/c/_cluster/monitoring/monitor/create.vue +29 -0
- package/pages/c/_cluster/monitoring/monitor/index.vue +99 -0
- package/pages/c/_cluster/monitoring/route-receiver/_id.vue +29 -0
- package/pages/c/_cluster/monitoring/route-receiver/create.vue +22 -0
- package/pages/c/_cluster/monitoring/route-receiver/index.vue +133 -0
- package/pages/c/_cluster/navlinks/_group.vue +42 -0
- package/pages/c/_cluster/neuvector/index.vue +75 -0
- package/pages/c/_cluster/settings/DefaultLinksEditor.vue +128 -0
- package/pages/c/_cluster/settings/banners.vue +361 -0
- package/pages/c/_cluster/settings/brand.vue +648 -0
- package/pages/c/_cluster/settings/index.vue +20 -0
- package/pages/c/_cluster/settings/links.vue +167 -0
- package/pages/c/_cluster/settings/performance.vue +515 -0
- package/pages/c/_cluster/uiplugins/AddExtensionRepos.vue +175 -0
- package/pages/c/_cluster/uiplugins/CatalogList/CatalogLoadDialog.vue +551 -0
- package/pages/c/_cluster/uiplugins/CatalogList/CatalogUninstallDialog.vue +193 -0
- package/pages/c/_cluster/uiplugins/CatalogList/index.vue +132 -0
- package/pages/c/_cluster/uiplugins/DeveloperInstallDialog.vue +261 -0
- package/pages/c/_cluster/uiplugins/InstallDialog.vue +366 -0
- package/pages/c/_cluster/uiplugins/PluginInfoPanel.vue +503 -0
- package/pages/c/_cluster/uiplugins/SetupUIPlugins.vue +83 -0
- package/pages/c/_cluster/uiplugins/UninstallDialog.vue +152 -0
- package/pages/c/_cluster/uiplugins/__tests__/AddExtensionRepos.test.ts +76 -0
- package/pages/c/_cluster/uiplugins/__tests__/SetupUIPlugins.test.ts +77 -0
- package/pages/c/_cluster/uiplugins/index.vue +1288 -0
- package/pages/clusters/index.vue +21 -0
- package/pages/diagnostic.vue +580 -0
- package/pages/fail-whale.vue +203 -0
- package/pages/home.vue +854 -0
- package/pages/index.vue +54 -0
- package/pages/prefs.vue +369 -0
- package/pages/support/index.vue +266 -0
- package/pkg/auto-import.js +118 -0
- package/pkg/babel.config.js +8 -0
- package/pkg/dynamic-importer.lib.js +82 -0
- package/pkg/dynamic-plugin-loader.js +28 -0
- package/pkg/import.js +10 -0
- package/pkg/model-loader-require.lib.js +3 -0
- package/pkg/tsconfig.json +65 -0
- package/pkg/vue.config.js +146 -0
- package/plugins/axios.js +31 -0
- package/plugins/clean-html.js +103 -0
- package/plugins/codemirror-loader.js +5 -0
- package/plugins/codemirror.js +359 -0
- package/plugins/dashboard-store/__tests__/actions.test.ts +250 -0
- package/plugins/dashboard-store/__tests__/getters.test.ts +100 -0
- package/plugins/dashboard-store/__tests__/mutations.test.ts +391 -0
- package/plugins/dashboard-store/__tests__/resource-class.test.ts +49 -0
- package/plugins/dashboard-store/__tests__/utils/store-mocks.ts +7 -0
- package/plugins/dashboard-store/actions.js +784 -0
- package/plugins/dashboard-store/classify.js +18 -0
- package/plugins/dashboard-store/getters.js +457 -0
- package/plugins/dashboard-store/index.js +53 -0
- package/plugins/dashboard-store/model-loader-require.js +12 -0
- package/plugins/dashboard-store/model-loader.js +76 -0
- package/plugins/dashboard-store/mutations.js +548 -0
- package/plugins/dashboard-store/normalize.js +50 -0
- package/plugins/dashboard-store/resource-class.js +1904 -0
- package/plugins/ember-cookie.js +13 -0
- package/plugins/extend-router.js +80 -0
- package/plugins/floating-vue.js +1 -0
- package/plugins/formatters.js +15 -0
- package/plugins/global-formatters.js +20 -0
- package/plugins/i18n.js +136 -0
- package/plugins/internal-api/index.ts +37 -0
- package/plugins/internal-api/shared/base-api.ts +13 -0
- package/plugins/internal-api/shell/shell.api.ts +108 -0
- package/plugins/js-yaml.js +4 -0
- package/plugins/nuxt-client-init.js +3 -0
- package/plugins/plugin.js +93 -0
- package/plugins/replaceall.js +19 -0
- package/plugins/shortkey.js +282 -0
- package/plugins/steve/__tests__/getters.test.ts +214 -0
- package/plugins/steve/__tests__/header-warnings.test.ts +238 -0
- package/plugins/steve/__tests__/mutations.test.ts +50 -0
- package/plugins/steve/__tests__/resource-utils.test.ts +159 -0
- package/plugins/steve/__tests__/steve-class.test.ts +59 -0
- package/plugins/steve/__tests__/subscribe.spec.ts +109 -0
- package/plugins/steve/__tests__/utils/mutation.test.helpers.ts +105 -0
- package/plugins/steve/__tests__/utils/steve-mocks.ts +31 -0
- package/plugins/steve/accept-or-reject-socket-message.ts +103 -0
- package/plugins/steve/actions.js +386 -0
- package/plugins/steve/caches/resourceCache.js +60 -0
- package/plugins/steve/getters.js +342 -0
- package/plugins/steve/header-warnings.ts +91 -0
- package/plugins/steve/hybrid-class.js +102 -0
- package/plugins/steve/index.js +76 -0
- package/plugins/steve/mutations.js +210 -0
- package/plugins/steve/norman-class.js +198 -0
- package/plugins/steve/performanceTesting.js +128 -0
- package/plugins/steve/projectAndNamespaceFiltering.utils.ts +80 -0
- package/plugins/steve/resource-utils.ts +38 -0
- package/plugins/steve/resourceWatcher.js +251 -0
- package/plugins/steve/schema.d.ts +22 -0
- package/plugins/steve/schema.utils.js +25 -0
- package/plugins/steve/steve-class.js +61 -0
- package/plugins/steve/steve-description-class.js +36 -0
- package/plugins/steve/steve-pagination-utils.ts +513 -0
- package/plugins/steve/subscribe.js +1092 -0
- package/plugins/steve/worker/index.js +24 -0
- package/plugins/steve/worker/web-worker.advanced.js +320 -0
- package/plugins/steve/worker/web-worker.basic.js +116 -0
- package/plugins/steve-create-worker.js +14 -0
- package/plugins/version.js +11 -0
- package/promptRemove/management.cattle.io.fleetworkspace.vue +98 -0
- package/promptRemove/management.cattle.io.globalrole.vue +49 -0
- package/promptRemove/management.cattle.io.project.vue +131 -0
- package/promptRemove/management.cattle.io.roletemplate.vue +51 -0
- package/promptRemove/mixin/roleDeletionCheck.js +105 -0
- package/promptRemove/pod.vue +132 -0
- package/public/index.html +75 -0
- package/rancher-components/Accordion/Accordion.test.ts +45 -0
- package/rancher-components/Accordion/Accordion.vue +86 -0
- package/rancher-components/Accordion/index.ts +1 -0
- package/rancher-components/BadgeState/BadgeState.test.ts +12 -0
- package/rancher-components/BadgeState/BadgeState.vue +122 -0
- package/rancher-components/BadgeState/index.ts +1 -0
- package/rancher-components/Banner/Banner.test.ts +59 -0
- package/rancher-components/Banner/Banner.vue +261 -0
- package/rancher-components/Banner/index.ts +1 -0
- package/rancher-components/Card/Card.test.ts +37 -0
- package/rancher-components/Card/Card.vue +189 -0
- package/rancher-components/Card/index.ts +1 -0
- package/rancher-components/Form/Checkbox/Checkbox.test.ts +68 -0
- package/rancher-components/Form/Checkbox/Checkbox.vue +507 -0
- package/rancher-components/Form/Checkbox/index.ts +1 -0
- package/rancher-components/Form/LabeledInput/LabeledInput.test.ts +57 -0
- package/rancher-components/Form/LabeledInput/LabeledInput.vue +512 -0
- package/rancher-components/Form/LabeledInput/index.ts +1 -0
- package/rancher-components/Form/Radio/RadioButton.test.ts +33 -0
- package/rancher-components/Form/Radio/RadioButton.vue +328 -0
- package/rancher-components/Form/Radio/RadioGroup.test.ts +27 -0
- package/rancher-components/Form/Radio/RadioGroup.vue +305 -0
- package/rancher-components/Form/Radio/index.ts +2 -0
- package/rancher-components/Form/TextArea/TextAreaAutoGrow.vue +199 -0
- package/rancher-components/Form/TextArea/index.ts +1 -0
- package/rancher-components/Form/ToggleSwitch/ToggleSwitch.test.ts +111 -0
- package/rancher-components/Form/ToggleSwitch/ToggleSwitch.vue +197 -0
- package/rancher-components/Form/ToggleSwitch/index.ts +1 -0
- package/rancher-components/Form/index.ts +5 -0
- package/rancher-components/LabeledTooltip/LabeledTooltip.vue +152 -0
- package/rancher-components/LabeledTooltip/index.ts +1 -0
- package/rancher-components/RcButton/RcButton.test.ts +97 -0
- package/rancher-components/RcButton/RcButton.vue +96 -0
- package/rancher-components/RcButton/index.ts +2 -0
- package/rancher-components/RcButton/types.ts +18 -0
- package/rancher-components/RcDropdown/RcDropdown.vue +163 -0
- package/rancher-components/RcDropdown/RcDropdownItem.vue +122 -0
- package/rancher-components/RcDropdown/RcDropdownMenu.vue +71 -0
- package/rancher-components/RcDropdown/RcDropdownSeparator.vue +6 -0
- package/rancher-components/RcDropdown/RcDropdownTrigger.vue +52 -0
- package/rancher-components/RcDropdown/index.ts +5 -0
- package/rancher-components/RcDropdown/types.ts +49 -0
- package/rancher-components/RcDropdown/useDropdownCollection.ts +54 -0
- package/rancher-components/RcDropdown/useDropdownContext.ts +119 -0
- package/rancher-components/StringList/StringList.test.ts +754 -0
- package/rancher-components/StringList/StringList.vue +645 -0
- package/rancher-components/StringList/index.ts +1 -0
- package/scripts/.gitlab/workflows/build-extension-catalog.gitlab-ci.yml +69 -0
- package/scripts/build-pkg.sh +102 -0
- package/scripts/clean +6 -0
- package/scripts/drone-build-pkg.sh +31 -0
- package/scripts/extension/bundle +106 -0
- package/scripts/extension/helm/charts/ui-plugin-server/.helmignore +23 -0
- package/scripts/extension/helm/charts/ui-plugin-server/Chart.yaml +18 -0
- package/scripts/extension/helm/charts/ui-plugin-server/templates/_helpers.tpl +63 -0
- package/scripts/extension/helm/charts/ui-plugin-server/templates/cr.yaml +15 -0
- package/scripts/extension/helm/charts/ui-plugin-server/values.yaml +10 -0
- package/scripts/extension/helm/package/Dockerfile +27 -0
- package/scripts/extension/helm/package/nginx.conf +17 -0
- package/scripts/extension/helm/scripts/package +31 -0
- package/scripts/extension/helm/scripts/patch +128 -0
- package/scripts/extension/helm/scripts/version +31 -0
- package/scripts/extension/helmpatch +80 -0
- package/scripts/extension/parse-tag-name +39 -0
- package/scripts/extension/publish +476 -0
- package/scripts/pkgfile.js +23 -0
- package/scripts/publish-pkg.sh +18 -0
- package/scripts/publish-shell.sh +119 -0
- package/scripts/record-deps.js +37 -0
- package/scripts/serve-pkgs +71 -0
- package/scripts/sync-shell-deps +37 -0
- package/scripts/test-plugins-build.sh +246 -0
- package/scripts/typegen.sh +101 -0
- package/scripts/vue-migrate.js +686 -0
- package/server/har-file.js +205 -0
- package/server/server-middleware.js +11 -0
- package/server/server.crt +22 -0
- package/server/server.csr +16 -0
- package/server/server.key +27 -0
- package/server/v3.ext +8 -0
- package/static/favicon.ico +0 -0
- package/static/favicon.png +0 -0
- package/static/loading-indicator.html +39 -0
- package/store/__tests__/auth.test.ts +120 -0
- package/store/__tests__/catalog.test.ts +207 -0
- package/store/__tests__/index.test.ts +110 -0
- package/store/__tests__/type-map.test.ts +1122 -0
- package/store/action-menu.js +240 -0
- package/store/auth.js +409 -0
- package/store/aws.js +263 -0
- package/store/catalog.js +666 -0
- package/store/cru-resource.ts +26 -0
- package/store/customisation.js +35 -0
- package/store/digitalocean.js +198 -0
- package/store/features.js +74 -0
- package/store/github.js +109 -0
- package/store/gitlab.js +159 -0
- package/store/growl.js +98 -0
- package/store/i18n.js +356 -0
- package/store/index.js +1290 -0
- package/store/linode.js +142 -0
- package/store/modal.ts +71 -0
- package/store/plugins.js +210 -0
- package/store/pnap.js +128 -0
- package/store/prefs.js +531 -0
- package/store/resource-fetch.js +44 -0
- package/store/slideInPanel.ts +47 -0
- package/store/store-types.js +7 -0
- package/store/type-map.js +2085 -0
- package/store/type-map.utils.ts +243 -0
- package/store/uiplugins.ts +67 -0
- package/store/wm.js +95 -0
- package/tsconfig.json +48 -0
- package/tsconfig.paths.json +21 -0
- package/types/api.d.ts +1 -0
- package/types/components/labeledSelect.ts +50 -0
- package/types/components/paginatedResourceTable.ts +25 -0
- package/types/components/resourceLabeledSelect.ts +48 -0
- package/types/fleet.d.ts +1 -0
- package/types/form.ts +1 -0
- package/types/generic.ts +2 -0
- package/types/global-vue.d.ts +5 -0
- package/types/internal-api/shell/growl.d.ts +25 -0
- package/types/internal-api/shell/modal.d.ts +77 -0
- package/types/internal-api/shell/slideIn.d.ts +15 -0
- package/types/rancher/index.d.ts +9 -0
- package/types/resources/fleet.d.ts +57 -0
- package/types/resources/pod-security-admission.ts +36 -0
- package/types/resources/settings.d.ts +93 -0
- package/types/resources/userPreferences.d.ts +13 -0
- package/types/shell/index.d.ts +4694 -0
- package/types/store/dashboard-store.types.ts +46 -0
- package/types/store/pagination.types.ts +470 -0
- package/types/store/type-map.ts +30 -0
- package/types/store/vuex.d.ts +17 -0
- package/types/t.ts +1 -0
- package/types/vue-shim.d.ts +23 -0
- package/utils/__mocks__/socket.js +21 -0
- package/utils/__tests__/array.test.ts +514 -0
- package/utils/__tests__/cluster.test.ts +57 -0
- package/utils/__tests__/create-yaml.test.ts +490 -0
- package/utils/__tests__/formatter.test.ts +77 -0
- package/utils/__tests__/grafana.test.ts +44 -0
- package/utils/__tests__/kontainer.test.ts +180 -0
- package/utils/__tests__/object.test.ts +443 -0
- package/utils/__tests__/pod-security-admission.test.ts +61 -0
- package/utils/__tests__/selector.test.ts +444 -0
- package/utils/__tests__/sort.test.ts +61 -0
- package/utils/__tests__/string.test.ts +91 -0
- package/utils/__tests__/version.test.ts +18 -0
- package/utils/alertmanagerconfig.js +181 -0
- package/utils/array.ts +256 -0
- package/utils/async.ts +38 -0
- package/utils/auth.js +335 -0
- package/utils/aws.js +0 -0
- package/utils/axios.js +171 -0
- package/utils/azure.js +24 -0
- package/utils/banners.js +58 -0
- package/utils/clipboard.js +5 -0
- package/utils/cluster.js +333 -0
- package/utils/color.js +148 -0
- package/utils/computed.js +45 -0
- package/utils/config.js +4 -0
- package/utils/cookie-universal.js +10 -0
- package/utils/create-yaml.js +518 -0
- package/utils/crypto/LICENSE.txt +15 -0
- package/utils/crypto/browserHashUtils.js +51 -0
- package/utils/crypto/browserMd5.js +183 -0
- package/utils/crypto/browserSha1.js +149 -0
- package/utils/crypto/browserSha256.js +237 -0
- package/utils/crypto/index.js +181 -0
- package/utils/custom-validators.js +32 -0
- package/utils/dom.js +15 -0
- package/utils/download.js +35 -0
- package/utils/duration.js +43 -0
- package/utils/dynamic-importer.js +134 -0
- package/utils/ember-page.js +30 -0
- package/utils/error.js +211 -0
- package/utils/errorTranslate.json +1336 -0
- package/utils/favicon.js +49 -0
- package/utils/fleet.ts +191 -0
- package/utils/formatter.js +13 -0
- package/utils/gatekeeper/util.js +35 -0
- package/utils/gc/gc-interval.ts +40 -0
- package/utils/gc/gc-root-store.js +76 -0
- package/utils/gc/gc-route-changed.ts +44 -0
- package/utils/gc/gc-types.ts +21 -0
- package/utils/gc/gc.ts +282 -0
- package/utils/git.ts +92 -0
- package/utils/grafana.js +114 -0
- package/utils/ingress.ts +64 -0
- package/utils/kontainer.ts +190 -0
- package/utils/kube.js +9 -0
- package/utils/monitoring.js +63 -0
- package/utils/namespace-filter.js +43 -0
- package/utils/object.js +541 -0
- package/utils/pagination-utils.ts +176 -0
- package/utils/pagination-wrapper.ts +70 -0
- package/utils/parse-externalid.js +139 -0
- package/utils/platform.js +64 -0
- package/utils/pod-security-admission.ts +39 -0
- package/utils/poller-sequential.js +53 -0
- package/utils/poller.js +39 -0
- package/utils/position.js +172 -0
- package/utils/promise.js +115 -0
- package/utils/queue.js +70 -0
- package/utils/router.js +140 -0
- package/utils/select.js +88 -0
- package/utils/selector.js +229 -0
- package/utils/settings.ts +108 -0
- package/utils/socket.js +409 -0
- package/utils/sort.js +225 -0
- package/utils/stream.js +49 -0
- package/utils/string.js +363 -0
- package/utils/svg-filter.js +301 -0
- package/utils/time.js +121 -0
- package/utils/title.ts +3 -0
- package/utils/type-helpers.ts +9 -0
- package/utils/uiplugins.ts +319 -0
- package/utils/unit-tests/ChildRenderingRouterLinkStub.ts +36 -0
- package/utils/units.js +184 -0
- package/utils/url.ts +171 -0
- package/utils/v-sphere.ts +285 -0
- package/utils/validators/__tests__/cidr.test.ts +33 -0
- package/utils/validators/cidr.js +14 -0
- package/utils/validators/cluster-name.js +12 -0
- package/utils/validators/container-images.js +24 -0
- package/utils/validators/cron-schedule.js +14 -0
- package/utils/validators/flow-output.js +15 -0
- package/utils/validators/formRules/__tests__/index.test.ts +1218 -0
- package/utils/validators/formRules/index.ts +535 -0
- package/utils/validators/index.js +244 -0
- package/utils/validators/kubernetes-name.js +39 -0
- package/utils/validators/logging-outputs.js +11 -0
- package/utils/validators/machine-pool.ts +20 -0
- package/utils/validators/monitoring-route.js +13 -0
- package/utils/validators/pod-affinity.js +128 -0
- package/utils/validators/prometheusrule.js +76 -0
- package/utils/validators/role-template.js +27 -0
- package/utils/validators/service.js +136 -0
- package/utils/validators/setting.js +9 -0
- package/utils/version.js +128 -0
- package/utils/versions.ts +39 -0
- package/utils/width.js +39 -0
- package/utils/window.js +46 -0
- package/vue-config-helper.js +135 -0
- package/vue.config.js +645 -0
|
@@ -0,0 +1,1092 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Handles subscriptions to websockets which receive updates to resources
|
|
3
|
+
*
|
|
4
|
+
* Covers three use cases
|
|
5
|
+
* 1) Handles subscription within this file
|
|
6
|
+
* 2) Handles `cluster` subscriptions for some basic types in a web worker (SETTING.UI_PERFORMANCE advancedWorker = false)
|
|
7
|
+
* 2) Handles `cluster` subscriptions and optimisations in an advanced worker (SETTING.UI_PERFORMANCE advancedWorker = true)
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
import { addObject, clear, removeObject } from '@shell/utils/array';
|
|
11
|
+
import { get, deepToRaw } from '@shell/utils/object';
|
|
12
|
+
import { SCHEMA, MANAGEMENT } from '@shell/config/types';
|
|
13
|
+
import { SETTING } from '@shell/config/settings';
|
|
14
|
+
import { CSRF } from '@shell/config/cookies';
|
|
15
|
+
import { getPerformanceSetting } from '@shell/utils/settings';
|
|
16
|
+
import Socket, {
|
|
17
|
+
EVENT_CONNECTED,
|
|
18
|
+
EVENT_DISCONNECTED,
|
|
19
|
+
EVENT_MESSAGE,
|
|
20
|
+
// EVENT_FRAME_TIMEOUT,
|
|
21
|
+
EVENT_CONNECT_ERROR,
|
|
22
|
+
EVENT_DISCONNECT_ERROR,
|
|
23
|
+
NO_WATCH,
|
|
24
|
+
NO_SCHEMA,
|
|
25
|
+
REVISION_TOO_OLD,
|
|
26
|
+
NO_PERMS
|
|
27
|
+
} from '@shell/utils/socket';
|
|
28
|
+
import { normalizeType } from '@shell/plugins/dashboard-store/normalize';
|
|
29
|
+
import day from 'dayjs';
|
|
30
|
+
import { DATE_FORMAT, TIME_FORMAT } from '@shell/store/prefs';
|
|
31
|
+
import { escapeHtml } from '@shell/utils/string';
|
|
32
|
+
import { keyForSubscribe } from '@shell/plugins/steve/resourceWatcher';
|
|
33
|
+
import { waitFor } from '@shell/utils/async';
|
|
34
|
+
import { WORKER_MODES } from './worker';
|
|
35
|
+
import acceptOrRejectSocketMessage from './accept-or-reject-socket-message';
|
|
36
|
+
import { BLANK_CLUSTER, STORE } from '@shell/store/store-types.js';
|
|
37
|
+
import paginationUtils from '@shell/utils/pagination-utils';
|
|
38
|
+
|
|
39
|
+
// minimum length of time a disconnect notification is shown
|
|
40
|
+
const MINIMUM_TIME_NOTIFIED = 3000;
|
|
41
|
+
|
|
42
|
+
const workerQueues = {};
|
|
43
|
+
|
|
44
|
+
const supportedStores = [STORE.CLUSTER, STORE.RANCHER, STORE.MANAGEMENT];
|
|
45
|
+
|
|
46
|
+
const isWaitingForDestroy = (storeName, store) => {
|
|
47
|
+
return store.$workers[storeName]?.waitingForDestroy && store.$workers[storeName].waitingForDestroy();
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
const waitForSettingsSchema = (storeName, store) => {
|
|
51
|
+
return waitFor(() => isWaitingForDestroy(storeName, store) || !!store.getters['management/byId'](SCHEMA, MANAGEMENT.SETTING));
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
const waitForSettings = (storeName, store) => {
|
|
55
|
+
return waitFor(() => isWaitingForDestroy(storeName, store) || !!store.getters['management/byId'](MANAGEMENT.SETTING, SETTING.UI_PERFORMANCE));
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
const isAdvancedWorker = (ctx) => {
|
|
59
|
+
const { rootGetters, getters } = ctx;
|
|
60
|
+
const storeName = getters.storeName;
|
|
61
|
+
const clusterId = rootGetters.clusterId;
|
|
62
|
+
|
|
63
|
+
if (!supportedStores.includes(storeName) || (clusterId === BLANK_CLUSTER && storeName === STORE.CLUSTER)) {
|
|
64
|
+
return false;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
const perfSetting = getPerformanceSetting(rootGetters);
|
|
68
|
+
|
|
69
|
+
return perfSetting?.advancedWorker.enabled;
|
|
70
|
+
};
|
|
71
|
+
|
|
72
|
+
export async function createWorker(store, ctx) {
|
|
73
|
+
const { getters, dispatch } = ctx;
|
|
74
|
+
const storeName = getters.storeName;
|
|
75
|
+
|
|
76
|
+
store.$workers = store.$workers || {};
|
|
77
|
+
|
|
78
|
+
if (!supportedStores.includes(storeName)) {
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
if (!store.$workers[storeName]) {
|
|
83
|
+
// we know we need a worker at this point but we don't know which one so we're creating a mock interface
|
|
84
|
+
// it will simply queue up any messages for the real worker to process when it loads up
|
|
85
|
+
store.$workers[storeName] = {
|
|
86
|
+
postMessage: (msg) => {
|
|
87
|
+
if (Object.keys(msg)?.[0] === 'destroyWorker') {
|
|
88
|
+
// The worker has been destroyed before it's been set up. Flag this so we stop waiting for mgmt settings and then can destroy worker.
|
|
89
|
+
// This can occurr when the user is redirected to the log in page
|
|
90
|
+
// - workers created (but waiting)
|
|
91
|
+
// - logout is called
|
|
92
|
+
// - <store>/unsubscribe is dispatched
|
|
93
|
+
// - wait for worker object to be destroyed <-- requires initial wait to be unblocked
|
|
94
|
+
store.$workers[storeName].mode = WORKER_MODES.DESTROY_MOCK;
|
|
95
|
+
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
if (workerQueues[storeName]) {
|
|
99
|
+
workerQueues[storeName].push(msg);
|
|
100
|
+
} else {
|
|
101
|
+
workerQueues[storeName] = [msg];
|
|
102
|
+
}
|
|
103
|
+
},
|
|
104
|
+
mode: WORKER_MODES.WAITING,
|
|
105
|
+
waitingForDestroy: () => {
|
|
106
|
+
return store.$workers[storeName]?.mode === WORKER_MODES.DESTROY_MOCK;
|
|
107
|
+
},
|
|
108
|
+
destroy: () => {
|
|
109
|
+
// Similar to workerActions.destroyWorker
|
|
110
|
+
delete store.$workers[storeName];
|
|
111
|
+
}
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
await waitForSettingsSchema(storeName, store);
|
|
116
|
+
await waitForSettings(storeName, store);
|
|
117
|
+
if (store.$workers[storeName].waitingForDestroy()) {
|
|
118
|
+
store.$workers[storeName].destroy();
|
|
119
|
+
|
|
120
|
+
return;
|
|
121
|
+
}
|
|
122
|
+
const advancedWorker = isAdvancedWorker(ctx);
|
|
123
|
+
|
|
124
|
+
const workerActions = {
|
|
125
|
+
load: (resource) => {
|
|
126
|
+
queueChange(ctx, resource, true, 'Change');
|
|
127
|
+
},
|
|
128
|
+
destroyWorker: () => {
|
|
129
|
+
if (store.$workers) {
|
|
130
|
+
store.$workers[storeName].terminate();
|
|
131
|
+
delete store.$workers[storeName];
|
|
132
|
+
}
|
|
133
|
+
},
|
|
134
|
+
batchChanges: (batch) => {
|
|
135
|
+
dispatch('batchChanges', acceptOrRejectSocketMessage.validateBatchChange(ctx, batch));
|
|
136
|
+
},
|
|
137
|
+
dispatch: (msg) => {
|
|
138
|
+
dispatch(`ws.${ msg.name }`, msg);
|
|
139
|
+
},
|
|
140
|
+
redispatch: (msg) => {
|
|
141
|
+
/**
|
|
142
|
+
* because we had to queue up some messages prior to loading the worker:
|
|
143
|
+
* the basic worker will need to redispatch some of the queued messages back to the UI thread
|
|
144
|
+
*/
|
|
145
|
+
Object.entries(msg).forEach(([action, params]) => {
|
|
146
|
+
dispatch(action, params);
|
|
147
|
+
});
|
|
148
|
+
},
|
|
149
|
+
[EVENT_CONNECT_ERROR]: (e) => {
|
|
150
|
+
dispatch('error', e );
|
|
151
|
+
},
|
|
152
|
+
[EVENT_DISCONNECT_ERROR]: (e) => {
|
|
153
|
+
dispatch('error', e );
|
|
154
|
+
},
|
|
155
|
+
};
|
|
156
|
+
|
|
157
|
+
if (!store.$workers[storeName] || store.$workers[storeName].mode === WORKER_MODES.WAITING) {
|
|
158
|
+
const workerMode = advancedWorker ? WORKER_MODES.ADVANCED : WORKER_MODES.BASIC;
|
|
159
|
+
const worker = store.steveCreateWorker(workerMode);
|
|
160
|
+
|
|
161
|
+
store.$workers[storeName] = worker;
|
|
162
|
+
|
|
163
|
+
worker.postMessage({ initWorker: { storeName } });
|
|
164
|
+
|
|
165
|
+
/**
|
|
166
|
+
* Covers message from Worker to UI thread
|
|
167
|
+
*/
|
|
168
|
+
store.$workers[storeName].onmessage = (e) => {
|
|
169
|
+
/* on the off chance there's more than key in the message, we handle them in the order that they "keys" method provides which is
|
|
170
|
+
// good enough for now considering that we never send more than one message action at a time right now */
|
|
171
|
+
const messageActions = Object.keys(e?.data);
|
|
172
|
+
|
|
173
|
+
messageActions.forEach((action) => {
|
|
174
|
+
workerActions[action](e?.data[action]);
|
|
175
|
+
});
|
|
176
|
+
};
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
while (workerQueues[storeName]?.length) {
|
|
180
|
+
const message = workerQueues[storeName].shift();
|
|
181
|
+
const safeMessage = deepToRaw(message);
|
|
182
|
+
|
|
183
|
+
store.$workers[storeName].postMessage(safeMessage);
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
export function equivalentWatch(a, b) {
|
|
188
|
+
const aresourceType = a.resourceType || a.type;
|
|
189
|
+
const bresourceType = b.resourceType || b.type;
|
|
190
|
+
|
|
191
|
+
if ( aresourceType !== bresourceType ) {
|
|
192
|
+
return false;
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
if ( a.id !== b.id && (a.id || b.id) ) {
|
|
196
|
+
return false;
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
if ( a.namespace !== b.namespace && (a.namespace || b.namespace) ) {
|
|
200
|
+
return false;
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
if ( a.selector !== b.selector && (a.selector || b.selector) ) {
|
|
204
|
+
return false;
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
return true;
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
function queueChange({ getters, state, rootGetters }, { data, revision }, load, label) {
|
|
211
|
+
const type = getters.normalizeType(data.type);
|
|
212
|
+
|
|
213
|
+
const entry = getters.typeEntry(type);
|
|
214
|
+
|
|
215
|
+
if ( entry ) {
|
|
216
|
+
entry.revision = Math.max(entry.revision, parseInt(revision, 10));
|
|
217
|
+
} else {
|
|
218
|
+
return;
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
// console.log(`${ label } Event [${ state.config.namespace }]`, data.type, data.id); // eslint-disable-line no-console
|
|
222
|
+
|
|
223
|
+
if (!acceptOrRejectSocketMessage.validChange({ getters, rootGetters }, type, data)) {
|
|
224
|
+
return;
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
if ( load ) {
|
|
228
|
+
state.queue.push({
|
|
229
|
+
action: 'dispatch',
|
|
230
|
+
event: 'load',
|
|
231
|
+
body: data
|
|
232
|
+
});
|
|
233
|
+
} else {
|
|
234
|
+
const obj = getters.byId(data.type, data.id);
|
|
235
|
+
|
|
236
|
+
if ( obj ) {
|
|
237
|
+
state.queue.push({
|
|
238
|
+
action: 'commit',
|
|
239
|
+
event: 'remove',
|
|
240
|
+
body: obj
|
|
241
|
+
});
|
|
242
|
+
}
|
|
243
|
+
|
|
244
|
+
if ( type === SCHEMA ) {
|
|
245
|
+
// Clear the current records in the store when a type disappears
|
|
246
|
+
state.queue.push({
|
|
247
|
+
action: 'commit',
|
|
248
|
+
event: 'forgetType',
|
|
249
|
+
body: data.id
|
|
250
|
+
});
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
function growlsDisabled(rootGetters) {
|
|
256
|
+
return getPerformanceSetting(rootGetters)?.disableWebsocketNotification;
|
|
257
|
+
}
|
|
258
|
+
|
|
259
|
+
/**
|
|
260
|
+
* Actions that cover all cases (see file description)
|
|
261
|
+
*/
|
|
262
|
+
const sharedActions = {
|
|
263
|
+
async subscribe(ctx, opt) {
|
|
264
|
+
const {
|
|
265
|
+
state, commit, dispatch, getters, rootGetters
|
|
266
|
+
} = ctx;
|
|
267
|
+
|
|
268
|
+
// ToDo: need to keep the worker up to date on CSRF cookie
|
|
269
|
+
|
|
270
|
+
if (rootGetters['isSingleProduct']?.disableSteveSockets) {
|
|
271
|
+
return;
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
let socket = state.socket;
|
|
275
|
+
|
|
276
|
+
commit('setWantSocket', true);
|
|
277
|
+
|
|
278
|
+
state.debugSocket && console.info(`Subscribe [${ getters.storeName }]`); // eslint-disable-line no-console
|
|
279
|
+
|
|
280
|
+
const url = `${ state.config.baseUrl }/subscribe`;
|
|
281
|
+
const maxTries = growlsDisabled(rootGetters) ? null : 3;
|
|
282
|
+
const metadata = get(opt, 'metadata');
|
|
283
|
+
|
|
284
|
+
if (isAdvancedWorker(ctx)) {
|
|
285
|
+
if (!this.$workers[getters.storeName]) {
|
|
286
|
+
await createWorker(this, ctx);
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
// if the worker is in advanced mode then it'll contain it's own socket which it calls a 'watcher'
|
|
290
|
+
this.$workers[getters.storeName].postMessage({
|
|
291
|
+
createWatcher: {
|
|
292
|
+
metadata,
|
|
293
|
+
url: `${ state.config.baseUrl }/subscribe`,
|
|
294
|
+
csrf: this.$cookies.get(CSRF, { parseJSON: false }),
|
|
295
|
+
maxTries
|
|
296
|
+
}
|
|
297
|
+
});
|
|
298
|
+
} else if ( socket ) {
|
|
299
|
+
socket.setAutoReconnect(true);
|
|
300
|
+
socket.setUrl(url);
|
|
301
|
+
socket.connect(metadata);
|
|
302
|
+
} else {
|
|
303
|
+
socket = new Socket(`${ state.config.baseUrl }/subscribe`, true, null, null, maxTries);
|
|
304
|
+
|
|
305
|
+
commit('setSocket', socket);
|
|
306
|
+
socket.addEventListener(EVENT_CONNECTED, (e) => {
|
|
307
|
+
dispatch('opened', e);
|
|
308
|
+
});
|
|
309
|
+
|
|
310
|
+
socket.addEventListener(EVENT_DISCONNECTED, (e) => {
|
|
311
|
+
dispatch('closed', e);
|
|
312
|
+
});
|
|
313
|
+
|
|
314
|
+
socket.addEventListener(EVENT_CONNECT_ERROR, (e) => {
|
|
315
|
+
dispatch('error', e );
|
|
316
|
+
});
|
|
317
|
+
|
|
318
|
+
socket.addEventListener(EVENT_DISCONNECT_ERROR, (e) => {
|
|
319
|
+
dispatch('error', e );
|
|
320
|
+
});
|
|
321
|
+
|
|
322
|
+
socket.addEventListener(EVENT_MESSAGE, (e) => {
|
|
323
|
+
const event = e.detail;
|
|
324
|
+
|
|
325
|
+
if ( event.data) {
|
|
326
|
+
const msg = JSON.parse(event.data);
|
|
327
|
+
|
|
328
|
+
if (msg.name) {
|
|
329
|
+
dispatch(`ws.${ msg.name }`, msg);
|
|
330
|
+
}
|
|
331
|
+
}
|
|
332
|
+
});
|
|
333
|
+
socket.connect(metadata);
|
|
334
|
+
}
|
|
335
|
+
},
|
|
336
|
+
|
|
337
|
+
unsubscribe({ commit, getters, state }) {
|
|
338
|
+
const socket = state.socket;
|
|
339
|
+
|
|
340
|
+
commit('setWantSocket', false);
|
|
341
|
+
const cleanupTasks = [];
|
|
342
|
+
|
|
343
|
+
const worker = (this.$workers || {})[getters.storeName];
|
|
344
|
+
|
|
345
|
+
if (worker) {
|
|
346
|
+
worker.postMessage({ destroyWorker: true }); // we're only passing the boolean here because the key needs to be something truthy to ensure it's passed on the object.
|
|
347
|
+
cleanupTasks.push(waitFor(() => !this.$workers[getters.storeName], 'Worker is destroyed'));
|
|
348
|
+
}
|
|
349
|
+
|
|
350
|
+
if ( socket ) {
|
|
351
|
+
cleanupTasks.push(socket.disconnect());
|
|
352
|
+
}
|
|
353
|
+
|
|
354
|
+
return Promise.all(cleanupTasks);
|
|
355
|
+
},
|
|
356
|
+
|
|
357
|
+
watch({
|
|
358
|
+
state, dispatch, getters, rootGetters
|
|
359
|
+
}, params) {
|
|
360
|
+
state.debugSocket && console.info(`Watch Request [${ getters.storeName }]`, JSON.stringify(params)); // eslint-disable-line no-console
|
|
361
|
+
|
|
362
|
+
let {
|
|
363
|
+
// eslint-disable-next-line prefer-const
|
|
364
|
+
type, selector, id, revision, namespace, stop, force
|
|
365
|
+
} = params;
|
|
366
|
+
|
|
367
|
+
namespace = acceptOrRejectSocketMessage.subscribeNamespace(namespace);
|
|
368
|
+
type = getters.normalizeType(type);
|
|
369
|
+
|
|
370
|
+
if (rootGetters['type-map/isSpoofed'](type)) {
|
|
371
|
+
state.debugSocket && console.info('Will not Watch (type is spoofed)', JSON.stringify(params)); // eslint-disable-line no-console
|
|
372
|
+
|
|
373
|
+
return;
|
|
374
|
+
}
|
|
375
|
+
|
|
376
|
+
const schema = getters.schemaFor(type, false, false);
|
|
377
|
+
|
|
378
|
+
if (!!schema?.attributes?.verbs?.includes && !schema.attributes.verbs.includes('watch')) {
|
|
379
|
+
state.debugSocket && console.info('Will not Watch (type does not have watch verb)', JSON.stringify(params)); // eslint-disable-line no-console
|
|
380
|
+
|
|
381
|
+
return;
|
|
382
|
+
}
|
|
383
|
+
|
|
384
|
+
// If socket is in error don't try to watch.... unless we `force` it
|
|
385
|
+
const inError = getters.inError(params);
|
|
386
|
+
|
|
387
|
+
if ( !stop && !force && inError ) {
|
|
388
|
+
// REVISION_TOO_OLD is a temporary state and will be handled when `resyncWatch` completes
|
|
389
|
+
if (inError !== REVISION_TOO_OLD) {
|
|
390
|
+
console.error(`Aborting Watch Request [${ getters.storeName }]. Watcher in error (${ inError })`, JSON.stringify(params)); // eslint-disable-line no-console
|
|
391
|
+
}
|
|
392
|
+
|
|
393
|
+
return;
|
|
394
|
+
}
|
|
395
|
+
|
|
396
|
+
if ( !stop && getters.watchStarted({
|
|
397
|
+
type, id, selector, namespace
|
|
398
|
+
}) ) {
|
|
399
|
+
// eslint-disable-next-line no-console
|
|
400
|
+
state.debugSocket && console.debug(`Already Watching [${ getters.storeName }]`, {
|
|
401
|
+
type, id, selector, namespace
|
|
402
|
+
});
|
|
403
|
+
|
|
404
|
+
return;
|
|
405
|
+
}
|
|
406
|
+
|
|
407
|
+
// isSteveCacheEnabled check is temporary and will be removed once Part 3 of https://github.com/rancher/dashboard/pull/10349 is resolved by backend
|
|
408
|
+
// Steve cache backed api does not return a revision, so `revision` here is always undefined
|
|
409
|
+
// Which means we find a revision within a resource itself and use it in the watch
|
|
410
|
+
// That revision is probably too old and results in a watch error
|
|
411
|
+
// Watch errors mean we make a http request to get latest revision (which is still missing) and try to re-watch with it...
|
|
412
|
+
// etc
|
|
413
|
+
if (typeof revision === 'undefined' && !paginationUtils.isSteveCacheEnabled({ rootGetters })) {
|
|
414
|
+
revision = getters.nextResourceVersion(type, id);
|
|
415
|
+
}
|
|
416
|
+
|
|
417
|
+
const msg = { resourceType: type };
|
|
418
|
+
|
|
419
|
+
if ( revision ) {
|
|
420
|
+
msg.resourceVersion = `${ revision }`;
|
|
421
|
+
}
|
|
422
|
+
|
|
423
|
+
if ( namespace ) {
|
|
424
|
+
msg.namespace = namespace;
|
|
425
|
+
}
|
|
426
|
+
|
|
427
|
+
if ( stop ) {
|
|
428
|
+
msg.stop = true;
|
|
429
|
+
}
|
|
430
|
+
|
|
431
|
+
if ( id ) {
|
|
432
|
+
msg.id = id;
|
|
433
|
+
}
|
|
434
|
+
|
|
435
|
+
if ( selector ) {
|
|
436
|
+
msg.selector = selector;
|
|
437
|
+
}
|
|
438
|
+
|
|
439
|
+
const worker = this.$workers?.[getters.storeName] || {};
|
|
440
|
+
|
|
441
|
+
if (worker.mode === WORKER_MODES.ADVANCED || worker.mode === WORKER_MODES.WAITING) {
|
|
442
|
+
if ( force ) {
|
|
443
|
+
msg.force = true;
|
|
444
|
+
}
|
|
445
|
+
|
|
446
|
+
worker.postMessage({ watch: msg });
|
|
447
|
+
|
|
448
|
+
return;
|
|
449
|
+
}
|
|
450
|
+
|
|
451
|
+
return dispatch('send', msg);
|
|
452
|
+
},
|
|
453
|
+
|
|
454
|
+
unwatch(ctx, {
|
|
455
|
+
type, id, namespace, selector, all
|
|
456
|
+
}) {
|
|
457
|
+
const { commit, getters, dispatch } = ctx;
|
|
458
|
+
|
|
459
|
+
if (getters['schemaFor'](type)) {
|
|
460
|
+
namespace = acceptOrRejectSocketMessage.subscribeNamespace(namespace);
|
|
461
|
+
|
|
462
|
+
const obj = {
|
|
463
|
+
type,
|
|
464
|
+
id,
|
|
465
|
+
namespace,
|
|
466
|
+
selector,
|
|
467
|
+
stop: true, // Stops the watch on a type
|
|
468
|
+
};
|
|
469
|
+
|
|
470
|
+
const unwatch = (obj) => {
|
|
471
|
+
if (getters['watchStarted'](obj)) {
|
|
472
|
+
// Set that we don't want to watch this type
|
|
473
|
+
// Otherwise, the dispatch to unwatch below will just cause a re-watch when we
|
|
474
|
+
// detect the stop message from the backend over the web socket
|
|
475
|
+
commit('setWatchStopped', obj);
|
|
476
|
+
dispatch('watch', obj); // Ask the backend to stop watching the type
|
|
477
|
+
// Make sure anything in the pending queue for the type is removed, since we've now removed the type
|
|
478
|
+
commit('clearFromQueue', type);
|
|
479
|
+
}
|
|
480
|
+
};
|
|
481
|
+
|
|
482
|
+
if (isAdvancedWorker(ctx)) {
|
|
483
|
+
dispatch('watch', obj); // Ask the backend to stop watching the type
|
|
484
|
+
} else if (all) {
|
|
485
|
+
getters['watchesOfType'](type).forEach((obj) => {
|
|
486
|
+
unwatch(obj);
|
|
487
|
+
});
|
|
488
|
+
} else if (getters['watchStarted'](obj)) {
|
|
489
|
+
unwatch(obj);
|
|
490
|
+
}
|
|
491
|
+
}
|
|
492
|
+
},
|
|
493
|
+
|
|
494
|
+
'ws.ping'({ getters, dispatch }, msg) {
|
|
495
|
+
if ( getters.storeName === 'management' ) {
|
|
496
|
+
const version = msg?.data?.version || null;
|
|
497
|
+
|
|
498
|
+
dispatch('updateServerVersion', version, { root: true });
|
|
499
|
+
console.info(`Ping [${ getters.storeName }] from ${ version || 'unknown version' }`); // eslint-disable-line no-console
|
|
500
|
+
}
|
|
501
|
+
},
|
|
502
|
+
};
|
|
503
|
+
|
|
504
|
+
/**
|
|
505
|
+
* Mutations that cover all cases (both subscriptions here and in advanced worker)
|
|
506
|
+
*/
|
|
507
|
+
const sharedMutations = {
|
|
508
|
+
debug(state, on, store) {
|
|
509
|
+
state.debugSocket = on !== false;
|
|
510
|
+
if (store && this.$workers[store]) {
|
|
511
|
+
this.$workers[store].postMessage({ toggleDebug: on !== false });
|
|
512
|
+
}
|
|
513
|
+
},
|
|
514
|
+
};
|
|
515
|
+
|
|
516
|
+
/**
|
|
517
|
+
* Actions that cover cases 1 & 2 (see file description)
|
|
518
|
+
*/
|
|
519
|
+
const defaultActions = {
|
|
520
|
+
|
|
521
|
+
async flush({
|
|
522
|
+
state, commit, dispatch, getters
|
|
523
|
+
}) {
|
|
524
|
+
const queue = state.queue;
|
|
525
|
+
let toLoad = [];
|
|
526
|
+
|
|
527
|
+
if ( !queue.length ) {
|
|
528
|
+
return;
|
|
529
|
+
}
|
|
530
|
+
|
|
531
|
+
const started = new Date().getTime();
|
|
532
|
+
|
|
533
|
+
state.queue = [];
|
|
534
|
+
|
|
535
|
+
state.debugSocket && console.debug(`Subscribe Flush [${ getters.storeName }]`, queue.length, 'items'); // eslint-disable-line no-console
|
|
536
|
+
|
|
537
|
+
for ( const { action, event, body } of queue ) {
|
|
538
|
+
if ( action === 'dispatch' && event === 'load' ) {
|
|
539
|
+
// Group loads into one loadMulti when possible
|
|
540
|
+
toLoad.push(body);
|
|
541
|
+
} else {
|
|
542
|
+
// When we hit a different kind of event, process all the previous loads, then the other event.
|
|
543
|
+
if ( toLoad.length ) {
|
|
544
|
+
await dispatch('loadMulti', toLoad);
|
|
545
|
+
toLoad = [];
|
|
546
|
+
}
|
|
547
|
+
|
|
548
|
+
if ( action === 'dispatch' ) {
|
|
549
|
+
await dispatch(event, body);
|
|
550
|
+
} else if ( action === 'commit' ) {
|
|
551
|
+
commit(event, body);
|
|
552
|
+
} else {
|
|
553
|
+
throw new Error('Invalid queued action');
|
|
554
|
+
}
|
|
555
|
+
}
|
|
556
|
+
}
|
|
557
|
+
|
|
558
|
+
// Process any remaining loads
|
|
559
|
+
if ( toLoad.length ) {
|
|
560
|
+
await dispatch('loadMulti', toLoad);
|
|
561
|
+
}
|
|
562
|
+
|
|
563
|
+
state.debugSocket && console.debug(`Subscribe Flush [${ getters.storeName }] finished`, (new Date().getTime()) - started, 'ms'); // eslint-disable-line no-console
|
|
564
|
+
},
|
|
565
|
+
|
|
566
|
+
rehydrateSubscribe({ state, dispatch }) {
|
|
567
|
+
if ( state.wantSocket && !state.socket ) {
|
|
568
|
+
dispatch('subscribe');
|
|
569
|
+
}
|
|
570
|
+
},
|
|
571
|
+
|
|
572
|
+
reconnectWatches({
|
|
573
|
+
state, getters, commit, dispatch
|
|
574
|
+
}) {
|
|
575
|
+
const promises = [];
|
|
576
|
+
|
|
577
|
+
for ( const entry of state.started.slice() ) {
|
|
578
|
+
console.info(`Reconnect [${ getters.storeName }]`, JSON.stringify(entry)); // eslint-disable-line no-console
|
|
579
|
+
|
|
580
|
+
if ( getters.schemaFor(entry.type) ) {
|
|
581
|
+
commit('setWatchStopped', entry);
|
|
582
|
+
delete entry.revision;
|
|
583
|
+
promises.push(dispatch('watch', entry));
|
|
584
|
+
}
|
|
585
|
+
}
|
|
586
|
+
|
|
587
|
+
return Promise.all(promises);
|
|
588
|
+
},
|
|
589
|
+
|
|
590
|
+
async resyncWatch({
|
|
591
|
+
state, getters, dispatch, commit
|
|
592
|
+
}, params) {
|
|
593
|
+
const {
|
|
594
|
+
resourceType, namespace, id, selector
|
|
595
|
+
} = params;
|
|
596
|
+
|
|
597
|
+
console.info(`Resync [${ getters.storeName }]`, params); // eslint-disable-line no-console
|
|
598
|
+
|
|
599
|
+
const opt = { force: true, forceWatch: true };
|
|
600
|
+
|
|
601
|
+
if ( id ) {
|
|
602
|
+
await dispatch('find', {
|
|
603
|
+
type: resourceType,
|
|
604
|
+
id,
|
|
605
|
+
opt: {
|
|
606
|
+
...opt,
|
|
607
|
+
// Pass the namespace so `find` can construct the url correctly
|
|
608
|
+
namespaced: namespace,
|
|
609
|
+
// Ensure that find calls watch with no revision (otherwise it'll use the revision from the resource which is probably stale)
|
|
610
|
+
revision: null
|
|
611
|
+
},
|
|
612
|
+
});
|
|
613
|
+
|
|
614
|
+
return;
|
|
615
|
+
}
|
|
616
|
+
let have, want;
|
|
617
|
+
|
|
618
|
+
if ( selector ) {
|
|
619
|
+
have = getters['matching'](resourceType, selector).slice();
|
|
620
|
+
want = await dispatch('findMatching', {
|
|
621
|
+
type: resourceType,
|
|
622
|
+
selector,
|
|
623
|
+
opt,
|
|
624
|
+
});
|
|
625
|
+
} else {
|
|
626
|
+
have = getters['all'](resourceType).slice();
|
|
627
|
+
|
|
628
|
+
if ( namespace ) {
|
|
629
|
+
have = have.filter((x) => x.metadata?.namespace === namespace);
|
|
630
|
+
}
|
|
631
|
+
|
|
632
|
+
want = await dispatch('findAll', {
|
|
633
|
+
type: resourceType,
|
|
634
|
+
watchNamespace: namespace,
|
|
635
|
+
opt
|
|
636
|
+
});
|
|
637
|
+
}
|
|
638
|
+
|
|
639
|
+
const wantMap = {};
|
|
640
|
+
|
|
641
|
+
for ( const obj of want ) {
|
|
642
|
+
wantMap[obj.id] = true;
|
|
643
|
+
}
|
|
644
|
+
|
|
645
|
+
for ( const obj of have ) {
|
|
646
|
+
if ( !wantMap[obj.id] ) {
|
|
647
|
+
state.debugSocket && console.info(`Remove stale [${ getters.storeName }]`, resourceType, obj.id); // eslint-disable-line no-console
|
|
648
|
+
|
|
649
|
+
commit('remove', obj);
|
|
650
|
+
}
|
|
651
|
+
}
|
|
652
|
+
},
|
|
653
|
+
|
|
654
|
+
async opened({
|
|
655
|
+
commit, dispatch, state, getters, rootGetters
|
|
656
|
+
}, event) {
|
|
657
|
+
state.debugSocket && console.info(`WebSocket Opened [${ getters.storeName }]`); // eslint-disable-line no-console
|
|
658
|
+
const socket = event.currentTarget;
|
|
659
|
+
const tries = event?.detail?.tries; // have to pull it off of the event because the socket's tries is already reset to 0
|
|
660
|
+
const t = rootGetters['i18n/t'];
|
|
661
|
+
const disableGrowl = growlsDisabled(rootGetters);
|
|
662
|
+
|
|
663
|
+
this.$socket = socket;
|
|
664
|
+
|
|
665
|
+
if ( !state.queue ) {
|
|
666
|
+
state.queue = [];
|
|
667
|
+
}
|
|
668
|
+
|
|
669
|
+
if ( !state.queueTimer ) {
|
|
670
|
+
state.flushQueue = async() => {
|
|
671
|
+
if ( state.queue.length ) {
|
|
672
|
+
await dispatch('flush');
|
|
673
|
+
}
|
|
674
|
+
|
|
675
|
+
state.queueTimer = setTimeout(state.flushQueue, 1000);
|
|
676
|
+
};
|
|
677
|
+
|
|
678
|
+
state.flushQueue();
|
|
679
|
+
}
|
|
680
|
+
|
|
681
|
+
if ( socket.hasReconnected ) {
|
|
682
|
+
await dispatch('reconnectWatches');
|
|
683
|
+
// Check for disconnect notifications and clear them
|
|
684
|
+
const growlErr = rootGetters['growl/find']({ key: 'url', val: socket.url });
|
|
685
|
+
|
|
686
|
+
if (growlErr) {
|
|
687
|
+
dispatch('growl/remove', growlErr.id, { root: true });
|
|
688
|
+
}
|
|
689
|
+
if (tries > 1 && !disableGrowl) {
|
|
690
|
+
dispatch('growl/success', {
|
|
691
|
+
title: t('growl.reconnected.title'),
|
|
692
|
+
message: t('growl.reconnected.message', { url: this.$socket.url, tries }),
|
|
693
|
+
}, { root: true });
|
|
694
|
+
}
|
|
695
|
+
}
|
|
696
|
+
|
|
697
|
+
// Try resending any frames that were attempted to be sent while the socket was down, once.
|
|
698
|
+
for ( const obj of state.pendingFrames.slice() ) {
|
|
699
|
+
commit('dequeuePendingFrame', obj);
|
|
700
|
+
dispatch('sendImmediate', obj);
|
|
701
|
+
}
|
|
702
|
+
},
|
|
703
|
+
|
|
704
|
+
closed({ state, getters }) {
|
|
705
|
+
state.debugSocket && console.info(`WebSocket Closed [${ getters.storeName }]`); // eslint-disable-line no-console
|
|
706
|
+
clearTimeout(state.queueTimer);
|
|
707
|
+
state.queueTimer = null;
|
|
708
|
+
},
|
|
709
|
+
|
|
710
|
+
error({
|
|
711
|
+
getters, state, dispatch, rootGetters
|
|
712
|
+
}, e) {
|
|
713
|
+
clearTimeout(state.queueTimer);
|
|
714
|
+
state.queueTimer = null;
|
|
715
|
+
|
|
716
|
+
// determine if websocket notifications are disabled
|
|
717
|
+
const disableGrowl = growlsDisabled(rootGetters);
|
|
718
|
+
|
|
719
|
+
if (!disableGrowl) {
|
|
720
|
+
const dateFormat = escapeHtml( rootGetters['prefs/get'](DATE_FORMAT));
|
|
721
|
+
const timeFormat = escapeHtml( rootGetters['prefs/get'](TIME_FORMAT));
|
|
722
|
+
const time = e?.srcElement?.disconnectedAt || Date.now();
|
|
723
|
+
|
|
724
|
+
const timeFormatted = `${ day(time).format(`${ dateFormat } ${ timeFormat }`) }`;
|
|
725
|
+
const url = e?.srcElement?.url;
|
|
726
|
+
const tries = state?.socket?.tries;
|
|
727
|
+
|
|
728
|
+
const t = rootGetters['i18n/t'];
|
|
729
|
+
|
|
730
|
+
const growlErr = rootGetters['growl/find']({ key: 'url', val: url });
|
|
731
|
+
|
|
732
|
+
if (e.type === EVENT_CONNECT_ERROR) { // if this occurs, then we're at least retrying to connect
|
|
733
|
+
if (growlErr) {
|
|
734
|
+
dispatch('growl/remove', growlErr.id, { root: true });
|
|
735
|
+
}
|
|
736
|
+
dispatch('growl/error', {
|
|
737
|
+
title: t('growl.connectError.title'),
|
|
738
|
+
message: t('growl.connectError.message', {
|
|
739
|
+
url, time: timeFormatted, tries
|
|
740
|
+
}, { raw: true }),
|
|
741
|
+
icon: 'error',
|
|
742
|
+
earliestClose: time + MINIMUM_TIME_NOTIFIED,
|
|
743
|
+
url
|
|
744
|
+
}, { root: true });
|
|
745
|
+
} else if (e.type === EVENT_DISCONNECT_ERROR) { // if this occurs, we've given up on trying to reconnect
|
|
746
|
+
if (growlErr) {
|
|
747
|
+
dispatch('growl/remove', growlErr.id, { root: true });
|
|
748
|
+
}
|
|
749
|
+
dispatch('growl/error', {
|
|
750
|
+
title: t('growl.disconnectError.title'),
|
|
751
|
+
message: t('growl.disconnectError.message', {
|
|
752
|
+
url, time: timeFormatted, tries
|
|
753
|
+
}, { raw: true }),
|
|
754
|
+
icon: 'error',
|
|
755
|
+
earliestClose: time + MINIMUM_TIME_NOTIFIED,
|
|
756
|
+
url
|
|
757
|
+
}, { root: true });
|
|
758
|
+
} else {
|
|
759
|
+
// if the error is not a connect error or disconnect error, the socket never worked: log whether the current browser is safari
|
|
760
|
+
console.error(`WebSocket Connection Error [${ getters.storeName }]`, e.detail); // eslint-disable-line no-console
|
|
761
|
+
}
|
|
762
|
+
}
|
|
763
|
+
},
|
|
764
|
+
|
|
765
|
+
send({ state, commit }, obj) {
|
|
766
|
+
if ( state.socket ) {
|
|
767
|
+
const ok = state.socket.send(JSON.stringify(obj));
|
|
768
|
+
|
|
769
|
+
if ( ok ) {
|
|
770
|
+
return;
|
|
771
|
+
}
|
|
772
|
+
}
|
|
773
|
+
|
|
774
|
+
commit('enqueuePendingFrame', obj);
|
|
775
|
+
},
|
|
776
|
+
|
|
777
|
+
sendImmediate({ state }, obj) {
|
|
778
|
+
if ( state.socket ) {
|
|
779
|
+
return state.socket.send(JSON.stringify(obj));
|
|
780
|
+
}
|
|
781
|
+
},
|
|
782
|
+
|
|
783
|
+
/**
|
|
784
|
+
* Steve only event
|
|
785
|
+
*/
|
|
786
|
+
'ws.resource.start'({
|
|
787
|
+
state, getters, commit, dispatch
|
|
788
|
+
}, msg) {
|
|
789
|
+
state.debugSocket && console.info(`Resource start: [${ getters.storeName }]`, msg); // eslint-disable-line no-console
|
|
790
|
+
|
|
791
|
+
const newWatch = {
|
|
792
|
+
type: msg.resourceType,
|
|
793
|
+
namespace: msg.namespace,
|
|
794
|
+
id: msg.id,
|
|
795
|
+
selector: msg.selector
|
|
796
|
+
};
|
|
797
|
+
|
|
798
|
+
state.started.filter((entry) => {
|
|
799
|
+
if (
|
|
800
|
+
entry.type === newWatch.type &&
|
|
801
|
+
entry.namespace !== newWatch.namespace
|
|
802
|
+
) {
|
|
803
|
+
return true;
|
|
804
|
+
}
|
|
805
|
+
}).forEach((entry) => {
|
|
806
|
+
dispatch('unwatch', entry);
|
|
807
|
+
});
|
|
808
|
+
|
|
809
|
+
commit('setWatchStarted', newWatch);
|
|
810
|
+
},
|
|
811
|
+
|
|
812
|
+
'ws.resource.error'({ getters, commit, dispatch }, msg) {
|
|
813
|
+
console.warn(`Resource error [${ getters.storeName }]`, msg.resourceType, ':', msg.data.error); // eslint-disable-line no-console
|
|
814
|
+
|
|
815
|
+
const err = msg.data?.error?.toLowerCase();
|
|
816
|
+
|
|
817
|
+
if ( err.includes('watch not allowed') ) {
|
|
818
|
+
commit('setInError', { msg, reason: NO_WATCH });
|
|
819
|
+
} else if ( err.includes('failed to find schema') ) {
|
|
820
|
+
commit('setInError', { msg, reason: NO_SCHEMA });
|
|
821
|
+
} else if ( err.includes('too old') ) {
|
|
822
|
+
// Set an error for (all) subs of this type. This..
|
|
823
|
+
// 1) blocks attempts by resource.stop to resub (as type is in error)
|
|
824
|
+
// 2) will be cleared when resyncWatch --> watch (with force) --> resource.start completes
|
|
825
|
+
commit('setInError', { msg, reason: REVISION_TOO_OLD });
|
|
826
|
+
dispatch('resyncWatch', msg);
|
|
827
|
+
} else if ( err.includes('the server does not allow this method on the requested resource')) {
|
|
828
|
+
commit('setInError', { msg, reason: NO_PERMS });
|
|
829
|
+
}
|
|
830
|
+
},
|
|
831
|
+
|
|
832
|
+
/**
|
|
833
|
+
* Steve only event
|
|
834
|
+
*
|
|
835
|
+
* Steve has stopped watching this resource. This happens for a couple of reasons
|
|
836
|
+
* - We have requested that the resource watch should be stopped (and we receive this event as confirmation)
|
|
837
|
+
* - Steve tells us that the resource watch has been stopped. Possible reasons
|
|
838
|
+
* - The rancher <--> k8s socket closed (happens every ~30 mins on mgmt socket)
|
|
839
|
+
* - Permissions has changed for the subscribed resource, so rancher closes socket
|
|
840
|
+
*/
|
|
841
|
+
'ws.resource.stop'({
|
|
842
|
+
state, getters, commit, dispatch
|
|
843
|
+
}, msg) {
|
|
844
|
+
const type = msg.resourceType;
|
|
845
|
+
const obj = {
|
|
846
|
+
type,
|
|
847
|
+
id: msg.id,
|
|
848
|
+
namespace: msg.namespace,
|
|
849
|
+
selector: msg.selector
|
|
850
|
+
};
|
|
851
|
+
|
|
852
|
+
state.debugSocket && console.info(`Resource Stop [${ getters.storeName }]`, type, msg); // eslint-disable-line no-console
|
|
853
|
+
|
|
854
|
+
if (!type) {
|
|
855
|
+
console.error(`Resource Stop [${ getters.storeName }]. Received resource.stop with an empty resourceType, aborting`, msg); // eslint-disable-line no-console
|
|
856
|
+
|
|
857
|
+
return;
|
|
858
|
+
}
|
|
859
|
+
|
|
860
|
+
// If we're trying to watch this event, attempt to re-watch
|
|
861
|
+
//
|
|
862
|
+
// To make life easier in the advanced worker `resource.stop` --> `watch` is handled here (basically for access to getters.nextResourceVersion)
|
|
863
|
+
// This means the concept of resource sub watch state needs massaging
|
|
864
|
+
const advancedWorker = msg.advancedWorker;
|
|
865
|
+
const localState = !advancedWorker;
|
|
866
|
+
const watchStarted = localState ? getters['watchStarted'](obj) : advancedWorker;
|
|
867
|
+
|
|
868
|
+
if ( getters['schemaFor'](type) && watchStarted) {
|
|
869
|
+
if (localState) {
|
|
870
|
+
commit('setWatchStopped', obj);
|
|
871
|
+
}
|
|
872
|
+
|
|
873
|
+
dispatch('watch', obj);
|
|
874
|
+
}
|
|
875
|
+
},
|
|
876
|
+
|
|
877
|
+
'ws.resource.create'(ctx, msg) {
|
|
878
|
+
ctx.state.debugSocket && console.info(`Resource Create [${ ctx.getters.storeName }]`, msg.resourceType, msg); // eslint-disable-line no-console
|
|
879
|
+
queueChange(ctx, msg, true, 'Create');
|
|
880
|
+
},
|
|
881
|
+
|
|
882
|
+
'ws.resource.change'(ctx, msg) {
|
|
883
|
+
const data = msg.data;
|
|
884
|
+
const type = data.type;
|
|
885
|
+
|
|
886
|
+
// Work-around for ws.error messages being sent as change events
|
|
887
|
+
// These have no id (or other metadata) which breaks lots if they are processed as change events
|
|
888
|
+
if (data.message && !data.id) {
|
|
889
|
+
return;
|
|
890
|
+
}
|
|
891
|
+
|
|
892
|
+
// Web worker can process schemas to check that they are actually changing and
|
|
893
|
+
// only load updates if the schema did actually change
|
|
894
|
+
if (type === SCHEMA) {
|
|
895
|
+
const worker = (this.$workers || {})[ctx.getters.storeName];
|
|
896
|
+
|
|
897
|
+
if (worker) {
|
|
898
|
+
worker.postMessage({ updateSchema: data });
|
|
899
|
+
|
|
900
|
+
// No further processing - let the web worker check the schema updates
|
|
901
|
+
return;
|
|
902
|
+
}
|
|
903
|
+
}
|
|
904
|
+
|
|
905
|
+
queueChange(ctx, msg, true, 'Change');
|
|
906
|
+
|
|
907
|
+
const typeOption = ctx.rootGetters['type-map/optionsFor'](type);
|
|
908
|
+
|
|
909
|
+
if (typeOption?.alias?.length > 0) {
|
|
910
|
+
const alias = typeOption?.alias || [];
|
|
911
|
+
|
|
912
|
+
alias.map((type) => {
|
|
913
|
+
ctx.state.queue.push({
|
|
914
|
+
action: 'dispatch',
|
|
915
|
+
event: 'load',
|
|
916
|
+
body: {
|
|
917
|
+
...data,
|
|
918
|
+
type,
|
|
919
|
+
},
|
|
920
|
+
});
|
|
921
|
+
});
|
|
922
|
+
}
|
|
923
|
+
},
|
|
924
|
+
|
|
925
|
+
'ws.resource.remove'(ctx, msg) {
|
|
926
|
+
const data = msg.data;
|
|
927
|
+
const type = data.type;
|
|
928
|
+
|
|
929
|
+
ctx.state.debugSocket && console.info(`Resource Remove [${ ctx.getters.storeName }]`, type, msg); // eslint-disable-line no-console
|
|
930
|
+
|
|
931
|
+
if (type === SCHEMA) {
|
|
932
|
+
const worker = (this.$workers || {})[ctx.getters.storeName];
|
|
933
|
+
|
|
934
|
+
if (worker) {
|
|
935
|
+
worker.postMessage({ removeSchema: data.id });
|
|
936
|
+
}
|
|
937
|
+
}
|
|
938
|
+
|
|
939
|
+
queueChange(ctx, msg, false, 'Remove');
|
|
940
|
+
|
|
941
|
+
const typeOption = ctx.rootGetters['type-map/optionsFor'](type);
|
|
942
|
+
|
|
943
|
+
if (typeOption?.alias?.length > 0) {
|
|
944
|
+
const alias = typeOption?.alias || [];
|
|
945
|
+
|
|
946
|
+
alias.map((type) => {
|
|
947
|
+
const obj = ctx.getters.byId(type, data.id);
|
|
948
|
+
|
|
949
|
+
ctx.state.queue.push({
|
|
950
|
+
action: 'commit',
|
|
951
|
+
event: 'remove',
|
|
952
|
+
body: obj,
|
|
953
|
+
});
|
|
954
|
+
});
|
|
955
|
+
}
|
|
956
|
+
},
|
|
957
|
+
};
|
|
958
|
+
|
|
959
|
+
/**
|
|
960
|
+
* Mutations that cover cases 1 & 2 (see file description)
|
|
961
|
+
*/
|
|
962
|
+
const defaultMutations = {
|
|
963
|
+
setSocket(state, socket) {
|
|
964
|
+
state.socket = socket;
|
|
965
|
+
},
|
|
966
|
+
|
|
967
|
+
setWantSocket(state, want) {
|
|
968
|
+
state.wantSocket = want;
|
|
969
|
+
},
|
|
970
|
+
|
|
971
|
+
enqueuePendingFrame(state, obj) {
|
|
972
|
+
state.pendingFrames.push(obj);
|
|
973
|
+
},
|
|
974
|
+
|
|
975
|
+
dequeuePendingFrame(state, obj) {
|
|
976
|
+
removeObject(state.pendingFrames, obj);
|
|
977
|
+
},
|
|
978
|
+
|
|
979
|
+
setWatchStarted(state, obj) {
|
|
980
|
+
const existing = state.started.find((entry) => equivalentWatch(obj, entry));
|
|
981
|
+
|
|
982
|
+
if ( !existing ) {
|
|
983
|
+
addObject(state.started, obj);
|
|
984
|
+
}
|
|
985
|
+
|
|
986
|
+
delete state.inError[keyForSubscribe(obj)];
|
|
987
|
+
},
|
|
988
|
+
|
|
989
|
+
setWatchStopped(state, obj) {
|
|
990
|
+
const existing = state.started.find((entry) => equivalentWatch(obj, entry));
|
|
991
|
+
|
|
992
|
+
if ( existing ) {
|
|
993
|
+
removeObject(state.started, existing);
|
|
994
|
+
} else {
|
|
995
|
+
console.warn("Tried to remove a watch that doesn't exist", obj); // eslint-disable-line no-console
|
|
996
|
+
}
|
|
997
|
+
},
|
|
998
|
+
|
|
999
|
+
setInError(state, { msg, reason }) {
|
|
1000
|
+
const key = keyForSubscribe(msg);
|
|
1001
|
+
|
|
1002
|
+
state.inError[key] = reason;
|
|
1003
|
+
},
|
|
1004
|
+
|
|
1005
|
+
clearInError(state, msg) {
|
|
1006
|
+
const key = keyForSubscribe(msg);
|
|
1007
|
+
|
|
1008
|
+
delete state.inError[key];
|
|
1009
|
+
},
|
|
1010
|
+
|
|
1011
|
+
resetSubscriptions(state) {
|
|
1012
|
+
// Clear out socket state. This is only ever called from reset... which is always called after we `disconnect` above.
|
|
1013
|
+
// This could probably be folded in to there
|
|
1014
|
+
clear(state.started);
|
|
1015
|
+
clear(state.pendingFrames);
|
|
1016
|
+
clear(state.queue);
|
|
1017
|
+
clearTimeout(state.queueTimer);
|
|
1018
|
+
state.deferredRequests = {};
|
|
1019
|
+
state.queueTimer = null;
|
|
1020
|
+
},
|
|
1021
|
+
|
|
1022
|
+
clearFromQueue(state, type) {
|
|
1023
|
+
// Remove anything in the queue that is a resource update for the given type
|
|
1024
|
+
state.queue = state.queue.filter((item) => {
|
|
1025
|
+
return item.body?.type !== type;
|
|
1026
|
+
});
|
|
1027
|
+
},
|
|
1028
|
+
};
|
|
1029
|
+
|
|
1030
|
+
/**
|
|
1031
|
+
* Getters that cover cases 1 & 2 (see file description)
|
|
1032
|
+
*/
|
|
1033
|
+
const defaultGetters = {
|
|
1034
|
+
inError: (state) => (obj) => {
|
|
1035
|
+
return state.inError[keyForSubscribe(obj)];
|
|
1036
|
+
},
|
|
1037
|
+
|
|
1038
|
+
watchesOfType: (state) => (type) => {
|
|
1039
|
+
return state.started.filter((entry) => type === (entry.resourceType || entry.type));
|
|
1040
|
+
},
|
|
1041
|
+
|
|
1042
|
+
watchStarted: (state) => (obj) => {
|
|
1043
|
+
return !!state.started.find((entry) => equivalentWatch(obj, entry));
|
|
1044
|
+
},
|
|
1045
|
+
|
|
1046
|
+
nextResourceVersion: (state, getters) => (type, id) => {
|
|
1047
|
+
type = normalizeType(type);
|
|
1048
|
+
let revision = 0;
|
|
1049
|
+
|
|
1050
|
+
if ( id ) {
|
|
1051
|
+
const existing = getters['byId'](type, id);
|
|
1052
|
+
|
|
1053
|
+
revision = parseInt(existing?.metadata?.resourceVersion, 10);
|
|
1054
|
+
}
|
|
1055
|
+
|
|
1056
|
+
if ( !revision ) {
|
|
1057
|
+
const cache = state.types[type];
|
|
1058
|
+
|
|
1059
|
+
if ( !cache ) {
|
|
1060
|
+
return null;
|
|
1061
|
+
}
|
|
1062
|
+
|
|
1063
|
+
revision = cache.revision; // This is always zero.....
|
|
1064
|
+
|
|
1065
|
+
for ( const obj of cache.list ) {
|
|
1066
|
+
if ( obj && obj.metadata ) {
|
|
1067
|
+
const neu = parseInt(obj.metadata.resourceVersion, 10);
|
|
1068
|
+
|
|
1069
|
+
revision = Math.max(revision, neu);
|
|
1070
|
+
}
|
|
1071
|
+
}
|
|
1072
|
+
}
|
|
1073
|
+
|
|
1074
|
+
if ( revision ) {
|
|
1075
|
+
return revision;
|
|
1076
|
+
}
|
|
1077
|
+
|
|
1078
|
+
return null;
|
|
1079
|
+
},
|
|
1080
|
+
};
|
|
1081
|
+
|
|
1082
|
+
export const actions = {
|
|
1083
|
+
...sharedActions,
|
|
1084
|
+
...defaultActions,
|
|
1085
|
+
};
|
|
1086
|
+
|
|
1087
|
+
export const mutations = {
|
|
1088
|
+
...sharedMutations,
|
|
1089
|
+
...defaultMutations,
|
|
1090
|
+
};
|
|
1091
|
+
|
|
1092
|
+
export const getters = { ...defaultGetters };
|