dashboard-shell-shell 1.0.111
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/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/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/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 +23 -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/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/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/app.scss +34 -0
- package/assets/styles/base/_basic.scss +146 -0
- package/assets/styles/base/_color.scss +11 -0
- package/assets/styles/base/_functions.scss +134 -0
- package/assets/styles/base/_helpers.scss +267 -0
- package/assets/styles/base/_mixins.scss +163 -0
- package/assets/styles/base/_typography.scss +69 -0
- package/assets/styles/base/_variables.scss +70 -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 +222 -0
- package/assets/styles/global/_cards.scss +94 -0
- package/assets/styles/global/_columns.scss +126 -0
- package/assets/styles/global/_form.scss +146 -0
- package/assets/styles/global/_gauges.scss +55 -0
- package/assets/styles/global/_labeled-input.scss +140 -0
- package/assets/styles/global/_layout.scss +165 -0
- package/assets/styles/global/_resource.scss +89 -0
- package/assets/styles/global/_select.scss +193 -0
- package/assets/styles/global/_table.scss +106 -0
- package/assets/styles/global/_tooltip.scss +165 -0
- package/assets/styles/themes/_csp.scss +25 -0
- package/assets/styles/themes/_dark.scss +232 -0
- package/assets/styles/themes/_light.scss +556 -0
- package/assets/styles/themes/_suse.scss +26 -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 +391 -0
- package/assets/translations/en-us.yaml +8103 -0
- package/assets/translations/zh-hans.yaml +7678 -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 +364 -0
- package/chart/monitoring/prometheus/index.vue +373 -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 +109 -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/ActionMenu.vue +366 -0
- package/components/ActionMenuShell.vue +105 -0
- package/components/AdvancedSection.vue +40 -0
- package/components/Alert.vue +55 -0
- package/components/AlertTable.vue +123 -0
- package/components/AppModal.vue +231 -0
- package/components/AssignTo.vue +185 -0
- package/components/AsyncButton.vue +315 -0
- package/components/AwsComplianceBanner.vue +47 -0
- package/components/BackLink.vue +44 -0
- package/components/BannerGraphic.vue +94 -0
- package/components/BrandImage.vue +135 -0
- package/components/ButtonDropdown.vue +318 -0
- package/components/ButtonGroup.vue +120 -0
- package/components/ButtonMultiAction.vue +51 -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 +488 -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 +148 -0
- package/components/ContainerResourceLimit.vue +254 -0
- package/components/CopyCode.vue +74 -0
- package/components/CopyToClipboard.vue +44 -0
- package/components/CopyToClipboardText.vue +82 -0
- package/components/CountBox.vue +114 -0
- package/components/CountGauge.vue +180 -0
- package/components/CreateDriver.vue +81 -0
- package/components/CruResource.vue +931 -0
- package/components/CruResourceFooter.vue +127 -0
- package/components/DashboardMetrics.vue +125 -0
- package/components/DashboardOptions.vue +147 -0
- package/components/DetailText.vue +215 -0
- package/components/DetailTop.vue +374 -0
- package/components/Dialog.vue +136 -0
- package/components/DisableAuthProviderModal.vue +114 -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 +612 -0
- package/components/ExtensionPanel.vue +42 -0
- package/components/FileDiff.vue +184 -0
- package/components/FixedBanner.vue +277 -0
- package/components/Flag.vue +83 -0
- package/components/Glance.vue +79 -0
- package/components/GlobalRoleBindings.vue +425 -0
- package/components/GradientBox.vue +82 -0
- package/components/GrafanaDashboard.vue +321 -0
- package/components/GroupPanel.vue +57 -0
- package/components/GrowlManager.vue +212 -0
- package/components/HardwareResourceGauge.vue +170 -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 +65 -0
- package/components/KeyValueView.vue +283 -0
- package/components/LabelValue.vue +42 -0
- package/components/LandingPagePreference.vue +152 -0
- package/components/LazyImage.vue +70 -0
- package/components/Loading.vue +85 -0
- package/components/LocaleSelector.vue +175 -0
- package/components/LogItem.vue +69 -0
- package/components/Markdown.vue +138 -0
- package/components/MessageLink.vue +79 -0
- package/components/ModalWithCard.vue +137 -0
- package/components/MoveModal.vue +166 -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 +109 -0
- package/components/PromptRemove.vue +471 -0
- package/components/PromptRestore.vue +327 -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 +127 -0
- package/components/ResourceDetail/Masthead.vue +692 -0
- package/components/ResourceDetail/__tests__/Masthead.test.ts +61 -0
- package/components/ResourceDetail/index.vue +534 -0
- package/components/ResourceList/Masthead.vue +246 -0
- package/components/ResourceList/ResourceLoadingIndicator.vue +137 -0
- package/components/ResourceList/index.vue +306 -0
- package/components/ResourceList/resource-list.config.js +7 -0
- package/components/ResourceSummary.vue +173 -0
- package/components/ResourceTable.vue +661 -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 +568 -0
- package/components/SimpleBox.vue +121 -0
- package/components/SingleClusterInfo.vue +199 -0
- package/components/SortableTable/THead.vue +526 -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 +2089 -0
- package/components/SortableTable/paging.js +147 -0
- package/components/SortableTable/selection.js +640 -0
- package/components/SortableTable/sortable-config.ts +4 -0
- package/components/SortableTable/sorting.js +129 -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 +569 -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__/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__/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 +212 -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 +83 -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 +418 -0
- package/components/form/ArrayListGrouped.vue +141 -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 +213 -0
- package/components/form/Conditions.vue +93 -0
- package/components/form/EnvVars.vue +154 -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 +116 -0
- package/components/form/GitPicker.vue +590 -0
- package/components/form/HealthCheck.vue +86 -0
- package/components/form/HookOption.vue +258 -0
- package/components/form/InputWithSelect.vue +329 -0
- package/components/form/KeyValue.vue +962 -0
- package/components/form/LabeledSelect.vue +723 -0
- package/components/form/Labels.vue +151 -0
- package/components/form/LifecycleHooks.vue +87 -0
- package/components/form/MatchExpressions.vue +446 -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 +554 -0
- package/components/form/Networking.vue +273 -0
- package/components/form/NodeAffinity.vue +250 -0
- package/components/form/NodeScheduling.vue +202 -0
- package/components/form/NotificationSettings.vue +71 -0
- package/components/form/Password.vue +185 -0
- package/components/form/PlusMinus.vue +109 -0
- package/components/form/PodAffinity.vue +497 -0
- package/components/form/Ports.vue +310 -0
- package/components/form/Probe.vue +374 -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 +103 -0
- package/components/form/ResourceQuota/ProjectRow.vue +115 -0
- package/components/form/ResourceQuota/shared.js +147 -0
- package/components/form/ResourceSelector.vue +146 -0
- package/components/form/ResourceTabs/index.vue +292 -0
- package/components/form/RuleSelector.vue +184 -0
- package/components/form/SSHKnownHosts/KnownHostsEditDialog.vue +193 -0
- package/components/form/SSHKnownHosts/__tests__/KnownHostsEditDialog.test.ts +104 -0
- package/components/form/SSHKnownHosts/index.vue +101 -0
- package/components/form/SchedulingCustomization.vue +85 -0
- package/components/form/SecretSelector.vue +269 -0
- package/components/form/Security.vue +247 -0
- package/components/form/Select.vue +370 -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 +91 -0
- package/components/form/SimpleSecretSelector.vue +258 -0
- package/components/form/Taints.vue +98 -0
- package/components/form/Tolerations.vue +315 -0
- package/components/form/UnitInput.vue +257 -0
- package/components/form/ValueFromResource.vue +394 -0
- package/components/form/WorkloadPorts.vue +514 -0
- package/components/form/__tests__/ArrayList.test.ts +124 -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 +72 -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 +74 -0
- package/components/form/__tests__/SSHKnownHosts.test.ts +59 -0
- package/components/form/__tests__/Security.test.ts +55 -0
- package/components/form/__tests__/Select.test.ts +30 -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 +256 -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 +63 -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/ExtensionCache.vue +74 -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 +62 -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/Port.vue +24 -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 +55 -0
- package/components/formatter/SecretType.vue +41 -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 +56 -0
- package/components/nav/GlobalLoading.vue +25 -0
- package/components/nav/Group.vue +462 -0
- package/components/nav/Header.vue +1156 -0
- package/components/nav/HeaderPageActionMenu.vue +22 -0
- package/components/nav/Jump.vue +128 -0
- package/components/nav/NamespaceFilter.vue +1155 -0
- package/components/nav/Pinned.vue +52 -0
- package/components/nav/TopLevelMenu.helper.ts +562 -0
- package/components/nav/TopLevelMenu.vue +1602 -0
- package/components/nav/Type.vue +292 -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 +598 -0
- package/components/nav/__tests__/Type.test.ts +491 -0
- package/components/templates/blank.vue +20 -0
- package/components/templates/default.vue +263 -0
- package/components/templates/home.vue +126 -0
- package/components/templates/plain.vue +134 -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 +68 -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/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 +94 -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 +488 -0
- package/config/schema.js +32 -0
- package/config/secret.js +14 -0
- package/config/settings.ts +258 -0
- package/config/store.js +184 -0
- package/config/system-namespaces.js +18 -0
- package/config/table-headers.js +1115 -0
- package/config/types.js +353 -0
- package/config/uiplugins.js +272 -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 +144 -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 +661 -0
- package/detail/__tests__/autoscaling.horizontalpodautoscaler.test.ts +135 -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 +254 -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 +1134 -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 +465 -0
- package/dialog/AddProjectMemberDialog.vue +181 -0
- package/dialog/AddonConfigConfirmationDialog.vue +101 -0
- package/dialog/DeactivateDriverDialog.vue +138 -0
- package/dialog/DiagnosticTimingsDialog.vue +141 -0
- package/dialog/DrainNode.vue +247 -0
- package/dialog/ForceMachineRemoveDialog.vue +131 -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 +57 -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 +151 -0
- package/edit/auth/azuread.vue +537 -0
- package/edit/auth/github.vue +269 -0
- package/edit/auth/googleoauth.vue +256 -0
- package/edit/auth/ldap/__tests__/config.test.ts +58 -0
- package/edit/auth/ldap/config.vue +403 -0
- package/edit/auth/ldap/index.vue +156 -0
- package/edit/auth/oidc.vue +412 -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 +79 -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 +319 -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 +187 -0
- package/edit/fleet.cattle.io.gitrepo.vue +910 -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 +279 -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 +264 -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 +152 -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 +282 -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 +65 -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/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 +93 -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 +303 -0
- package/edit/provisioning.cattle.io.cluster/Labels.vue +46 -0
- package/edit/provisioning.cattle.io.cluster/SelectCredential.vue +324 -0
- package/edit/provisioning.cattle.io.cluster/__tests__/Advanced.test.ts +306 -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 +2547 -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 +221 -0
- package/edit/provisioning.cattle.io.cluster/tabs/AgentConfiguration.vue +335 -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 +374 -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 +549 -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 +316 -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 +72 -0
- package/edit/workload/__tests__/Upgrading.test.ts +61 -0
- package/edit/workload/__tests__/index.test.ts +103 -0
- package/edit/workload/index.vue +676 -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 +128 -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 +244 -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 +367 -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 +79 -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 +318 -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 +187 -0
- package/machine-config/__tests__/vmwarevsphere.test.ts +257 -0
- package/machine-config/amazonec2.vue +702 -0
- package/machine-config/azure.vue +901 -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 +1252 -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 +290 -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__/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 +165 -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 +336 -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 +85 -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 +114 -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 +71 -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 +262 -0
- package/models/networking.istio.io.destinationrule.js +19 -0
- package/models/networking.k8s.io.ingress.js +209 -0
- package/models/nodedriver.js +93 -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 +688 -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 +303 -0
- package/pages/account/create-key.vue +16 -0
- package/pages/account/index.vue +252 -0
- package/pages/auth/login.vue +591 -0
- package/pages/auth/logout.vue +44 -0
- package/pages/auth/setup.vue +521 -0
- package/pages/auth/verify.vue +198 -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 +116 -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 +121 -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 +1002 -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 +19 -0
- package/pages/c/_cluster/monitoring/monitor/create.vue +27 -0
- package/pages/c/_cluster/monitoring/monitor/index.vue +99 -0
- package/pages/c/_cluster/monitoring/route-receiver/_id.vue +27 -0
- package/pages/c/_cluster/monitoring/route-receiver/create.vue +19 -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 +134 -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 +532 -0
- package/pages/fail-whale.vue +197 -0
- package/pages/home.vue +848 -0
- package/pages/index.vue +54 -0
- package/pages/prefs.vue +367 -0
- package/pages/support/index.vue +263 -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 +48 -0
- package/plugins/dashboard-store/resource-class.js +1902 -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/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 +74 -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 +118 -0
- package/rancher-components/BadgeState/index.ts +1 -0
- package/rancher-components/Banner/Banner.test.ts +59 -0
- package/rancher-components/Banner/Banner.vue +257 -0
- package/rancher-components/Banner/index.ts +1 -0
- package/rancher-components/Card/Card.test.ts +37 -0
- package/rancher-components/Card/Card.vue +187 -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 +488 -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 +471 -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 +304 -0
- package/rancher-components/Form/Radio/RadioGroup.test.ts +27 -0
- package/rancher-components/Form/Radio/RadioGroup.vue +298 -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 +94 -0
- package/rancher-components/Form/ToggleSwitch/ToggleSwitch.vue +192 -0
- package/rancher-components/Form/ToggleSwitch/index.ts +1 -0
- package/rancher-components/Form/index.ts +5 -0
- package/rancher-components/LabeledTooltip/LabeledTooltip.vue +140 -0
- package/rancher-components/LabeledTooltip/index.ts +1 -0
- package/rancher-components/RcButton/RcButton.test.ts +97 -0
- package/rancher-components/RcButton/RcButton.vue +95 -0
- package/rancher-components/RcButton/index.ts +2 -0
- package/rancher-components/RcButton/types.ts +17 -0
- package/rancher-components/RcDropdown/RcDropdown.vue +124 -0
- package/rancher-components/RcDropdown/RcDropdownItem.vue +121 -0
- package/rancher-components/RcDropdown/RcDropdownMenu.vue +66 -0
- package/rancher-components/RcDropdown/RcDropdownSeparator.vue +6 -0
- package/rancher-components/RcDropdown/RcDropdownTrigger.vue +42 -0
- package/rancher-components/RcDropdown/index.ts +5 -0
- package/rancher-components/RcDropdown/types.ts +49 -0
- package/rancher-components/RcDropdown/useDropdownCollection.ts +46 -0
- package/rancher-components/RcDropdown/useDropdownContext.ts +113 -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 +86 -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 +14 -0
- package/scripts/extension/helm/charts/ui-plugin-server/values.yaml +8 -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 +67 -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 +115 -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 +248 -0
- package/scripts/typegen.sh +102 -0
- package/scripts/vue-migrate.js +686 -0
- package/server/har-file.js +183 -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 +256 -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 +73 -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/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/store-types.js +7 -0
- package/store/type-map.js +2057 -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/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 +4704 -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 +20 -0
- package/types/vue-shim.d.ts +20 -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 +409 -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 +334 -0
- package/utils/aws.js +0 -0
- package/utils/axios.js +171 -0
- package/utils/azure.js +24 -0
- package/utils/banners.js +103 -0
- package/utils/clipboard.js +5 -0
- package/utils/cluster.js +298 -0
- package/utils/color.js +147 -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 +131 -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 +501 -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 +119 -0
- package/utils/select.js +65 -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 +362 -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/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 +577 -0
|
@@ -0,0 +1,1218 @@
|
|
|
1
|
+
import formRulesGenerator from '@shell/utils/validators/formRules';
|
|
2
|
+
|
|
3
|
+
const mockT = (key: string, args: any) => {
|
|
4
|
+
return JSON.stringify({
|
|
5
|
+
message: key,
|
|
6
|
+
...args
|
|
7
|
+
});
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
describe('formRules', () => {
|
|
11
|
+
const formRules = formRulesGenerator(mockT, { key: 'testDisplayKey' });
|
|
12
|
+
|
|
13
|
+
it('"required" : returns undefined when value supplied', () => {
|
|
14
|
+
const testValue = 'foo';
|
|
15
|
+
const formRuleResult = formRules.required(testValue);
|
|
16
|
+
|
|
17
|
+
expect(formRuleResult).toBeUndefined();
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
it('"required" : returns the correct message when value undefined', () => {
|
|
21
|
+
const formRuleResult = formRules.required(undefined);
|
|
22
|
+
const expectedResult = JSON.stringify({
|
|
23
|
+
message: 'validation.required',
|
|
24
|
+
key: 'testDisplayKey'
|
|
25
|
+
});
|
|
26
|
+
|
|
27
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
it('"https" : returns undefined when valid https url value is supplied', () => {
|
|
31
|
+
const testValue = 'https://url.com';
|
|
32
|
+
const formRuleResult = formRules.https(testValue);
|
|
33
|
+
|
|
34
|
+
expect(formRuleResult).toBeUndefined();
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
it('"https" : returns correct message when http url value is supplied', () => {
|
|
38
|
+
const testValue = 'http://url.com';
|
|
39
|
+
const formRuleResult = formRules.https(testValue);
|
|
40
|
+
const expectedResult = JSON.stringify({ message: 'validation.setting.serverUrl.https' });
|
|
41
|
+
|
|
42
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
describe('localhost', () => {
|
|
46
|
+
const message = JSON.stringify({ message: 'validation.setting.serverUrl.localhost' });
|
|
47
|
+
const testCases = [
|
|
48
|
+
['http://LOCALhosT:8005', message],
|
|
49
|
+
['http://localhost:8005', message],
|
|
50
|
+
['https://localhost:8005', message],
|
|
51
|
+
['localhost', message],
|
|
52
|
+
['http://127.0.0.1', message],
|
|
53
|
+
['https://127.0.0.1', message],
|
|
54
|
+
['127.0.0.1', message],
|
|
55
|
+
['https://test.com', undefined],
|
|
56
|
+
['https://test.com/localhost', undefined],
|
|
57
|
+
[undefined, undefined]
|
|
58
|
+
];
|
|
59
|
+
|
|
60
|
+
it.each(testCases)(
|
|
61
|
+
'should return undefined or correct message based on the provided url',
|
|
62
|
+
(url, expected) => {
|
|
63
|
+
const formRuleResult = formRules.localhost(url);
|
|
64
|
+
|
|
65
|
+
expect(formRuleResult).toStrictEqual(expected);
|
|
66
|
+
}
|
|
67
|
+
);
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
describe('trailingForwardSlash', () => {
|
|
71
|
+
const message = JSON.stringify({ message: 'validation.setting.serverUrl.trailingForwardSlash' });
|
|
72
|
+
const testCases = [
|
|
73
|
+
['https://test.com', undefined],
|
|
74
|
+
['https://test.com/', message],
|
|
75
|
+
['https://', undefined],
|
|
76
|
+
['/', undefined],
|
|
77
|
+
[undefined, undefined]
|
|
78
|
+
];
|
|
79
|
+
|
|
80
|
+
it.each(testCases)(
|
|
81
|
+
'should return undefined or correct message based on the provided url',
|
|
82
|
+
(url, expected) => {
|
|
83
|
+
const formRuleResult = formRules.trailingForwardSlash(url);
|
|
84
|
+
|
|
85
|
+
expect(formRuleResult).toStrictEqual(expected);
|
|
86
|
+
}
|
|
87
|
+
);
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
describe('gitRepository', () => {
|
|
91
|
+
const message = JSON.stringify({ message: 'validation.git.repository' });
|
|
92
|
+
const testCases = [
|
|
93
|
+
// Valid HTTP(s)
|
|
94
|
+
['https://github.com/rancher/dashboard.git', undefined],
|
|
95
|
+
['http://github.com/rancher/dashboard.git', undefined],
|
|
96
|
+
['https://github.com/rancher/dashboard', undefined],
|
|
97
|
+
['https://github.com/rancher/dashboard/', undefined],
|
|
98
|
+
|
|
99
|
+
// Valid SSH
|
|
100
|
+
['git@github.com:rancher/dashboard.git', undefined],
|
|
101
|
+
['git@github.com:rancher/dashboard', undefined],
|
|
102
|
+
['git@github.com:rancher/dashboard/', undefined],
|
|
103
|
+
|
|
104
|
+
// Not valid HTTP(s)
|
|
105
|
+
['https://github.com/rancher/ dashboard.git', message],
|
|
106
|
+
['http://github.com/rancher/ dashboard.git', message],
|
|
107
|
+
['https://github.com/rancher/dashboard ', message],
|
|
108
|
+
['foo://github.com/rancher/dashboard/', message],
|
|
109
|
+
['github.com/rancher/dashboard/', message],
|
|
110
|
+
|
|
111
|
+
// Not valid SSH
|
|
112
|
+
['git@github.com:rancher/ dashboard.git', message],
|
|
113
|
+
['git@github.com:rancher/dashboard ', message],
|
|
114
|
+
['git@github.comrancher/dashboard', message],
|
|
115
|
+
|
|
116
|
+
[undefined, undefined]
|
|
117
|
+
];
|
|
118
|
+
|
|
119
|
+
it.each(testCases)(
|
|
120
|
+
'should return undefined or correct message based on the provided Git url: %p',
|
|
121
|
+
(url, expected) => {
|
|
122
|
+
const formRuleResult = formRules.gitRepository(url);
|
|
123
|
+
|
|
124
|
+
expect(formRuleResult).toStrictEqual(expected);
|
|
125
|
+
}
|
|
126
|
+
);
|
|
127
|
+
});
|
|
128
|
+
|
|
129
|
+
describe('alphanumeric', () => {
|
|
130
|
+
const message = JSON.stringify({ message: 'validation.alphanumeric', key: 'testDisplayKey' });
|
|
131
|
+
const testCases = [
|
|
132
|
+
['', undefined],
|
|
133
|
+
['aaaAAAA111', undefined],
|
|
134
|
+
['aaaAAAA111//', message],
|
|
135
|
+
['/', message],
|
|
136
|
+
['+1', message],
|
|
137
|
+
[undefined, undefined]
|
|
138
|
+
];
|
|
139
|
+
|
|
140
|
+
it.each(testCases)(
|
|
141
|
+
'should return undefined or correct message based on the provided url',
|
|
142
|
+
(val, expected) => {
|
|
143
|
+
const formRuleResult = formRules.alphanumeric(val);
|
|
144
|
+
|
|
145
|
+
expect(formRuleResult).toStrictEqual(expected);
|
|
146
|
+
}
|
|
147
|
+
);
|
|
148
|
+
});
|
|
149
|
+
|
|
150
|
+
it('"interval" : returns undefined when valid hour interval value is supplied', () => {
|
|
151
|
+
const testValue = '5h';
|
|
152
|
+
const formRuleResult = formRules.interval(testValue);
|
|
153
|
+
|
|
154
|
+
expect(formRuleResult).toBeUndefined();
|
|
155
|
+
});
|
|
156
|
+
|
|
157
|
+
it('"interval" : returns undefined when valid minute interval value is supplied', () => {
|
|
158
|
+
const testValue = '5m';
|
|
159
|
+
const formRuleResult = formRules.interval(testValue);
|
|
160
|
+
|
|
161
|
+
expect(formRuleResult).toBeUndefined();
|
|
162
|
+
});
|
|
163
|
+
|
|
164
|
+
it('"interval" : returns undefined when valid second interval value is supplied', () => {
|
|
165
|
+
const testValue = '5s';
|
|
166
|
+
const formRuleResult = formRules.interval(testValue);
|
|
167
|
+
|
|
168
|
+
expect(formRuleResult).toBeUndefined();
|
|
169
|
+
});
|
|
170
|
+
|
|
171
|
+
it('"interval" : returns correct message when interval unit is supplied but not integer', () => {
|
|
172
|
+
const testValue = 's';
|
|
173
|
+
const formRuleResult = formRules.interval(testValue);
|
|
174
|
+
const expectedResult = JSON.stringify({
|
|
175
|
+
message: 'validation.monitoring.route.interval',
|
|
176
|
+
key: 'testDisplayKey'
|
|
177
|
+
});
|
|
178
|
+
|
|
179
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
180
|
+
});
|
|
181
|
+
|
|
182
|
+
it('"interval" : returns correct message when interval integer is supplied but not unit', () => {
|
|
183
|
+
const testValue = '5';
|
|
184
|
+
const formRuleResult = formRules.interval(testValue);
|
|
185
|
+
const expectedResult = JSON.stringify({
|
|
186
|
+
message: 'validation.monitoring.route.interval',
|
|
187
|
+
key: 'testDisplayKey'
|
|
188
|
+
});
|
|
189
|
+
|
|
190
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
191
|
+
});
|
|
192
|
+
|
|
193
|
+
it('"containerImage" : returns undefined when valid container with image is supplied', () => {
|
|
194
|
+
const testValue = { image: 'imageName' };
|
|
195
|
+
const formRuleResult = formRules.containerImage(testValue);
|
|
196
|
+
|
|
197
|
+
expect(formRuleResult).toBeUndefined();
|
|
198
|
+
});
|
|
199
|
+
|
|
200
|
+
it('"containerImage" : returns correct message when container without image is supplied', () => {
|
|
201
|
+
const testValue = { name: 'testName' };
|
|
202
|
+
const formRuleResult = formRules.containerImage(testValue);
|
|
203
|
+
const expectedResult = JSON.stringify({
|
|
204
|
+
message: 'workload.validation.containerImage',
|
|
205
|
+
name: testValue.name
|
|
206
|
+
});
|
|
207
|
+
|
|
208
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
209
|
+
});
|
|
210
|
+
|
|
211
|
+
it('"containerImages" : returns undefined when valid jobTemplate value is supplied', () => {
|
|
212
|
+
const testValue = { jobTemplate: { spec: { template: { spec: { containers: [{ image: 'imageName', name: 'name' }] } } } } };
|
|
213
|
+
const formRuleResult = formRules.containerImages(testValue);
|
|
214
|
+
|
|
215
|
+
expect(formRuleResult).toBeUndefined();
|
|
216
|
+
});
|
|
217
|
+
|
|
218
|
+
it('"containerImages" : returns undefined when valid non-jobTemplate value is supplied', () => {
|
|
219
|
+
const testValue = { template: { spec: { containers: [{ image: 'imageName', name: 'name' }] } } };
|
|
220
|
+
const formRuleResult = formRules.containerImages(testValue);
|
|
221
|
+
|
|
222
|
+
expect(formRuleResult).toBeUndefined();
|
|
223
|
+
});
|
|
224
|
+
|
|
225
|
+
it('"containerImages" : returns correct message when supplied value contains no containers', () => {
|
|
226
|
+
const testValue = { template: { spec: { containers: [] } } };
|
|
227
|
+
const formRuleResult = formRules.containerImages(testValue);
|
|
228
|
+
const expectedResult = JSON.stringify({
|
|
229
|
+
message: 'validation.required',
|
|
230
|
+
key: JSON.stringify({ message: 'workload.container.titles.containers' })
|
|
231
|
+
});
|
|
232
|
+
|
|
233
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
234
|
+
});
|
|
235
|
+
|
|
236
|
+
it('"containerImages" : returns correct message when supplied value has containers but one has no image', () => {
|
|
237
|
+
const testValue = { template: { spec: { containers: [{ name: 'testName' }] } } };
|
|
238
|
+
const formRuleResult = formRules.containerImages(testValue);
|
|
239
|
+
const expectedResult = JSON.stringify({
|
|
240
|
+
message: 'workload.validation.containerImage',
|
|
241
|
+
name: 'testName'
|
|
242
|
+
});
|
|
243
|
+
|
|
244
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
245
|
+
});
|
|
246
|
+
|
|
247
|
+
describe('"registryUrl": has the expected output for each input', () => {
|
|
248
|
+
const expectedTranslation = JSON.stringify({ message: 'cluster.privateRegistry.privateRegistryUrlError' });
|
|
249
|
+
const testCases = [
|
|
250
|
+
// Empty
|
|
251
|
+
[undefined, undefined],
|
|
252
|
+
|
|
253
|
+
// Word
|
|
254
|
+
['registry', expectedTranslation],
|
|
255
|
+
|
|
256
|
+
// Without schema
|
|
257
|
+
['registry.io', undefined],
|
|
258
|
+
|
|
259
|
+
// With schemas
|
|
260
|
+
['http://registry.io', undefined],
|
|
261
|
+
['https://registry.io', undefined],
|
|
262
|
+
];
|
|
263
|
+
|
|
264
|
+
it.each(testCases)(
|
|
265
|
+
'should return undefined or correct message based on the provided url',
|
|
266
|
+
(url, expected) => {
|
|
267
|
+
const formRuleResult = formRules.registryUrl(url);
|
|
268
|
+
|
|
269
|
+
expect(formRuleResult).toStrictEqual(expected);
|
|
270
|
+
}
|
|
271
|
+
);
|
|
272
|
+
});
|
|
273
|
+
|
|
274
|
+
it('"ruleGroups" : returns undefined when rulegroups are supplied', () => {
|
|
275
|
+
const testValue = { groups: ['group1'] };
|
|
276
|
+
const formRuleResult = formRules.ruleGroups(testValue);
|
|
277
|
+
|
|
278
|
+
expect(formRuleResult).toBeUndefined();
|
|
279
|
+
});
|
|
280
|
+
|
|
281
|
+
it('"groupsAreValid" : returns undefined when valid rulegroups are supplied', () => {
|
|
282
|
+
const testValue = [
|
|
283
|
+
{
|
|
284
|
+
name: 'group',
|
|
285
|
+
rules: [
|
|
286
|
+
{
|
|
287
|
+
alert: { name: 'alertname' },
|
|
288
|
+
record: { name: 'recordname' },
|
|
289
|
+
expr: { name: 'exprname' },
|
|
290
|
+
labels: ['label1']
|
|
291
|
+
}
|
|
292
|
+
]
|
|
293
|
+
}
|
|
294
|
+
];
|
|
295
|
+
const formRuleResult = formRules.groupsAreValid(testValue);
|
|
296
|
+
|
|
297
|
+
expect(formRuleResult).toBeUndefined();
|
|
298
|
+
});
|
|
299
|
+
|
|
300
|
+
it('"groupsAreValid" : returns correct message when rules are empty', () => {
|
|
301
|
+
const testValue = [
|
|
302
|
+
{
|
|
303
|
+
name: 'group',
|
|
304
|
+
rules: []
|
|
305
|
+
}
|
|
306
|
+
];
|
|
307
|
+
const formRuleResult = formRules.groupsAreValid(testValue);
|
|
308
|
+
const expectedResult = JSON.stringify({
|
|
309
|
+
message: 'validation.prometheusRule.groups.valid.singleEntry',
|
|
310
|
+
index: 1
|
|
311
|
+
});
|
|
312
|
+
|
|
313
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
314
|
+
});
|
|
315
|
+
|
|
316
|
+
it('"groupsAreValid" : returns correct message when rule alert is empty', () => {
|
|
317
|
+
const testValue = [
|
|
318
|
+
{
|
|
319
|
+
name: 'group',
|
|
320
|
+
rules: [
|
|
321
|
+
{
|
|
322
|
+
alert: '',
|
|
323
|
+
record: '',
|
|
324
|
+
expr: '',
|
|
325
|
+
labels: { severity: 'none' }
|
|
326
|
+
}
|
|
327
|
+
]
|
|
328
|
+
}
|
|
329
|
+
];
|
|
330
|
+
const formRuleResult = formRules.groupsAreValid(testValue);
|
|
331
|
+
const expectedResult = JSON.stringify({
|
|
332
|
+
message: 'validation.prometheusRule.groups.valid.rule.alertName',
|
|
333
|
+
groupIndex: 1,
|
|
334
|
+
ruleIndex: 1
|
|
335
|
+
});
|
|
336
|
+
|
|
337
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
338
|
+
});
|
|
339
|
+
|
|
340
|
+
it('"groupsAreValid" : returns correct message when rule record is empty', () => {
|
|
341
|
+
const testValue = [
|
|
342
|
+
{
|
|
343
|
+
name: 'group',
|
|
344
|
+
rules: [
|
|
345
|
+
{
|
|
346
|
+
alert: 'name',
|
|
347
|
+
record: '',
|
|
348
|
+
expr: '',
|
|
349
|
+
labels: { severity: 'none' }
|
|
350
|
+
}
|
|
351
|
+
]
|
|
352
|
+
}
|
|
353
|
+
];
|
|
354
|
+
const formRuleResult = formRules.groupsAreValid(testValue);
|
|
355
|
+
const expectedResult = JSON.stringify({
|
|
356
|
+
message: 'validation.prometheusRule.groups.valid.rule.recordName',
|
|
357
|
+
groupIndex: 1,
|
|
358
|
+
ruleIndex: 1
|
|
359
|
+
});
|
|
360
|
+
|
|
361
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
362
|
+
});
|
|
363
|
+
|
|
364
|
+
it('"groupsAreValid" : returns correct message when rule expr is empty', () => {
|
|
365
|
+
const testValue = [
|
|
366
|
+
{
|
|
367
|
+
name: 'group',
|
|
368
|
+
rules: [
|
|
369
|
+
{
|
|
370
|
+
alert: 'name',
|
|
371
|
+
record: 'record',
|
|
372
|
+
expr: '',
|
|
373
|
+
labels: { severity: 'none' }
|
|
374
|
+
}
|
|
375
|
+
]
|
|
376
|
+
}
|
|
377
|
+
];
|
|
378
|
+
const formRuleResult = formRules.groupsAreValid(testValue);
|
|
379
|
+
const expectedResult = JSON.stringify({
|
|
380
|
+
message: 'validation.prometheusRule.groups.valid.rule.expr',
|
|
381
|
+
groupIndex: 1,
|
|
382
|
+
ruleIndex: 1
|
|
383
|
+
});
|
|
384
|
+
|
|
385
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
386
|
+
});
|
|
387
|
+
|
|
388
|
+
it('"groupsAreValid" : returns correct message when rule labels is empty', () => {
|
|
389
|
+
const testValue = [
|
|
390
|
+
{
|
|
391
|
+
name: 'group',
|
|
392
|
+
rules: [
|
|
393
|
+
{
|
|
394
|
+
alert: 'name',
|
|
395
|
+
record: 'record',
|
|
396
|
+
expr: 'expr',
|
|
397
|
+
labels: {}
|
|
398
|
+
}
|
|
399
|
+
]
|
|
400
|
+
}
|
|
401
|
+
];
|
|
402
|
+
const formRuleResult = formRules.groupsAreValid(testValue);
|
|
403
|
+
const expectedResult = JSON.stringify({
|
|
404
|
+
message: 'validation.prometheusRule.groups.valid.rule.labels',
|
|
405
|
+
groupIndex: 1,
|
|
406
|
+
ruleIndex: 1
|
|
407
|
+
});
|
|
408
|
+
|
|
409
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
410
|
+
});
|
|
411
|
+
|
|
412
|
+
it('"matching" : returns undefined when is not empty and match_re is not empty', () => {
|
|
413
|
+
const testValue = { match: 'matchValue', match_re: 'match_reValue' };
|
|
414
|
+
const formRuleResult = formRules.matching(testValue);
|
|
415
|
+
|
|
416
|
+
expect(formRuleResult).toBeUndefined();
|
|
417
|
+
});
|
|
418
|
+
|
|
419
|
+
it('"matching" : returns undefined when match is empty and match_re is not empty', () => {
|
|
420
|
+
const testValue = { match: '', match_re: 'match_reValue' };
|
|
421
|
+
const formRuleResult = formRules.matching(testValue);
|
|
422
|
+
|
|
423
|
+
expect(formRuleResult).toBeUndefined();
|
|
424
|
+
});
|
|
425
|
+
|
|
426
|
+
it('"matching" : returns undefined when match is not empty and match_re is empty', () => {
|
|
427
|
+
const testValue = { match: 'matchValue', match_re: '' };
|
|
428
|
+
const formRuleResult = formRules.matching(testValue);
|
|
429
|
+
|
|
430
|
+
expect(formRuleResult).toBeUndefined();
|
|
431
|
+
});
|
|
432
|
+
|
|
433
|
+
it('"matching" : returns correct message when match is empty and match_re is empty', () => {
|
|
434
|
+
const testValue = { match: '', match_re: '' };
|
|
435
|
+
const formRuleResult = formRules.matching(testValue);
|
|
436
|
+
const expectedResult = JSON.stringify({ message: 'validation.monitoring.route.match' });
|
|
437
|
+
|
|
438
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
439
|
+
});
|
|
440
|
+
|
|
441
|
+
it('"clusterName" : returns undefined when "isRke2" is false', () => {
|
|
442
|
+
const testValue = 'clusterName';
|
|
443
|
+
const formRuleResult = formRules.clusterName(false)(testValue);
|
|
444
|
+
|
|
445
|
+
expect(formRuleResult).toBeUndefined();
|
|
446
|
+
});
|
|
447
|
+
|
|
448
|
+
it('"clusterName" : returns undefined when "isRke2" is true and clusterName is valid', () => {
|
|
449
|
+
const testValue = 'clustername';
|
|
450
|
+
const formRuleResult = formRules.clusterName(true)(testValue);
|
|
451
|
+
|
|
452
|
+
expect(formRuleResult).toBeUndefined();
|
|
453
|
+
});
|
|
454
|
+
|
|
455
|
+
it('"clusterName" : returns correct message when "isRke2" is true and clusterName is 5 characters long with "c-" as a prefix', () => {
|
|
456
|
+
const testValue = 'c-12345';
|
|
457
|
+
const formRuleResult = formRules.clusterName(true)(testValue);
|
|
458
|
+
const expectedResult = JSON.stringify({ message: 'validation.cluster.name' });
|
|
459
|
+
|
|
460
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
461
|
+
});
|
|
462
|
+
|
|
463
|
+
it('"clusterName" : returns undefined when "isRke2" is true and clusterName is less than 5 characters long with "c-" as a prefix', () => {
|
|
464
|
+
const testValue = 'c-1234';
|
|
465
|
+
const formRuleResult = formRules.clusterName(true)(testValue);
|
|
466
|
+
|
|
467
|
+
expect(formRuleResult).toBeUndefined();
|
|
468
|
+
});
|
|
469
|
+
|
|
470
|
+
it('"clusterName" : returns undefined when "isRke2" is true and clusterName is more than 5 characters long with "c-" as a prefix', () => {
|
|
471
|
+
const testValue = 'c-123456';
|
|
472
|
+
const formRuleResult = formRules.clusterName(true)(testValue);
|
|
473
|
+
|
|
474
|
+
expect(formRuleResult).toBeUndefined();
|
|
475
|
+
});
|
|
476
|
+
|
|
477
|
+
it('"roleTemplateRules" : returns undefined when type is RBAC role and value contains valid rules', () => {
|
|
478
|
+
const testValue: [{}] = [
|
|
479
|
+
{
|
|
480
|
+
verbs: ['verb1'], resources: ['resource1'], apiGroups: ['apiGroup1']
|
|
481
|
+
}
|
|
482
|
+
];
|
|
483
|
+
const formRuleResult = formRules.roleTemplateRules('rbac.authorization.k8s.io.role')(testValue);
|
|
484
|
+
|
|
485
|
+
expect(formRuleResult).toBeUndefined();
|
|
486
|
+
});
|
|
487
|
+
|
|
488
|
+
it('"roleTemplateRules" : returns correct message when type is RBAC role and value is missing verbs', () => {
|
|
489
|
+
const testValue: [{}] = [
|
|
490
|
+
{
|
|
491
|
+
verbs: [], resources: ['resource1'], apiGroups: ['apiGroup1']
|
|
492
|
+
}
|
|
493
|
+
];
|
|
494
|
+
const formRuleResult = formRules.roleTemplateRules('rbac.authorization.k8s.io.role')(testValue);
|
|
495
|
+
const expectedResult = JSON.stringify({ message: 'validation.roleTemplate.roleTemplateRules.missingVerb' });
|
|
496
|
+
|
|
497
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
498
|
+
});
|
|
499
|
+
|
|
500
|
+
it('"roleTemplateRules" : returns correct message when type is RBAC role and value is missing resources', () => {
|
|
501
|
+
const testValue: [{}] = [
|
|
502
|
+
{
|
|
503
|
+
verbs: ['verb1'], resources: [], apiGroups: ['apiGroup1']
|
|
504
|
+
}
|
|
505
|
+
];
|
|
506
|
+
const formRuleResult = formRules.roleTemplateRules('rbac.authorization.k8s.io.role')(testValue);
|
|
507
|
+
const expectedResult = JSON.stringify({ message: 'validation.roleTemplate.roleTemplateRules.missingResource' });
|
|
508
|
+
|
|
509
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
510
|
+
});
|
|
511
|
+
|
|
512
|
+
it('"roleTemplateRules" : returns correct message when type is RBAC role rule defines both resources and nonResourceURLs', () => {
|
|
513
|
+
const testValue: [{}] = [
|
|
514
|
+
{
|
|
515
|
+
verbs: ['verb1'], resources: ['resource1'], apiGroups: ['apiGroup1'], nonResourceURLs: ['nonResourceUrl1']
|
|
516
|
+
}
|
|
517
|
+
];
|
|
518
|
+
const formRuleResult = formRules.roleTemplateRules('rbac.authorization.k8s.io.role')(testValue);
|
|
519
|
+
const expectedResult = JSON.stringify({ message: 'validation.roleTemplate.roleTemplateRules.noResourceAndNonResource' });
|
|
520
|
+
|
|
521
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
522
|
+
});
|
|
523
|
+
|
|
524
|
+
it('"roleTemplateRules" : returns correct message when type is RBAC role and value is missing apiGroups', () => {
|
|
525
|
+
const testValue: [{}] = [
|
|
526
|
+
{
|
|
527
|
+
verbs: ['verb1'], resources: ['resource1'], apiGroups: []
|
|
528
|
+
}
|
|
529
|
+
];
|
|
530
|
+
const formRuleResult = formRules.roleTemplateRules('rbac.authorization.k8s.io.role')(testValue);
|
|
531
|
+
const expectedResult = JSON.stringify({ message: 'validation.roleTemplate.roleTemplateRules.missingApiGroup' });
|
|
532
|
+
|
|
533
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
534
|
+
});
|
|
535
|
+
|
|
536
|
+
it('"roleTemplateRules" : returns undefined when type is not RBAC role and value contains valid rules', () => {
|
|
537
|
+
const testValue: [{}] = [
|
|
538
|
+
{
|
|
539
|
+
verbs: ['verb1'], resources: ['resource1'], apiGroups: ['apiGroup1']
|
|
540
|
+
}
|
|
541
|
+
];
|
|
542
|
+
const formRuleResult = formRules.roleTemplateRules('nonrbactype')(testValue);
|
|
543
|
+
|
|
544
|
+
expect(formRuleResult).toBeUndefined();
|
|
545
|
+
});
|
|
546
|
+
|
|
547
|
+
it('"roleTemplateRules" : returns undefined when type is not RBAC role and value is missing resources and nonResourceURLs and apiGroups', () => {
|
|
548
|
+
const testValue: [{}] = [
|
|
549
|
+
{
|
|
550
|
+
verbs: ['verb1'], nonResourceURLs: [], resources: [], apiGroups: []
|
|
551
|
+
}
|
|
552
|
+
];
|
|
553
|
+
const formRuleResult = formRules.roleTemplateRules('nonrbactype')(testValue);
|
|
554
|
+
const expectedResult = JSON.stringify({ message: 'validation.roleTemplate.roleTemplateRules.missingOneResource' });
|
|
555
|
+
|
|
556
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
557
|
+
});
|
|
558
|
+
|
|
559
|
+
it('"servicePort" : returns undefined when servicePort is valid', () => {
|
|
560
|
+
const testValue = {
|
|
561
|
+
name: 'portName',
|
|
562
|
+
nodePort: '8081',
|
|
563
|
+
port: '8082',
|
|
564
|
+
targetPort: '8083',
|
|
565
|
+
idx: 0
|
|
566
|
+
};
|
|
567
|
+
const formRuleResult = formRules.servicePort(testValue);
|
|
568
|
+
|
|
569
|
+
expect(formRuleResult).toBeUndefined();
|
|
570
|
+
});
|
|
571
|
+
|
|
572
|
+
it('"servicePort" : returns correct message when servicePort name is empty', () => {
|
|
573
|
+
const testValue = {
|
|
574
|
+
name: '',
|
|
575
|
+
nodePort: '8081',
|
|
576
|
+
port: '8082',
|
|
577
|
+
targetPort: '8083',
|
|
578
|
+
idx: 0
|
|
579
|
+
};
|
|
580
|
+
const formRuleResult = formRules.servicePort(testValue);
|
|
581
|
+
const expectedResult = JSON.stringify({ message: 'validation.service.ports.name.required', position: 1 });
|
|
582
|
+
|
|
583
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
584
|
+
});
|
|
585
|
+
|
|
586
|
+
it('"servicePort" : returns correct message when servicePort nodePort is not an integer', () => {
|
|
587
|
+
const testValue = {
|
|
588
|
+
name: 'portName',
|
|
589
|
+
nodePort: 'test',
|
|
590
|
+
port: '8082',
|
|
591
|
+
targetPort: '8083',
|
|
592
|
+
idx: 0
|
|
593
|
+
};
|
|
594
|
+
const formRuleResult = formRules.servicePort(testValue);
|
|
595
|
+
const expectedResult = JSON.stringify({ message: 'validation.service.ports.nodePort.requiredInt', position: 1 });
|
|
596
|
+
|
|
597
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
598
|
+
});
|
|
599
|
+
|
|
600
|
+
it('"servicePort" : returns correct message when servicePort port is not an integer', () => {
|
|
601
|
+
const testValue = {
|
|
602
|
+
name: 'portName',
|
|
603
|
+
nodePort: '8081',
|
|
604
|
+
port: 'test',
|
|
605
|
+
targetPort: '8083',
|
|
606
|
+
idx: 0
|
|
607
|
+
};
|
|
608
|
+
const formRuleResult = formRules.servicePort(testValue);
|
|
609
|
+
const expectedResult = JSON.stringify({ message: 'validation.service.ports.port.requiredInt', position: 1 });
|
|
610
|
+
|
|
611
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
612
|
+
});
|
|
613
|
+
|
|
614
|
+
it('"servicePort" : returns correct message when port is not provided', () => {
|
|
615
|
+
const testValue = {
|
|
616
|
+
name: 'portName',
|
|
617
|
+
nodePort: '8081',
|
|
618
|
+
targetPort: '8083',
|
|
619
|
+
idx: 0
|
|
620
|
+
};
|
|
621
|
+
const formRuleResult = formRules.servicePort(testValue);
|
|
622
|
+
const expectedResult = JSON.stringify({ message: 'validation.service.ports.port.required', position: 1 });
|
|
623
|
+
|
|
624
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
625
|
+
});
|
|
626
|
+
|
|
627
|
+
it('"servicePort" : returns correct message when targetPort port is not an integer but is a valid dnsLabelIanaServiceName', () => {
|
|
628
|
+
const testValue = {
|
|
629
|
+
name: 'portName',
|
|
630
|
+
nodePort: '8081',
|
|
631
|
+
port: '8082',
|
|
632
|
+
targetPort: 'test',
|
|
633
|
+
idx: 0
|
|
634
|
+
};
|
|
635
|
+
const formRuleResult = formRules.servicePort(testValue);
|
|
636
|
+
|
|
637
|
+
expect(formRuleResult).toBeUndefined();
|
|
638
|
+
});
|
|
639
|
+
|
|
640
|
+
it('"servicePort" : returns correct message when targetPort port is not an integer but is not a valid dnsLabelIanaServiceName', () => {
|
|
641
|
+
const testValue = {
|
|
642
|
+
name: 'portName',
|
|
643
|
+
nodePort: '8081',
|
|
644
|
+
port: '8082',
|
|
645
|
+
targetPort: 'te st',
|
|
646
|
+
idx: 0
|
|
647
|
+
};
|
|
648
|
+
const formRuleResult = formRules.servicePort(testValue);
|
|
649
|
+
const expectedResult = JSON.stringify({
|
|
650
|
+
message: 'validation.chars', key: 'testDisplayKey', count: 1, chars: 'Space'
|
|
651
|
+
});
|
|
652
|
+
|
|
653
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
654
|
+
});
|
|
655
|
+
|
|
656
|
+
it('"servicePort" : returns correct message when targetPort port is below the valid range', () => {
|
|
657
|
+
const testValue = {
|
|
658
|
+
name: 'portName',
|
|
659
|
+
nodePort: '8081',
|
|
660
|
+
port: '8082',
|
|
661
|
+
targetPort: '0',
|
|
662
|
+
idx: 0
|
|
663
|
+
};
|
|
664
|
+
const formRuleResult = formRules.servicePort(testValue);
|
|
665
|
+
const expectedResult = JSON.stringify({ message: 'validation.service.ports.targetPort.between', position: 1 });
|
|
666
|
+
|
|
667
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
668
|
+
});
|
|
669
|
+
|
|
670
|
+
it('"servicePort" : returns correct message when targetPort port is above the valid range', () => {
|
|
671
|
+
const testValue = {
|
|
672
|
+
name: 'portName',
|
|
673
|
+
nodePort: '8081',
|
|
674
|
+
port: '8082',
|
|
675
|
+
targetPort: '65536',
|
|
676
|
+
idx: 0
|
|
677
|
+
};
|
|
678
|
+
const formRuleResult = formRules.servicePort(testValue);
|
|
679
|
+
const expectedResult = JSON.stringify({ message: 'validation.service.ports.targetPort.between', position: 1 });
|
|
680
|
+
|
|
681
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
682
|
+
});
|
|
683
|
+
|
|
684
|
+
it('"clusterIp" : always returns undefined', () => {
|
|
685
|
+
const formRuleResult = formRules.clusterIp('');
|
|
686
|
+
|
|
687
|
+
expect(formRuleResult).toBeUndefined();
|
|
688
|
+
});
|
|
689
|
+
|
|
690
|
+
it('"externalName" : returns undefined when value is a valid externalName', () => {
|
|
691
|
+
const testValue = 'test';
|
|
692
|
+
const formRuleResult = formRules.externalName(testValue);
|
|
693
|
+
|
|
694
|
+
expect(formRuleResult).toBeUndefined();
|
|
695
|
+
});
|
|
696
|
+
|
|
697
|
+
it('"externalName" : returns expected message when value empty', () => {
|
|
698
|
+
const testValue = '';
|
|
699
|
+
const formRuleResult = formRules.externalName(testValue);
|
|
700
|
+
const expectedResult = JSON.stringify({ message: 'validation.service.externalName.none' });
|
|
701
|
+
|
|
702
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
703
|
+
});
|
|
704
|
+
|
|
705
|
+
it('"externalName" : returns expected message when value starts with a dot', () => {
|
|
706
|
+
const testValue = '.hostname';
|
|
707
|
+
const formRuleResult = formRules.externalName(testValue);
|
|
708
|
+
const expectedResult = JSON.stringify({ message: 'validation.dns.hostname.startDot', key: 'testDisplayKey' });
|
|
709
|
+
|
|
710
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
711
|
+
});
|
|
712
|
+
|
|
713
|
+
it('"externalName" : returns expected message when value starts is too long for a hostname', () => {
|
|
714
|
+
const testValue = 'There.are.many.variations.of.passages.of.Lorem.Ipsum.available.but.the.majority.have.suffered.alteration.in.some.form.by.injected.humour.or.randomised.words.which.dont.look.even.slightly.believable.If.you.are.going.to.use.a.passage.of.Lorem.Ipsum.you.need';
|
|
715
|
+
const formRuleResult = formRules.externalName(testValue);
|
|
716
|
+
const expectedResult = JSON.stringify({
|
|
717
|
+
message: 'validation.dns.hostname.tooLong', key: 'testDisplayKey', max: 253
|
|
718
|
+
});
|
|
719
|
+
|
|
720
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
721
|
+
});
|
|
722
|
+
|
|
723
|
+
it('"externalName" : returns expected message when value contains invalid characters', () => {
|
|
724
|
+
const testValue = 'www.host*name.com';
|
|
725
|
+
const formRuleResult = formRules.externalName(testValue);
|
|
726
|
+
const expectedResult = JSON.stringify({
|
|
727
|
+
message: 'validation.chars', key: 'testDisplayKey', count: 1, chars: '"*"'
|
|
728
|
+
});
|
|
729
|
+
|
|
730
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
731
|
+
});
|
|
732
|
+
|
|
733
|
+
it('"externalName" : returns expected message when hostname label starts with a dash', () => {
|
|
734
|
+
const testValue = 'www.-hostname.com';
|
|
735
|
+
const formRuleResult = formRules.externalName(testValue);
|
|
736
|
+
const expectedResult = JSON.stringify({ message: 'validation.dns.hostname.startHyphen', key: 'testDisplayKey' });
|
|
737
|
+
|
|
738
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
739
|
+
});
|
|
740
|
+
|
|
741
|
+
it('"externalName" : returns expected message when hostname label ends with a dash', () => {
|
|
742
|
+
const testValue = 'www.hostname-.com';
|
|
743
|
+
const formRuleResult = formRules.externalName(testValue);
|
|
744
|
+
const expectedResult = JSON.stringify({ message: 'validation.dns.hostname.endHyphen', key: 'testDisplayKey' });
|
|
745
|
+
|
|
746
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
747
|
+
});
|
|
748
|
+
|
|
749
|
+
it('"externalName" : returns expected message when hostname label contains a double-dash at the third character position', () => {
|
|
750
|
+
const testValue = 'www.ho--stname.com';
|
|
751
|
+
const formRuleResult = formRules.externalName(testValue);
|
|
752
|
+
const expectedResult = JSON.stringify({ message: 'validation.dns.doubleHyphen', key: 'testDisplayKey' });
|
|
753
|
+
|
|
754
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
755
|
+
});
|
|
756
|
+
|
|
757
|
+
it('"externalName" : returns expected message when hostname label is empty', () => {
|
|
758
|
+
const testValue = 'www..com';
|
|
759
|
+
const formRuleResult = formRules.externalName(testValue);
|
|
760
|
+
const expectedResult = JSON.stringify({
|
|
761
|
+
message: 'validation.dns.hostname.emptyLabel', key: 'testDisplayKey', min: 1
|
|
762
|
+
});
|
|
763
|
+
|
|
764
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
765
|
+
});
|
|
766
|
+
|
|
767
|
+
it('"externalName" : returns expected message when hostname label is too long', () => {
|
|
768
|
+
const testValue = 'www.0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef.com';
|
|
769
|
+
const formRuleResult = formRules.externalName(testValue);
|
|
770
|
+
const expectedResult = JSON.stringify({
|
|
771
|
+
message: 'validation.dns.hostname.tooLongLabel', key: 'testDisplayKey', max: 63
|
|
772
|
+
});
|
|
773
|
+
|
|
774
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
775
|
+
});
|
|
776
|
+
|
|
777
|
+
it('"backupTarget" : returns undefined when value is valid backupTarget', () => {
|
|
778
|
+
const testValue = JSON.stringify({ type: 'type' });
|
|
779
|
+
const formRuleResult = formRules.backupTarget(testValue);
|
|
780
|
+
|
|
781
|
+
expect(formRuleResult).toBeUndefined();
|
|
782
|
+
});
|
|
783
|
+
|
|
784
|
+
it('"backupTarget" : returns expected message when value is backupTarget without a type', () => {
|
|
785
|
+
const testValue = JSON.stringify({});
|
|
786
|
+
const formRuleResult = formRules.backupTarget(testValue);
|
|
787
|
+
const expectedResult = JSON.stringify({ message: 'validation.required', key: 'Type' });
|
|
788
|
+
|
|
789
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
790
|
+
});
|
|
791
|
+
|
|
792
|
+
it('"backupTarget" : returns expected message when value is backupTarget with a type of s3 but no accessKeyId', () => {
|
|
793
|
+
const testValue = JSON.stringify({ type: 's3' });
|
|
794
|
+
const formRuleResult = formRules.backupTarget(testValue);
|
|
795
|
+
const expectedResult = JSON.stringify({ message: 'validation.required', key: 'accessKeyId' });
|
|
796
|
+
|
|
797
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
798
|
+
});
|
|
799
|
+
|
|
800
|
+
it('"backupTarget" : returns expected message when value is backupTarget with a type of s3 but no secretAccessKey', () => {
|
|
801
|
+
const testValue = JSON.stringify({ type: 's3', accessKeyId: 'id' });
|
|
802
|
+
const formRuleResult = formRules.backupTarget(testValue);
|
|
803
|
+
const expectedResult = JSON.stringify({ message: 'validation.required', key: 'secretAccessKey' });
|
|
804
|
+
|
|
805
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
806
|
+
});
|
|
807
|
+
|
|
808
|
+
it('"backupTarget" : returns expected message when value is backupTarget with a type of s3 but no bucketRegion', () => {
|
|
809
|
+
const testValue = JSON.stringify({
|
|
810
|
+
type: 's3', accessKeyId: 'id', secretAccessKey: 'key'
|
|
811
|
+
});
|
|
812
|
+
const formRuleResult = formRules.backupTarget(testValue);
|
|
813
|
+
const expectedResult = JSON.stringify({ message: 'validation.required', key: 'bucketRegion' });
|
|
814
|
+
|
|
815
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
816
|
+
});
|
|
817
|
+
|
|
818
|
+
it('"backupTarget" : returns expected message when value is backupTarget with a type of s3 but no bucketName', () => {
|
|
819
|
+
const testValue = JSON.stringify({
|
|
820
|
+
type: 's3', accessKeyId: 'id', secretAccessKey: 'key', bucketRegion: 'region'
|
|
821
|
+
});
|
|
822
|
+
const formRuleResult = formRules.backupTarget(testValue);
|
|
823
|
+
const expectedResult = JSON.stringify({ message: 'validation.required', key: 'bucketName' });
|
|
824
|
+
|
|
825
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
826
|
+
});
|
|
827
|
+
|
|
828
|
+
it('"backupTarget" : returns undefined when value is backupTarget with a type of s3 and all other values', () => {
|
|
829
|
+
const testValue = JSON.stringify({
|
|
830
|
+
type: 's3', accessKeyId: 'id', secretAccessKey: 'key', bucketRegion: 'region', bucketName: 'name'
|
|
831
|
+
});
|
|
832
|
+
const formRuleResult = formRules.backupTarget(testValue);
|
|
833
|
+
|
|
834
|
+
expect(formRuleResult).toBeUndefined();
|
|
835
|
+
});
|
|
836
|
+
|
|
837
|
+
it('"imageUrl" : returns undefined when value is a valid imageUrl', () => {
|
|
838
|
+
const testValue = 'https://url/image.iso';
|
|
839
|
+
const formRuleResult = formRules.imageUrl(testValue);
|
|
840
|
+
|
|
841
|
+
expect(formRuleResult).toBeUndefined();
|
|
842
|
+
});
|
|
843
|
+
|
|
844
|
+
it('"imageUrl" : returns expected message when value has an invalid file extension', () => {
|
|
845
|
+
const testValue = 'https://url/image.isi';
|
|
846
|
+
const formRuleResult = formRules.imageUrl(testValue);
|
|
847
|
+
const expectedResult = JSON.stringify({ message: 'harvester.validation.image.ruleTip' });
|
|
848
|
+
|
|
849
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
850
|
+
});
|
|
851
|
+
|
|
852
|
+
it('"fileRequired" : returns undefined when value has an image name key', () => {
|
|
853
|
+
const testValue = { 'harvesterhci.io/image-name': 'test' };
|
|
854
|
+
const formRuleResult = formRules.fileRequired(testValue);
|
|
855
|
+
|
|
856
|
+
expect(formRuleResult).toBeUndefined();
|
|
857
|
+
});
|
|
858
|
+
|
|
859
|
+
it('"fileRequired" : returns expected message when value is invalid', () => {
|
|
860
|
+
const testValue = {};
|
|
861
|
+
const formRuleResult = formRules.fileRequired(testValue);
|
|
862
|
+
const expectedResult = JSON.stringify({ message: 'validation.required', key: JSON.stringify({ message: 'harvester.image.fileName' }) });
|
|
863
|
+
|
|
864
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
865
|
+
});
|
|
866
|
+
|
|
867
|
+
it('"dnsLabel" : returns undefined when valid dnsLabel value is supplied', () => {
|
|
868
|
+
const testValue = 'bob';
|
|
869
|
+
const formRuleResult = formRules.dnsLabel(testValue);
|
|
870
|
+
|
|
871
|
+
expect(formRuleResult).toBeUndefined();
|
|
872
|
+
});
|
|
873
|
+
|
|
874
|
+
it('"dnsLabel" : returns correct message when dnsLabel value with invalid characters is supplied', () => {
|
|
875
|
+
const testValue = 'bob*bob';
|
|
876
|
+
const formRuleResult = formRules.dnsLabel(testValue);
|
|
877
|
+
const expectedResult = JSON.stringify({
|
|
878
|
+
message: 'validation.chars',
|
|
879
|
+
key: 'testDisplayKey',
|
|
880
|
+
count: 1,
|
|
881
|
+
chars: '"*"'
|
|
882
|
+
});
|
|
883
|
+
|
|
884
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
885
|
+
});
|
|
886
|
+
|
|
887
|
+
it('"dnsLabel" : returns correct message when dnsLabel value that starts with a dash is supplied', () => {
|
|
888
|
+
const testValue = '-bob';
|
|
889
|
+
const formRuleResult = formRules.dnsLabel(testValue);
|
|
890
|
+
const expectedResult = JSON.stringify({
|
|
891
|
+
message: 'validation.dns.label.startHyphen',
|
|
892
|
+
key: 'testDisplayKey'
|
|
893
|
+
});
|
|
894
|
+
|
|
895
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
896
|
+
});
|
|
897
|
+
|
|
898
|
+
it('"dnsLabel" : returns correct message when dnsLabel value that ends with a dash is supplied', () => {
|
|
899
|
+
const testValue = 'bob-';
|
|
900
|
+
const formRuleResult = formRules.dnsLabel(testValue);
|
|
901
|
+
const expectedResult = JSON.stringify({
|
|
902
|
+
message: 'validation.dns.label.endHyphen',
|
|
903
|
+
key: 'testDisplayKey'
|
|
904
|
+
});
|
|
905
|
+
|
|
906
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
907
|
+
});
|
|
908
|
+
|
|
909
|
+
it('"dnsLabel" : returns correct message when dnsLabel value with double-dash after first two characters is supplied', () => {
|
|
910
|
+
const testValue = 'jo--jane';
|
|
911
|
+
const formRuleResult = formRules.dnsLabel(testValue);
|
|
912
|
+
const expectedResult = JSON.stringify({
|
|
913
|
+
message: 'validation.dns.doubleHyphen',
|
|
914
|
+
key: 'testDisplayKey'
|
|
915
|
+
});
|
|
916
|
+
|
|
917
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
918
|
+
});
|
|
919
|
+
|
|
920
|
+
it('"dnsLabel" : returns correct message when dnsLabel value is too long', () => {
|
|
921
|
+
const testValue = 'abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz';
|
|
922
|
+
const formRuleResult = formRules.dnsLabel(testValue);
|
|
923
|
+
const expectedResult = JSON.stringify({
|
|
924
|
+
message: 'validation.dns.label.tooLongLabel',
|
|
925
|
+
key: 'testDisplayKey',
|
|
926
|
+
max: 63
|
|
927
|
+
});
|
|
928
|
+
|
|
929
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
930
|
+
});
|
|
931
|
+
|
|
932
|
+
// this rule is pretty much identical to the standard dnsLabel other than the dnsLabel length
|
|
933
|
+
it('"dnsLabelIanaServiceName" : returns correct message when dnsLabel value is too long', () => {
|
|
934
|
+
const testValue = '0123456789abcdef';
|
|
935
|
+
const formRuleResult = formRules.dnsLabelIanaServiceName(testValue);
|
|
936
|
+
const expectedResult = JSON.stringify({
|
|
937
|
+
message: 'validation.dns.label.tooLongLabel',
|
|
938
|
+
key: 'testDisplayKey',
|
|
939
|
+
max: 15
|
|
940
|
+
});
|
|
941
|
+
|
|
942
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
943
|
+
});
|
|
944
|
+
|
|
945
|
+
// this rule is pretty much identical to the standard dnsLabel other than the startNumber test
|
|
946
|
+
it('"dnsLabelRestricted" : returns correct message when dnsLabel starts with a number', () => {
|
|
947
|
+
const testValue = '1testUrl';
|
|
948
|
+
const formRuleResult = formRules.dnsLabelRestricted(testValue);
|
|
949
|
+
const expectedResult = JSON.stringify({
|
|
950
|
+
message: 'validation.dns.label.startNumber',
|
|
951
|
+
key: 'testDisplayKey'
|
|
952
|
+
});
|
|
953
|
+
|
|
954
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
955
|
+
});
|
|
956
|
+
|
|
957
|
+
// this rule is pretty much identical to the standard dnsLabel other than the startNumber test
|
|
958
|
+
it('"hostName" : returns undefined when value is valid hostname', () => {
|
|
959
|
+
const testValue = 'www.url.com';
|
|
960
|
+
const formRuleResult = formRules.hostname(testValue);
|
|
961
|
+
|
|
962
|
+
expect(formRuleResult).toBeUndefined();
|
|
963
|
+
});
|
|
964
|
+
|
|
965
|
+
it('"hostName" : returns expected message when value starts with a dot', () => {
|
|
966
|
+
const testValue = '.hostname';
|
|
967
|
+
const formRuleResult = formRules.hostname(testValue);
|
|
968
|
+
const expectedResult = JSON.stringify({ message: 'validation.dns.hostname.startDot', key: 'testDisplayKey' });
|
|
969
|
+
|
|
970
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
971
|
+
});
|
|
972
|
+
|
|
973
|
+
it('"hostName" : returns expected message when value starts is too long for a hostname', () => {
|
|
974
|
+
const testValue = 'There.are.many.variations.of.passages.of.Lorem.Ipsum.available.but.the.majority.have.suffered.alteration.in.some.form.by.injected.humour.or.randomised.words.which.dont.look.even.slightly.believable.If.you.are.going.to.use.a.passage.of.Lorem.Ipsum.you.need';
|
|
975
|
+
const formRuleResult = formRules.hostname(testValue);
|
|
976
|
+
const expectedResult = JSON.stringify({
|
|
977
|
+
message: 'validation.dns.hostname.tooLong', key: 'testDisplayKey', max: 253
|
|
978
|
+
});
|
|
979
|
+
|
|
980
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
981
|
+
});
|
|
982
|
+
|
|
983
|
+
it('"hostName" : returns expected message when value contains invalid characters', () => {
|
|
984
|
+
const testValue = 'www.host*name.com';
|
|
985
|
+
const formRuleResult = formRules.hostname(testValue);
|
|
986
|
+
const expectedResult = JSON.stringify({
|
|
987
|
+
message: 'validation.chars', key: 'testDisplayKey', count: 1, chars: '"*"'
|
|
988
|
+
});
|
|
989
|
+
|
|
990
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
991
|
+
});
|
|
992
|
+
|
|
993
|
+
it('"hostName" : returns expected message when value contains a space character', () => {
|
|
994
|
+
const testValue = 'www.host name.com';
|
|
995
|
+
const formRuleResult = formRules.hostname(testValue);
|
|
996
|
+
const expectedResult = JSON.stringify({
|
|
997
|
+
message: 'validation.chars', key: 'testDisplayKey', count: 1, chars: 'Space'
|
|
998
|
+
});
|
|
999
|
+
|
|
1000
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
1001
|
+
});
|
|
1002
|
+
|
|
1003
|
+
it('"hostName" : returns expected message when hostname label starts with a dash', () => {
|
|
1004
|
+
const testValue = 'www.-hostname.com';
|
|
1005
|
+
const formRuleResult = formRules.hostname(testValue);
|
|
1006
|
+
const expectedResult = JSON.stringify({ message: 'validation.dns.hostname.startHyphen', key: 'testDisplayKey' });
|
|
1007
|
+
|
|
1008
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
1009
|
+
});
|
|
1010
|
+
|
|
1011
|
+
it('"hostName" : returns expected message when hostname label ends with a dash', () => {
|
|
1012
|
+
const testValue = 'www.hostname-.com';
|
|
1013
|
+
const formRuleResult = formRules.hostname(testValue);
|
|
1014
|
+
const expectedResult = JSON.stringify({ message: 'validation.dns.hostname.endHyphen', key: 'testDisplayKey' });
|
|
1015
|
+
|
|
1016
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
1017
|
+
});
|
|
1018
|
+
|
|
1019
|
+
it('"hostName" : returns expected message when hostname label contains a double-dash at the third character position', () => {
|
|
1020
|
+
const testValue = 'www.ho--stname.com';
|
|
1021
|
+
const formRuleResult = formRules.hostname(testValue);
|
|
1022
|
+
const expectedResult = JSON.stringify({ message: 'validation.dns.doubleHyphen', key: 'testDisplayKey' });
|
|
1023
|
+
|
|
1024
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
1025
|
+
});
|
|
1026
|
+
|
|
1027
|
+
it('"hostName" : returns expected message when hostname label is too long', () => {
|
|
1028
|
+
const testValue = 'www.0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef.com';
|
|
1029
|
+
const formRuleResult = formRules.hostname(testValue);
|
|
1030
|
+
const expectedResult = JSON.stringify({
|
|
1031
|
+
message: 'validation.dns.hostname.tooLongLabel', key: 'testDisplayKey', max: 63
|
|
1032
|
+
});
|
|
1033
|
+
|
|
1034
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
1035
|
+
});
|
|
1036
|
+
|
|
1037
|
+
// this rule is pretty much identical to the standard hostname, but also allows for wildcards
|
|
1038
|
+
it('"wildcardHostname" : returns undefined when value is valid hostname', () => {
|
|
1039
|
+
const testValue = 'www.url.com';
|
|
1040
|
+
const formRuleResult = formRules.wildcardHostname(testValue);
|
|
1041
|
+
|
|
1042
|
+
expect(formRuleResult).toBeUndefined();
|
|
1043
|
+
});
|
|
1044
|
+
|
|
1045
|
+
it('"wildcardHostname" : returns expected message when value starts with a dot', () => {
|
|
1046
|
+
const testValue = '.hostname';
|
|
1047
|
+
const formRuleResult = formRules.wildcardHostname(testValue);
|
|
1048
|
+
const expectedResult = JSON.stringify({ message: 'validation.dns.hostname.startDot', key: 'testDisplayKey' });
|
|
1049
|
+
|
|
1050
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
1051
|
+
});
|
|
1052
|
+
|
|
1053
|
+
it('"wildcardHostname" : returns expected message when value starts is too long for a hostname', () => {
|
|
1054
|
+
const testValue = 'There.are.many.variations.of.passages.of.Lorem.Ipsum.available.but.the.majority.have.suffered.alteration.in.some.form.by.injected.humour.or.randomised.words.which.dont.look.even.slightly.believable.If.you.are.going.to.use.a.passage.of.Lorem.Ipsum.you.need';
|
|
1055
|
+
const formRuleResult = formRules.wildcardHostname(testValue);
|
|
1056
|
+
const expectedResult = JSON.stringify({
|
|
1057
|
+
message: 'validation.dns.hostname.tooLong', key: 'testDisplayKey', max: 253
|
|
1058
|
+
});
|
|
1059
|
+
|
|
1060
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
1061
|
+
});
|
|
1062
|
+
|
|
1063
|
+
it('"wildcardHostname" : returns expected message when value contains invalid characters', () => {
|
|
1064
|
+
const testValue = 'www.host*name.com';
|
|
1065
|
+
const formRuleResult = formRules.wildcardHostname(testValue);
|
|
1066
|
+
const expectedResult = JSON.stringify({
|
|
1067
|
+
message: 'validation.chars', key: 'testDisplayKey', count: 1, chars: '"*"'
|
|
1068
|
+
});
|
|
1069
|
+
|
|
1070
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
1071
|
+
});
|
|
1072
|
+
|
|
1073
|
+
it('"wildcardHostname" : returns expected message when value contains a space character', () => {
|
|
1074
|
+
const testValue = 'www.host name.com';
|
|
1075
|
+
const formRuleResult = formRules.wildcardHostname(testValue);
|
|
1076
|
+
const expectedResult = JSON.stringify({
|
|
1077
|
+
message: 'validation.chars', key: 'testDisplayKey', count: 1, chars: 'Space'
|
|
1078
|
+
});
|
|
1079
|
+
|
|
1080
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
1081
|
+
});
|
|
1082
|
+
|
|
1083
|
+
it('"wildcardHostname" : returns expected message when hostname label starts with a dash', () => {
|
|
1084
|
+
const testValue = 'www.-hostname.com';
|
|
1085
|
+
const formRuleResult = formRules.wildcardHostname(testValue);
|
|
1086
|
+
const expectedResult = JSON.stringify({ message: 'validation.dns.hostname.startHyphen', key: 'testDisplayKey' });
|
|
1087
|
+
|
|
1088
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
1089
|
+
});
|
|
1090
|
+
|
|
1091
|
+
it('"wildcardHostname" : returns expected message when hostname label ends with a dash', () => {
|
|
1092
|
+
const testValue = 'www.hostname-.com';
|
|
1093
|
+
const formRuleResult = formRules.wildcardHostname(testValue);
|
|
1094
|
+
const expectedResult = JSON.stringify({ message: 'validation.dns.hostname.endHyphen', key: 'testDisplayKey' });
|
|
1095
|
+
|
|
1096
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
1097
|
+
});
|
|
1098
|
+
|
|
1099
|
+
it('"wildcardHostname" : returns expected message when hostname label contains a double-dash at the third character position', () => {
|
|
1100
|
+
const testValue = 'www.ho--stname.com';
|
|
1101
|
+
const formRuleResult = formRules.wildcardHostname(testValue);
|
|
1102
|
+
const expectedResult = JSON.stringify({ message: 'validation.dns.doubleHyphen', key: 'testDisplayKey' });
|
|
1103
|
+
|
|
1104
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
1105
|
+
});
|
|
1106
|
+
|
|
1107
|
+
it('"wildcardHostname" : returns expected message when hostname label is too long', () => {
|
|
1108
|
+
const testValue = 'www.0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef.com';
|
|
1109
|
+
const formRuleResult = formRules.wildcardHostname(testValue);
|
|
1110
|
+
const expectedResult = JSON.stringify({
|
|
1111
|
+
message: 'validation.dns.hostname.tooLongLabel', key: 'testDisplayKey', max: 63
|
|
1112
|
+
});
|
|
1113
|
+
|
|
1114
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
1115
|
+
});
|
|
1116
|
+
|
|
1117
|
+
it('"wildcardHostname" : returns expected message when wildcard character is not the first part', () => {
|
|
1118
|
+
const testValue = 'www.*.hostname.com';
|
|
1119
|
+
const formRuleResult = formRules.wildcardHostname(testValue);
|
|
1120
|
+
const expectedResult = JSON.stringify({
|
|
1121
|
+
message: 'validation.chars', key: 'testDisplayKey', count: 1, chars: '"*"'
|
|
1122
|
+
});
|
|
1123
|
+
|
|
1124
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
1125
|
+
});
|
|
1126
|
+
|
|
1127
|
+
it('"wildcardHostname" : returns expected message when wildcard character is at the beginning but not its own part', () => {
|
|
1128
|
+
const testValue = '*hostname.com';
|
|
1129
|
+
const formRuleResult = formRules.wildcardHostname(testValue);
|
|
1130
|
+
|
|
1131
|
+
const expectedResult = JSON.stringify({
|
|
1132
|
+
message: 'validation.chars', key: 'testDisplayKey', count: 1, chars: '"*"'
|
|
1133
|
+
});
|
|
1134
|
+
|
|
1135
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
1136
|
+
});
|
|
1137
|
+
|
|
1138
|
+
it('"wildcardHostname" : returns valid when wildcard character is the first part', () => {
|
|
1139
|
+
const testValue = '*.hostname.com';
|
|
1140
|
+
const formRuleResult = formRules.wildcardHostname(testValue);
|
|
1141
|
+
|
|
1142
|
+
expect(formRuleResult).toBeUndefined();
|
|
1143
|
+
});
|
|
1144
|
+
|
|
1145
|
+
it('"absolutePath" : return expected message when path doesn\'t begin with a "/"', () => {
|
|
1146
|
+
const formRuleResult = formRules.absolutePath('absolute_path');
|
|
1147
|
+
const expectedResult = JSON.stringify({ message: 'validation.path', key: 'testDisplayKey' });
|
|
1148
|
+
|
|
1149
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
1150
|
+
});
|
|
1151
|
+
|
|
1152
|
+
it('"absolutePath" : returns undefined when path begins with a "/"', () => {
|
|
1153
|
+
const formRuleResult = formRules.absolutePath('/absolute_path');
|
|
1154
|
+
|
|
1155
|
+
expect(formRuleResult).toBeUndefined();
|
|
1156
|
+
});
|
|
1157
|
+
|
|
1158
|
+
it('"testRule" : always returns the expected string', () => {
|
|
1159
|
+
const formRuleResult = formRules.testRule('');
|
|
1160
|
+
const expectedResult = 'This is an error returned by the testRule validator';
|
|
1161
|
+
|
|
1162
|
+
expect(formRuleResult).toStrictEqual(expectedResult);
|
|
1163
|
+
});
|
|
1164
|
+
|
|
1165
|
+
/**
|
|
1166
|
+
* Test all factory validators
|
|
1167
|
+
* @param rule - the name of the factory validator
|
|
1168
|
+
* @param argument - the value to validate
|
|
1169
|
+
* @param correctValues - an array of values that should pass the validation
|
|
1170
|
+
* @param wrongValues - an array of values that should fail the validation
|
|
1171
|
+
*/
|
|
1172
|
+
describe.each([
|
|
1173
|
+
['minValue', 2, [3], [1]],
|
|
1174
|
+
['maxValue', 256, [1], [300]],
|
|
1175
|
+
['betweenValues', [2, 256], [3], [1, 300]],
|
|
1176
|
+
['minLength', 2, ['test'], ['x']],
|
|
1177
|
+
['maxLength', 10, ['x'], ['wrong value']],
|
|
1178
|
+
['betweenLengths', [2, 10], ['test'], ['x', 'wrong value']],
|
|
1179
|
+
])('given factory validator %p with parameter %p', (rule, argument, correctValues, wrongValues) => {
|
|
1180
|
+
it.each(wrongValues as [])('should return error for value %p', (wrong) => {
|
|
1181
|
+
const formRuleResult = (formRules as any)[rule](argument)(wrong);
|
|
1182
|
+
|
|
1183
|
+
expect(formRuleResult).not.toBeUndefined();
|
|
1184
|
+
});
|
|
1185
|
+
|
|
1186
|
+
it.each(correctValues as [])('should return valid for value %p', (correct) => {
|
|
1187
|
+
const formRuleResult = (formRules as any)[rule](argument)(correct);
|
|
1188
|
+
|
|
1189
|
+
expect(formRuleResult).toBeUndefined();
|
|
1190
|
+
});
|
|
1191
|
+
});
|
|
1192
|
+
|
|
1193
|
+
/**
|
|
1194
|
+
* Test all standard validators
|
|
1195
|
+
* @param rule - the name of the standard validator
|
|
1196
|
+
* @param correctValues - an array of values that should pass the validation
|
|
1197
|
+
* @param wrongValues - an array of values that should fail the validation
|
|
1198
|
+
*/
|
|
1199
|
+
describe.each([
|
|
1200
|
+
['requiredInt', [2, 2.2], ['e']],
|
|
1201
|
+
['isInteger', ['2', 2, 0], [2.2, 'e', '1.0']],
|
|
1202
|
+
['isPositive', ['0', 1], [-1]],
|
|
1203
|
+
['isOctal', ['0', 0, 10], ['01']],
|
|
1204
|
+
['cronSchedule', ['0 * * * *', '@daily'], ['0 * * **']],
|
|
1205
|
+
])('given validator %p', (rule, correctValues, wrongValues) => {
|
|
1206
|
+
it.each(wrongValues as [])('should return error for value %p', (wrong) => {
|
|
1207
|
+
const formRuleResult = (formRules as any)[rule](wrong);
|
|
1208
|
+
|
|
1209
|
+
expect(formRuleResult).not.toBeUndefined();
|
|
1210
|
+
});
|
|
1211
|
+
|
|
1212
|
+
it.each(correctValues as [])('should return valid for value %p', (correct) => {
|
|
1213
|
+
const formRuleResult = (formRules as any)[rule](correct);
|
|
1214
|
+
|
|
1215
|
+
expect(formRuleResult).toBeUndefined();
|
|
1216
|
+
});
|
|
1217
|
+
});
|
|
1218
|
+
});
|