From d7456fe4c1c2b882d50664c81570354c2c427f9d Mon Sep 17 00:00:00 2001 From: Nicholas openSUSE Software Engineer Date: Mon, 11 Nov 2024 19:16:51 -0300 Subject: [PATCH] [dev-v2.9] forward-port after 2.8.10 to dev 2.9 (#4736) --- .../elemental-crd-103.4.1+up1.6.5.tgz | Bin 0 -> 19683 bytes .../elemental/elemental-103.4.1+up1.6.5.tgz | Bin 0 -> 3978 bytes .../fleet-agent-103.1.10+up0.9.11.tgz | Bin 0 -> 3203 bytes .../fleet-crd/fleet-crd-103.1.10+up0.9.11.tgz | Bin 0 -> 50474 bytes assets/fleet/fleet-103.1.10+up0.9.11.tgz | Bin 0 -> 5340 bytes .../rancher-cis-benchmark-crd-5.6.0.tgz | Bin 0 -> 1463 bytes .../rancher-cis-benchmark-5.6.0.tgz | Bin 0 -> 7256 bytes .../rancher-webhook-103.0.12+up0.4.13.tgz | Bin 0 -> 2801 bytes ...ui-plugin-operator-crd-103.0.3+up0.2.2.tgz | Bin 0 -> 822 bytes .../ui-plugin-operator-103.0.3+up0.2.2.tgz | Bin 0 -> 4351 bytes .../elemental-crd/103.4.1+up1.6.5/Chart.yaml | 11 + .../103.4.1+up1.6.5/templates/crds.yaml | 3747 ++++++++ .../validate-no-pending-deletions.yaml | 17 + charts/elemental/103.4.1+up1.6.5/Chart.yaml | 20 + charts/elemental/103.4.1+up1.6.5/README.md | 5 + .../elemental/103.4.1+up1.6.5/app-readme.md | 5 + .../elemental/103.4.1+up1.6.5/questions.yaml | 27 + .../103.4.1+up1.6.5/templates/_helpers.tpl | 17 + .../103.4.1+up1.6.5/templates/apiservice.yaml | 9 + .../103.4.1+up1.6.5/templates/capi_rbac.yaml | 10 + .../templates/channel-dev.yaml | 13 + .../103.4.1+up1.6.5/templates/channels.yaml | 30 + .../templates/cluster_role.yaml | 268 + .../templates/cluster_role_binding.yaml | 13 + .../103.4.1+up1.6.5/templates/deployment.yaml | 50 + .../103.4.1+up1.6.5/templates/globalrole.yaml | 16 + .../103.4.1+up1.6.5/templates/metadata.yaml | 10 + .../templates/serviceaccount.yaml | 4 + .../templates/validate-install-crd.yaml | 26 + charts/elemental/103.4.1+up1.6.5/values.yaml | 43 + .../fleet-agent/103.1.10+up0.9.11/Chart.yaml | 15 + .../fleet-agent/103.1.10+up0.9.11/README.md | 8 + .../103.1.10+up0.9.11/templates/_helpers.tpl | 22 + .../templates/configmap.yaml | 13 + .../templates/deployment.yaml | 51 + .../templates/network_policy_allow_all.yaml | 15 + .../patch_default_serviceaccount.yaml | 28 + .../103.1.10+up0.9.11/templates/rbac.yaml | 28 + .../103.1.10+up0.9.11/templates/secret.yaml | 10 + .../templates/serviceaccount.yaml | 4 + .../103.1.10+up0.9.11/templates/validate.yaml | 11 + .../fleet-agent/103.1.10+up0.9.11/values.yaml | 67 + charts/fleet-crd/103.1.10+up0.9.11/Chart.yaml | 13 + charts/fleet-crd/103.1.10+up0.9.11/README.md | 5 + .../103.1.10+up0.9.11/templates/crds.yaml | 6859 +++++++++++++++ .../templates/gitjobs-crds.yaml | 7690 +++++++++++++++++ .../fleet-crd/103.1.10+up0.9.11/values.yaml | 1 + charts/fleet/103.1.10+up0.9.11/Chart.yaml | 22 + charts/fleet/103.1.10+up0.9.11/README.md | 30 + .../charts/gitjob/.helmignore | 23 + .../charts/gitjob/Chart.yaml | 5 + .../charts/gitjob/templates/_helpers.tpl | 7 + .../charts/gitjob/templates/clusterrole.yaml | 38 + .../gitjob/templates/clusterrolebinding.yaml | 12 + .../charts/gitjob/templates/deployment.yaml | 52 + .../charts/gitjob/templates/leases.yaml | 23 + .../charts/gitjob/templates/service.yaml | 12 + .../gitjob/templates/serviceaccount.yaml | 4 + .../charts/gitjob/values.yaml | 27 + .../103.1.10+up0.9.11/templates/_helpers.tpl | 22 + .../templates/configmap.yaml | 26 + .../templates/deployment.yaml | 102 + .../job_cleanup_clusterregistrations.yaml | 40 + .../103.1.10+up0.9.11/templates/rbac.yaml | 114 + .../templates/serviceaccount.yaml | 12 + charts/fleet/103.1.10+up0.9.11/values.yaml | 87 + .../5.6.0/Chart.yaml | 10 + .../rancher-cis-benchmark-crd/5.6.0/README.md | 2 + .../5.6.0/templates/clusterscan.yaml | 148 + .../5.6.0/templates/clusterscanbenchmark.yaml | 54 + .../5.6.0/templates/clusterscanprofile.yaml | 36 + .../5.6.0/templates/clusterscanreport.yaml | 39 + charts/rancher-cis-benchmark/5.6.0/Chart.yaml | 22 + charts/rancher-cis-benchmark/5.6.0/README.md | 9 + .../rancher-cis-benchmark/5.6.0/app-readme.md | 55 + .../5.6.0/templates/_helpers.tpl | 27 + .../5.6.0/templates/alertingrule.yaml | 14 + .../5.6.0/templates/benchmark-aks-1.0.yaml | 8 + .../5.6.0/templates/benchmark-cis-1.7.yaml | 9 + .../5.6.0/templates/benchmark-cis-1.8.yaml | 8 + .../5.6.0/templates/benchmark-eks-1.2.0.yaml | 8 + .../5.6.0/templates/benchmark-gke-1.2.0.yaml | 8 + .../benchmark-k3s-cis-1.7-hardened.yaml | 9 + .../benchmark-k3s-cis-1.7-permissive.yaml | 9 + .../benchmark-k3s-cis-1.8-hardened.yaml | 8 + .../benchmark-k3s-cis-1.8-permissive.yaml | 8 + .../benchmark-rke-cis-1.7-hardened.yaml | 9 + .../benchmark-rke-cis-1.7-permissive.yaml | 9 + .../benchmark-rke-cis-1.8-hardened.yaml | 8 + .../benchmark-rke-cis-1.8-permissive.yaml | 8 + .../benchmark-rke2-cis-1.7-hardened.yaml | 9 + .../benchmark-rke2-cis-1.7-permissive.yaml | 9 + .../benchmark-rke2-cis-1.8-hardened.yaml | 8 + .../benchmark-rke2-cis-1.8-permissive.yaml | 8 + .../5.6.0/templates/cis-roles.yaml | 49 + .../5.6.0/templates/configmap.yaml | 18 + .../5.6.0/templates/deployment.yaml | 61 + .../templates/network_policy_allow_all.yaml | 15 + .../patch_default_serviceaccount.yaml | 29 + .../5.6.0/templates/psp.yaml | 59 + .../5.6.0/templates/rbac.yaml | 219 + .../5.6.0/templates/scanprofile-cis-1.7.yaml | 9 + .../5.6.0/templates/scanprofile-cis-1.8.yaml | 9 + .../scanprofile-k3s-cis-1.7-hardened.yml | 9 + .../scanprofile-k3s-cis-1.7-permissive.yml | 9 + .../scanprofile-k3s-cis-1.8-hardened.yml | 9 + .../scanprofile-k3s-cis-1.8-permissive.yml | 9 + .../scanprofile-rke-1.7-hardened.yaml | 9 + .../scanprofile-rke-1.7-permissive.yaml | 9 + .../scanprofile-rke-1.8-hardened.yaml | 9 + .../scanprofile-rke-1.8-permissive.yaml | 9 + .../scanprofile-rke2-cis-1.7-hardened.yml | 9 + .../scanprofile-rke2-cis-1.7-permissive.yml | 9 + .../scanprofile-rke2-cis-1.8-hardened.yml | 9 + .../scanprofile-rke2-cis-1.8-permissive.yml | 9 + .../5.6.0/templates/scanprofileaks.yml | 9 + .../5.6.0/templates/scanprofileeks.yml | 9 + .../5.6.0/templates/scanprofilegke.yml | 9 + .../5.6.0/templates/serviceaccount.yaml | 14 + .../5.6.0/templates/validate-install-crd.yaml | 17 + .../5.6.0/templates/validate-psp-install.yaml | 7 + .../rancher-cis-benchmark/5.6.0/values.yaml | 55 + .../103.0.12+up0.4.13/Chart.yaml | 14 + .../103.0.12+up0.4.13/templates/_helpers.tpl | 22 + .../templates/deployment.yaml | 82 + .../103.0.12+up0.4.13/templates/rbac.yaml | 12 + .../103.0.12+up0.4.13/templates/secret.yaml | 11 + .../103.0.12+up0.4.13/templates/service.yaml | 13 + .../templates/serviceaccount.yaml | 11 + .../103.0.12+up0.4.13/templates/webhook.yaml | 9 + .../103.0.12+up0.4.13/tests/README.md | 16 + .../tests/deployment_test.yaml | 73 + .../103.0.12+up0.4.13/tests/service_test.yaml | 18 + .../103.0.12+up0.4.13/values.yaml | 30 + .../103.0.3+up0.2.2/Chart.yaml | 10 + .../103.0.3+up0.2.2/README.md | 2 + .../103.0.3+up0.2.2/templates/crds.yaml | 61 + .../103.0.3+up0.2.2/Chart.yaml | 19 + .../103.0.3+up0.2.2/app-readme.md | 21 + .../103.0.3+up0.2.2/templates/_helpers.tpl | 89 + .../templates/dashboardrole.yaml | 33 + .../103.0.3+up0.2.2/templates/deployment.yaml | 67 + .../103.0.3+up0.2.2/templates/hardened.yaml | 123 + .../103.0.3+up0.2.2/templates/service.yaml | 15 + .../templates/serviceaccount.yaml | 101 + .../templates/validate-psp-install.yaml | 7 + .../103.0.3+up0.2.2/values.yaml | 69 + index.yaml | 196 + release.yaml | 72 +- 149 files changed, 22233 insertions(+), 57 deletions(-) create mode 100644 assets/elemental-crd/elemental-crd-103.4.1+up1.6.5.tgz create mode 100644 assets/elemental/elemental-103.4.1+up1.6.5.tgz create mode 100644 assets/fleet-agent/fleet-agent-103.1.10+up0.9.11.tgz create mode 100644 assets/fleet-crd/fleet-crd-103.1.10+up0.9.11.tgz create mode 100644 assets/fleet/fleet-103.1.10+up0.9.11.tgz create mode 100644 assets/rancher-cis-benchmark-crd/rancher-cis-benchmark-crd-5.6.0.tgz create mode 100644 assets/rancher-cis-benchmark/rancher-cis-benchmark-5.6.0.tgz create mode 100644 assets/rancher-webhook/rancher-webhook-103.0.12+up0.4.13.tgz create mode 100644 assets/ui-plugin-operator-crd/ui-plugin-operator-crd-103.0.3+up0.2.2.tgz create mode 100644 assets/ui-plugin-operator/ui-plugin-operator-103.0.3+up0.2.2.tgz create mode 100644 charts/elemental-crd/103.4.1+up1.6.5/Chart.yaml create mode 100644 charts/elemental-crd/103.4.1+up1.6.5/templates/crds.yaml create mode 100644 charts/elemental-crd/103.4.1+up1.6.5/templates/validate-no-pending-deletions.yaml create mode 100644 charts/elemental/103.4.1+up1.6.5/Chart.yaml create mode 100644 charts/elemental/103.4.1+up1.6.5/README.md create mode 100644 charts/elemental/103.4.1+up1.6.5/app-readme.md create mode 100644 charts/elemental/103.4.1+up1.6.5/questions.yaml create mode 100644 charts/elemental/103.4.1+up1.6.5/templates/_helpers.tpl create mode 100644 charts/elemental/103.4.1+up1.6.5/templates/apiservice.yaml create mode 100644 charts/elemental/103.4.1+up1.6.5/templates/capi_rbac.yaml create mode 100644 charts/elemental/103.4.1+up1.6.5/templates/channel-dev.yaml create mode 100644 charts/elemental/103.4.1+up1.6.5/templates/channels.yaml create mode 100644 charts/elemental/103.4.1+up1.6.5/templates/cluster_role.yaml create mode 100644 charts/elemental/103.4.1+up1.6.5/templates/cluster_role_binding.yaml create mode 100644 charts/elemental/103.4.1+up1.6.5/templates/deployment.yaml create mode 100644 charts/elemental/103.4.1+up1.6.5/templates/globalrole.yaml create mode 100644 charts/elemental/103.4.1+up1.6.5/templates/metadata.yaml create mode 100644 charts/elemental/103.4.1+up1.6.5/templates/serviceaccount.yaml create mode 100644 charts/elemental/103.4.1+up1.6.5/templates/validate-install-crd.yaml create mode 100644 charts/elemental/103.4.1+up1.6.5/values.yaml create mode 100644 charts/fleet-agent/103.1.10+up0.9.11/Chart.yaml create mode 100644 charts/fleet-agent/103.1.10+up0.9.11/README.md create mode 100644 charts/fleet-agent/103.1.10+up0.9.11/templates/_helpers.tpl create mode 100644 charts/fleet-agent/103.1.10+up0.9.11/templates/configmap.yaml create mode 100644 charts/fleet-agent/103.1.10+up0.9.11/templates/deployment.yaml create mode 100644 charts/fleet-agent/103.1.10+up0.9.11/templates/network_policy_allow_all.yaml create mode 100644 charts/fleet-agent/103.1.10+up0.9.11/templates/patch_default_serviceaccount.yaml create mode 100644 charts/fleet-agent/103.1.10+up0.9.11/templates/rbac.yaml create mode 100644 charts/fleet-agent/103.1.10+up0.9.11/templates/secret.yaml create mode 100644 charts/fleet-agent/103.1.10+up0.9.11/templates/serviceaccount.yaml create mode 100644 charts/fleet-agent/103.1.10+up0.9.11/templates/validate.yaml create mode 100644 charts/fleet-agent/103.1.10+up0.9.11/values.yaml create mode 100644 charts/fleet-crd/103.1.10+up0.9.11/Chart.yaml create mode 100644 charts/fleet-crd/103.1.10+up0.9.11/README.md create mode 100644 charts/fleet-crd/103.1.10+up0.9.11/templates/crds.yaml create mode 100644 charts/fleet-crd/103.1.10+up0.9.11/templates/gitjobs-crds.yaml create mode 100644 charts/fleet-crd/103.1.10+up0.9.11/values.yaml create mode 100644 charts/fleet/103.1.10+up0.9.11/Chart.yaml create mode 100644 charts/fleet/103.1.10+up0.9.11/README.md create mode 100644 charts/fleet/103.1.10+up0.9.11/charts/gitjob/.helmignore create mode 100644 charts/fleet/103.1.10+up0.9.11/charts/gitjob/Chart.yaml create mode 100644 charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/_helpers.tpl create mode 100644 charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/clusterrole.yaml create mode 100644 charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/clusterrolebinding.yaml create mode 100644 charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/deployment.yaml create mode 100644 charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/leases.yaml create mode 100644 charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/service.yaml create mode 100644 charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/serviceaccount.yaml create mode 100644 charts/fleet/103.1.10+up0.9.11/charts/gitjob/values.yaml create mode 100644 charts/fleet/103.1.10+up0.9.11/templates/_helpers.tpl create mode 100644 charts/fleet/103.1.10+up0.9.11/templates/configmap.yaml create mode 100644 charts/fleet/103.1.10+up0.9.11/templates/deployment.yaml create mode 100644 charts/fleet/103.1.10+up0.9.11/templates/job_cleanup_clusterregistrations.yaml create mode 100644 charts/fleet/103.1.10+up0.9.11/templates/rbac.yaml create mode 100644 charts/fleet/103.1.10+up0.9.11/templates/serviceaccount.yaml create mode 100644 charts/fleet/103.1.10+up0.9.11/values.yaml create mode 100644 charts/rancher-cis-benchmark-crd/5.6.0/Chart.yaml create mode 100644 charts/rancher-cis-benchmark-crd/5.6.0/README.md create mode 100644 charts/rancher-cis-benchmark-crd/5.6.0/templates/clusterscan.yaml create mode 100644 charts/rancher-cis-benchmark-crd/5.6.0/templates/clusterscanbenchmark.yaml create mode 100644 charts/rancher-cis-benchmark-crd/5.6.0/templates/clusterscanprofile.yaml create mode 100644 charts/rancher-cis-benchmark-crd/5.6.0/templates/clusterscanreport.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/Chart.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/README.md create mode 100644 charts/rancher-cis-benchmark/5.6.0/app-readme.md create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/_helpers.tpl create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/alertingrule.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/benchmark-aks-1.0.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/benchmark-cis-1.7.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/benchmark-cis-1.8.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/benchmark-eks-1.2.0.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/benchmark-gke-1.2.0.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/benchmark-k3s-cis-1.7-hardened.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/benchmark-k3s-cis-1.7-permissive.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/benchmark-k3s-cis-1.8-hardened.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/benchmark-k3s-cis-1.8-permissive.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke-cis-1.7-hardened.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke-cis-1.7-permissive.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke-cis-1.8-hardened.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke-cis-1.8-permissive.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke2-cis-1.7-hardened.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke2-cis-1.7-permissive.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke2-cis-1.8-hardened.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke2-cis-1.8-permissive.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/cis-roles.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/configmap.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/deployment.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/network_policy_allow_all.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/patch_default_serviceaccount.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/psp.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/rbac.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-cis-1.7.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-cis-1.8.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-k3s-cis-1.7-hardened.yml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-k3s-cis-1.7-permissive.yml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-k3s-cis-1.8-hardened.yml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-k3s-cis-1.8-permissive.yml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke-1.7-hardened.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke-1.7-permissive.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke-1.8-hardened.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke-1.8-permissive.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke2-cis-1.7-hardened.yml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke2-cis-1.7-permissive.yml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke2-cis-1.8-hardened.yml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke2-cis-1.8-permissive.yml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/scanprofileaks.yml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/scanprofileeks.yml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/scanprofilegke.yml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/serviceaccount.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/validate-install-crd.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/templates/validate-psp-install.yaml create mode 100644 charts/rancher-cis-benchmark/5.6.0/values.yaml create mode 100644 charts/rancher-webhook/103.0.12+up0.4.13/Chart.yaml create mode 100644 charts/rancher-webhook/103.0.12+up0.4.13/templates/_helpers.tpl create mode 100644 charts/rancher-webhook/103.0.12+up0.4.13/templates/deployment.yaml create mode 100644 charts/rancher-webhook/103.0.12+up0.4.13/templates/rbac.yaml create mode 100644 charts/rancher-webhook/103.0.12+up0.4.13/templates/secret.yaml create mode 100644 charts/rancher-webhook/103.0.12+up0.4.13/templates/service.yaml create mode 100644 charts/rancher-webhook/103.0.12+up0.4.13/templates/serviceaccount.yaml create mode 100644 charts/rancher-webhook/103.0.12+up0.4.13/templates/webhook.yaml create mode 100644 charts/rancher-webhook/103.0.12+up0.4.13/tests/README.md create mode 100644 charts/rancher-webhook/103.0.12+up0.4.13/tests/deployment_test.yaml create mode 100644 charts/rancher-webhook/103.0.12+up0.4.13/tests/service_test.yaml create mode 100644 charts/rancher-webhook/103.0.12+up0.4.13/values.yaml create mode 100644 charts/ui-plugin-operator-crd/103.0.3+up0.2.2/Chart.yaml create mode 100644 charts/ui-plugin-operator-crd/103.0.3+up0.2.2/README.md create mode 100644 charts/ui-plugin-operator-crd/103.0.3+up0.2.2/templates/crds.yaml create mode 100644 charts/ui-plugin-operator/103.0.3+up0.2.2/Chart.yaml create mode 100644 charts/ui-plugin-operator/103.0.3+up0.2.2/app-readme.md create mode 100644 charts/ui-plugin-operator/103.0.3+up0.2.2/templates/_helpers.tpl create mode 100644 charts/ui-plugin-operator/103.0.3+up0.2.2/templates/dashboardrole.yaml create mode 100644 charts/ui-plugin-operator/103.0.3+up0.2.2/templates/deployment.yaml create mode 100644 charts/ui-plugin-operator/103.0.3+up0.2.2/templates/hardened.yaml create mode 100644 charts/ui-plugin-operator/103.0.3+up0.2.2/templates/service.yaml create mode 100644 charts/ui-plugin-operator/103.0.3+up0.2.2/templates/serviceaccount.yaml create mode 100644 charts/ui-plugin-operator/103.0.3+up0.2.2/templates/validate-psp-install.yaml create mode 100644 charts/ui-plugin-operator/103.0.3+up0.2.2/values.yaml diff --git a/assets/elemental-crd/elemental-crd-103.4.1+up1.6.5.tgz b/assets/elemental-crd/elemental-crd-103.4.1+up1.6.5.tgz new file mode 100644 index 0000000000000000000000000000000000000000..e52b652e89624184ad71672b0889d77ab3e64b75 GIT binary patch literal 19683 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 literal 0 HcmV?d00001 diff --git a/assets/elemental/elemental-103.4.1+up1.6.5.tgz b/assets/elemental/elemental-103.4.1+up1.6.5.tgz new file mode 100644 index 0000000000000000000000000000000000000000..609c5bcc1a246ea17c2510af996a89d2dedf9a97 GIT binary patch literal 3978 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 literal 0 HcmV?d00001 diff --git a/assets/fleet-crd/fleet-crd-103.1.10+up0.9.11.tgz b/assets/fleet-crd/fleet-crd-103.1.10+up0.9.11.tgz new file mode 100644 index 0000000000000000000000000000000000000000..7b70f0319ae462cef6e05e2d71e8f79572b932a2 GIT binary patch literal 50474 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 FzW{y!3UdGe literal 0 HcmV?d00001 diff --git a/assets/fleet/fleet-103.1.10+up0.9.11.tgz b/assets/fleet/fleet-103.1.10+up0.9.11.tgz new file mode 100644 index 0000000000000000000000000000000000000000..12d0e8d297e97de1e91bbafa6330f34b173f606a GIT binary patch literal 5340 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 literal 0 HcmV?d00001 diff --git a/assets/rancher-cis-benchmark-crd/rancher-cis-benchmark-crd-5.6.0.tgz b/assets/rancher-cis-benchmark-crd/rancher-cis-benchmark-crd-5.6.0.tgz new file mode 100644 index 0000000000000000000000000000000000000000..135ee14a45c140f982a7f23c285f83915851a5b2 GIT binary patch literal 1463 zcmV;o1xWfIiwG0|00000|0w_~VMtOiV@ORlOnEsqVl!4SWK%V1T2nbTPgYhoO;>Dc zVQyr3R8em|NM&qo0PI>(bK*7-&NIJ4bA85V6CfSla@@6ZZ7-K0>GgS$H=v6xd8BoE zOsD_7BijkKu`vciu5;`QgCu_|+24LEt*t@wCF(vGrawo?mm%oKKG*)+=@K+KD+q&& z1I=|^cRU;>zpm?+f8Ei*z3_%t-f%c{FUOY`t~YkC+zaL&>UbB64S~LJ5B61F-2cQt zN<~0INi*p&#(^ME3x@+yfR0daIcgFQ0{scgxKcT6DSRL0guNjhGlF4M7kXMoVPV z*?Yqtl&;2ddQFaK72$+I6a|7OcdhsI?04jh9k=(|&$F%7$3I~h1wd%t@*p;Z+HjD2 z>B08+_uPT!72|*4U5>nS{GY<|kpq#yZ-mnRGtT4B#)jaN*LxJwpRj3cNQE;rD%Kp| zW+g?=32n_leIx`tA!-gQx(La z%x2bSUyYKtK+6ep3<1T)3Bb@SmUf=ET0MvWZy-#;p6^O-DcO*$I~5f}TF6DM0~3cK z=#@i?ASmG8=UQ4pMPN(;>2}@F3g`huaZ10e8(IOGM-df(?$!;hfc^$83qXIZ8(INL zMc1j?&x7LQyivq9x^}|OxNnz+e=G$1YOPH{K{!NGQC5G_asUnouw;#V;-W8e|i?q%5B-S{|#hDhY zt$JMQs1R7?ZpLIB1olDXqBw6Gi_1fA+_%>7^%J+2e+pIojqnXCu%?kvTFsiOSW>l@ z6v7JHA`!{5*_(VFpr+X&6Wx9|~a_XCJ&S~k|_9b`Cq_ZI2G4yWm8`;pfu3**vQFr&u zH6a(4Ze2$;S2E4v6)Y5lVI?`6sB4w`UV}6VveoE1zU>evjUk=-`!n)^@c6z$G{)|N zj_O1s7$uMEql(>K`$z^H(Zg0L+9@bNYgm=~d|{#hRvl+I)LQ9n38!9jw{q_AoM@SF zG;n&+flAqDjmzKijH^!*UCLv5585TRnx{vsUs0k?swA7}+qNRv-n(O(+Qhowwy1Ch z*bl-c`#tw$kD}t?>~dvtQrz!SdwkmG%34ZSb`%<4yAbk&TFd(1x>VYt5ZF-vA6yN` zrTX9HU^qC}|4w1YuK&Fdro%$uyJyU#yP_hvcKW)d!3epNP3u;xC*i+HW}zZj>f52z z6AJlzJVz~&&}7fAfc&X`z%KCctpUD%zz*;{VbaS}OiM1GAlj&y?lAB`cgg#xoqgs< zf7jKr66rcUS8usLr}C4&MeNX772!L@uL#HP@DJHswaoufdKzi>8n7Y%d!xZ+DgO_y zhUfSHC$VGa|BNslX8-)Vvx?mR?6CXH|2+x(OQ;?}tn7*N9u2iAoHmwIwiZ+NENC_B z9@}HXR=%}`-NC!+&cf??~_X4;Cl(10}L!*0@um{dV{H=7jtBBgB8b{?9&KzyI{X3H^h8G=2Z; z4F{#~e@DZ?x&C(&`)SL^uGegq_A$N$O^lX6Ol*8k8yoc5d{y^J?Q5^_Y-c;$+0IsF R{{;X5|NnDfFsuMH008-_>)HSS literal 0 HcmV?d00001 diff --git a/assets/rancher-cis-benchmark/rancher-cis-benchmark-5.6.0.tgz b/assets/rancher-cis-benchmark/rancher-cis-benchmark-5.6.0.tgz new file mode 100644 index 0000000000000000000000000000000000000000..b6628f5a8af70f58910803629bbcdf9cfc889c47 GIT binary patch literal 7256 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 literal 0 HcmV?d00001 diff --git a/assets/rancher-webhook/rancher-webhook-103.0.12+up0.4.13.tgz b/assets/rancher-webhook/rancher-webhook-103.0.12+up0.4.13.tgz new file mode 100644 index 0000000000000000000000000000000000000000..7e800d01d4280cbea21a028957d5955956ab9900 GIT binary patch literal 2801 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 DDn@;< literal 0 HcmV?d00001 diff --git a/assets/ui-plugin-operator-crd/ui-plugin-operator-crd-103.0.3+up0.2.2.tgz b/assets/ui-plugin-operator-crd/ui-plugin-operator-crd-103.0.3+up0.2.2.tgz new file mode 100644 index 0000000000000000000000000000000000000000..101a3f93d3f26b5d6dbd064d4ab0b26d044559ba GIT binary patch literal 822 zcmV-61Ihd!iwG0|00000|0w_~VMtOiV@ORlOnEsqVl!4SWK%V1T2nbTPgYhoO;>Dc zVQyr3R8em|NM&qo0PI&yZ{s!)^;y4Suss%5sMt;l-2!I|Vsjsp6N?*)B*>B5 zpy+=u^x?)IQk+GyyI4T)B4{+6c|-Dz$VyMWsn*&~ou`28!c+!zwk$Ak`h=yKyd6Ra zaWS7aPa(wNQ!LIGlWcx*DdySY@G;WngNko#1Sj-A6XN_p z|Ch7Ni&6jI1G~aOujy|lTffEh@wZsZZ<8gD+NvCuRb*G*QFK+1bWIQ1>P7}7F)C!N z`^Q#6?VgJ1k(`t0N!Fh0;3}UV>%9xobR&Q^_2--0CSGImrV40wk~G$+?Yc4;p6v;M z4-_eE=(Bya?l1ehCZl2w4`?DK08zSH(tmFIl1czNO*iSMfJ!wrqPY#)GKHlxRcSkN zQ}_~{y+tl^Nb9=Nu2-dX1&zygMq2(&s?OfFlgL5abx$-#u43A;*$Z{QXM0tc`mxXF z(~jjRMC-E2+KH6~m6&(F&Xc{my}6%#+B4TvUH1>x+l6bfUF>J{`*rKO*7nf)(uf*l zm3P{5-!}kT8G|cBIn=+UUYDcl_p!UVkFmQyUSj!5E+^T1MMZA)g(UYlG^_iKX3M%I z%3>gVJ9g!qA+$Xn+u!Lo;Wjua10P!Dyms%(y6Q$#$LvoqA7tH2?8w;kH?Dc zVQyr3R8em|NM&qo0PH;Na@#nP^P5l6MbDNKk4Z`XN=~&iRbJ2BtnX$rDm&S&t!yfR z$d-gN2yg*Vw$5?Y{lB-oC%M80DUzaP$M)E{Tcc7j1pUcpi_RYhTe!t&8*xR#z`~80V?_lSk|IJ|U;8lO`VDQSc8|=N>d-VlJI1Pva?xARnEvF;v~Z%ygP=G9R+^#qjYvUE5;bjQ7S6<5H^4K z9tQE?Anr$f_#+JBoqsWpo1I zZ8)bq73Zq6xu-{S20QU*_b_yb(d?Ja`vPg6x zF}N04y~uG`?;KP#8T5DKe!Tl#k@w@Bcqe%3{qp~2$;jrBNP_%-}-mA-wL}A>|bH$XC4X2Z2$TDj|&Wsp*Z} zkR=_$gfN8xKt}nAo4+!12gt}pt)jn#dNg|XPE$tz)5^pV$^^MKgfc^yM6^HxiAoeQ zK{bTSD}#MfNU9e{f@{3cma+vuRBr@75ke0^%L2>FcM7E)xE};uq3r^6$t*23o1c_xlqAt`PW22%Qe>!SSSUC; zQQL4N_=HY>CAr$R`1<`*joE>jMdWZgl{j6Gi$BIY@wNg+N=R=-$sKmuZb;uO zSNTsR;cBSlDsQl)Vbc`H#k3@^{qYOVkqx2$Pi|3k=>JMm_dd>$5X8hjCpHieZ1t|Lg3HUu>{`kZ!d0G$ zO}7xDWkb8YV;4$zV_?RAab{&*)xu}9Z+QX-yY`W0r^RGKFCdIU@UW1l<}t8{dPzsB z5sdO)z&{GYtdnVc2s?#1_$xZtw!JnZnCU1OV?qjrphSl7@5LA;M~%u&d_s|>3XDO+ zXhw~pqXlSV1ict9EKz=Zb86aBJ_VIy@-hyNC*a*N2P6?(6UvpNpR1!r(lTZ&qr%ul z#F$hDd5`UFXj~d9OFGj@Mb@?zQ!uggz&o%!jIvXZ!D2zf;(i@t&nw19kw%MS*&I~JAolwUIOI_ zE7G;oj2$9tn<{UL{^AFVYh2}Na9Bk)%sZ0j@maO0V=8)8B;oS1qswRbM1?Be^jg78if z5NF&PSy?E&}M`n+p$r5qsi58ZZjZG&+TVT{HharHGH)9}!_kY`MgR6%0Bx-o)EW|$VN)WuRQb&bPm10X}+*HqwSf{7kN_(q)i@lAEfT0;nbGL}c!CQT;-9H5WtV|7Mon5K z5|cvDg!D1T`0TYaq6Wbk<>?Sk1j8UhO;V!CFaW4bk-B+$brn^tO)ka5x zw~}07i{yC+&_EV8^c4Zg>CaLWxosY~c;PYxYU{j)R=r$`i$(3d9oF}oX`K&O#<4X` zMIYxvYPh-zm;KZicbuaf`;j-dHiIaNf;*7^Pn4&WPoHoV1j7@Ym^S4)tU*2isIks% zP*uhFKQPgDpiaS*8*_B^vxZjNZYFJ`9ivu@CxrzK3H3F6c z*vw0bZ8MGLKv)snJf5@ct;OF+#u_8PUUq9t*A&*6-~DD-jZ>~w=ZxCP*Cj41Y1#Ws ztd+2=g+w}iuNAN@kGl@e$EQk!x>|gOHmnA6joj%qxHa6VmL?keT^c^3~Wc#tTs~fBthAr z#Wbx(HJ<5rGCtTWF{5+jsMJV`F%BEAz!Lsv)a`13oaosQdaLzzHCpSn0TM|{f9Fve zeh+ks;_}2sO|6t?IPNBTpW0}7E)Q1L+W#{mQ{8 z<#ufhK-mm0O*Dib`(am*z$K)XKEv2p&r7G_-^BP%nwecSyi@~I>#t~QTSWT-L9t?~|sU@KLTB#0@d+c3t7kQmu&o1vnDSB}hj zN8lFpfe!QiW(qW|^IO?^?Ln_K-a3yG)?U>P6jmxq6RAtn=nc;8X8_P?SsIR%gijH^ z{kRR^a?6u-7OgZ=X(p9;N0*njeNEGQGx2s-;J6 zH$SY;)8;C#$0zDT!~0DqMK(V)hPU-;x#4URipn6X*rQA#DCyD1A~>qnkD?`3vR6MWdZQML+l)72Uk zS}D~CGRocO2Cih}Vh9KO`@8!Az(l!?_CVl_*ZUi13p25Qr3`(-rXtB)up%pgMX;%C z9B{K82e`=yXm2g<7KifbiVXAXb}gHEeHqzP^5*{)?(%j;#UO@vYoAE~P(GEYN?~kj zuwCJH!P`Y%%Iss;$3Fk$9v|DwUhDsrIm~;03U-74*FPAvzyEr*yZ8M4*Q1nmy6GwM zKJH_yjy$?~;l`^4Od}r>yFTw;M&fIqX>|dwUN5_JMN%7K*=8E)J{gt0rwgjxX8(JG z_|9VB#{BQjUOWH$YUers`zYmiI{))KpZbCKVc7Pd!o+^HmXTbAHOJ|FxD|eQgtInZ z{Rx|UI6Zgtbsjzn@cXmX%2f+3KC`x3L7mK0&0jsGi7wO%@3lq{LZ+10>CrWYoz^O> z$MWC50(QQYPyhH_eGd=*A&FY|*KZSs`hDE-hn&%~^Zk`L-%o9mJeS8SYwiCzVKgNg zqg>@>w(JgGz>WTYzjgoD&fwMVbN=^H%7)h=Qw=W|a(KanI4g1p*I5=Jgf-TDX&9Z36j1Iy3U{CQy8JKXQY47Rz>32qA-qhz?)jr`KzK9+`?n^%B7o%(d#3dD&hr z(y095kAw7HI!Q7{z602RLpB zR)4L=HW0q3z_?2~K+lMVbE1GKB@#-^tSq9Y?dWt=yM}3XfhdOwnHzFWfPkWW$`ITH z9r)q8`7YP7h5W>DZ$-p9CwH=LsW>cFX4$Q7nNtD;KFyG2C8$sE0_VsLVa)&;;RRuA z0SQCGp~#nWeQDUKyljMFspI}^fR&e&SbiBxafTd}CK@f>tV+WQUsWVCN8?E$?T)uF zoRYA6)ed1asgVru!XwN*SAN=VO<@~QC-KYJP^zMpbPKJ(sA#2&09nOj1 z%6?H^lQ?FRn*A^n=Z3r$F)ZB1jGd389K*fK1viXnWyLzKE-w+=uHEKgC+)bXgVEgg zQkWX7s5b0BBW$u12c=l6uGKS@YQm^1^OXd*7L9WVod**bdW-DkDqp zBiTp^r1!GCSk2#CQ&~gTu7^P^GfbVLCX_W6$i`=lR#>il ty?%w{Ia@RvoNB^TB2yJVxq']`, `metadata.annotations['']`, + spec.nodeName, spec.serviceAccountName, status.hostIP, status.podIP, status.podIPs. + properties: + apiVersion: + description: Version of the schema the FieldPath + is written in terms of, defaults to "v1". + type: string + fieldPath: + description: Path of the field to select in the + specified API version. + type: string + required: + - fieldPath + type: object + x-kubernetes-map-type: atomic + resourceFieldRef: + description: |- + Selects a resource of the container: only resources limits and requests + (limits.cpu, limits.memory, limits.ephemeral-storage, requests.cpu, requests.memory and requests.ephemeral-storage) are currently supported. + properties: + containerName: + description: 'Container name: required for volumes, + optional for env vars' + type: string + divisor: + anyOf: + - type: integer + - type: string + description: Specifies the output format of the + exposed resources, defaults to "1" + pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ + x-kubernetes-int-or-string: true + resource: + description: 'Required: resource to select' + type: string + required: + - resource + type: object + x-kubernetes-map-type: atomic + secretKeyRef: + description: Selects a key of a secret in the pod's + namespace + properties: + key: + description: The key of the secret to select from. Must + be a valid secret key. + type: string + name: + description: |- + Name of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names + TODO: Add other useful fields. apiVersion, kind, uid? + type: string + optional: + description: Specify whether the Secret or its key + must be defined + type: boolean + required: + - key + type: object + x-kubernetes-map-type: atomic + type: object + required: + - name + type: object + type: array + image: + type: string + securityContext: + description: |- + SecurityContext holds security configuration that will be applied to a container. + Some fields are present in both SecurityContext and PodSecurityContext. When both + are set, the values in SecurityContext take precedence. + properties: + allowPrivilegeEscalation: + description: |- + AllowPrivilegeEscalation controls whether a process can gain more + privileges than its parent process. This bool directly controls if + the no_new_privs flag will be set on the container process. + AllowPrivilegeEscalation is true always when the container is: + 1) run as Privileged + 2) has CAP_SYS_ADMIN + Note that this field cannot be set when spec.os.name is windows. + type: boolean + capabilities: + description: |- + The capabilities to add/drop when running containers. + Defaults to the default set of capabilities granted by the container runtime. + Note that this field cannot be set when spec.os.name is windows. + properties: + add: + description: Added capabilities + items: + description: Capability represent POSIX capabilities + type + type: string + type: array + drop: + description: Removed capabilities + items: + description: Capability represent POSIX capabilities + type + type: string + type: array + type: object + privileged: + description: |- + Run container in privileged mode. + Processes in privileged containers are essentially equivalent to root on the host. + Defaults to false. + Note that this field cannot be set when spec.os.name is windows. + type: boolean + procMount: + description: |- + procMount denotes the type of proc mount to use for the containers. + The default is DefaultProcMount which uses the container runtime defaults for + readonly paths and masked paths. + This requires the ProcMountType feature flag to be enabled. + Note that this field cannot be set when spec.os.name is windows. + type: string + readOnlyRootFilesystem: + description: |- + Whether this container has a read-only root filesystem. + Default is false. + Note that this field cannot be set when spec.os.name is windows. + type: boolean + runAsGroup: + description: |- + The GID to run the entrypoint of the container process. + Uses runtime default if unset. + May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + Note that this field cannot be set when spec.os.name is windows. + format: int64 + type: integer + runAsNonRoot: + description: |- + Indicates that the container must run as a non-root user. + If true, the Kubelet will validate the image at runtime to ensure that it + does not run as UID 0 (root) and fail to start the container if it does. + If unset or false, no such validation will be performed. + May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + type: boolean + runAsUser: + description: |- + The UID to run the entrypoint of the container process. + Defaults to user specified in image metadata if unspecified. + May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + Note that this field cannot be set when spec.os.name is windows. + format: int64 + type: integer + seLinuxOptions: + description: |- + The SELinux context to be applied to the container. + If unspecified, the container runtime will allocate a random SELinux context for each + container. May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + Note that this field cannot be set when spec.os.name is windows. + properties: + level: + description: Level is SELinux level label that applies + to the container. + type: string + role: + description: Role is a SELinux role label that applies + to the container. + type: string + type: + description: Type is a SELinux type label that applies + to the container. + type: string + user: + description: User is a SELinux user label that applies + to the container. + type: string + type: object + seccompProfile: + description: |- + The seccomp options to use by this container. If seccomp options are + provided at both the pod & container level, the container options + override the pod options. + Note that this field cannot be set when spec.os.name is windows. + properties: + localhostProfile: + description: |- + localhostProfile indicates a profile defined in a file on the node should be used. + The profile must be preconfigured on the node to work. + Must be a descending path, relative to the kubelet's configured seccomp profile location. + Must be set if type is "Localhost". Must NOT be set for any other type. + type: string + type: + description: |- + type indicates which kind of seccomp profile will be applied. + Valid options are: + + + Localhost - a profile defined in a file on the node should be used. + RuntimeDefault - the container runtime default profile should be used. + Unconfined - no profile should be applied. + type: string + required: + - type + type: object + windowsOptions: + description: |- + The Windows specific settings applied to all containers. + If unspecified, the options from the PodSecurityContext will be used. + If set in both SecurityContext and PodSecurityContext, the value specified in SecurityContext takes precedence. + Note that this field cannot be set when spec.os.name is linux. + properties: + gmsaCredentialSpec: + description: |- + GMSACredentialSpec is where the GMSA admission webhook + (https://github.com/kubernetes-sigs/windows-gmsa) inlines the contents of the + GMSA credential spec named by the GMSACredentialSpecName field. + type: string + gmsaCredentialSpecName: + description: GMSACredentialSpecName is the name of the + GMSA credential spec to use. + type: string + hostProcess: + description: |- + HostProcess determines if a container should be run as a 'Host Process' container. + All of a Pod's containers must have the same effective HostProcess value + (it is not allowed to have a mix of HostProcess containers and non-HostProcess containers). + In addition, if HostProcess is true then HostNetwork must also be set to true. + type: boolean + runAsUserName: + description: |- + The UserName in Windows to run the entrypoint of the container process. + Defaults to the user specified in image metadata if unspecified. + May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + type: string + type: object + type: object + volumes: + items: + properties: + destination: + type: string + name: + type: string + source: + type: string + type: object + type: array + type: object + upgradeContainer: + description: ContainerSpec is a simplified container template. + properties: + args: + items: + type: string + type: array + command: + items: + type: string + type: array + envFrom: + items: + description: EnvFromSource represents the source of a set of + ConfigMaps + properties: + configMapRef: + description: The ConfigMap to select from + properties: + name: + description: |- + Name of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names + TODO: Add other useful fields. apiVersion, kind, uid? + type: string + optional: + description: Specify whether the ConfigMap must be defined + type: boolean + type: object + x-kubernetes-map-type: atomic + prefix: + description: An optional identifier to prepend to each key + in the ConfigMap. Must be a C_IDENTIFIER. + type: string + secretRef: + description: The Secret to select from + properties: + name: + description: |- + Name of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names + TODO: Add other useful fields. apiVersion, kind, uid? + type: string + optional: + description: Specify whether the Secret must be defined + type: boolean + type: object + x-kubernetes-map-type: atomic + type: object + type: array + envs: + items: + description: EnvVar represents an environment variable present + in a Container. + properties: + name: + description: Name of the environment variable. Must be a + C_IDENTIFIER. + type: string + value: + description: |- + Variable references $(VAR_NAME) are expanded + using the previously defined environment variables in the container and + any service environment variables. If a variable cannot be resolved, + the reference in the input string will be unchanged. Double $$ are reduced + to a single $, which allows for escaping the $(VAR_NAME) syntax: i.e. + "$$(VAR_NAME)" will produce the string literal "$(VAR_NAME)". + Escaped references will never be expanded, regardless of whether the variable + exists or not. + Defaults to "". + type: string + valueFrom: + description: Source for the environment variable's value. + Cannot be used if value is not empty. + properties: + configMapKeyRef: + description: Selects a key of a ConfigMap. + properties: + key: + description: The key to select. + type: string + name: + description: |- + Name of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names + TODO: Add other useful fields. apiVersion, kind, uid? + type: string + optional: + description: Specify whether the ConfigMap or its + key must be defined + type: boolean + required: + - key + type: object + x-kubernetes-map-type: atomic + fieldRef: + description: |- + Selects a field of the pod: supports metadata.name, metadata.namespace, `metadata.labels['']`, `metadata.annotations['']`, + spec.nodeName, spec.serviceAccountName, status.hostIP, status.podIP, status.podIPs. + properties: + apiVersion: + description: Version of the schema the FieldPath + is written in terms of, defaults to "v1". + type: string + fieldPath: + description: Path of the field to select in the + specified API version. + type: string + required: + - fieldPath + type: object + x-kubernetes-map-type: atomic + resourceFieldRef: + description: |- + Selects a resource of the container: only resources limits and requests + (limits.cpu, limits.memory, limits.ephemeral-storage, requests.cpu, requests.memory and requests.ephemeral-storage) are currently supported. + properties: + containerName: + description: 'Container name: required for volumes, + optional for env vars' + type: string + divisor: + anyOf: + - type: integer + - type: string + description: Specifies the output format of the + exposed resources, defaults to "1" + pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ + x-kubernetes-int-or-string: true + resource: + description: 'Required: resource to select' + type: string + required: + - resource + type: object + x-kubernetes-map-type: atomic + secretKeyRef: + description: Selects a key of a secret in the pod's + namespace + properties: + key: + description: The key of the secret to select from. Must + be a valid secret key. + type: string + name: + description: |- + Name of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names + TODO: Add other useful fields. apiVersion, kind, uid? + type: string + optional: + description: Specify whether the Secret or its key + must be defined + type: boolean + required: + - key + type: object + x-kubernetes-map-type: atomic + type: object + required: + - name + type: object + type: array + image: + type: string + securityContext: + description: |- + SecurityContext holds security configuration that will be applied to a container. + Some fields are present in both SecurityContext and PodSecurityContext. When both + are set, the values in SecurityContext take precedence. + properties: + allowPrivilegeEscalation: + description: |- + AllowPrivilegeEscalation controls whether a process can gain more + privileges than its parent process. This bool directly controls if + the no_new_privs flag will be set on the container process. + AllowPrivilegeEscalation is true always when the container is: + 1) run as Privileged + 2) has CAP_SYS_ADMIN + Note that this field cannot be set when spec.os.name is windows. + type: boolean + capabilities: + description: |- + The capabilities to add/drop when running containers. + Defaults to the default set of capabilities granted by the container runtime. + Note that this field cannot be set when spec.os.name is windows. + properties: + add: + description: Added capabilities + items: + description: Capability represent POSIX capabilities + type + type: string + type: array + drop: + description: Removed capabilities + items: + description: Capability represent POSIX capabilities + type + type: string + type: array + type: object + privileged: + description: |- + Run container in privileged mode. + Processes in privileged containers are essentially equivalent to root on the host. + Defaults to false. + Note that this field cannot be set when spec.os.name is windows. + type: boolean + procMount: + description: |- + procMount denotes the type of proc mount to use for the containers. + The default is DefaultProcMount which uses the container runtime defaults for + readonly paths and masked paths. + This requires the ProcMountType feature flag to be enabled. + Note that this field cannot be set when spec.os.name is windows. + type: string + readOnlyRootFilesystem: + description: |- + Whether this container has a read-only root filesystem. + Default is false. + Note that this field cannot be set when spec.os.name is windows. + type: boolean + runAsGroup: + description: |- + The GID to run the entrypoint of the container process. + Uses runtime default if unset. + May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + Note that this field cannot be set when spec.os.name is windows. + format: int64 + type: integer + runAsNonRoot: + description: |- + Indicates that the container must run as a non-root user. + If true, the Kubelet will validate the image at runtime to ensure that it + does not run as UID 0 (root) and fail to start the container if it does. + If unset or false, no such validation will be performed. + May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + type: boolean + runAsUser: + description: |- + The UID to run the entrypoint of the container process. + Defaults to user specified in image metadata if unspecified. + May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + Note that this field cannot be set when spec.os.name is windows. + format: int64 + type: integer + seLinuxOptions: + description: |- + The SELinux context to be applied to the container. + If unspecified, the container runtime will allocate a random SELinux context for each + container. May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + Note that this field cannot be set when spec.os.name is windows. + properties: + level: + description: Level is SELinux level label that applies + to the container. + type: string + role: + description: Role is a SELinux role label that applies + to the container. + type: string + type: + description: Type is a SELinux type label that applies + to the container. + type: string + user: + description: User is a SELinux user label that applies + to the container. + type: string + type: object + seccompProfile: + description: |- + The seccomp options to use by this container. If seccomp options are + provided at both the pod & container level, the container options + override the pod options. + Note that this field cannot be set when spec.os.name is windows. + properties: + localhostProfile: + description: |- + localhostProfile indicates a profile defined in a file on the node should be used. + The profile must be preconfigured on the node to work. + Must be a descending path, relative to the kubelet's configured seccomp profile location. + Must be set if type is "Localhost". Must NOT be set for any other type. + type: string + type: + description: |- + type indicates which kind of seccomp profile will be applied. + Valid options are: + + + Localhost - a profile defined in a file on the node should be used. + RuntimeDefault - the container runtime default profile should be used. + Unconfined - no profile should be applied. + type: string + required: + - type + type: object + windowsOptions: + description: |- + The Windows specific settings applied to all containers. + If unspecified, the options from the PodSecurityContext will be used. + If set in both SecurityContext and PodSecurityContext, the value specified in SecurityContext takes precedence. + Note that this field cannot be set when spec.os.name is linux. + properties: + gmsaCredentialSpec: + description: |- + GMSACredentialSpec is where the GMSA admission webhook + (https://github.com/kubernetes-sigs/windows-gmsa) inlines the contents of the + GMSA credential spec named by the GMSACredentialSpecName field. + type: string + gmsaCredentialSpecName: + description: GMSACredentialSpecName is the name of the + GMSA credential spec to use. + type: string + hostProcess: + description: |- + HostProcess determines if a container should be run as a 'Host Process' container. + All of a Pod's containers must have the same effective HostProcess value + (it is not allowed to have a mix of HostProcess containers and non-HostProcess containers). + In addition, if HostProcess is true then HostNetwork must also be set to true. + type: boolean + runAsUserName: + description: |- + The UserName in Windows to run the entrypoint of the container process. + Defaults to the user specified in image metadata if unspecified. + May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + type: string + type: object + type: object + volumes: + items: + properties: + destination: + type: string + name: + type: string + source: + type: string + type: object + type: array + type: object + required: + - drain + type: object + status: + properties: + conditions: + items: + description: "Condition contains details for one aspect of the current + state of this API Resource.\n---\nThis struct is intended for + direct use as an array at the field path .status.conditions. For + example,\n\n\n\ttype FooStatus struct{\n\t // Represents the + observations of a foo's current state.\n\t // Known .status.conditions.type + are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // + +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t + \ // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" + patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t + \ // other fields\n\t}" + properties: + lastTransitionTime: + description: |- + lastTransitionTime is the last time the condition transitioned from one status to another. + This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable. + format: date-time + type: string + message: + description: |- + message is a human readable message indicating details about the transition. + This may be an empty string. + maxLength: 32768 + type: string + observedGeneration: + description: |- + observedGeneration represents the .metadata.generation that the condition was set based upon. + For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date + with respect to the current state of the instance. + format: int64 + minimum: 0 + type: integer + reason: + description: |- + reason contains a programmatic identifier indicating the reason for the condition's last transition. + Producers of specific condition types may define expected values and meanings for this field, + and whether the values are considered a guaranteed API. + The value should be a CamelCase string. + This field may not be empty. + maxLength: 1024 + minLength: 1 + pattern: ^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$ + type: string + status: + description: status of the condition, one of True, False, Unknown. + enum: + - "True" + - "False" + - Unknown + type: string + type: + description: |- + type of condition in CamelCase or in foo.example.com/CamelCase. + --- + Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be + useful (see .node.status.conditions), the ability to deconflict is important. + The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt) + maxLength: 316 + pattern: ^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$ + type: string + required: + - lastTransitionTime + - message + - reason + - status + - type + type: object + type: array + type: object + type: object + served: true + storage: true + subresources: + status: {} +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + annotations: + app.kubernetes.io/instance: '{{ .Release.Name }}' + app.kubernetes.io/part-of: Elemental Operator + app.kubernetes.io/version: '{{ .Chart.Version }}' + controller-gen.kubebuilder.io/version: v0.14.0 + labels: + cluster.x-k8s.io/provider: infrastructure-elemental + cluster.x-k8s.io/v1beta1: v1beta1 + release-name: '{{ .Release.Name }}' + name: managedosversionchannels.elemental.cattle.io +spec: + group: elemental.cattle.io + names: + kind: ManagedOSVersionChannel + listKind: ManagedOSVersionChannelList + plural: managedosversionchannels + singular: managedosversionchannel + scope: Namespaced + versions: + - name: v1beta1 + schema: + openAPIV3Schema: + properties: + apiVersion: + description: |- + APIVersion defines the versioned schema of this representation of an object. + Servers should convert recognized schemas to the latest internal value, and + may reject unrecognized values. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources + type: string + kind: + description: |- + Kind is a string value representing the REST resource this object represents. + Servers may infer this from the endpoint the client submits requests to. + Cannot be updated. + In CamelCase. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds + type: string + metadata: + type: object + spec: + properties: + deleteNoLongerInSyncVersions: + default: false + description: |- + DeleteNoLongerInSyncVersions automatically deletes + all no-longer-in-sync ManagedOSVersions that were created by this channel. + type: boolean + options: + x-kubernetes-preserve-unknown-fields: true + syncInterval: + default: 1h + type: string + type: + type: string + upgradeContainer: + description: ContainerSpec is a simplified container template. + properties: + args: + items: + type: string + type: array + command: + items: + type: string + type: array + envFrom: + items: + description: EnvFromSource represents the source of a set of + ConfigMaps + properties: + configMapRef: + description: The ConfigMap to select from + properties: + name: + description: |- + Name of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names + TODO: Add other useful fields. apiVersion, kind, uid? + type: string + optional: + description: Specify whether the ConfigMap must be defined + type: boolean + type: object + x-kubernetes-map-type: atomic + prefix: + description: An optional identifier to prepend to each key + in the ConfigMap. Must be a C_IDENTIFIER. + type: string + secretRef: + description: The Secret to select from + properties: + name: + description: |- + Name of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names + TODO: Add other useful fields. apiVersion, kind, uid? + type: string + optional: + description: Specify whether the Secret must be defined + type: boolean + type: object + x-kubernetes-map-type: atomic + type: object + type: array + envs: + items: + description: EnvVar represents an environment variable present + in a Container. + properties: + name: + description: Name of the environment variable. Must be a + C_IDENTIFIER. + type: string + value: + description: |- + Variable references $(VAR_NAME) are expanded + using the previously defined environment variables in the container and + any service environment variables. If a variable cannot be resolved, + the reference in the input string will be unchanged. Double $$ are reduced + to a single $, which allows for escaping the $(VAR_NAME) syntax: i.e. + "$$(VAR_NAME)" will produce the string literal "$(VAR_NAME)". + Escaped references will never be expanded, regardless of whether the variable + exists or not. + Defaults to "". + type: string + valueFrom: + description: Source for the environment variable's value. + Cannot be used if value is not empty. + properties: + configMapKeyRef: + description: Selects a key of a ConfigMap. + properties: + key: + description: The key to select. + type: string + name: + description: |- + Name of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names + TODO: Add other useful fields. apiVersion, kind, uid? + type: string + optional: + description: Specify whether the ConfigMap or its + key must be defined + type: boolean + required: + - key + type: object + x-kubernetes-map-type: atomic + fieldRef: + description: |- + Selects a field of the pod: supports metadata.name, metadata.namespace, `metadata.labels['']`, `metadata.annotations['']`, + spec.nodeName, spec.serviceAccountName, status.hostIP, status.podIP, status.podIPs. + properties: + apiVersion: + description: Version of the schema the FieldPath + is written in terms of, defaults to "v1". + type: string + fieldPath: + description: Path of the field to select in the + specified API version. + type: string + required: + - fieldPath + type: object + x-kubernetes-map-type: atomic + resourceFieldRef: + description: |- + Selects a resource of the container: only resources limits and requests + (limits.cpu, limits.memory, limits.ephemeral-storage, requests.cpu, requests.memory and requests.ephemeral-storage) are currently supported. + properties: + containerName: + description: 'Container name: required for volumes, + optional for env vars' + type: string + divisor: + anyOf: + - type: integer + - type: string + description: Specifies the output format of the + exposed resources, defaults to "1" + pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ + x-kubernetes-int-or-string: true + resource: + description: 'Required: resource to select' + type: string + required: + - resource + type: object + x-kubernetes-map-type: atomic + secretKeyRef: + description: Selects a key of a secret in the pod's + namespace + properties: + key: + description: The key of the secret to select from. Must + be a valid secret key. + type: string + name: + description: |- + Name of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names + TODO: Add other useful fields. apiVersion, kind, uid? + type: string + optional: + description: Specify whether the Secret or its key + must be defined + type: boolean + required: + - key + type: object + x-kubernetes-map-type: atomic + type: object + required: + - name + type: object + type: array + image: + type: string + securityContext: + description: |- + SecurityContext holds security configuration that will be applied to a container. + Some fields are present in both SecurityContext and PodSecurityContext. When both + are set, the values in SecurityContext take precedence. + properties: + allowPrivilegeEscalation: + description: |- + AllowPrivilegeEscalation controls whether a process can gain more + privileges than its parent process. This bool directly controls if + the no_new_privs flag will be set on the container process. + AllowPrivilegeEscalation is true always when the container is: + 1) run as Privileged + 2) has CAP_SYS_ADMIN + Note that this field cannot be set when spec.os.name is windows. + type: boolean + capabilities: + description: |- + The capabilities to add/drop when running containers. + Defaults to the default set of capabilities granted by the container runtime. + Note that this field cannot be set when spec.os.name is windows. + properties: + add: + description: Added capabilities + items: + description: Capability represent POSIX capabilities + type + type: string + type: array + drop: + description: Removed capabilities + items: + description: Capability represent POSIX capabilities + type + type: string + type: array + type: object + privileged: + description: |- + Run container in privileged mode. + Processes in privileged containers are essentially equivalent to root on the host. + Defaults to false. + Note that this field cannot be set when spec.os.name is windows. + type: boolean + procMount: + description: |- + procMount denotes the type of proc mount to use for the containers. + The default is DefaultProcMount which uses the container runtime defaults for + readonly paths and masked paths. + This requires the ProcMountType feature flag to be enabled. + Note that this field cannot be set when spec.os.name is windows. + type: string + readOnlyRootFilesystem: + description: |- + Whether this container has a read-only root filesystem. + Default is false. + Note that this field cannot be set when spec.os.name is windows. + type: boolean + runAsGroup: + description: |- + The GID to run the entrypoint of the container process. + Uses runtime default if unset. + May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + Note that this field cannot be set when spec.os.name is windows. + format: int64 + type: integer + runAsNonRoot: + description: |- + Indicates that the container must run as a non-root user. + If true, the Kubelet will validate the image at runtime to ensure that it + does not run as UID 0 (root) and fail to start the container if it does. + If unset or false, no such validation will be performed. + May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + type: boolean + runAsUser: + description: |- + The UID to run the entrypoint of the container process. + Defaults to user specified in image metadata if unspecified. + May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + Note that this field cannot be set when spec.os.name is windows. + format: int64 + type: integer + seLinuxOptions: + description: |- + The SELinux context to be applied to the container. + If unspecified, the container runtime will allocate a random SELinux context for each + container. May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + Note that this field cannot be set when spec.os.name is windows. + properties: + level: + description: Level is SELinux level label that applies + to the container. + type: string + role: + description: Role is a SELinux role label that applies + to the container. + type: string + type: + description: Type is a SELinux type label that applies + to the container. + type: string + user: + description: User is a SELinux user label that applies + to the container. + type: string + type: object + seccompProfile: + description: |- + The seccomp options to use by this container. If seccomp options are + provided at both the pod & container level, the container options + override the pod options. + Note that this field cannot be set when spec.os.name is windows. + properties: + localhostProfile: + description: |- + localhostProfile indicates a profile defined in a file on the node should be used. + The profile must be preconfigured on the node to work. + Must be a descending path, relative to the kubelet's configured seccomp profile location. + Must be set if type is "Localhost". Must NOT be set for any other type. + type: string + type: + description: |- + type indicates which kind of seccomp profile will be applied. + Valid options are: + + + Localhost - a profile defined in a file on the node should be used. + RuntimeDefault - the container runtime default profile should be used. + Unconfined - no profile should be applied. + type: string + required: + - type + type: object + windowsOptions: + description: |- + The Windows specific settings applied to all containers. + If unspecified, the options from the PodSecurityContext will be used. + If set in both SecurityContext and PodSecurityContext, the value specified in SecurityContext takes precedence. + Note that this field cannot be set when spec.os.name is linux. + properties: + gmsaCredentialSpec: + description: |- + GMSACredentialSpec is where the GMSA admission webhook + (https://github.com/kubernetes-sigs/windows-gmsa) inlines the contents of the + GMSA credential spec named by the GMSACredentialSpecName field. + type: string + gmsaCredentialSpecName: + description: GMSACredentialSpecName is the name of the + GMSA credential spec to use. + type: string + hostProcess: + description: |- + HostProcess determines if a container should be run as a 'Host Process' container. + All of a Pod's containers must have the same effective HostProcess value + (it is not allowed to have a mix of HostProcess containers and non-HostProcess containers). + In addition, if HostProcess is true then HostNetwork must also be set to true. + type: boolean + runAsUserName: + description: |- + The UserName in Windows to run the entrypoint of the container process. + Defaults to the user specified in image metadata if unspecified. + May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + type: string + type: object + type: object + volumes: + items: + properties: + destination: + type: string + name: + type: string + source: + type: string + type: object + type: array + type: object + type: object + status: + properties: + conditions: + description: Conditions describe the state of the managed OS version + object. + items: + description: "Condition contains details for one aspect of the current + state of this API Resource.\n---\nThis struct is intended for + direct use as an array at the field path .status.conditions. For + example,\n\n\n\ttype FooStatus struct{\n\t // Represents the + observations of a foo's current state.\n\t // Known .status.conditions.type + are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // + +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t + \ // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" + patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t + \ // other fields\n\t}" + properties: + lastTransitionTime: + description: |- + lastTransitionTime is the last time the condition transitioned from one status to another. + This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable. + format: date-time + type: string + message: + description: |- + message is a human readable message indicating details about the transition. + This may be an empty string. + maxLength: 32768 + type: string + observedGeneration: + description: |- + observedGeneration represents the .metadata.generation that the condition was set based upon. + For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date + with respect to the current state of the instance. + format: int64 + minimum: 0 + type: integer + reason: + description: |- + reason contains a programmatic identifier indicating the reason for the condition's last transition. + Producers of specific condition types may define expected values and meanings for this field, + and whether the values are considered a guaranteed API. + The value should be a CamelCase string. + This field may not be empty. + maxLength: 1024 + minLength: 1 + pattern: ^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$ + type: string + status: + description: status of the condition, one of True, False, Unknown. + enum: + - "True" + - "False" + - Unknown + type: string + type: + description: |- + type of condition in CamelCase or in foo.example.com/CamelCase. + --- + Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be + useful (see .node.status.conditions), the ability to deconflict is important. + The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt) + maxLength: 316 + pattern: ^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$ + type: string + required: + - lastTransitionTime + - message + - reason + - status + - type + type: object + type: array + failedSynchronizationAttempts: + description: FailedSynchronizationAttempts counts the number of consecutive + synchronization failures + type: integer + lastSyncedTime: + description: LastSyncedTime is the timestamp of the last synchronization + format: date-time + type: string + syncedGeneration: + description: SyncedGeneration tracks the spec generation of the last + synchronization + format: int64 + type: integer + type: object + type: object + served: true + storage: true + subresources: + status: {} +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + annotations: + app.kubernetes.io/instance: '{{ .Release.Name }}' + app.kubernetes.io/part-of: Elemental Operator + app.kubernetes.io/version: '{{ .Chart.Version }}' + controller-gen.kubebuilder.io/version: v0.14.0 + labels: + cluster.x-k8s.io/provider: infrastructure-elemental + cluster.x-k8s.io/v1beta1: v1beta1 + release-name: '{{ .Release.Name }}' + name: managedosversions.elemental.cattle.io +spec: + group: elemental.cattle.io + names: + kind: ManagedOSVersion + listKind: ManagedOSVersionList + plural: managedosversions + singular: managedosversion + scope: Namespaced + versions: + - name: v1beta1 + schema: + openAPIV3Schema: + properties: + apiVersion: + description: |- + APIVersion defines the versioned schema of this representation of an object. + Servers should convert recognized schemas to the latest internal value, and + may reject unrecognized values. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources + type: string + kind: + description: |- + Kind is a string value representing the REST resource this object represents. + Servers may infer this from the endpoint the client submits requests to. + Cannot be updated. + In CamelCase. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds + type: string + metadata: + type: object + spec: + properties: + metadata: + x-kubernetes-preserve-unknown-fields: true + minVersion: + type: string + type: + type: string + upgradeContainer: + description: ContainerSpec is a simplified container template. + properties: + args: + items: + type: string + type: array + command: + items: + type: string + type: array + envFrom: + items: + description: EnvFromSource represents the source of a set of + ConfigMaps + properties: + configMapRef: + description: The ConfigMap to select from + properties: + name: + description: |- + Name of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names + TODO: Add other useful fields. apiVersion, kind, uid? + type: string + optional: + description: Specify whether the ConfigMap must be defined + type: boolean + type: object + x-kubernetes-map-type: atomic + prefix: + description: An optional identifier to prepend to each key + in the ConfigMap. Must be a C_IDENTIFIER. + type: string + secretRef: + description: The Secret to select from + properties: + name: + description: |- + Name of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names + TODO: Add other useful fields. apiVersion, kind, uid? + type: string + optional: + description: Specify whether the Secret must be defined + type: boolean + type: object + x-kubernetes-map-type: atomic + type: object + type: array + envs: + items: + description: EnvVar represents an environment variable present + in a Container. + properties: + name: + description: Name of the environment variable. Must be a + C_IDENTIFIER. + type: string + value: + description: |- + Variable references $(VAR_NAME) are expanded + using the previously defined environment variables in the container and + any service environment variables. If a variable cannot be resolved, + the reference in the input string will be unchanged. Double $$ are reduced + to a single $, which allows for escaping the $(VAR_NAME) syntax: i.e. + "$$(VAR_NAME)" will produce the string literal "$(VAR_NAME)". + Escaped references will never be expanded, regardless of whether the variable + exists or not. + Defaults to "". + type: string + valueFrom: + description: Source for the environment variable's value. + Cannot be used if value is not empty. + properties: + configMapKeyRef: + description: Selects a key of a ConfigMap. + properties: + key: + description: The key to select. + type: string + name: + description: |- + Name of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names + TODO: Add other useful fields. apiVersion, kind, uid? + type: string + optional: + description: Specify whether the ConfigMap or its + key must be defined + type: boolean + required: + - key + type: object + x-kubernetes-map-type: atomic + fieldRef: + description: |- + Selects a field of the pod: supports metadata.name, metadata.namespace, `metadata.labels['']`, `metadata.annotations['']`, + spec.nodeName, spec.serviceAccountName, status.hostIP, status.podIP, status.podIPs. + properties: + apiVersion: + description: Version of the schema the FieldPath + is written in terms of, defaults to "v1". + type: string + fieldPath: + description: Path of the field to select in the + specified API version. + type: string + required: + - fieldPath + type: object + x-kubernetes-map-type: atomic + resourceFieldRef: + description: |- + Selects a resource of the container: only resources limits and requests + (limits.cpu, limits.memory, limits.ephemeral-storage, requests.cpu, requests.memory and requests.ephemeral-storage) are currently supported. + properties: + containerName: + description: 'Container name: required for volumes, + optional for env vars' + type: string + divisor: + anyOf: + - type: integer + - type: string + description: Specifies the output format of the + exposed resources, defaults to "1" + pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ + x-kubernetes-int-or-string: true + resource: + description: 'Required: resource to select' + type: string + required: + - resource + type: object + x-kubernetes-map-type: atomic + secretKeyRef: + description: Selects a key of a secret in the pod's + namespace + properties: + key: + description: The key of the secret to select from. Must + be a valid secret key. + type: string + name: + description: |- + Name of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names + TODO: Add other useful fields. apiVersion, kind, uid? + type: string + optional: + description: Specify whether the Secret or its key + must be defined + type: boolean + required: + - key + type: object + x-kubernetes-map-type: atomic + type: object + required: + - name + type: object + type: array + image: + type: string + securityContext: + description: |- + SecurityContext holds security configuration that will be applied to a container. + Some fields are present in both SecurityContext and PodSecurityContext. When both + are set, the values in SecurityContext take precedence. + properties: + allowPrivilegeEscalation: + description: |- + AllowPrivilegeEscalation controls whether a process can gain more + privileges than its parent process. This bool directly controls if + the no_new_privs flag will be set on the container process. + AllowPrivilegeEscalation is true always when the container is: + 1) run as Privileged + 2) has CAP_SYS_ADMIN + Note that this field cannot be set when spec.os.name is windows. + type: boolean + capabilities: + description: |- + The capabilities to add/drop when running containers. + Defaults to the default set of capabilities granted by the container runtime. + Note that this field cannot be set when spec.os.name is windows. + properties: + add: + description: Added capabilities + items: + description: Capability represent POSIX capabilities + type + type: string + type: array + drop: + description: Removed capabilities + items: + description: Capability represent POSIX capabilities + type + type: string + type: array + type: object + privileged: + description: |- + Run container in privileged mode. + Processes in privileged containers are essentially equivalent to root on the host. + Defaults to false. + Note that this field cannot be set when spec.os.name is windows. + type: boolean + procMount: + description: |- + procMount denotes the type of proc mount to use for the containers. + The default is DefaultProcMount which uses the container runtime defaults for + readonly paths and masked paths. + This requires the ProcMountType feature flag to be enabled. + Note that this field cannot be set when spec.os.name is windows. + type: string + readOnlyRootFilesystem: + description: |- + Whether this container has a read-only root filesystem. + Default is false. + Note that this field cannot be set when spec.os.name is windows. + type: boolean + runAsGroup: + description: |- + The GID to run the entrypoint of the container process. + Uses runtime default if unset. + May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + Note that this field cannot be set when spec.os.name is windows. + format: int64 + type: integer + runAsNonRoot: + description: |- + Indicates that the container must run as a non-root user. + If true, the Kubelet will validate the image at runtime to ensure that it + does not run as UID 0 (root) and fail to start the container if it does. + If unset or false, no such validation will be performed. + May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + type: boolean + runAsUser: + description: |- + The UID to run the entrypoint of the container process. + Defaults to user specified in image metadata if unspecified. + May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + Note that this field cannot be set when spec.os.name is windows. + format: int64 + type: integer + seLinuxOptions: + description: |- + The SELinux context to be applied to the container. + If unspecified, the container runtime will allocate a random SELinux context for each + container. May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + Note that this field cannot be set when spec.os.name is windows. + properties: + level: + description: Level is SELinux level label that applies + to the container. + type: string + role: + description: Role is a SELinux role label that applies + to the container. + type: string + type: + description: Type is a SELinux type label that applies + to the container. + type: string + user: + description: User is a SELinux user label that applies + to the container. + type: string + type: object + seccompProfile: + description: |- + The seccomp options to use by this container. If seccomp options are + provided at both the pod & container level, the container options + override the pod options. + Note that this field cannot be set when spec.os.name is windows. + properties: + localhostProfile: + description: |- + localhostProfile indicates a profile defined in a file on the node should be used. + The profile must be preconfigured on the node to work. + Must be a descending path, relative to the kubelet's configured seccomp profile location. + Must be set if type is "Localhost". Must NOT be set for any other type. + type: string + type: + description: |- + type indicates which kind of seccomp profile will be applied. + Valid options are: + + + Localhost - a profile defined in a file on the node should be used. + RuntimeDefault - the container runtime default profile should be used. + Unconfined - no profile should be applied. + type: string + required: + - type + type: object + windowsOptions: + description: |- + The Windows specific settings applied to all containers. + If unspecified, the options from the PodSecurityContext will be used. + If set in both SecurityContext and PodSecurityContext, the value specified in SecurityContext takes precedence. + Note that this field cannot be set when spec.os.name is linux. + properties: + gmsaCredentialSpec: + description: |- + GMSACredentialSpec is where the GMSA admission webhook + (https://github.com/kubernetes-sigs/windows-gmsa) inlines the contents of the + GMSA credential spec named by the GMSACredentialSpecName field. + type: string + gmsaCredentialSpecName: + description: GMSACredentialSpecName is the name of the + GMSA credential spec to use. + type: string + hostProcess: + description: |- + HostProcess determines if a container should be run as a 'Host Process' container. + All of a Pod's containers must have the same effective HostProcess value + (it is not allowed to have a mix of HostProcess containers and non-HostProcess containers). + In addition, if HostProcess is true then HostNetwork must also be set to true. + type: boolean + runAsUserName: + description: |- + The UserName in Windows to run the entrypoint of the container process. + Defaults to the user specified in image metadata if unspecified. + May also be set in PodSecurityContext. If set in both SecurityContext and + PodSecurityContext, the value specified in SecurityContext takes precedence. + type: string + type: object + type: object + volumes: + items: + properties: + destination: + type: string + name: + type: string + source: + type: string + type: object + type: array + type: object + version: + type: string + type: object + status: + type: object + type: object + served: true + storage: true + subresources: + status: {} +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + annotations: + app.kubernetes.io/instance: '{{ .Release.Name }}' + app.kubernetes.io/part-of: Elemental Operator + app.kubernetes.io/version: '{{ .Chart.Version }}' + controller-gen.kubebuilder.io/version: v0.14.0 + labels: + cluster.x-k8s.io/provider: infrastructure-elemental + cluster.x-k8s.io/v1beta1: v1beta1 + release-name: '{{ .Release.Name }}' + name: metadata.elemental.cattle.io +spec: + group: elemental.cattle.io + names: + kind: Metadata + listKind: MetadataList + plural: metadata + singular: metadata + scope: Namespaced + versions: + - name: v1beta1 + schema: + openAPIV3Schema: + properties: + apiVersion: + description: |- + APIVersion defines the versioned schema of this representation of an object. + Servers should convert recognized schemas to the latest internal value, and + may reject unrecognized values. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources + type: string + kind: + description: |- + Kind is a string value representing the REST resource this object represents. + Servers may infer this from the endpoint the client submits requests to. + Cannot be updated. + In CamelCase. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds + type: string + metadata: + type: object + spec: + properties: + annotations: + additionalProperties: + type: string + type: object + appVersion: + type: string + type: object + status: + type: object + type: object + served: true + storage: true + subresources: + status: {} +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + annotations: + app.kubernetes.io/instance: '{{ .Release.Name }}' + app.kubernetes.io/part-of: Elemental Operator + app.kubernetes.io/version: '{{ .Chart.Version }}' + controller-gen.kubebuilder.io/version: v0.14.0 + labels: + cluster.x-k8s.io/provider: infrastructure-elemental + cluster.x-k8s.io/v1beta1: v1beta1 + release-name: '{{ .Release.Name }}' + name: seedimages.elemental.cattle.io +spec: + group: elemental.cattle.io + names: + kind: SeedImage + listKind: SeedImageList + plural: seedimages + singular: seedimage + scope: Namespaced + versions: + - name: v1beta1 + schema: + openAPIV3Schema: + properties: + apiVersion: + description: |- + APIVersion defines the versioned schema of this representation of an object. + Servers should convert recognized schemas to the latest internal value, and + may reject unrecognized values. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources + type: string + kind: + description: |- + Kind is a string value representing the REST resource this object represents. + Servers may infer this from the endpoint the client submits requests to. + Cannot be updated. + In CamelCase. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds + type: string + metadata: + type: object + spec: + properties: + baseImage: + description: BaseImg the base elemental image used to build the seed + image. + type: string + buildContainer: + description: |- + BuildContainer settings for a custom container used to generate the + downloadable image. + properties: + args: + description: Args same as corev1.Container.Args + items: + type: string + type: array + command: + description: Command same as corev1.Container.Command + items: + type: string + type: array + image: + description: Image container image to run + type: string + imagePullPolicy: + description: Args same as corev1.Container.ImagePullPolicy + type: string + name: + description: Name of the spawned container + type: string + type: object + cleanupAfterMinutes: + default: 60 + description: |- + LifetimeMinutes the time at which the built seed image will be cleaned up. + If when the lifetime elapses the built image is being downloaded, the active + download will be completed before removing the built image. + Default is 60 minutes, set to 0 to disable. + format: int32 + type: integer + cloud-config: + description: CloudConfig contains cloud-config data to be put in the + generated iso. + x-kubernetes-preserve-unknown-fields: true + registrationRef: + description: MachineRegistrationRef a reference to the related MachineRegistration. + properties: + apiVersion: + description: API version of the referent. + type: string + fieldPath: + description: |- + If referring to a piece of an object instead of an entire object, this string + should contain a valid JSON/Go field access statement, such as desiredState.manifest.containers[2]. + For example, if the object reference is to a container within a pod, this would take on a value like: + "spec.containers{name}" (where "name" refers to the name of the container that triggered + the event) or if no container name is specified "spec.containers[2]" (container with + index 2 in this pod). This syntax is chosen only to have some well-defined way of + referencing a part of an object. + TODO: this design is not final and this field is subject to change in the future. + type: string + kind: + description: |- + Kind of the referent. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds + type: string + name: + description: |- + Name of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names + type: string + namespace: + description: |- + Namespace of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/namespaces/ + type: string + resourceVersion: + description: |- + Specific resourceVersion to which this reference is made, if any. + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#concurrency-control-and-consistency + type: string + uid: + description: |- + UID of the referent. + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#uids + type: string + type: object + x-kubernetes-map-type: atomic + retriggerBuild: + description: RetriggerBuild triggers to build again a cleaned up seed + image. + type: boolean + size: + anyOf: + - type: integer + - type: string + default: 6442450944 + description: |- + Size specifies the size of the volume used to store the image. + Defaults to 6Gi + pattern: ^(\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))(([KMGTPE]i)|[numkMGTPE]|([eE](\+|-)?(([0-9]+(\.[0-9]*)?)|(\.[0-9]+))))?$ + x-kubernetes-int-or-string: true + targetPlatform: + description: 'Platform specifies the target platform for the built + image. Example: linux/amd64' + example: linux/amd64 + pattern: ^$|^\S+\/\S+$ + type: string + type: + default: iso + description: |- + Type specifies the type of seed image to built. + Valid values are iso|raw + Defaults to "iso" + enum: + - iso + - raw + type: string + required: + - registrationRef + - type + type: object + status: + properties: + checksumURL: + description: ChecksumURL the URL from which the SeedImage checksum + can be downloaded once the image is built. + type: string + conditions: + description: Conditions describe the state of the machine registration + object. + items: + description: "Condition contains details for one aspect of the current + state of this API Resource.\n---\nThis struct is intended for + direct use as an array at the field path .status.conditions. For + example,\n\n\n\ttype FooStatus struct{\n\t // Represents the + observations of a foo's current state.\n\t // Known .status.conditions.type + are: \"Available\", \"Progressing\", and \"Degraded\"\n\t // + +patchMergeKey=type\n\t // +patchStrategy=merge\n\t // +listType=map\n\t + \ // +listMapKey=type\n\t Conditions []metav1.Condition `json:\"conditions,omitempty\" + patchStrategy:\"merge\" patchMergeKey:\"type\" protobuf:\"bytes,1,rep,name=conditions\"`\n\n\n\t + \ // other fields\n\t}" + properties: + lastTransitionTime: + description: |- + lastTransitionTime is the last time the condition transitioned from one status to another. + This should be when the underlying condition changed. If that is not known, then using the time when the API field changed is acceptable. + format: date-time + type: string + message: + description: |- + message is a human readable message indicating details about the transition. + This may be an empty string. + maxLength: 32768 + type: string + observedGeneration: + description: |- + observedGeneration represents the .metadata.generation that the condition was set based upon. + For instance, if .metadata.generation is currently 12, but the .status.conditions[x].observedGeneration is 9, the condition is out of date + with respect to the current state of the instance. + format: int64 + minimum: 0 + type: integer + reason: + description: |- + reason contains a programmatic identifier indicating the reason for the condition's last transition. + Producers of specific condition types may define expected values and meanings for this field, + and whether the values are considered a guaranteed API. + The value should be a CamelCase string. + This field may not be empty. + maxLength: 1024 + minLength: 1 + pattern: ^[A-Za-z]([A-Za-z0-9_,:]*[A-Za-z0-9_])?$ + type: string + status: + description: status of the condition, one of True, False, Unknown. + enum: + - "True" + - "False" + - Unknown + type: string + type: + description: |- + type of condition in CamelCase or in foo.example.com/CamelCase. + --- + Many .condition.type values are consistent across resources like Available, but because arbitrary conditions can be + useful (see .node.status.conditions), the ability to deconflict is important. + The regex it matches is (dns1123SubdomainFmt/)?(qualifiedNameFmt) + maxLength: 316 + pattern: ^([a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*/)?(([A-Za-z0-9][-A-Za-z0-9_.]*)?[A-Za-z0-9])$ + type: string + required: + - lastTransitionTime + - message + - reason + - status + - type + type: object + type: array + downloadToken: + description: DownloadToken a token to identify the seed image to download. + type: string + downloadURL: + description: DownloadURL the URL from which the SeedImage can be downloaded + once built. + type: string + state: + description: State reflect the state of the seed image build process. + enum: + - Initialized + - Started + - Completed + - Failed + - NotStarted + type: string + type: object + type: object + served: true + storage: true + subresources: + status: {} diff --git a/charts/elemental-crd/103.4.1+up1.6.5/templates/validate-no-pending-deletions.yaml b/charts/elemental-crd/103.4.1+up1.6.5/templates/validate-no-pending-deletions.yaml new file mode 100644 index 0000000000..6e16863118 --- /dev/null +++ b/charts/elemental-crd/103.4.1+up1.6.5/templates/validate-no-pending-deletions.yaml @@ -0,0 +1,17 @@ +{{- $crds := list + "machineinventories.elemental.cattle.io" + "machineinventoryselectors.elemental.cattle.io" + "machineinventoryselectortemplates.elemental.cattle.io" + "machineregistrations.elemental.cattle.io" + "managedosimages.elemental.cattle.io" + "managedosversionchannels.elemental.cattle.io" + "managedosversions.elemental.cattle.io" + "seedimages.elemental.cattle.io" + "metadata.elemental.cattle.io" +-}} +{{- range $index, $crd := $crds -}} + {{- $obj := lookup "apiextensions.k8s.io/v1" "CustomResourceDefinition" $.Release.Namespace $crd -}} + {{- if and $obj $obj.metadata.deletionTimestamp -}} + {{- required "CRDs from previous installations are pending to be removed (deletionTimestamp is set). Fully deleting them before (re-)installing is required" "" -}} + {{- end -}} +{{- end -}} diff --git a/charts/elemental/103.4.1+up1.6.5/Chart.yaml b/charts/elemental/103.4.1+up1.6.5/Chart.yaml new file mode 100644 index 0000000000..e4ed82b675 --- /dev/null +++ b/charts/elemental/103.4.1+up1.6.5/Chart.yaml @@ -0,0 +1,20 @@ +annotations: + catalog.cattle.io/auto-install: elemental-crd=match + catalog.cattle.io/certified: rancher + catalog.cattle.io/display-name: Elemental + catalog.cattle.io/kube-version: '>= 1.23.0-0' + catalog.cattle.io/namespace: cattle-elemental-system + catalog.cattle.io/os: linux + catalog.cattle.io/permits-os: linux + catalog.cattle.io/provides-gvr: elemental.cattle.io/v1beta1 + catalog.cattle.io/rancher-version: '>= 2.8.0-0 < 2.9.0-0' + catalog.cattle.io/release-name: elemental-operator + catalog.cattle.io/scope: management + catalog.cattle.io/type: cluster-tool + catalog.cattle.io/upstream-version: 1.6.5 +apiVersion: v2 +appVersion: 1.6.5 +description: Elemental provides Cloud Native OS Management for Cluster Nodes. +icon: https://raw.githubusercontent.com/rancher/elemental/main/logo/icon-elemental.svg +name: elemental +version: 103.4.1+up1.6.5 diff --git a/charts/elemental/103.4.1+up1.6.5/README.md b/charts/elemental/103.4.1+up1.6.5/README.md new file mode 100644 index 0000000000..bf7b83ea6c --- /dev/null +++ b/charts/elemental/103.4.1+up1.6.5/README.md @@ -0,0 +1,5 @@ +# Elemental Operator Helm Chart + +This chart bootstraps an elemental-operator deployment on a [Rancher Manager](https://rancher.com/docs/rancher/) cluster using the [Helm](https://helm.sh) package manager. + +Check out the [Elemental Operator Helm Chart documentation](https://elemental.docs.rancher.com/elementaloperatorchart-reference/) in the official [Elemental guide](https://elemental.docs.rancher.com/). diff --git a/charts/elemental/103.4.1+up1.6.5/app-readme.md b/charts/elemental/103.4.1+up1.6.5/app-readme.md new file mode 100644 index 0000000000..3d694ac5f6 --- /dev/null +++ b/charts/elemental/103.4.1+up1.6.5/app-readme.md @@ -0,0 +1,5 @@ +# Elemental + +Elemental brings to Rancher the ability to install and manage the OS of bare metal and virtualized machines. + +For more information on how to deploy an Elemental Cluster, follow the [official documentation](https://elemental.docs.rancher.com/). \ No newline at end of file diff --git a/charts/elemental/103.4.1+up1.6.5/questions.yaml b/charts/elemental/103.4.1+up1.6.5/questions.yaml new file mode 100644 index 0000000000..53a85c6e32 --- /dev/null +++ b/charts/elemental/103.4.1+up1.6.5/questions.yaml @@ -0,0 +1,27 @@ +questions: +- variable: channel.defaultChannel + default: "true" + description: "Provide an Elemental OS Channel container image" + label: Elemental OS Channel + type: boolean + show_subquestion_if: true + group: "Elemental OS Channel" + subquestions: + - variable: channel.image + default: "registry.suse.com/rancher/elemental-channel/sl-micro" + description: "Specify the Elemental OS channel: for air-gapped scenarios you need to provide your own OS channel image (see https://elemental.docs.rancher.com/airgap for detailed instructions)" + type: string + label: Elemental OS Channel Image + group: "Elemental OS Channel" + - variable: channel.tag + default: "6.0-baremetal" + description: "Specify Elemental OS channel image tag" + type: string + label: "Elemental OS Channel Tag" + group: "Elemental OS Channel" +- variable: debug + default: "false" + description: "Enable debug logging in the Elemental operator" + type: boolean + label: "Enable Debug Logging" + group: "Logging" diff --git a/charts/elemental/103.4.1+up1.6.5/templates/_helpers.tpl b/charts/elemental/103.4.1+up1.6.5/templates/_helpers.tpl new file mode 100644 index 0000000000..ee1e6fe7d8 --- /dev/null +++ b/charts/elemental/103.4.1+up1.6.5/templates/_helpers.tpl @@ -0,0 +1,17 @@ +{{- define "system_default_registry" -}} +{{- if .Values.global.cattle.systemDefaultRegistry -}} +{{- printf "%s/" .Values.global.cattle.systemDefaultRegistry -}} +{{- else -}} +{{- "" -}} +{{- end -}} +{{- end -}} + +{{- define "registry_url" -}} +{{- if .Values.global.cattle.systemDefaultRegistry -}} +{{ include "system_default_registry" . }} +{{- else if .Values.registryUrl -}} +{{- printf "%s/" .Values.registryUrl -}} +{{- else -}} +{{- "" -}} +{{- end -}} +{{- end -}} diff --git a/charts/elemental/103.4.1+up1.6.5/templates/apiservice.yaml b/charts/elemental/103.4.1+up1.6.5/templates/apiservice.yaml new file mode 100644 index 0000000000..73ae2e505f --- /dev/null +++ b/charts/elemental/103.4.1+up1.6.5/templates/apiservice.yaml @@ -0,0 +1,9 @@ +kind: APIService +apiVersion: management.cattle.io/v3 +metadata: + name: {{ .Release.Name }} +spec: + secretName: elemental-operator + secretNamespace: {{ .Release.Namespace }} + pathPrefixes: + - /elemental/ diff --git a/charts/elemental/103.4.1+up1.6.5/templates/capi_rbac.yaml b/charts/elemental/103.4.1+up1.6.5/templates/capi_rbac.yaml new file mode 100644 index 0000000000..8692f75269 --- /dev/null +++ b/charts/elemental/103.4.1+up1.6.5/templates/capi_rbac.yaml @@ -0,0 +1,10 @@ +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + name: elemental-capi-role + labels: + cluster.x-k8s.io/aggregate-to-manager: "true" +rules: + - apiGroups: ["elemental.cattle.io"] + resources: ["*"] + verbs: ["*"] diff --git a/charts/elemental/103.4.1+up1.6.5/templates/channel-dev.yaml b/charts/elemental/103.4.1+up1.6.5/templates/channel-dev.yaml new file mode 100644 index 0000000000..da66784034 --- /dev/null +++ b/charts/elemental/103.4.1+up1.6.5/templates/channel-dev.yaml @@ -0,0 +1,13 @@ +# Unstable channel for testing isv:Rancher:Elemental OBS projects +# it is only rendered if the registryUrl value includes a known OBS project reference +{{ if and (hasPrefix "registry.opensuse.org" .Values.registryUrl) (contains "isv/rancher/elemental" .Values.registryUrl) }} +apiVersion: elemental.cattle.io/v1beta1 +kind: ManagedOSVersionChannel +metadata: + name: unstable-testing-channel + namespace: fleet-default +spec: + options: + image: {{ .Values.registryUrl }}/rancher/elemental-unstable-channel:latest + type: custom +{{ end }} diff --git a/charts/elemental/103.4.1+up1.6.5/templates/channels.yaml b/charts/elemental/103.4.1+up1.6.5/templates/channels.yaml new file mode 100644 index 0000000000..c180d36d05 --- /dev/null +++ b/charts/elemental/103.4.1+up1.6.5/templates/channels.yaml @@ -0,0 +1,30 @@ +{{ $defChannelName := "" }} +{{ if and .Values.channel .Values.channel.image .Values.channel.tag .Values.channel.name }} +{{ $defChannelName := .Values.channel.name }} +apiVersion: elemental.cattle.io/v1beta1 +kind: ManagedOSVersionChannel +metadata: + name: {{ .Values.channel.name }} + namespace: fleet-default +spec: + options: + image: {{ .Values.channel.image }}:{{ .Values.channel.tag }} + type: custom +{{ end }} + +# Keep pre-existing channels managed by Helm if they do not match with the current default +# this way if an upgrade introduces a new channel any pre-existing channel managed by Helm is not deleted +{{ range $index, $channel := (lookup "elemental.cattle.io/v1beta1" "ManagedOSVersionChannel" "fleet-default" "").items }} + {{ if and (eq (index $channel.metadata.labels "app.kubernetes.io/managed-by") "Helm") (ne $channel.metadata.name $defChannelName) }} +--- +apiVersion: elemental.cattle.io/v1beta1 +kind: ManagedOSVersionChannel +metadata: + name: {{ $channel.metadata.name }} + namespace: fleet-default +spec: + options: + image: {{ $channel.spec.options.image }} + type: custom + {{ end }} +{{ end }} diff --git a/charts/elemental/103.4.1+up1.6.5/templates/cluster_role.yaml b/charts/elemental/103.4.1+up1.6.5/templates/cluster_role.yaml new file mode 100644 index 0000000000..aaa3a0f2ec --- /dev/null +++ b/charts/elemental/103.4.1+up1.6.5/templates/cluster_role.yaml @@ -0,0 +1,268 @@ +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + name: '{{ .Release.Name }}' +rules: +- apiGroups: + - "" + resources: + - configmaps + verbs: + - create + - delete + - get + - list + - patch + - update + - watch +- apiGroups: + - "" + resources: + - events + verbs: + - create + - patch +- apiGroups: + - "" + resources: + - pods + verbs: + - create + - delete + - get + - list + - patch + - update + - watch +- apiGroups: + - "" + resources: + - pods/log + verbs: + - get +- apiGroups: + - "" + resources: + - pods/status + verbs: + - get +- apiGroups: + - "" + resources: + - secrets + verbs: + - create + - delete + - get + - list + - patch + - update + - watch +- apiGroups: + - "" + resources: + - serviceaccounts + verbs: + - create + - delete + - get + - list + - watch +- apiGroups: + - "" + resources: + - services + verbs: + - create + - delete + - get + - list + - patch + - update + - watch +- apiGroups: + - "" + resources: + - services/status + verbs: + - get +- apiGroups: + - cluster.x-k8s.io + resources: + - machines + verbs: + - get + - list + - watch +- apiGroups: + - elemental.cattle.io + resources: + - machineinventories + verbs: + - create + - delete + - get + - list + - patch + - update + - watch +- apiGroups: + - elemental.cattle.io + resources: + - machineinventories/status + verbs: + - get + - patch + - update +- apiGroups: + - elemental.cattle.io + resources: + - machineinventoryselectors + verbs: + - create + - delete + - get + - list + - patch + - update + - watch +- apiGroups: + - elemental.cattle.io + resources: + - machineinventoryselectors/status + verbs: + - get + - list + - patch + - update +- apiGroups: + - elemental.cattle.io + resources: + - machineregistrations + verbs: + - create + - delete + - get + - list + - patch + - update + - watch +- apiGroups: + - elemental.cattle.io + resources: + - machineregistrations/status + verbs: + - get + - patch + - update +- apiGroups: + - elemental.cattle.io + resources: + - managedosimages + verbs: + - create + - delete + - get + - list + - patch + - update + - watch +- apiGroups: + - elemental.cattle.io + resources: + - managedosimages/status + verbs: + - get + - list + - patch + - update +- apiGroups: + - elemental.cattle.io + resources: + - managedosversionchannels + verbs: + - create + - delete + - get + - list + - patch + - update + - watch +- apiGroups: + - elemental.cattle.io + resources: + - managedosversionchannels/status + verbs: + - get + - list + - patch + - update +- apiGroups: + - elemental.cattle.io + resources: + - managedosversions + verbs: + - create + - delete + - get + - list + - patch + - update + - watch +- apiGroups: + - elemental.cattle.io + resources: + - managedosversions/status + verbs: + - get + - list + - patch + - update +- apiGroups: + - elemental.cattle.io + resources: + - seedimages + verbs: + - create + - delete + - get + - list + - patch + - update + - watch +- apiGroups: + - elemental.cattle.io + resources: + - seedimages/status + verbs: + - get + - patch + - update +- apiGroups: + - fleet.cattle.io + resources: + - bundles + verbs: + - create + - get + - list + - update + - watch +- apiGroups: + - management.cattle.io + resources: + - settings + verbs: + - get + - list + - watch +- apiGroups: + - rbac.authorization.k8s.io + resources: + - rolebindings + - roles + verbs: + - create + - delete + - list + - watch diff --git a/charts/elemental/103.4.1+up1.6.5/templates/cluster_role_binding.yaml b/charts/elemental/103.4.1+up1.6.5/templates/cluster_role_binding.yaml new file mode 100644 index 0000000000..e68c7bc96b --- /dev/null +++ b/charts/elemental/103.4.1+up1.6.5/templates/cluster_role_binding.yaml @@ -0,0 +1,13 @@ +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: {{ .Release.Name }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: {{ .Release.Name }} +subjects: +- kind: ServiceAccount + name: {{ .Release.Name }} + namespace: {{.Release.Namespace}} + diff --git a/charts/elemental/103.4.1+up1.6.5/templates/deployment.yaml b/charts/elemental/103.4.1+up1.6.5/templates/deployment.yaml new file mode 100644 index 0000000000..576d58d596 --- /dev/null +++ b/charts/elemental/103.4.1+up1.6.5/templates/deployment.yaml @@ -0,0 +1,50 @@ +apiVersion: apps/v1 +kind: Deployment +metadata: + name: {{ .Release.Name }} +spec: + replicas: {{ .Values.replicas }} + selector: + matchLabels: + app: elemental-operator + template: + metadata: + labels: + app: elemental-operator + spec: + containers: + - env: + - name: NO_PROXY + value: {{ .Values.noProxy }} + {{- if .Values.proxy }} + - name: HTTP_PROXY + value: {{ .Values.proxy }} + - name: HTTPS_PROXY + value: {{ .Values.proxy }} + {{- end }} + name: {{ .Release.Name }} + imagePullPolicy: "{{ .Values.image.imagePullPolicy }}" + image: {{ template "registry_url" . }}{{ .Values.image.repository }}:{{ .Values.image.tag | default .Chart.AppVersion }} + args: + - operator + {{- if .Values.debug }} + - --v=5 + - --debug + {{- end }} + - --namespace + - {{ .Release.Namespace }} + - --operator-image + - {{ template "registry_url" . }}{{ .Values.image.repository }}:{{ .Values.image.tag | default .Chart.AppVersion }} + - --seedimage-image + - {{ template "registry_url" . }}{{ .Values.seedImage.repository }}:{{ .Values.seedImage.tag | default .Chart.AppVersion }} + - --seedimage-image-pullpolicy + - {{ .Values.seedImage.imagePullPolicy}} + serviceAccountName: {{ .Release.Name }} + {{- with .Values.tolerations }} + tolerations: + {{- toYaml . | nindent 8 }} + {{- end }} + {{- with .Values.nodeSelector }} + nodeSelector: + {{- toYaml . | nindent 8 }} + {{- end }} diff --git a/charts/elemental/103.4.1+up1.6.5/templates/globalrole.yaml b/charts/elemental/103.4.1+up1.6.5/templates/globalrole.yaml new file mode 100644 index 0000000000..323cf2ead8 --- /dev/null +++ b/charts/elemental/103.4.1+up1.6.5/templates/globalrole.yaml @@ -0,0 +1,16 @@ +apiVersion: management.cattle.io/v3 +builtin: false +description: "Elemental Administrator Role" +displayName: Elemental Administrator +kind: GlobalRole +metadata: + labels: + cattle.io/creator: norman + name: {{ .Release.Name }} +rules: +- apiGroups: + - elemental.cattle.io + resources: + - '*' + verbs: + - '*' diff --git a/charts/elemental/103.4.1+up1.6.5/templates/metadata.yaml b/charts/elemental/103.4.1+up1.6.5/templates/metadata.yaml new file mode 100644 index 0000000000..d102d9f2ea --- /dev/null +++ b/charts/elemental/103.4.1+up1.6.5/templates/metadata.yaml @@ -0,0 +1,10 @@ +apiVersion: elemental.cattle.io/v1beta1 +kind: Metadata +metadata: + name: {{ .Release.Name }} +spec: + appVersion: {{ .Chart.AppVersion }} + annotations: + {{- range $key, $value := .Chart.Annotations }} + {{ $key }}: {{ toYaml $value }} + {{- end }} diff --git a/charts/elemental/103.4.1+up1.6.5/templates/serviceaccount.yaml b/charts/elemental/103.4.1+up1.6.5/templates/serviceaccount.yaml new file mode 100644 index 0000000000..cb203d6f6c --- /dev/null +++ b/charts/elemental/103.4.1+up1.6.5/templates/serviceaccount.yaml @@ -0,0 +1,4 @@ +apiVersion: v1 +kind: ServiceAccount +metadata: + name: {{ .Release.Name }} diff --git a/charts/elemental/103.4.1+up1.6.5/templates/validate-install-crd.yaml b/charts/elemental/103.4.1+up1.6.5/templates/validate-install-crd.yaml new file mode 100644 index 0000000000..45008251ae --- /dev/null +++ b/charts/elemental/103.4.1+up1.6.5/templates/validate-install-crd.yaml @@ -0,0 +1,26 @@ +{{ if gt (len (lookup "rbac.authorization.k8s.io/v1" "ClusterRole" "" "")) 0 }} + {{ $apis := dict + "elemental.cattle.io/v1beta1/MachineInventory" "machineinventories" + "elemental.cattle.io/v1beta1/MachineInventorySelector" "machineinventoryselectors" + "elemental.cattle.io/v1beta1/MachineInventorySelectorTemplate" "machineinventoryselectortemplates" + "elemental.cattle.io/v1beta1/MachineRegistration" "machineregistrations" + "elemental.cattle.io/v1beta1/ManagedOSImage" "managedosimages" + "elemental.cattle.io/v1beta1/ManagedOSVersionChannel" "managedosversionchannels" + "elemental.cattle.io/v1beta1/ManagedOSVersion" "managedosversions" + "elemental.cattle.io/v1beta1/SeedImage" "seedimages" + "elemental.cattle.io/v1beta1/Metadata" "metadata" + }} + {{- range $api, $crd := $apis -}} + {{- if not ($.Capabilities.APIVersions.Has $api) -}} + {{- required "Required CRDs are missing. Please install the corresponding CRD chart before installing this chart." "" -}} + {{- end -}} + {{- $crdobj := lookup "apiextensions.k8s.io/v1" "CustomResourceDefinition" "" (print $crd ".elemental.cattle.io") -}} + {{- if not $crdobj -}} + {{- print "Cannot lookup " $crd ".elemental.cattle.io crd object" | fail -}} + {{- end -}} + {{- $crdrelease := index $crdobj.metadata.annotations "meta.helm.sh/release-name" -}} + {{- if eq $crdrelease $.Release.Name -}} + {{- required "Elemental CRDs should be moved to the new elemental-operator-crds chart before upgrading this operator." "" -}} + {{- end -}} + {{- end -}} +{{- end -}} diff --git a/charts/elemental/103.4.1+up1.6.5/values.yaml b/charts/elemental/103.4.1+up1.6.5/values.yaml new file mode 100644 index 0000000000..812abf75a2 --- /dev/null +++ b/charts/elemental/103.4.1+up1.6.5/values.yaml @@ -0,0 +1,43 @@ +image: + empty: rancher/pause:3.1 + repository: "rancher/mirrored-elemental-operator" + tag: "1.6.5" + imagePullPolicy: IfNotPresent + +seedImage: + repository: "rancher/mirrored-elemental-seedimage-builder" + tag: "1.6.5" + imagePullPolicy: IfNotPresent + +channel: + name: "sl-micro-6.0-baremetal-channel" + image: "registry.suse.com/rancher/elemental-channel/sl-micro" + tag: "6.0-baremetal" + +# number of operator replicas to deploy +replicas: 1 + +# http[s] proxy server +# proxy: http://@:: + +# comma separated list of domains or ip addresses that will not use the proxy +noProxy: 127.0.0.0/8,10.0.0.0/8,172.16.0.0/12,192.168.0.0/16,.svc,.cluster.local + +global: + cattle: + systemDefaultRegistry: "" + +# used only if systemDefaultRegistry is empty +registryUrl: "" + +# enable debug output for operator +debug: false + +nodeSelector: + kubernetes.io/os: linux + +tolerations: + - key: cattle.io/os + operator: "Equal" + value: "linux" + effect: NoSchedule diff --git a/charts/fleet-agent/103.1.10+up0.9.11/Chart.yaml b/charts/fleet-agent/103.1.10+up0.9.11/Chart.yaml new file mode 100644 index 0000000000..e0bafd42a4 --- /dev/null +++ b/charts/fleet-agent/103.1.10+up0.9.11/Chart.yaml @@ -0,0 +1,15 @@ +annotations: + catalog.cattle.io/certified: rancher + catalog.cattle.io/hidden: "true" + catalog.cattle.io/kube-version: '>= 1.23.0-0 < 1.29.0-0' + catalog.cattle.io/namespace: cattle-fleet-system + catalog.cattle.io/os: linux + catalog.cattle.io/permits-os: linux,windows + catalog.cattle.io/rancher-version: '>= 2.8.0-0 < 2.9.0-0' + catalog.cattle.io/release-name: fleet-agent +apiVersion: v2 +appVersion: 0.9.11 +description: Fleet Manager Agent - GitOps at Scale +icon: https://charts.rancher.io/assets/logos/fleet.svg +name: fleet-agent +version: 103.1.10+up0.9.11 diff --git a/charts/fleet-agent/103.1.10+up0.9.11/README.md b/charts/fleet-agent/103.1.10+up0.9.11/README.md new file mode 100644 index 0000000000..2c5724dcef --- /dev/null +++ b/charts/fleet-agent/103.1.10+up0.9.11/README.md @@ -0,0 +1,8 @@ +## Fleet Agent Helm Chart + +Every Fleet-managed downstream cluster will run an agent that communicates back to the Fleet controller. This agent is just another set of Kubernetes controllers running in the downstream cluster. + +Standalone Fleet users use this chart for agent-initiated registration. For more details see [agent-initiated registration](https://fleet.rancher.io/cluster-registration#agent-initiated). +Fleet in Rancher does not use this chart, but creates the agent deployments programmatically. + +The Fleet documentation is centralized in the [doc website](https://fleet.rancher.io/). \ No newline at end of file diff --git a/charts/fleet-agent/103.1.10+up0.9.11/templates/_helpers.tpl b/charts/fleet-agent/103.1.10+up0.9.11/templates/_helpers.tpl new file mode 100644 index 0000000000..6cd96c3ace --- /dev/null +++ b/charts/fleet-agent/103.1.10+up0.9.11/templates/_helpers.tpl @@ -0,0 +1,22 @@ +{{- define "system_default_registry" -}} +{{- if .Values.global.cattle.systemDefaultRegistry -}} +{{- printf "%s/" .Values.global.cattle.systemDefaultRegistry -}} +{{- else -}} +{{- "" -}} +{{- end -}} +{{- end -}} + +{{/* +Windows cluster will add default taint for linux nodes, +add below linux tolerations to workloads could be scheduled to those linux nodes +*/}} +{{- define "linux-node-tolerations" -}} +- key: "cattle.io/os" + value: "linux" + effect: "NoSchedule" + operator: "Equal" +{{- end -}} + +{{- define "linux-node-selector" -}} +kubernetes.io/os: linux +{{- end -}} \ No newline at end of file diff --git a/charts/fleet-agent/103.1.10+up0.9.11/templates/configmap.yaml b/charts/fleet-agent/103.1.10+up0.9.11/templates/configmap.yaml new file mode 100644 index 0000000000..f3e83a89cc --- /dev/null +++ b/charts/fleet-agent/103.1.10+up0.9.11/templates/configmap.yaml @@ -0,0 +1,13 @@ +kind: ConfigMap +apiVersion: v1 +metadata: + name: fleet-agent +data: + config: |- + { + {{ if .Values.labels }} + "labels":{{toJson .Values.labels}}, + {{ end }} + "clientID":"{{.Values.clientID}}", + "agentTLSMode": "{{.Values.agentTLSMode}}" + } diff --git a/charts/fleet-agent/103.1.10+up0.9.11/templates/deployment.yaml b/charts/fleet-agent/103.1.10+up0.9.11/templates/deployment.yaml new file mode 100644 index 0000000000..582eed608d --- /dev/null +++ b/charts/fleet-agent/103.1.10+up0.9.11/templates/deployment.yaml @@ -0,0 +1,51 @@ +apiVersion: apps/v1 +kind: Deployment +metadata: + name: fleet-agent +spec: + selector: + matchLabels: + app: fleet-agent + template: + metadata: + labels: + app: fleet-agent + spec: + containers: + - env: + - name: NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + image: '{{ template "system_default_registry" . }}{{.Values.image.repository}}:{{.Values.image.tag}}' + name: fleet-agent + command: + - fleetagent + {{- if .Values.debug }} + - --debug + - --debug-level + - {{ quote .Values.debugLevel }} + {{- else }} + securityContext: + allowPrivilegeEscalation: false + readOnlyRootFilesystem: true + privileged: false + capabilities: + drop: + - ALL + {{- end }} + serviceAccountName: fleet-agent + nodeSelector: {{ include "linux-node-selector" . | nindent 8 }} +{{- if .Values.fleetAgent.nodeSelector }} +{{ toYaml .Values.fleetAgent.nodeSelector | indent 8 }} +{{- end }} + tolerations: {{ include "linux-node-tolerations" . | nindent 8 }} +{{- if .Values.fleetAgent.tolerations }} +{{ toYaml .Values.fleetAgent.tolerations | indent 8 }} +{{- end }} +{{- if not .Values.debug }} + securityContext: + runAsNonRoot: true + runAsUser: 1000 + runAsGroup: 1000 +{{- end }} diff --git a/charts/fleet-agent/103.1.10+up0.9.11/templates/network_policy_allow_all.yaml b/charts/fleet-agent/103.1.10+up0.9.11/templates/network_policy_allow_all.yaml new file mode 100644 index 0000000000..a72109a062 --- /dev/null +++ b/charts/fleet-agent/103.1.10+up0.9.11/templates/network_policy_allow_all.yaml @@ -0,0 +1,15 @@ +--- +apiVersion: networking.k8s.io/v1 +kind: NetworkPolicy +metadata: + name: default-allow-all + namespace: {{ .Values.internal.systemNamespace }} +spec: + podSelector: {} + ingress: + - {} + egress: + - {} + policyTypes: + - Ingress + - Egress diff --git a/charts/fleet-agent/103.1.10+up0.9.11/templates/patch_default_serviceaccount.yaml b/charts/fleet-agent/103.1.10+up0.9.11/templates/patch_default_serviceaccount.yaml new file mode 100644 index 0000000000..aad4eea415 --- /dev/null +++ b/charts/fleet-agent/103.1.10+up0.9.11/templates/patch_default_serviceaccount.yaml @@ -0,0 +1,28 @@ +--- +apiVersion: batch/v1 +kind: Job +metadata: + name: patch-fleet-sa + annotations: + "helm.sh/hook": post-install, post-upgrade + "helm.sh/hook-delete-policy": hook-succeeded, before-hook-creation +spec: + template: + spec: + serviceAccountName: fleet-agent + restartPolicy: Never + containers: + - name: sa + image: "{{ template "system_default_registry" . }}{{ .Values.global.kubectl.repository }}:{{ .Values.global.kubectl.tag }}" + imagePullPolicy: {{ .Values.global.imagePullPolicy }} + command: ["kubectl", "patch", "serviceaccount", "default", "-p", "{\"automountServiceAccountToken\": false}"] + args: ["-n", {{ .Values.internal.systemNamespace }}] + nodeSelector: {{ include "linux-node-selector" . | nindent 8 }} +{{- if .Values.kubectl.nodeSelector }} +{{ toYaml .Values.kubectl.nodeSelector | indent 8 }} +{{- end }} + tolerations: {{ include "linux-node-tolerations" . | nindent 8 }} +{{- if .Values.kubectl.tolerations }} +{{ toYaml .Values.kubectl.tolerations | indent 8 }} +{{- end }} + backoffLimit: 1 diff --git a/charts/fleet-agent/103.1.10+up0.9.11/templates/rbac.yaml b/charts/fleet-agent/103.1.10+up0.9.11/templates/rbac.yaml new file mode 100644 index 0000000000..1a7e8d8841 --- /dev/null +++ b/charts/fleet-agent/103.1.10+up0.9.11/templates/rbac.yaml @@ -0,0 +1,28 @@ +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + name: fleet-agent-system-fleet-agent-role +rules: +- apiGroups: + - '*' + resources: + - '*' + verbs: + - '*' +- nonResourceURLs: + - "*" + verbs: + - "*" +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: fleet-agent-system-fleet-agent-role-binding +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: fleet-agent-system-fleet-agent-role +subjects: +- kind: ServiceAccount + name: fleet-agent + namespace: {{.Release.Namespace}} diff --git a/charts/fleet-agent/103.1.10+up0.9.11/templates/secret.yaml b/charts/fleet-agent/103.1.10+up0.9.11/templates/secret.yaml new file mode 100644 index 0000000000..4715882047 --- /dev/null +++ b/charts/fleet-agent/103.1.10+up0.9.11/templates/secret.yaml @@ -0,0 +1,10 @@ +apiVersion: v1 +data: + systemRegistrationNamespace: "{{b64enc .Values.systemRegistrationNamespace}}" + clusterNamespace: "{{b64enc .Values.clusterNamespace}}" + token: "{{b64enc .Values.token}}" + apiServerURL: "{{b64enc .Values.apiServerURL}}" + apiServerCA: "{{b64enc .Values.apiServerCA}}" +kind: Secret +metadata: + name: fleet-agent-bootstrap diff --git a/charts/fleet-agent/103.1.10+up0.9.11/templates/serviceaccount.yaml b/charts/fleet-agent/103.1.10+up0.9.11/templates/serviceaccount.yaml new file mode 100644 index 0000000000..73e27f0be9 --- /dev/null +++ b/charts/fleet-agent/103.1.10+up0.9.11/templates/serviceaccount.yaml @@ -0,0 +1,4 @@ +apiVersion: v1 +kind: ServiceAccount +metadata: + name: fleet-agent diff --git a/charts/fleet-agent/103.1.10+up0.9.11/templates/validate.yaml b/charts/fleet-agent/103.1.10+up0.9.11/templates/validate.yaml new file mode 100644 index 0000000000..d53ff1c508 --- /dev/null +++ b/charts/fleet-agent/103.1.10+up0.9.11/templates/validate.yaml @@ -0,0 +1,11 @@ +{{if ne .Release.Namespace .Values.internal.systemNamespace }} +{{ fail (printf "This chart must be installed in the namespace %s as the release name fleet-agent" .Values.internal.systemNamespace) }} +{{end}} + +{{if ne .Release.Name .Values.internal.managedReleaseName }} +{{ fail (printf "This chart must be installed in the namespace %s as the release name fleet-agent" .Values.internal.managedReleaseName) }} +{{end}} + +{{if not .Values.apiServerURL }} +{{ fail "apiServerURL is required to be set, and most likely also apiServerCA" }} +{{end}} diff --git a/charts/fleet-agent/103.1.10+up0.9.11/values.yaml b/charts/fleet-agent/103.1.10+up0.9.11/values.yaml new file mode 100644 index 0000000000..92be5a40f0 --- /dev/null +++ b/charts/fleet-agent/103.1.10+up0.9.11/values.yaml @@ -0,0 +1,67 @@ +image: + os: "windows,linux" + repository: rancher/fleet-agent + tag: v0.9.11 + +# The public URL of the Kubernetes API server running the Fleet Manager must be set here +# Example: https://example.com:6443 +apiServerURL: "" + +# The the pem encoded value of the CA of the Kubernetes API server running the Fleet Manager. +# If left empty it is assumed this Kubernetes API TLS is signed by a well known CA. +apiServerCA: "" + +# Determines whether the agent should trust CA bundles from the operating system's trust store when connecting to a +# management cluster. True in `system-store` mode, false in `strict` mode. +agentTLSMode: "system-store" + +# The cluster registration value +token: "" + +# Labels to add to the cluster upon registration only. They are not added after the fact. +#labels: +# foo: bar + +# The client ID of the cluster to associate with +clientID: "" + +# The namespace of the cluster we are register with +clusterNamespace: "" + +# The namespace containing the clusters registration secrets +systemRegistrationNamespace: cattle-fleet-clusters-system + +# Please do not change the below setting unless you really know what you are doing +internal: + systemNamespace: cattle-fleet-system + managedReleaseName: fleet-agent + +# The nodeSelector and tolerations for the agent deployment +fleetAgent: + ## Node labels for pod assignment + ## Ref: https://kubernetes.io/docs/user-guide/node-selection/ + ## + nodeSelector: {} + ## List of node taints to tolerate (requires Kubernetes >= 1.6) + tolerations: [] +kubectl: + ## Node labels for pod assignment + ## Ref: https://kubernetes.io/docs/user-guide/node-selection/ + ## + nodeSelector: {} + ## List of node taints to tolerate (requires Kubernetes >= 1.6) + tolerations: + - key: node.cloudprovider.kubernetes.io/uninitialized + operator: "Equal" + value: "true" + effect: NoSchedule + +global: + cattle: + systemDefaultRegistry: "" + kubectl: + repository: rancher/kubectl + tag: v1.21.5 + +debug: false +debugLevel: 0 diff --git a/charts/fleet-crd/103.1.10+up0.9.11/Chart.yaml b/charts/fleet-crd/103.1.10+up0.9.11/Chart.yaml new file mode 100644 index 0000000000..c2957bf5c7 --- /dev/null +++ b/charts/fleet-crd/103.1.10+up0.9.11/Chart.yaml @@ -0,0 +1,13 @@ +annotations: + catalog.cattle.io/certified: rancher + catalog.cattle.io/hidden: "true" + catalog.cattle.io/namespace: cattle-fleet-system + catalog.cattle.io/os: linux + catalog.cattle.io/permits-os: linux,windows + catalog.cattle.io/release-name: fleet-crd +apiVersion: v2 +appVersion: 0.9.11 +description: Fleet Manager CustomResourceDefinitions +icon: https://charts.rancher.io/assets/logos/fleet.svg +name: fleet-crd +version: 103.1.10+up0.9.11 diff --git a/charts/fleet-crd/103.1.10+up0.9.11/README.md b/charts/fleet-crd/103.1.10+up0.9.11/README.md new file mode 100644 index 0000000000..2452ab2f1f --- /dev/null +++ b/charts/fleet-crd/103.1.10+up0.9.11/README.md @@ -0,0 +1,5 @@ +# Fleet CRD Helm Chart + +Fleet Manager CustomResourceDefinitions Helm chart is a requirement for the Fleet Helm Chart. + +The Fleet documentation is centralized in the [doc website](https://fleet.rancher.io/). \ No newline at end of file diff --git a/charts/fleet-crd/103.1.10+up0.9.11/templates/crds.yaml b/charts/fleet-crd/103.1.10+up0.9.11/templates/crds.yaml new file mode 100644 index 0000000000..d42811945d --- /dev/null +++ b/charts/fleet-crd/103.1.10+up0.9.11/templates/crds.yaml @@ -0,0 +1,6859 @@ +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: bundledeployments.fleet.cattle.io +spec: + group: fleet.cattle.io + names: + kind: BundleDeployment + plural: bundledeployments + singular: bundledeployment + preserveUnknownFields: false + scope: Namespaced + versions: + - additionalPrinterColumns: + - jsonPath: .status.display.deployed + name: Deployed + type: string + - jsonPath: .status.display.monitored + name: Monitored + type: string + - jsonPath: .status.conditions[?(@.type=="Ready")].message + name: Status + type: string + name: v1alpha1 + schema: + openAPIV3Schema: + description: 'BundleDeployment is used internally by Fleet and should not + be used directly. + + When a Bundle is deployed to a cluster an instance of a Bundle is called + a + + BundleDeployment. A BundleDeployment represents the state of that Bundle + on + + a specific cluster with its cluster-specific customizations. The Fleet + agent + + is only aware of BundleDeployment resources that are created for the cluster + + the agent is managing.' + properties: + apiVersion: + description: 'APIVersion defines the versioned schema of this representation + of an object. + + Servers should convert recognized schemas to the latest internal value, + and + + may reject unrecognized values. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + type: string + kind: + description: 'Kind is a string value representing the REST resource + this object represents. + + Servers may infer this from the endpoint the client submits requests + to. + + Cannot be updated. + + In CamelCase. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + type: string + metadata: + type: object + spec: + properties: + correctDrift: + description: CorrectDrift specifies how drift correction should + work. + nullable: true + properties: + enabled: + description: Enabled correct drift if true. + type: boolean + force: + description: Force helm rollback with --force option will be + used if true. This will try to recreate all resources in the + release. + type: boolean + keepFailHistory: + description: KeepFailHistory keeps track of failed rollbacks + in the helm history. + type: boolean + type: object + dependsOn: + description: DependsOn refers to the bundles which must be ready + before this bundle can be deployed. + items: + properties: + name: + description: Name of the bundle. + nullable: true + type: string + selector: + description: Selector matching bundle's labels. + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of label selector + requirements. The requirements are ANDed. + items: + description: 'A label selector requirement is a selector + that contains values, a key, and an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that the selector + applies to. + nullable: true + type: string + operator: + description: 'operator represents a key''s relationship + to a set of values. + + Valid operators are In, NotIn, Exists and DoesNotExist.' + nullable: true + type: string + values: + description: 'values is an array of string values. + If the operator is In or NotIn, + + the values array must be non-empty. If the operator + is Exists or DoesNotExist, + + the values array must be empty. This array is + replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} pairs. + A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains only + "value". The requirements are ANDed.' + nullable: true + type: object + type: object + type: object + nullable: true + type: array + deploymentID: + description: DeploymentID is the ID of the currently applied deployment. + nullable: true + type: string + options: + description: Options are the deployment options, that are currently + applied. + properties: + correctDrift: + description: CorrectDrift specifies how drift correction should + work. + nullable: true + properties: + enabled: + description: Enabled correct drift if true. + type: boolean + force: + description: Force helm rollback with --force option will + be used if true. This will try to recreate all resources + in the release. + type: boolean + keepFailHistory: + description: KeepFailHistory keeps track of failed rollbacks + in the helm history. + type: boolean + type: object + defaultNamespace: + description: 'DefaultNamespace is the namespace to use for resources + that do not + + specify a namespace. This field is not used to enforce or + lock down + + the deployment to a specific namespace.' + nullable: true + type: string + deleteCRDResources: + description: DeleteCRDResources deletes CRDs. Warning! this + will also delete all your Custom Resources. + type: boolean + diff: + description: Diff can be used to ignore the modified state of + objects which are amended at runtime. + nullable: true + properties: + comparePatches: + description: ComparePatches match a resource and remove + fields from the check for modifications. + items: + description: ComparePatch matches a resource and removes + fields from the check for modifications. + properties: + apiVersion: + description: APIVersion is the apiVersion of the resource + to match. + nullable: true + type: string + jsonPointers: + description: JSONPointers ignore diffs at a certain + JSON path. + items: + nullable: true + type: string + nullable: true + type: array + kind: + description: Kind is the kind of the resource to match. + nullable: true + type: string + name: + description: Name is the name of the resource to match. + nullable: true + type: string + namespace: + description: Namespace is the namespace of the resource + to match. + nullable: true + type: string + operations: + description: Operations remove a JSON path from the + resource. + items: + description: Operation of a ComparePatch, usually + "remove". + properties: + op: + description: Op is usually "remove" + nullable: true + type: string + path: + description: Path is the JSON path to remove. + nullable: true + type: string + value: + description: Value is usually empty. + nullable: true + type: string + type: object + nullable: true + type: array + type: object + nullable: true + type: array + type: object + forceSyncGeneration: + description: ForceSyncGeneration is used to force a redeployment + type: integer + helm: + description: Helm options for the deployment, like the chart + name, repo and values. + nullable: true + properties: + atomic: + description: Atomic sets the --atomic flag when Helm is + performing an upgrade + type: boolean + chart: + description: 'Chart can refer to any go-getter URL or OCI + registry based helm + + chart URL. The chart will be downloaded.' + nullable: true + type: string + disableDNS: + description: DisableDNS can be used to customize Helm's + EnableDNS option, which Fleet sets to `true` by default. + type: boolean + disablePreProcess: + description: DisablePreProcess disables template processing + in values + type: boolean + force: + description: Force allows to override immutable resources. + This could be dangerous. + type: boolean + maxHistory: + description: MaxHistory limits the maximum number of revisions + saved per release by Helm. + type: integer + releaseName: + description: 'ReleaseName sets a custom release name to + deploy the chart as. If + + not specified a release name will be generated by combining + the + + invoking GitRepo.name + GitRepo.path.' + maxLength: 53 + nullable: true + pattern: ^[a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*$ + type: string + repo: + description: Repo is the name of the HTTPS helm repo to + download the chart from. + nullable: true + type: string + skipSchemaValidation: + description: SkipSchemaValidation allows skipping schema + validation against the chart values + type: boolean + takeOwnership: + description: TakeOwnership makes helm skip the check for + its own annotations + type: boolean + timeoutSeconds: + description: TimeoutSeconds is the time to wait for Helm + operations. + type: integer + values: + description: 'Values passed to Helm. It is possible to specify + the keys and values + + as go template strings.' + nullable: true + type: object + x-kubernetes-preserve-unknown-fields: true + valuesFiles: + description: ValuesFiles is a list of files to load values + from. + items: + nullable: true + type: string + nullable: true + type: array + valuesFrom: + description: ValuesFrom loads the values from configmaps + and secrets. + items: + description: 'Define helm values that can come from configmap, + secret or external. Credit: https://github.com/fluxcd/helm-operator/blob/0cfea875b5d44bea995abe7324819432070dfbdc/pkg/apis/helm.fluxcd.io/v1/types_helmrelease.go#L439' + properties: + configMapKeyRef: + description: The reference to a config map with release + values. + nullable: true + properties: + key: + nullable: true + type: string + name: + description: Name of a resource in the same namespace + as the referent. + nullable: true + type: string + namespace: + nullable: true + type: string + type: object + secretKeyRef: + description: The reference to a secret with release + values. + nullable: true + properties: + key: + nullable: true + type: string + name: + description: Name of a resource in the same namespace + as the referent. + nullable: true + type: string + namespace: + nullable: true + type: string + type: object + type: object + nullable: true + type: array + version: + description: Version of the chart to download + nullable: true + type: string + waitForJobs: + description: 'WaitForJobs if set and timeoutSeconds provided, + will wait until all + + Jobs have been completed before marking the GitRepo as + ready. It + + will wait for as long as timeoutSeconds' + type: boolean + type: object + ignore: + description: IgnoreOptions can be used to ignore fields when + monitoring the bundle. + properties: + conditions: + description: Conditions is a list of conditions to be ignored + when monitoring the Bundle. + items: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + nullable: true + type: array + type: object + keepResources: + description: KeepResources can be used to keep the deployed + resources when removing the bundle + type: boolean + kustomize: + description: 'Kustomize options for the deployment, like the + dir containing the + + kustomization.yaml file.' + nullable: true + properties: + dir: + description: 'Dir points to a custom folder for kustomize + resources. This folder must contain + + a kustomization.yaml file.' + nullable: true + type: string + type: object + namespace: + description: 'TargetNamespace if present will assign all resource + to this + + namespace and if any cluster scoped resource exists the deployment + + will fail.' + nullable: true + type: string + namespaceAnnotations: + additionalProperties: + nullable: true + type: string + description: NamespaceAnnotations are annotations that will + be appended to the namespace created by Fleet. + nullable: true + type: object + namespaceLabels: + additionalProperties: + nullable: true + type: string + description: NamespaceLabels are labels that will be appended + to the namespace created by Fleet. + nullable: true + type: object + serviceAccount: + description: ServiceAccount which will be used to perform this + deployment. + nullable: true + type: string + yaml: + description: 'YAML options, if using raw YAML these are names + that map to + + overlays/{name} files that will be used to replace or patch + a resource.' + nullable: true + properties: + overlays: + description: 'Overlays is a list of names that maps to folders + in "overlays/". + + If you wish to customize the file ./subdir/resource.yaml + then a file + + ./overlays/myoverlay/subdir/resource.yaml will replace + the base + + file. + + A file named ./overlays/myoverlay/subdir/resource_patch.yaml + will patch the base file.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + type: object + paused: + description: 'Paused if set to true, will stop any BundleDeployments + from being + + updated. If true, BundleDeployments will be marked as out of sync + + when changes are detected.' + type: boolean + stagedDeploymentID: + description: StagedDeploymentID is the ID of the staged deployment. + nullable: true + type: string + stagedOptions: + description: 'StagedOptions are the deployment options, that are + staged for + + the next deployment.' + properties: + correctDrift: + description: CorrectDrift specifies how drift correction should + work. + nullable: true + properties: + enabled: + description: Enabled correct drift if true. + type: boolean + force: + description: Force helm rollback with --force option will + be used if true. This will try to recreate all resources + in the release. + type: boolean + keepFailHistory: + description: KeepFailHistory keeps track of failed rollbacks + in the helm history. + type: boolean + type: object + defaultNamespace: + description: 'DefaultNamespace is the namespace to use for resources + that do not + + specify a namespace. This field is not used to enforce or + lock down + + the deployment to a specific namespace.' + nullable: true + type: string + deleteCRDResources: + description: DeleteCRDResources deletes CRDs. Warning! this + will also delete all your Custom Resources. + type: boolean + diff: + description: Diff can be used to ignore the modified state of + objects which are amended at runtime. + nullable: true + properties: + comparePatches: + description: ComparePatches match a resource and remove + fields from the check for modifications. + items: + description: ComparePatch matches a resource and removes + fields from the check for modifications. + properties: + apiVersion: + description: APIVersion is the apiVersion of the resource + to match. + nullable: true + type: string + jsonPointers: + description: JSONPointers ignore diffs at a certain + JSON path. + items: + nullable: true + type: string + nullable: true + type: array + kind: + description: Kind is the kind of the resource to match. + nullable: true + type: string + name: + description: Name is the name of the resource to match. + nullable: true + type: string + namespace: + description: Namespace is the namespace of the resource + to match. + nullable: true + type: string + operations: + description: Operations remove a JSON path from the + resource. + items: + description: Operation of a ComparePatch, usually + "remove". + properties: + op: + description: Op is usually "remove" + nullable: true + type: string + path: + description: Path is the JSON path to remove. + nullable: true + type: string + value: + description: Value is usually empty. + nullable: true + type: string + type: object + nullable: true + type: array + type: object + nullable: true + type: array + type: object + forceSyncGeneration: + description: ForceSyncGeneration is used to force a redeployment + type: integer + helm: + description: Helm options for the deployment, like the chart + name, repo and values. + nullable: true + properties: + atomic: + description: Atomic sets the --atomic flag when Helm is + performing an upgrade + type: boolean + chart: + description: 'Chart can refer to any go-getter URL or OCI + registry based helm + + chart URL. The chart will be downloaded.' + nullable: true + type: string + disableDNS: + description: DisableDNS can be used to customize Helm's + EnableDNS option, which Fleet sets to `true` by default. + type: boolean + disablePreProcess: + description: DisablePreProcess disables template processing + in values + type: boolean + force: + description: Force allows to override immutable resources. + This could be dangerous. + type: boolean + maxHistory: + description: MaxHistory limits the maximum number of revisions + saved per release by Helm. + type: integer + releaseName: + description: 'ReleaseName sets a custom release name to + deploy the chart as. If + + not specified a release name will be generated by combining + the + + invoking GitRepo.name + GitRepo.path.' + nullable: true + type: string + repo: + description: Repo is the name of the HTTPS helm repo to + download the chart from. + nullable: true + type: string + skipSchemaValidation: + description: SkipSchemaValidation allows skipping schema + validation against the chart values + type: boolean + takeOwnership: + description: TakeOwnership makes helm skip the check for + its own annotations + type: boolean + timeoutSeconds: + description: TimeoutSeconds is the time to wait for Helm + operations. + type: integer + values: + description: 'Values passed to Helm. It is possible to specify + the keys and values + + as go template strings.' + nullable: true + type: object + x-kubernetes-preserve-unknown-fields: true + valuesFiles: + description: ValuesFiles is a list of files to load values + from. + items: + nullable: true + type: string + nullable: true + type: array + valuesFrom: + description: ValuesFrom loads the values from configmaps + and secrets. + items: + description: 'Define helm values that can come from configmap, + secret or external. Credit: https://github.com/fluxcd/helm-operator/blob/0cfea875b5d44bea995abe7324819432070dfbdc/pkg/apis/helm.fluxcd.io/v1/types_helmrelease.go#L439' + properties: + configMapKeyRef: + description: The reference to a config map with release + values. + nullable: true + properties: + key: + nullable: true + type: string + name: + description: Name of a resource in the same namespace + as the referent. + nullable: true + type: string + namespace: + nullable: true + type: string + type: object + secretKeyRef: + description: The reference to a secret with release + values. + nullable: true + properties: + key: + nullable: true + type: string + name: + description: Name of a resource in the same namespace + as the referent. + nullable: true + type: string + namespace: + nullable: true + type: string + type: object + type: object + nullable: true + type: array + version: + description: Version of the chart to download + nullable: true + type: string + waitForJobs: + description: 'WaitForJobs if set and timeoutSeconds provided, + will wait until all + + Jobs have been completed before marking the GitRepo as + ready. It + + will wait for as long as timeoutSeconds' + type: boolean + type: object + ignore: + description: IgnoreOptions can be used to ignore fields when + monitoring the bundle. + properties: + conditions: + description: Conditions is a list of conditions to be ignored + when monitoring the Bundle. + items: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + nullable: true + type: array + type: object + keepResources: + description: KeepResources can be used to keep the deployed + resources when removing the bundle + type: boolean + kustomize: + description: 'Kustomize options for the deployment, like the + dir containing the + + kustomization.yaml file.' + nullable: true + properties: + dir: + description: 'Dir points to a custom folder for kustomize + resources. This folder must contain + + a kustomization.yaml file.' + nullable: true + type: string + type: object + namespace: + description: 'TargetNamespace if present will assign all resource + to this + + namespace and if any cluster scoped resource exists the deployment + + will fail.' + nullable: true + type: string + namespaceAnnotations: + additionalProperties: + nullable: true + type: string + description: NamespaceAnnotations are annotations that will + be appended to the namespace created by Fleet. + nullable: true + type: object + namespaceLabels: + additionalProperties: + nullable: true + type: string + description: NamespaceLabels are labels that will be appended + to the namespace created by Fleet. + nullable: true + type: object + serviceAccount: + description: ServiceAccount which will be used to perform this + deployment. + nullable: true + type: string + yaml: + description: 'YAML options, if using raw YAML these are names + that map to + + overlays/{name} files that will be used to replace or patch + a resource.' + nullable: true + properties: + overlays: + description: 'Overlays is a list of names that maps to folders + in "overlays/". + + If you wish to customize the file ./subdir/resource.yaml + then a file + + ./overlays/myoverlay/subdir/resource.yaml will replace + the base + + file. + + A file named ./overlays/myoverlay/subdir/resource_patch.yaml + will patch the base file.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + type: object + type: object + status: + properties: + appliedDeploymentID: + nullable: true + type: string + conditions: + items: + properties: + lastTransitionTime: + description: Last time the condition transitioned from one + status to another. + nullable: true + type: string + lastUpdateTime: + description: The last time this condition was updated. + nullable: true + type: string + message: + description: Human-readable message indicating details about + last transition + nullable: true + type: string + reason: + description: The reason for the condition's last transition. + nullable: true + type: string + status: + description: Status of the condition, one of True, False, + Unknown. + nullable: true + type: string + type: + description: Type of cluster condition. + nullable: true + type: string + type: object + nullable: true + type: array + display: + properties: + deployed: + nullable: true + type: string + monitored: + nullable: true + type: string + state: + nullable: true + type: string + type: object + modifiedStatus: + items: + description: 'ModifiedStatus is used to report the status of a + resource that is modified. + + It indicates if the modification was a create, a delete or a + patch.' + properties: + apiVersion: + nullable: true + type: string + delete: + type: boolean + kind: + nullable: true + type: string + missing: + type: boolean + name: + nullable: true + type: string + namespace: + nullable: true + type: string + patch: + nullable: true + type: string + type: object + nullable: true + type: array + nonModified: + type: boolean + nonReadyStatus: + items: + description: NonReadyStatus is used to report the status of a + resource that is not ready. It includes a summary. + properties: + apiVersion: + nullable: true + type: string + kind: + nullable: true + type: string + name: + nullable: true + type: string + namespace: + nullable: true + type: string + summary: + properties: + error: + type: boolean + message: + items: + nullable: true + type: string + nullable: true + type: array + state: + nullable: true + type: string + transitioning: + type: boolean + type: object + uid: + description: 'UID is a type that holds unique ID values, including + UUIDs. Because we + + don''t ONLY use UUIDs, this is an alias to string. Being + a type captures + + intent and helps make sure that UIDs and names do not get + conflated.' + nullable: true + type: string + type: object + nullable: true + type: array + ready: + type: boolean + release: + nullable: true + type: string + resources: + description: 'Resources lists the metadata of resources that were + deployed + + according to the helm release history.' + items: + description: BundleDeploymentResource contains the metadata of + a deployed resource. + properties: + apiVersion: + nullable: true + type: string + createdAt: + nullable: true + type: string + kind: + nullable: true + type: string + name: + nullable: true + type: string + namespace: + nullable: true + type: string + type: object + nullable: true + type: array + syncGeneration: + nullable: true + type: integer + type: object + type: object + served: true + storage: true + subresources: + status: {} +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: bundlenamespacemappings.fleet.cattle.io +spec: + group: fleet.cattle.io + names: + kind: BundleNamespaceMapping + plural: bundlenamespacemappings + singular: bundlenamespacemapping + preserveUnknownFields: false + scope: Namespaced + versions: + - name: v1alpha1 + schema: + openAPIV3Schema: + description: BundleNamespaceMapping maps bundles to clusters in other namespaces. + properties: + apiVersion: + description: 'APIVersion defines the versioned schema of this representation + of an object. + + Servers should convert recognized schemas to the latest internal value, + and + + may reject unrecognized values. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + type: string + bundleSelector: + description: 'A label selector is a label query over a set of resources. + The result of matchLabels and + + matchExpressions are ANDed. An empty label selector matches all objects. + A null + + label selector matches no objects.' + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of label selector requirements. + The requirements are ANDed. + items: + description: 'A label selector requirement is a selector that + contains values, a key, and an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that the selector applies + to. + nullable: true + type: string + operator: + description: 'operator represents a key''s relationship to + a set of values. + + Valid operators are In, NotIn, Exists and DoesNotExist.' + nullable: true + type: string + values: + description: 'values is an array of string values. If the + operator is In or NotIn, + + the values array must be non-empty. If the operator is Exists + or DoesNotExist, + + the values array must be empty. This array is replaced during + a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} pairs. A single + {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, whose key + field is "key", the + + operator is "In", and the values array contains only "value". + The requirements are ANDed.' + nullable: true + type: object + type: object + kind: + description: 'Kind is a string value representing the REST resource + this object represents. + + Servers may infer this from the endpoint the client submits requests + to. + + Cannot be updated. + + In CamelCase. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + type: string + metadata: + type: object + namespaceSelector: + description: 'A label selector is a label query over a set of resources. + The result of matchLabels and + + matchExpressions are ANDed. An empty label selector matches all objects. + A null + + label selector matches no objects.' + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of label selector requirements. + The requirements are ANDed. + items: + description: 'A label selector requirement is a selector that + contains values, a key, and an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that the selector applies + to. + nullable: true + type: string + operator: + description: 'operator represents a key''s relationship to + a set of values. + + Valid operators are In, NotIn, Exists and DoesNotExist.' + nullable: true + type: string + values: + description: 'values is an array of string values. If the + operator is In or NotIn, + + the values array must be non-empty. If the operator is Exists + or DoesNotExist, + + the values array must be empty. This array is replaced during + a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} pairs. A single + {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, whose key + field is "key", the + + operator is "In", and the values array contains only "value". + The requirements are ANDed.' + nullable: true + type: object + type: object + type: object + served: true + storage: true + subresources: + status: {} +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: bundles.fleet.cattle.io +spec: + group: fleet.cattle.io + names: + kind: Bundle + plural: bundles + singular: bundle + preserveUnknownFields: false + scope: Namespaced + versions: + - additionalPrinterColumns: + - jsonPath: .status.display.readyClusters + name: BundleDeployments-Ready + type: string + - jsonPath: .status.conditions[?(@.type=="Ready")].message + name: Status + type: string + name: v1alpha1 + schema: + openAPIV3Schema: + description: 'Bundle contains the resources of an application and its deployment + options. + + It will be deployed as a Helm chart to target clusters. + + + + When a GitRepo is scanned it will produce one or more bundles. Bundles + are + + a collection of resources that get deployed to one or more cluster(s). + Bundle is the + + fundamental deployment unit used in Fleet. The contents of a Bundle may + be + + Kubernetes manifests, Kustomize configuration, or Helm charts. Regardless + + of the source the contents are dynamically rendered into a Helm chart + by + + the agent and installed into the downstream cluster as a Helm release.' + properties: + apiVersion: + description: 'APIVersion defines the versioned schema of this representation + of an object. + + Servers should convert recognized schemas to the latest internal value, + and + + may reject unrecognized values. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + type: string + kind: + description: 'Kind is a string value representing the REST resource + this object represents. + + Servers may infer this from the endpoint the client submits requests + to. + + Cannot be updated. + + In CamelCase. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + type: string + metadata: + type: object + spec: + properties: + correctDrift: + description: CorrectDrift specifies how drift correction should + work. + nullable: true + properties: + enabled: + description: Enabled correct drift if true. + type: boolean + force: + description: Force helm rollback with --force option will be + used if true. This will try to recreate all resources in the + release. + type: boolean + keepFailHistory: + description: KeepFailHistory keeps track of failed rollbacks + in the helm history. + type: boolean + type: object + defaultNamespace: + description: 'DefaultNamespace is the namespace to use for resources + that do not + + specify a namespace. This field is not used to enforce or lock + down + + the deployment to a specific namespace.' + nullable: true + type: string + deleteCRDResources: + description: DeleteCRDResources deletes CRDs. Warning! this will + also delete all your Custom Resources. + type: boolean + dependsOn: + description: DependsOn refers to the bundles which must be ready + before this bundle can be deployed. + items: + properties: + name: + description: Name of the bundle. + nullable: true + type: string + selector: + description: Selector matching bundle's labels. + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of label selector + requirements. The requirements are ANDed. + items: + description: 'A label selector requirement is a selector + that contains values, a key, and an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that the selector + applies to. + nullable: true + type: string + operator: + description: 'operator represents a key''s relationship + to a set of values. + + Valid operators are In, NotIn, Exists and DoesNotExist.' + nullable: true + type: string + values: + description: 'values is an array of string values. + If the operator is In or NotIn, + + the values array must be non-empty. If the operator + is Exists or DoesNotExist, + + the values array must be empty. This array is + replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} pairs. + A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains only + "value". The requirements are ANDed.' + nullable: true + type: object + type: object + type: object + nullable: true + type: array + diff: + description: Diff can be used to ignore the modified state of objects + which are amended at runtime. + nullable: true + properties: + comparePatches: + description: ComparePatches match a resource and remove fields + from the check for modifications. + items: + description: ComparePatch matches a resource and removes fields + from the check for modifications. + properties: + apiVersion: + description: APIVersion is the apiVersion of the resource + to match. + nullable: true + type: string + jsonPointers: + description: JSONPointers ignore diffs at a certain JSON + path. + items: + nullable: true + type: string + nullable: true + type: array + kind: + description: Kind is the kind of the resource to match. + nullable: true + type: string + name: + description: Name is the name of the resource to match. + nullable: true + type: string + namespace: + description: Namespace is the namespace of the resource + to match. + nullable: true + type: string + operations: + description: Operations remove a JSON path from the resource. + items: + description: Operation of a ComparePatch, usually "remove". + properties: + op: + description: Op is usually "remove" + nullable: true + type: string + path: + description: Path is the JSON path to remove. + nullable: true + type: string + value: + description: Value is usually empty. + nullable: true + type: string + type: object + nullable: true + type: array + type: object + nullable: true + type: array + type: object + forceSyncGeneration: + description: ForceSyncGeneration is used to force a redeployment + type: integer + helm: + description: Helm options for the deployment, like the chart name, + repo and values. + nullable: true + properties: + atomic: + description: Atomic sets the --atomic flag when Helm is performing + an upgrade + type: boolean + chart: + description: 'Chart can refer to any go-getter URL or OCI registry + based helm + + chart URL. The chart will be downloaded.' + nullable: true + type: string + disableDNS: + description: DisableDNS can be used to customize Helm's EnableDNS + option, which Fleet sets to `true` by default. + type: boolean + disablePreProcess: + description: DisablePreProcess disables template processing + in values + type: boolean + force: + description: Force allows to override immutable resources. This + could be dangerous. + type: boolean + maxHistory: + description: MaxHistory limits the maximum number of revisions + saved per release by Helm. + type: integer + releaseName: + description: 'ReleaseName sets a custom release name to deploy + the chart as. If + + not specified a release name will be generated by combining + the + + invoking GitRepo.name + GitRepo.path.' + maxLength: 53 + nullable: true + pattern: ^[a-z0-9]([-a-z0-9]*[a-z0-9])?(\.[a-z0-9]([-a-z0-9]*[a-z0-9])?)*$ + type: string + repo: + description: Repo is the name of the HTTPS helm repo to download + the chart from. + nullable: true + type: string + skipSchemaValidation: + description: SkipSchemaValidation allows skipping schema validation + against the chart values + type: boolean + takeOwnership: + description: TakeOwnership makes helm skip the check for its + own annotations + type: boolean + timeoutSeconds: + description: TimeoutSeconds is the time to wait for Helm operations. + type: integer + values: + description: 'Values passed to Helm. It is possible to specify + the keys and values + + as go template strings.' + nullable: true + type: object + x-kubernetes-preserve-unknown-fields: true + valuesFiles: + description: ValuesFiles is a list of files to load values from. + items: + nullable: true + type: string + nullable: true + type: array + valuesFrom: + description: ValuesFrom loads the values from configmaps and + secrets. + items: + description: 'Define helm values that can come from configmap, + secret or external. Credit: https://github.com/fluxcd/helm-operator/blob/0cfea875b5d44bea995abe7324819432070dfbdc/pkg/apis/helm.fluxcd.io/v1/types_helmrelease.go#L439' + properties: + configMapKeyRef: + description: The reference to a config map with release + values. + nullable: true + properties: + key: + nullable: true + type: string + name: + description: Name of a resource in the same namespace + as the referent. + nullable: true + type: string + namespace: + nullable: true + type: string + type: object + secretKeyRef: + description: The reference to a secret with release values. + nullable: true + properties: + key: + nullable: true + type: string + name: + description: Name of a resource in the same namespace + as the referent. + nullable: true + type: string + namespace: + nullable: true + type: string + type: object + type: object + nullable: true + type: array + version: + description: Version of the chart to download + nullable: true + type: string + waitForJobs: + description: 'WaitForJobs if set and timeoutSeconds provided, + will wait until all + + Jobs have been completed before marking the GitRepo as ready. + It + + will wait for as long as timeoutSeconds' + type: boolean + type: object + ignore: + description: IgnoreOptions can be used to ignore fields when monitoring + the bundle. + properties: + conditions: + description: Conditions is a list of conditions to be ignored + when monitoring the Bundle. + items: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + nullable: true + type: array + type: object + keepResources: + description: KeepResources can be used to keep the deployed resources + when removing the bundle + type: boolean + kustomize: + description: 'Kustomize options for the deployment, like the dir + containing the + + kustomization.yaml file.' + nullable: true + properties: + dir: + description: 'Dir points to a custom folder for kustomize resources. + This folder must contain + + a kustomization.yaml file.' + nullable: true + type: string + type: object + namespace: + description: 'TargetNamespace if present will assign all resource + to this + + namespace and if any cluster scoped resource exists the deployment + + will fail.' + nullable: true + type: string + namespaceAnnotations: + additionalProperties: + nullable: true + type: string + description: NamespaceAnnotations are annotations that will be appended + to the namespace created by Fleet. + nullable: true + type: object + namespaceLabels: + additionalProperties: + nullable: true + type: string + description: NamespaceLabels are labels that will be appended to + the namespace created by Fleet. + nullable: true + type: object + paused: + description: Paused if set to true, will stop any BundleDeployments + from being updated. It will be marked as out of sync. + type: boolean + resources: + description: 'Resources contains the resources that were read from + the bundle''s + + path. This includes the content of downloaded helm charts.' + items: + description: BundleResource represents the content of a single + resource from the bundle, like a YAML manifest. + properties: + content: + description: The content of the resource, can be compressed. + nullable: true + type: string + encoding: + description: Encoding is either empty or "base64+gz". + nullable: true + type: string + name: + description: Name of the resource, can include the bundle's + internal path. + nullable: true + type: string + type: object + nullable: true + type: array + rolloutStrategy: + description: 'RolloutStrategy controls the rollout of bundles, by + defining + + partitions, canaries and percentages for cluster availability.' + nullable: true + properties: + autoPartitionSize: + description: 'A number or percentage of how to automatically + partition clusters if no + + specific partitioning strategy is configured. + + default: 25%' + nullable: true + x-kubernetes-int-or-string: true + maxUnavailable: + description: 'A number or percentage of clusters that can be + unavailable during an update + + of a bundle. This follows the same basic approach as a deployment + rollout + + strategy. Once the number of clusters meets unavailable state + update will be + + paused. Default value is 100% which doesn''t take effect on + update. + + default: 100%' + nullable: true + x-kubernetes-int-or-string: true + maxUnavailablePartitions: + description: 'A number or percentage of cluster partitions that + can be unavailable during + + an update of a bundle. + + default: 0' + nullable: true + x-kubernetes-int-or-string: true + partitions: + description: 'A list of definitions of partitions. If any target + clusters do not match + + the configuration they are added to partitions at the end + following the + + autoPartitionSize.' + items: + description: Partition defines a separate rollout strategy + for a set of clusters. + properties: + clusterGroup: + description: A cluster group name to include in this partition + nullable: true + type: string + clusterGroupSelector: + description: Selector matching cluster group labels to + include in this partition + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of label selector + requirements. The requirements are ANDed. + items: + description: 'A label selector requirement is a + selector that contains values, a key, and an operator + that + + relates the key and values.' + properties: + key: + description: key is the label key that the selector + applies to. + nullable: true + type: string + operator: + description: 'operator represents a key''s relationship + to a set of values. + + Valid operators are In, NotIn, Exists and + DoesNotExist.' + nullable: true + type: string + values: + description: 'values is an array of string values. + If the operator is In or NotIn, + + the values array must be non-empty. If the + operator is Exists or DoesNotExist, + + the values array must be empty. This array + is replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} + pairs. A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains + only "value". The requirements are ANDed.' + nullable: true + type: object + type: object + clusterName: + description: ClusterName is the name of a cluster to include + in this partition + nullable: true + type: string + clusterSelector: + description: Selector matching cluster labels to include + in this partition + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of label selector + requirements. The requirements are ANDed. + items: + description: 'A label selector requirement is a + selector that contains values, a key, and an operator + that + + relates the key and values.' + properties: + key: + description: key is the label key that the selector + applies to. + nullable: true + type: string + operator: + description: 'operator represents a key''s relationship + to a set of values. + + Valid operators are In, NotIn, Exists and + DoesNotExist.' + nullable: true + type: string + values: + description: 'values is an array of string values. + If the operator is In or NotIn, + + the values array must be non-empty. If the + operator is Exists or DoesNotExist, + + the values array must be empty. This array + is replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} + pairs. A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains + only "value". The requirements are ANDed.' + nullable: true + type: object + type: object + maxUnavailable: + description: 'A number or percentage of clusters that + can be unavailable in this + + partition before this partition is treated as done. + + default: 10%' + nullable: true + x-kubernetes-int-or-string: true + name: + description: A user-friendly name given to the partition + used for Display (optional). + nullable: true + type: string + type: object + nullable: true + type: array + type: object + serviceAccount: + description: ServiceAccount which will be used to perform this deployment. + nullable: true + type: string + targetRestrictions: + description: TargetRestrictions is an allow list, which controls + if a bundledeployment is created for a target. + items: + description: 'BundleTargetRestriction is used internally by Fleet + and should not be modified. + + It acts as an allow list, to prevent the creation of BundleDeployments + from + + Targets created by TargetCustomizations in fleet.yaml.' + properties: + clusterGroup: + nullable: true + type: string + clusterGroupSelector: + description: 'A label selector is a label query over a set + of resources. The result of matchLabels and + + matchExpressions are ANDed. An empty label selector matches + all objects. A null + + label selector matches no objects.' + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of label selector + requirements. The requirements are ANDed. + items: + description: 'A label selector requirement is a selector + that contains values, a key, and an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that the selector + applies to. + nullable: true + type: string + operator: + description: 'operator represents a key''s relationship + to a set of values. + + Valid operators are In, NotIn, Exists and DoesNotExist.' + nullable: true + type: string + values: + description: 'values is an array of string values. + If the operator is In or NotIn, + + the values array must be non-empty. If the operator + is Exists or DoesNotExist, + + the values array must be empty. This array is + replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} pairs. + A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains only + "value". The requirements are ANDed.' + nullable: true + type: object + type: object + clusterName: + nullable: true + type: string + clusterSelector: + description: 'A label selector is a label query over a set + of resources. The result of matchLabels and + + matchExpressions are ANDed. An empty label selector matches + all objects. A null + + label selector matches no objects.' + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of label selector + requirements. The requirements are ANDed. + items: + description: 'A label selector requirement is a selector + that contains values, a key, and an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that the selector + applies to. + nullable: true + type: string + operator: + description: 'operator represents a key''s relationship + to a set of values. + + Valid operators are In, NotIn, Exists and DoesNotExist.' + nullable: true + type: string + values: + description: 'values is an array of string values. + If the operator is In or NotIn, + + the values array must be non-empty. If the operator + is Exists or DoesNotExist, + + the values array must be empty. This array is + replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} pairs. + A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains only + "value". The requirements are ANDed.' + nullable: true + type: object + type: object + name: + nullable: true + type: string + type: object + nullable: true + type: array + targets: + description: 'Targets refer to the clusters which will be deployed + to. + + Targets are evaluated in order and the first one to match is used.' + items: + description: 'BundleTarget declares clusters to deploy to. Fleet + will merge the + + BundleDeploymentOptions from customizations into this struct.' + properties: + clusterGroup: + description: ClusterGroup to match a specific cluster group + by name. + nullable: true + type: string + clusterGroupSelector: + description: ClusterGroupSelector is a selector to match cluster + groups. + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of label selector + requirements. The requirements are ANDed. + items: + description: 'A label selector requirement is a selector + that contains values, a key, and an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that the selector + applies to. + nullable: true + type: string + operator: + description: 'operator represents a key''s relationship + to a set of values. + + Valid operators are In, NotIn, Exists and DoesNotExist.' + nullable: true + type: string + values: + description: 'values is an array of string values. + If the operator is In or NotIn, + + the values array must be non-empty. If the operator + is Exists or DoesNotExist, + + the values array must be empty. This array is + replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} pairs. + A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains only + "value". The requirements are ANDed.' + nullable: true + type: object + type: object + clusterName: + description: 'ClusterName to match a specific cluster by name + that will be + + selected' + nullable: true + type: string + clusterSelector: + description: 'ClusterSelector is a selector to match clusters. + The structure is + + the standard metav1.LabelSelector format. If clusterGroupSelector + or + + clusterGroup is specified, clusterSelector will be used + only to + + further refine the selection after clusterGroupSelector + and + + clusterGroup is evaluated.' + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of label selector + requirements. The requirements are ANDed. + items: + description: 'A label selector requirement is a selector + that contains values, a key, and an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that the selector + applies to. + nullable: true + type: string + operator: + description: 'operator represents a key''s relationship + to a set of values. + + Valid operators are In, NotIn, Exists and DoesNotExist.' + nullable: true + type: string + values: + description: 'values is an array of string values. + If the operator is In or NotIn, + + the values array must be non-empty. If the operator + is Exists or DoesNotExist, + + the values array must be empty. This array is + replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} pairs. + A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains only + "value". The requirements are ANDed.' + nullable: true + type: object + type: object + correctDrift: + description: CorrectDrift specifies how drift correction should + work. + nullable: true + properties: + enabled: + description: Enabled correct drift if true. + type: boolean + force: + description: Force helm rollback with --force option will + be used if true. This will try to recreate all resources + in the release. + type: boolean + keepFailHistory: + description: KeepFailHistory keeps track of failed rollbacks + in the helm history. + type: boolean + type: object + defaultNamespace: + description: 'DefaultNamespace is the namespace to use for + resources that do not + + specify a namespace. This field is not used to enforce or + lock down + + the deployment to a specific namespace.' + nullable: true + type: string + deleteCRDResources: + description: DeleteCRDResources deletes CRDs. Warning! this + will also delete all your Custom Resources. + type: boolean + diff: + description: Diff can be used to ignore the modified state + of objects which are amended at runtime. + nullable: true + properties: + comparePatches: + description: ComparePatches match a resource and remove + fields from the check for modifications. + items: + description: ComparePatch matches a resource and removes + fields from the check for modifications. + properties: + apiVersion: + description: APIVersion is the apiVersion of the + resource to match. + nullable: true + type: string + jsonPointers: + description: JSONPointers ignore diffs at a certain + JSON path. + items: + nullable: true + type: string + nullable: true + type: array + kind: + description: Kind is the kind of the resource to + match. + nullable: true + type: string + name: + description: Name is the name of the resource to + match. + nullable: true + type: string + namespace: + description: Namespace is the namespace of the resource + to match. + nullable: true + type: string + operations: + description: Operations remove a JSON path from + the resource. + items: + description: Operation of a ComparePatch, usually + "remove". + properties: + op: + description: Op is usually "remove" + nullable: true + type: string + path: + description: Path is the JSON path to remove. + nullable: true + type: string + value: + description: Value is usually empty. + nullable: true + type: string + type: object + nullable: true + type: array + type: object + nullable: true + type: array + type: object + doNotDeploy: + description: DoNotDeploy if set to true, will not deploy to + this target. + type: boolean + forceSyncGeneration: + description: ForceSyncGeneration is used to force a redeployment + type: integer + helm: + description: Helm options for the deployment, like the chart + name, repo and values. + nullable: true + properties: + atomic: + description: Atomic sets the --atomic flag when Helm is + performing an upgrade + type: boolean + chart: + description: 'Chart can refer to any go-getter URL or + OCI registry based helm + + chart URL. The chart will be downloaded.' + nullable: true + type: string + disableDNS: + description: DisableDNS can be used to customize Helm's + EnableDNS option, which Fleet sets to `true` by default. + type: boolean + disablePreProcess: + description: DisablePreProcess disables template processing + in values + type: boolean + force: + description: Force allows to override immutable resources. + This could be dangerous. + type: boolean + maxHistory: + description: MaxHistory limits the maximum number of revisions + saved per release by Helm. + type: integer + releaseName: + description: 'ReleaseName sets a custom release name to + deploy the chart as. If + + not specified a release name will be generated by combining + the + + invoking GitRepo.name + GitRepo.path.' + nullable: true + type: string + repo: + description: Repo is the name of the HTTPS helm repo to + download the chart from. + nullable: true + type: string + skipSchemaValidation: + description: SkipSchemaValidation allows skipping schema + validation against the chart values + type: boolean + takeOwnership: + description: TakeOwnership makes helm skip the check for + its own annotations + type: boolean + timeoutSeconds: + description: TimeoutSeconds is the time to wait for Helm + operations. + type: integer + values: + description: 'Values passed to Helm. It is possible to + specify the keys and values + + as go template strings.' + nullable: true + type: object + x-kubernetes-preserve-unknown-fields: true + valuesFiles: + description: ValuesFiles is a list of files to load values + from. + items: + nullable: true + type: string + nullable: true + type: array + valuesFrom: + description: ValuesFrom loads the values from configmaps + and secrets. + items: + description: 'Define helm values that can come from + configmap, secret or external. Credit: https://github.com/fluxcd/helm-operator/blob/0cfea875b5d44bea995abe7324819432070dfbdc/pkg/apis/helm.fluxcd.io/v1/types_helmrelease.go#L439' + properties: + configMapKeyRef: + description: The reference to a config map with + release values. + nullable: true + properties: + key: + nullable: true + type: string + name: + description: Name of a resource in the same + namespace as the referent. + nullable: true + type: string + namespace: + nullable: true + type: string + type: object + secretKeyRef: + description: The reference to a secret with release + values. + nullable: true + properties: + key: + nullable: true + type: string + name: + description: Name of a resource in the same + namespace as the referent. + nullable: true + type: string + namespace: + nullable: true + type: string + type: object + type: object + nullable: true + type: array + version: + description: Version of the chart to download + nullable: true + type: string + waitForJobs: + description: 'WaitForJobs if set and timeoutSeconds provided, + will wait until all + + Jobs have been completed before marking the GitRepo + as ready. It + + will wait for as long as timeoutSeconds' + type: boolean + type: object + ignore: + description: IgnoreOptions can be used to ignore fields when + monitoring the bundle. + properties: + conditions: + description: Conditions is a list of conditions to be + ignored when monitoring the Bundle. + items: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + nullable: true + type: array + type: object + keepResources: + description: KeepResources can be used to keep the deployed + resources when removing the bundle + type: boolean + kustomize: + description: 'Kustomize options for the deployment, like the + dir containing the + + kustomization.yaml file.' + nullable: true + properties: + dir: + description: 'Dir points to a custom folder for kustomize + resources. This folder must contain + + a kustomization.yaml file.' + nullable: true + type: string + type: object + name: + description: 'Name of target. This value is largely for display + and logging. If + + not specified a default name of the format "target000" will + be used' + nullable: true + type: string + namespace: + description: 'TargetNamespace if present will assign all resource + to this + + namespace and if any cluster scoped resource exists the + deployment + + will fail.' + nullable: true + type: string + namespaceAnnotations: + additionalProperties: + nullable: true + type: string + description: NamespaceAnnotations are annotations that will + be appended to the namespace created by Fleet. + nullable: true + type: object + namespaceLabels: + additionalProperties: + nullable: true + type: string + description: NamespaceLabels are labels that will be appended + to the namespace created by Fleet. + nullable: true + type: object + serviceAccount: + description: ServiceAccount which will be used to perform + this deployment. + nullable: true + type: string + yaml: + description: 'YAML options, if using raw YAML these are names + that map to + + overlays/{name} files that will be used to replace or patch + a resource.' + nullable: true + properties: + overlays: + description: 'Overlays is a list of names that maps to + folders in "overlays/". + + If you wish to customize the file ./subdir/resource.yaml + then a file + + ./overlays/myoverlay/subdir/resource.yaml will replace + the base + + file. + + A file named ./overlays/myoverlay/subdir/resource_patch.yaml + will patch the base file.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + type: object + nullable: true + type: array + yaml: + description: 'YAML options, if using raw YAML these are names that + map to + + overlays/{name} files that will be used to replace or patch a + resource.' + nullable: true + properties: + overlays: + description: 'Overlays is a list of names that maps to folders + in "overlays/". + + If you wish to customize the file ./subdir/resource.yaml then + a file + + ./overlays/myoverlay/subdir/resource.yaml will replace the + base + + file. + + A file named ./overlays/myoverlay/subdir/resource_patch.yaml + will patch the base file.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + type: object + status: + properties: + conditions: + description: 'Conditions is a list of Wrangler conditions that describe + the state + + of the bundle.' + items: + properties: + lastTransitionTime: + description: Last time the condition transitioned from one + status to another. + nullable: true + type: string + lastUpdateTime: + description: The last time this condition was updated. + nullable: true + type: string + message: + description: Human-readable message indicating details about + last transition + nullable: true + type: string + reason: + description: The reason for the condition's last transition. + nullable: true + type: string + status: + description: Status of the condition, one of True, False, + Unknown. + nullable: true + type: string + type: + description: Type of cluster condition. + nullable: true + type: string + type: object + nullable: true + type: array + display: + description: 'Display contains the number of ready, desiredready + clusters and a + + summary state for the bundle''s resources.' + properties: + readyClusters: + description: 'ReadyClusters is a string in the form "%d/%d", + that describes the + + number of clusters that are ready vs. the number of clusters + desired + + to be ready.' + nullable: true + type: string + state: + description: State is a summary state for the bundle, calculated + over the non-ready resources. + nullable: true + type: string + type: object + maxNew: + description: 'MaxNew is always 50. A bundle change can only stage + 50 + + bundledeployments at a time.' + type: integer + maxUnavailable: + description: 'MaxUnavailable is the maximum number of unavailable + deployments. See + + rollout configuration.' + type: integer + maxUnavailablePartitions: + description: 'MaxUnavailablePartitions is the maximum number of + unavailable + + partitions. The rollout configuration defines a maximum number + or + + percentage of unavailable partitions.' + type: integer + newlyCreated: + description: 'NewlyCreated is the number of bundle deployments that + have been created, + + not updated.' + type: integer + observedGeneration: + description: ObservedGeneration is the current generation of the + bundle. + type: integer + partitions: + description: PartitionStatus lists the status of each partition. + items: + description: PartitionStatus is the status of a single rollout + partition. + properties: + count: + description: Count is the number of clusters in the partition. + type: integer + maxUnavailable: + description: MaxUnavailable is the maximum number of unavailable + clusters in the partition. + type: integer + name: + description: Name is the name of the partition. + nullable: true + type: string + summary: + description: Summary is a summary state for the partition, + calculated over its non-ready resources. + properties: + desiredReady: + description: 'DesiredReady is the number of bundle deployments + that should be + + ready.' + type: integer + errApplied: + description: 'ErrApplied is the number of bundle deployments + that have been synced + + from the Fleet controller and the downstream cluster, + but with some + + errors when deploying the bundle.' + type: integer + modified: + description: 'Modified is the number of bundle deployments + that have been deployed + + and for which all resources are ready, but where some + changes from the + + Git repository have not yet been synced.' + type: integer + nonReadyResources: + description: 'NonReadyClusters is a list of states, which + is filled for a bundle + + that is not ready.' + items: + description: 'NonReadyResource contains information + about a bundle that is not ready for a + + given state like "ErrApplied". It contains a list + of non-ready or modified + + resources and their states.' + properties: + bundleState: + description: State is the state of the resource, + like e.g. "NotReady" or "ErrApplied". + nullable: true + type: string + message: + description: Message contains information why the + bundle is not ready. + nullable: true + type: string + modifiedStatus: + description: ModifiedStatus lists the state for + each modified resource. + items: + description: 'ModifiedStatus is used to report + the status of a resource that is modified. + + It indicates if the modification was a create, + a delete or a patch.' + properties: + apiVersion: + nullable: true + type: string + delete: + type: boolean + kind: + nullable: true + type: string + missing: + type: boolean + name: + nullable: true + type: string + namespace: + nullable: true + type: string + patch: + nullable: true + type: string + type: object + nullable: true + type: array + name: + description: Name is the name of the resource. + nullable: true + type: string + nonReadyStatus: + description: NonReadyStatus lists the state for + each non-ready resource. + items: + description: NonReadyStatus is used to report + the status of a resource that is not ready. + It includes a summary. + properties: + apiVersion: + nullable: true + type: string + kind: + nullable: true + type: string + name: + nullable: true + type: string + namespace: + nullable: true + type: string + summary: + properties: + error: + type: boolean + message: + items: + nullable: true + type: string + nullable: true + type: array + state: + nullable: true + type: string + transitioning: + type: boolean + type: object + uid: + description: 'UID is a type that holds unique + ID values, including UUIDs. Because we + + don''t ONLY use UUIDs, this is an alias + to string. Being a type captures + + intent and helps make sure that UIDs and + names do not get conflated.' + nullable: true + type: string + type: object + nullable: true + type: array + type: object + nullable: true + type: array + notReady: + description: 'NotReady is the number of bundle deployments + that have been deployed + + where some resources are not ready.' + type: integer + outOfSync: + description: 'OutOfSync is the number of bundle deployments + that have been synced + + from Fleet controller, but not yet by the downstream + agent.' + type: integer + pending: + description: 'Pending is the number of bundle deployments + that are being processed + + by Fleet controller.' + type: integer + ready: + description: 'Ready is the number of bundle deployments + that have been deployed + + where all resources are ready.' + type: integer + waitApplied: + description: 'WaitApplied is the number of bundle deployments + that have been + + synced from Fleet controller and downstream cluster, + but are waiting + + to be deployed.' + type: integer + type: object + unavailable: + description: Unavailable is the number of unavailable clusters + in the partition. + type: integer + type: object + nullable: true + type: array + resourceKey: + description: 'ResourceKey lists resources, which will likely be + deployed. The + + actual list of resources on a cluster might differ, depending + on the + + helm chart, value templating, etc..' + items: + description: ResourceKey lists resources, which will likely be + deployed. + properties: + apiVersion: + description: APIVersion is the k8s api version of the resource. + nullable: true + type: string + kind: + description: Kind is the k8s api kind of the resource. + nullable: true + type: string + name: + description: Name is the name of the resource. + nullable: true + type: string + namespace: + description: Namespace is the namespace of the resource. + nullable: true + type: string + type: object + nullable: true + type: array + summary: + description: 'Summary contains the number of bundle deployments + in each state and + + a list of non-ready resources.' + properties: + desiredReady: + description: 'DesiredReady is the number of bundle deployments + that should be + + ready.' + type: integer + errApplied: + description: 'ErrApplied is the number of bundle deployments + that have been synced + + from the Fleet controller and the downstream cluster, but + with some + + errors when deploying the bundle.' + type: integer + modified: + description: 'Modified is the number of bundle deployments that + have been deployed + + and for which all resources are ready, but where some changes + from the + + Git repository have not yet been synced.' + type: integer + nonReadyResources: + description: 'NonReadyClusters is a list of states, which is + filled for a bundle + + that is not ready.' + items: + description: 'NonReadyResource contains information about + a bundle that is not ready for a + + given state like "ErrApplied". It contains a list of non-ready + or modified + + resources and their states.' + properties: + bundleState: + description: State is the state of the resource, like + e.g. "NotReady" or "ErrApplied". + nullable: true + type: string + message: + description: Message contains information why the bundle + is not ready. + nullable: true + type: string + modifiedStatus: + description: ModifiedStatus lists the state for each modified + resource. + items: + description: 'ModifiedStatus is used to report the status + of a resource that is modified. + + It indicates if the modification was a create, a delete + or a patch.' + properties: + apiVersion: + nullable: true + type: string + delete: + type: boolean + kind: + nullable: true + type: string + missing: + type: boolean + name: + nullable: true + type: string + namespace: + nullable: true + type: string + patch: + nullable: true + type: string + type: object + nullable: true + type: array + name: + description: Name is the name of the resource. + nullable: true + type: string + nonReadyStatus: + description: NonReadyStatus lists the state for each non-ready + resource. + items: + description: NonReadyStatus is used to report the status + of a resource that is not ready. It includes a summary. + properties: + apiVersion: + nullable: true + type: string + kind: + nullable: true + type: string + name: + nullable: true + type: string + namespace: + nullable: true + type: string + summary: + properties: + error: + type: boolean + message: + items: + nullable: true + type: string + nullable: true + type: array + state: + nullable: true + type: string + transitioning: + type: boolean + type: object + uid: + description: 'UID is a type that holds unique ID + values, including UUIDs. Because we + + don''t ONLY use UUIDs, this is an alias to string. Being + a type captures + + intent and helps make sure that UIDs and names + do not get conflated.' + nullable: true + type: string + type: object + nullable: true + type: array + type: object + nullable: true + type: array + notReady: + description: 'NotReady is the number of bundle deployments that + have been deployed + + where some resources are not ready.' + type: integer + outOfSync: + description: 'OutOfSync is the number of bundle deployments + that have been synced + + from Fleet controller, but not yet by the downstream agent.' + type: integer + pending: + description: 'Pending is the number of bundle deployments that + are being processed + + by Fleet controller.' + type: integer + ready: + description: 'Ready is the number of bundle deployments that + have been deployed + + where all resources are ready.' + type: integer + waitApplied: + description: 'WaitApplied is the number of bundle deployments + that have been + + synced from Fleet controller and downstream cluster, but are + waiting + + to be deployed.' + type: integer + type: object + unavailable: + description: 'Unavailable is the number of bundle deployments that + are not ready or + + where the AppliedDeploymentID in the status does not match the + + DeploymentID from the spec.' + type: integer + unavailablePartitions: + description: UnavailablePartitions is the number of unavailable + partitions. + type: integer + type: object + type: object + served: true + storage: true + subresources: + status: {} +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: clustergroups.fleet.cattle.io +spec: + group: fleet.cattle.io + names: + categories: + - fleet + kind: ClusterGroup + plural: clustergroups + singular: clustergroup + preserveUnknownFields: false + scope: Namespaced + versions: + - additionalPrinterColumns: + - jsonPath: .status.display.readyClusters + name: Clusters-Ready + type: string + - jsonPath: .status.display.readyBundles + name: Bundles-Ready + type: string + - jsonPath: .status.conditions[?(@.type=="Ready")].message + name: Status + type: string + name: v1alpha1 + schema: + openAPIV3Schema: + description: ClusterGroup is a re-usable selector to target a group of clusters. + properties: + apiVersion: + description: 'APIVersion defines the versioned schema of this representation + of an object. + + Servers should convert recognized schemas to the latest internal value, + and + + may reject unrecognized values. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + type: string + kind: + description: 'Kind is a string value representing the REST resource + this object represents. + + Servers may infer this from the endpoint the client submits requests + to. + + Cannot be updated. + + In CamelCase. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + type: string + metadata: + type: object + spec: + properties: + selector: + description: Selector is a label selector, used to select clusters + for this group. + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of label selector requirements. + The requirements are ANDed. + items: + description: 'A label selector requirement is a selector that + contains values, a key, and an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that the selector applies + to. + nullable: true + type: string + operator: + description: 'operator represents a key''s relationship + to a set of values. + + Valid operators are In, NotIn, Exists and DoesNotExist.' + nullable: true + type: string + values: + description: 'values is an array of string values. If + the operator is In or NotIn, + + the values array must be non-empty. If the operator + is Exists or DoesNotExist, + + the values array must be empty. This array is replaced + during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} pairs. A single + {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, whose + key field is "key", the + + operator is "In", and the values array contains only "value". + The requirements are ANDed.' + nullable: true + type: object + type: object + type: object + status: + properties: + clusterCount: + description: ClusterCount is the number of clusters in the cluster + group. + type: integer + conditions: + description: Conditions is a list of conditions and their statuses + for the cluster group. + items: + properties: + lastTransitionTime: + description: Last time the condition transitioned from one + status to another. + nullable: true + type: string + lastUpdateTime: + description: The last time this condition was updated. + nullable: true + type: string + message: + description: Human-readable message indicating details about + last transition + nullable: true + type: string + reason: + description: The reason for the condition's last transition. + nullable: true + type: string + status: + description: Status of the condition, one of True, False, + Unknown. + nullable: true + type: string + type: + description: Type of cluster condition. + nullable: true + type: string + type: object + nullable: true + type: array + display: + description: 'Display contains the number of ready, desiredready + clusters and a + + summary state for the bundle''s resources.' + properties: + readyBundles: + description: 'ReadyBundles is a string in the form "%d/%d", + that describes the + + number of bundles that are ready vs. the number of bundles + desired + + to be ready.' + nullable: true + type: string + readyClusters: + description: 'ReadyClusters is a string in the form "%d/%d", + that describes the + + number of clusters that are ready vs. the number of clusters + desired + + to be ready.' + nullable: true + type: string + state: + description: 'State is a summary state for the cluster group, + showing "NotReady" if + + there are non-ready resources.' + nullable: true + type: string + type: object + nonReadyClusterCount: + description: NonReadyClusterCount is the number of clusters that + are not ready. + type: integer + nonReadyClusters: + description: NonReadyClusters is a list of cluster names that are + not ready. + items: + nullable: true + type: string + nullable: true + type: array + resourceCounts: + description: 'ResourceCounts contains the number of resources in + each state over + + all bundles in the cluster group.' + properties: + desiredReady: + description: DesiredReady is the number of resources that should + be ready. + type: integer + missing: + description: Missing is the number of missing resources. + type: integer + modified: + description: Modified is the number of resources that have been + modified. + type: integer + notReady: + description: 'NotReady is the number of not ready resources. + Resources are not + + ready if they do not match any other state.' + type: integer + orphaned: + description: Orphaned is the number of orphaned resources. + type: integer + ready: + description: Ready is the number of ready resources. + type: integer + unknown: + description: Unknown is the number of resources in an unknown + state. + type: integer + waitApplied: + description: WaitApplied is the number of resources that are + waiting to be applied. + type: integer + type: object + summary: + description: 'Summary is a summary of the bundle deployments and + their resources + + in the cluster group.' + properties: + desiredReady: + description: 'DesiredReady is the number of bundle deployments + that should be + + ready.' + type: integer + errApplied: + description: 'ErrApplied is the number of bundle deployments + that have been synced + + from the Fleet controller and the downstream cluster, but + with some + + errors when deploying the bundle.' + type: integer + modified: + description: 'Modified is the number of bundle deployments that + have been deployed + + and for which all resources are ready, but where some changes + from the + + Git repository have not yet been synced.' + type: integer + nonReadyResources: + description: 'NonReadyClusters is a list of states, which is + filled for a bundle + + that is not ready.' + items: + description: 'NonReadyResource contains information about + a bundle that is not ready for a + + given state like "ErrApplied". It contains a list of non-ready + or modified + + resources and their states.' + properties: + bundleState: + description: State is the state of the resource, like + e.g. "NotReady" or "ErrApplied". + nullable: true + type: string + message: + description: Message contains information why the bundle + is not ready. + nullable: true + type: string + modifiedStatus: + description: ModifiedStatus lists the state for each modified + resource. + items: + description: 'ModifiedStatus is used to report the status + of a resource that is modified. + + It indicates if the modification was a create, a delete + or a patch.' + properties: + apiVersion: + nullable: true + type: string + delete: + type: boolean + kind: + nullable: true + type: string + missing: + type: boolean + name: + nullable: true + type: string + namespace: + nullable: true + type: string + patch: + nullable: true + type: string + type: object + nullable: true + type: array + name: + description: Name is the name of the resource. + nullable: true + type: string + nonReadyStatus: + description: NonReadyStatus lists the state for each non-ready + resource. + items: + description: NonReadyStatus is used to report the status + of a resource that is not ready. It includes a summary. + properties: + apiVersion: + nullable: true + type: string + kind: + nullable: true + type: string + name: + nullable: true + type: string + namespace: + nullable: true + type: string + summary: + properties: + error: + type: boolean + message: + items: + nullable: true + type: string + nullable: true + type: array + state: + nullable: true + type: string + transitioning: + type: boolean + type: object + uid: + description: 'UID is a type that holds unique ID + values, including UUIDs. Because we + + don''t ONLY use UUIDs, this is an alias to string. Being + a type captures + + intent and helps make sure that UIDs and names + do not get conflated.' + nullable: true + type: string + type: object + nullable: true + type: array + type: object + nullable: true + type: array + notReady: + description: 'NotReady is the number of bundle deployments that + have been deployed + + where some resources are not ready.' + type: integer + outOfSync: + description: 'OutOfSync is the number of bundle deployments + that have been synced + + from Fleet controller, but not yet by the downstream agent.' + type: integer + pending: + description: 'Pending is the number of bundle deployments that + are being processed + + by Fleet controller.' + type: integer + ready: + description: 'Ready is the number of bundle deployments that + have been deployed + + where all resources are ready.' + type: integer + waitApplied: + description: 'WaitApplied is the number of bundle deployments + that have been + + synced from Fleet controller and downstream cluster, but are + waiting + + to be deployed.' + type: integer + type: object + type: object + type: object + served: true + storage: true + subresources: + status: {} +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: clusterregistrations.fleet.cattle.io +spec: + group: fleet.cattle.io + names: + kind: ClusterRegistration + plural: clusterregistrations + singular: clusterregistration + preserveUnknownFields: false + scope: Namespaced + versions: + - additionalPrinterColumns: + - jsonPath: .status.clusterName + name: Cluster-Name + type: string + - jsonPath: .spec.clusterLabels + name: Labels + type: string + name: v1alpha1 + schema: + openAPIV3Schema: + description: ClusterRegistration is used internally by Fleet and should + not be used directly. + properties: + apiVersion: + description: 'APIVersion defines the versioned schema of this representation + of an object. + + Servers should convert recognized schemas to the latest internal value, + and + + may reject unrecognized values. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + type: string + kind: + description: 'Kind is a string value representing the REST resource + this object represents. + + Servers may infer this from the endpoint the client submits requests + to. + + Cannot be updated. + + In CamelCase. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + type: string + metadata: + type: object + spec: + properties: + clientID: + description: 'ClientID is a unique string that will identify the + cluster. The + + agent either uses the configured ID or the kubeSystem.UID.' + nullable: true + type: string + clientRandom: + description: 'ClientRandom is a random string that the agent generates. + When + + fleet-controller grants a registration, it creates a registration + + secret with this string in the name.' + nullable: true + type: string + clusterLabels: + additionalProperties: + nullable: true + type: string + description: ClusterLabels are copied to the cluster resource during + the registration. + nullable: true + type: object + type: object + status: + properties: + clusterName: + description: 'ClusterName is only set after the registration is + being processed by + + fleet-controller.' + nullable: true + type: string + granted: + description: 'Granted is set to true, if the request service account + is present + + and its token secret exists. This happens directly before creating + + the registration secret, roles and rolebindings.' + type: boolean + type: object + type: object + served: true + storage: true + subresources: + status: {} +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: clusterregistrationtokens.fleet.cattle.io +spec: + group: fleet.cattle.io + names: + kind: ClusterRegistrationToken + plural: clusterregistrationtokens + singular: clusterregistrationtoken + preserveUnknownFields: false + scope: Namespaced + versions: + - additionalPrinterColumns: + - jsonPath: .status.secretName + name: Secret-Name + type: string + name: v1alpha1 + schema: + openAPIV3Schema: + description: ClusterRegistrationToken is used by agents to register a new + cluster. + properties: + apiVersion: + description: 'APIVersion defines the versioned schema of this representation + of an object. + + Servers should convert recognized schemas to the latest internal value, + and + + may reject unrecognized values. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + type: string + kind: + description: 'Kind is a string value representing the REST resource + this object represents. + + Servers may infer this from the endpoint the client submits requests + to. + + Cannot be updated. + + In CamelCase. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + type: string + metadata: + properties: + name: + maxLength: 63 + pattern: ^[-a-z0-9]+$ + type: string + type: object + spec: + properties: + ttl: + description: 'TTL is the time to live for the token. It is used + to calculate the + + expiration time. If the token expires, it will be deleted.' + nullable: true + type: string + type: object + status: + properties: + expires: + description: Expires is the time when the token expires. + nullable: true + type: string + secretName: + description: SecretName is the name of the secret containing the + token. + nullable: true + type: string + type: object + type: object + served: true + storage: true + subresources: + status: {} +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: clusters.fleet.cattle.io +spec: + group: fleet.cattle.io + names: + kind: Cluster + plural: clusters + singular: cluster + preserveUnknownFields: false + scope: Namespaced + versions: + - additionalPrinterColumns: + - jsonPath: .status.display.readyBundles + name: Bundles-Ready + type: string + - jsonPath: .status.display.readyNodes + name: Nodes-Ready + type: string + - jsonPath: .status.display.sampleNode + name: Sample-Node + type: string + - jsonPath: .status.agent.lastSeen + name: Last-Seen + type: string + - jsonPath: .status.conditions[?(@.type=="Ready")].message + name: Status + type: string + name: v1alpha1 + schema: + openAPIV3Schema: + description: 'Cluster corresponds to a Kubernetes cluster. Fleet deploys + bundles to targeted clusters. + + Clusters to which Fleet deploys manifests are referred to as downstream + + clusters. In the single cluster use case, the Fleet manager Kubernetes + + cluster is both the manager and downstream cluster at the same time.' + properties: + apiVersion: + description: 'APIVersion defines the versioned schema of this representation + of an object. + + Servers should convert recognized schemas to the latest internal value, + and + + may reject unrecognized values. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + type: string + kind: + description: 'Kind is a string value representing the REST resource + this object represents. + + Servers may infer this from the endpoint the client submits requests + to. + + Cannot be updated. + + In CamelCase. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + type: string + metadata: + properties: + name: + maxLength: 63 + pattern: ^[-a-z0-9]+$ + type: string + type: object + spec: + properties: + agentAffinity: + description: 'AgentAffinity overrides the default affinity for the + cluster''s agent + + deployment. If this value is nil the default affinity is used.' + nullable: true + properties: + nodeAffinity: + description: Describes node affinity scheduling rules for the + pod. + nullable: true + properties: + preferredDuringSchedulingIgnoredDuringExecution: + description: 'The scheduler will prefer to schedule pods + to nodes that satisfy + + the affinity expressions specified by this field, but + it may choose + + a node that violates one or more of the expressions. The + node that is + + most preferred is the one with the greatest sum of weights, + i.e. + + for each node that meets all of the scheduling requirements + (resource + + request, requiredDuringScheduling affinity expressions, + etc.), + + compute a sum by iterating through the elements of this + field and adding + + "weight" to the sum if the node matches the corresponding + matchExpressions; the + + node(s) with the highest sum are the most preferred.' + items: + description: 'An empty preferred scheduling term matches + all objects with implicit weight 0 + + (i.e. it''s a no-op). A null preferred scheduling term + matches no objects (i.e. is also a no-op).' + properties: + preference: + description: A node selector term, associated with + the corresponding weight. + properties: + matchExpressions: + description: A list of node selector requirements + by node's labels. + items: + description: 'A node selector requirement is + a selector that contains values, a key, and + an operator + + that relates the key and values.' + properties: + key: + description: The label key that the selector + applies to. + nullable: true + type: string + operator: + description: 'Represents a key''s relationship + to a set of values. + + Valid operators are In, NotIn, Exists, + DoesNotExist. Gt, and Lt.' + enum: + - In + - NotIn + - Exists + - DoesNotExist + - Gt + - Lt + nullable: true + type: string + values: + description: 'An array of string values. + If the operator is In or NotIn, + + the values array must be non-empty. If + the operator is Exists or DoesNotExist, + + the values array must be empty. If the + operator is Gt or Lt, the values + + array must have a single element, which + will be interpreted as an integer. + + This array is replaced during a strategic + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchFields: + description: A list of node selector requirements + by node's fields. + items: + description: 'A node selector requirement is + a selector that contains values, a key, and + an operator + + that relates the key and values.' + properties: + key: + description: The label key that the selector + applies to. + nullable: true + type: string + operator: + description: 'Represents a key''s relationship + to a set of values. + + Valid operators are In, NotIn, Exists, + DoesNotExist. Gt, and Lt.' + enum: + - In + - NotIn + - Exists + - DoesNotExist + - Gt + - Lt + nullable: true + type: string + values: + description: 'An array of string values. + If the operator is In or NotIn, + + the values array must be non-empty. If + the operator is Exists or DoesNotExist, + + the values array must be empty. If the + operator is Gt or Lt, the values + + array must have a single element, which + will be interpreted as an integer. + + This array is replaced during a strategic + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + type: object + weight: + description: Weight associated with matching the corresponding + nodeSelectorTerm, in the range 1-100. + type: integer + type: object + nullable: true + type: array + requiredDuringSchedulingIgnoredDuringExecution: + description: 'If the affinity requirements specified by + this field are not met at + + scheduling time, the pod will not be scheduled onto the + node. + + If the affinity requirements specified by this field cease + to be met + + at some point during pod execution (e.g. due to an update), + the system + + may or may not try to eventually evict the pod from its + node.' + nullable: true + properties: + nodeSelectorTerms: + description: Required. A list of node selector terms. + The terms are ORed. + items: + description: 'A null or empty node selector term matches + no objects. The requirements of + + them are ANDed. + + The TopologySelectorTerm type implements a subset + of the NodeSelectorTerm.' + properties: + matchExpressions: + description: A list of node selector requirements + by node's labels. + items: + description: 'A node selector requirement is + a selector that contains values, a key, and + an operator + + that relates the key and values.' + properties: + key: + description: The label key that the selector + applies to. + nullable: true + type: string + operator: + description: 'Represents a key''s relationship + to a set of values. + + Valid operators are In, NotIn, Exists, + DoesNotExist. Gt, and Lt.' + enum: + - In + - NotIn + - Exists + - DoesNotExist + - Gt + - Lt + nullable: true + type: string + values: + description: 'An array of string values. + If the operator is In or NotIn, + + the values array must be non-empty. If + the operator is Exists or DoesNotExist, + + the values array must be empty. If the + operator is Gt or Lt, the values + + array must have a single element, which + will be interpreted as an integer. + + This array is replaced during a strategic + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchFields: + description: A list of node selector requirements + by node's fields. + items: + description: 'A node selector requirement is + a selector that contains values, a key, and + an operator + + that relates the key and values.' + properties: + key: + description: The label key that the selector + applies to. + nullable: true + type: string + operator: + description: 'Represents a key''s relationship + to a set of values. + + Valid operators are In, NotIn, Exists, + DoesNotExist. Gt, and Lt.' + enum: + - In + - NotIn + - Exists + - DoesNotExist + - Gt + - Lt + nullable: true + type: string + values: + description: 'An array of string values. + If the operator is In or NotIn, + + the values array must be non-empty. If + the operator is Exists or DoesNotExist, + + the values array must be empty. If the + operator is Gt or Lt, the values + + array must have a single element, which + will be interpreted as an integer. + + This array is replaced during a strategic + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + type: object + nullable: true + type: array + type: object + type: object + podAffinity: + description: Describes pod affinity scheduling rules (e.g. co-locate + this pod in the same node, zone, etc. as some other pod(s)). + nullable: true + properties: + preferredDuringSchedulingIgnoredDuringExecution: + description: 'The scheduler will prefer to schedule pods + to nodes that satisfy + + the affinity expressions specified by this field, but + it may choose + + a node that violates one or more of the expressions. The + node that is + + most preferred is the one with the greatest sum of weights, + i.e. + + for each node that meets all of the scheduling requirements + (resource + + request, requiredDuringScheduling affinity expressions, + etc.), + + compute a sum by iterating through the elements of this + field and adding + + "weight" to the sum if the node has pods which matches + the corresponding podAffinityTerm; the + + node(s) with the highest sum are the most preferred.' + items: + description: The weights of all of the matched WeightedPodAffinityTerm + fields are added per-node to find the most preferred + node(s) + properties: + podAffinityTerm: + description: Required. A pod affinity term, associated + with the corresponding weight. + properties: + labelSelector: + description: A label query over a set of resources, + in this case pods. + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of + label selector requirements. The requirements + are ANDed. + items: + description: 'A label selector requirement + is a selector that contains values, a + key, and an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that + the selector applies to. + nullable: true + type: string + operator: + description: 'operator represents a + key''s relationship to a set of values. + + Valid operators are In, NotIn, Exists + and DoesNotExist.' + enum: + - In + - NotIn + - Exists + - DoesNotExist + nullable: true + type: string + values: + description: 'values is an array of + string values. If the operator is + In or NotIn, + + the values array must be non-empty. + If the operator is Exists or DoesNotExist, + + the values array must be empty. This + array is replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} + pairs. A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains + only "value". The requirements are ANDed.' + nullable: true + type: object + type: object + namespaceSelector: + description: 'A label query over the set of namespaces + that the term applies to. + + The term is applied to the union of the namespaces + selected by this field + + and the ones listed in the namespaces field. + + null selector and null or empty namespaces list + means "this pod''s namespace". + + An empty selector ({}) matches all namespaces.' + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of + label selector requirements. The requirements + are ANDed. + items: + description: 'A label selector requirement + is a selector that contains values, a + key, and an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that + the selector applies to. + nullable: true + type: string + operator: + description: 'operator represents a + key''s relationship to a set of values. + + Valid operators are In, NotIn, Exists + and DoesNotExist.' + enum: + - In + - NotIn + - Exists + - DoesNotExist + nullable: true + type: string + values: + description: 'values is an array of + string values. If the operator is + In or NotIn, + + the values array must be non-empty. + If the operator is Exists or DoesNotExist, + + the values array must be empty. This + array is replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} + pairs. A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains + only "value". The requirements are ANDed.' + nullable: true + type: object + type: object + namespaces: + description: 'namespaces specifies a static list + of namespace names that the term applies to. + + The term is applied to the union of the namespaces + listed in this field + + and the ones selected by namespaceSelector. + + null or empty namespaces list and null namespaceSelector + means "this pod''s namespace".' + items: + nullable: true + type: string + nullable: true + type: array + topologyKey: + description: 'This pod should be co-located (affinity) + or not co-located (anti-affinity) with the pods + matching + + the labelSelector in the specified namespaces, + where co-located is defined as running on a + node + + whose value of the label with key topologyKey + matches that of any node on which any of the + + selected pods is running. + + Empty topologyKey is not allowed.' + nullable: true + type: string + type: object + weight: + description: 'weight associated with matching the + corresponding podAffinityTerm, + + in the range 1-100.' + type: integer + type: object + nullable: true + type: array + requiredDuringSchedulingIgnoredDuringExecution: + description: 'If the affinity requirements specified by + this field are not met at + + scheduling time, the pod will not be scheduled onto the + node. + + If the affinity requirements specified by this field cease + to be met + + at some point during pod execution (e.g. due to a pod + label update), the + + system may or may not try to eventually evict the pod + from its node. + + When there are multiple elements, the lists of nodes corresponding + to each + + podAffinityTerm are intersected, i.e. all terms must be + satisfied.' + items: + description: 'Defines a set of pods (namely those matching + the labelSelector + + relative to the given namespace(s)) that this pod should + be + + co-located (affinity) or not co-located (anti-affinity) + with, + + where co-located is defined as running on a node whose + value of + + the label with key matches that of any + node on which + + a pod of the set of pods is running' + properties: + labelSelector: + description: A label query over a set of resources, + in this case pods. + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of label + selector requirements. The requirements are + ANDed. + items: + description: 'A label selector requirement is + a selector that contains values, a key, and + an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that the + selector applies to. + nullable: true + type: string + operator: + description: 'operator represents a key''s + relationship to a set of values. + + Valid operators are In, NotIn, Exists + and DoesNotExist.' + enum: + - In + - NotIn + - Exists + - DoesNotExist + nullable: true + type: string + values: + description: 'values is an array of string + values. If the operator is In or NotIn, + + the values array must be non-empty. If + the operator is Exists or DoesNotExist, + + the values array must be empty. This array + is replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} + pairs. A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains + only "value". The requirements are ANDed.' + nullable: true + type: object + type: object + namespaceSelector: + description: 'A label query over the set of namespaces + that the term applies to. + + The term is applied to the union of the namespaces + selected by this field + + and the ones listed in the namespaces field. + + null selector and null or empty namespaces list + means "this pod''s namespace". + + An empty selector ({}) matches all namespaces.' + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of label + selector requirements. The requirements are + ANDed. + items: + description: 'A label selector requirement is + a selector that contains values, a key, and + an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that the + selector applies to. + nullable: true + type: string + operator: + description: 'operator represents a key''s + relationship to a set of values. + + Valid operators are In, NotIn, Exists + and DoesNotExist.' + enum: + - In + - NotIn + - Exists + - DoesNotExist + nullable: true + type: string + values: + description: 'values is an array of string + values. If the operator is In or NotIn, + + the values array must be non-empty. If + the operator is Exists or DoesNotExist, + + the values array must be empty. This array + is replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} + pairs. A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains + only "value". The requirements are ANDed.' + nullable: true + type: object + type: object + namespaces: + description: 'namespaces specifies a static list of + namespace names that the term applies to. + + The term is applied to the union of the namespaces + listed in this field + + and the ones selected by namespaceSelector. + + null or empty namespaces list and null namespaceSelector + means "this pod''s namespace".' + items: + nullable: true + type: string + nullable: true + type: array + topologyKey: + description: 'This pod should be co-located (affinity) + or not co-located (anti-affinity) with the pods + matching + + the labelSelector in the specified namespaces, where + co-located is defined as running on a node + + whose value of the label with key topologyKey matches + that of any node on which any of the + + selected pods is running. + + Empty topologyKey is not allowed.' + nullable: true + type: string + type: object + nullable: true + type: array + type: object + podAntiAffinity: + description: Describes pod anti-affinity scheduling rules (e.g. + avoid putting this pod in the same node, zone, etc. as some + other pod(s)). + nullable: true + properties: + preferredDuringSchedulingIgnoredDuringExecution: + description: 'The scheduler will prefer to schedule pods + to nodes that satisfy + + the anti-affinity expressions specified by this field, + but it may choose + + a node that violates one or more of the expressions. The + node that is + + most preferred is the one with the greatest sum of weights, + i.e. + + for each node that meets all of the scheduling requirements + (resource + + request, requiredDuringScheduling anti-affinity expressions, + etc.), + + compute a sum by iterating through the elements of this + field and adding + + "weight" to the sum if the node has pods which matches + the corresponding podAffinityTerm; the + + node(s) with the highest sum are the most preferred.' + items: + description: The weights of all of the matched WeightedPodAffinityTerm + fields are added per-node to find the most preferred + node(s) + properties: + podAffinityTerm: + description: Required. A pod affinity term, associated + with the corresponding weight. + properties: + labelSelector: + description: A label query over a set of resources, + in this case pods. + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of + label selector requirements. The requirements + are ANDed. + items: + description: 'A label selector requirement + is a selector that contains values, a + key, and an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that + the selector applies to. + nullable: true + type: string + operator: + description: 'operator represents a + key''s relationship to a set of values. + + Valid operators are In, NotIn, Exists + and DoesNotExist.' + enum: + - In + - NotIn + - Exists + - DoesNotExist + nullable: true + type: string + values: + description: 'values is an array of + string values. If the operator is + In or NotIn, + + the values array must be non-empty. + If the operator is Exists or DoesNotExist, + + the values array must be empty. This + array is replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} + pairs. A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains + only "value". The requirements are ANDed.' + nullable: true + type: object + type: object + namespaceSelector: + description: 'A label query over the set of namespaces + that the term applies to. + + The term is applied to the union of the namespaces + selected by this field + + and the ones listed in the namespaces field. + + null selector and null or empty namespaces list + means "this pod''s namespace". + + An empty selector ({}) matches all namespaces.' + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of + label selector requirements. The requirements + are ANDed. + items: + description: 'A label selector requirement + is a selector that contains values, a + key, and an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that + the selector applies to. + nullable: true + type: string + operator: + description: 'operator represents a + key''s relationship to a set of values. + + Valid operators are In, NotIn, Exists + and DoesNotExist.' + enum: + - In + - NotIn + - Exists + - DoesNotExist + nullable: true + type: string + values: + description: 'values is an array of + string values. If the operator is + In or NotIn, + + the values array must be non-empty. + If the operator is Exists or DoesNotExist, + + the values array must be empty. This + array is replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} + pairs. A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains + only "value". The requirements are ANDed.' + nullable: true + type: object + type: object + namespaces: + description: 'namespaces specifies a static list + of namespace names that the term applies to. + + The term is applied to the union of the namespaces + listed in this field + + and the ones selected by namespaceSelector. + + null or empty namespaces list and null namespaceSelector + means "this pod''s namespace".' + items: + nullable: true + type: string + nullable: true + type: array + topologyKey: + description: 'This pod should be co-located (affinity) + or not co-located (anti-affinity) with the pods + matching + + the labelSelector in the specified namespaces, + where co-located is defined as running on a + node + + whose value of the label with key topologyKey + matches that of any node on which any of the + + selected pods is running. + + Empty topologyKey is not allowed.' + nullable: true + type: string + type: object + weight: + description: 'weight associated with matching the + corresponding podAffinityTerm, + + in the range 1-100.' + type: integer + type: object + nullable: true + type: array + requiredDuringSchedulingIgnoredDuringExecution: + description: 'If the anti-affinity requirements specified + by this field are not met at + + scheduling time, the pod will not be scheduled onto the + node. + + If the anti-affinity requirements specified by this field + cease to be met + + at some point during pod execution (e.g. due to a pod + label update), the + + system may or may not try to eventually evict the pod + from its node. + + When there are multiple elements, the lists of nodes corresponding + to each + + podAffinityTerm are intersected, i.e. all terms must be + satisfied.' + items: + description: 'Defines a set of pods (namely those matching + the labelSelector + + relative to the given namespace(s)) that this pod should + be + + co-located (affinity) or not co-located (anti-affinity) + with, + + where co-located is defined as running on a node whose + value of + + the label with key matches that of any + node on which + + a pod of the set of pods is running' + properties: + labelSelector: + description: A label query over a set of resources, + in this case pods. + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of label + selector requirements. The requirements are + ANDed. + items: + description: 'A label selector requirement is + a selector that contains values, a key, and + an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that the + selector applies to. + nullable: true + type: string + operator: + description: 'operator represents a key''s + relationship to a set of values. + + Valid operators are In, NotIn, Exists + and DoesNotExist.' + enum: + - In + - NotIn + - Exists + - DoesNotExist + nullable: true + type: string + values: + description: 'values is an array of string + values. If the operator is In or NotIn, + + the values array must be non-empty. If + the operator is Exists or DoesNotExist, + + the values array must be empty. This array + is replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} + pairs. A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains + only "value". The requirements are ANDed.' + nullable: true + type: object + type: object + namespaceSelector: + description: 'A label query over the set of namespaces + that the term applies to. + + The term is applied to the union of the namespaces + selected by this field + + and the ones listed in the namespaces field. + + null selector and null or empty namespaces list + means "this pod''s namespace". + + An empty selector ({}) matches all namespaces.' + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of label + selector requirements. The requirements are + ANDed. + items: + description: 'A label selector requirement is + a selector that contains values, a key, and + an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that the + selector applies to. + nullable: true + type: string + operator: + description: 'operator represents a key''s + relationship to a set of values. + + Valid operators are In, NotIn, Exists + and DoesNotExist.' + enum: + - In + - NotIn + - Exists + - DoesNotExist + nullable: true + type: string + values: + description: 'values is an array of string + values. If the operator is In or NotIn, + + the values array must be non-empty. If + the operator is Exists or DoesNotExist, + + the values array must be empty. This array + is replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} + pairs. A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains + only "value". The requirements are ANDed.' + nullable: true + type: object + type: object + namespaces: + description: 'namespaces specifies a static list of + namespace names that the term applies to. + + The term is applied to the union of the namespaces + listed in this field + + and the ones selected by namespaceSelector. + + null or empty namespaces list and null namespaceSelector + means "this pod''s namespace".' + items: + nullable: true + type: string + nullable: true + type: array + topologyKey: + description: 'This pod should be co-located (affinity) + or not co-located (anti-affinity) with the pods + matching + + the labelSelector in the specified namespaces, where + co-located is defined as running on a node + + whose value of the label with key topologyKey matches + that of any node on which any of the + + selected pods is running. + + Empty topologyKey is not allowed.' + nullable: true + type: string + type: object + nullable: true + type: array + type: object + type: object + agentEnvVars: + description: AgentEnvVars are extra environment variables to be + added to the agent deployment. + items: + description: EnvVar represents an environment variable present + in a Container. + properties: + name: + description: Name of the environment variable. Must be a C_IDENTIFIER. + nullable: true + type: string + value: + description: 'Variable references $(VAR_NAME) are expanded + + using the previously defined environment variables in the + container and + + any service environment variables. If a variable cannot + be resolved, + + the reference in the input string will be unchanged. Double + $$ are reduced + + to a single $, which allows for escaping the $(VAR_NAME) + syntax: i.e. + + "$$(VAR_NAME)" will produce the string literal "$(VAR_NAME)". + + Escaped references will never be expanded, regardless of + whether the variable + + exists or not. + + Defaults to "".' + nullable: true + type: string + valueFrom: + description: Source for the environment variable's value. + Cannot be used if value is not empty. + nullable: true + properties: + configMapKeyRef: + description: Selects a key of a ConfigMap. + nullable: true + properties: + key: + description: The key to select. + nullable: true + type: string + name: + description: 'Name of the referent. + + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names + + TODO: Add other useful fields. apiVersion, kind, + uid?' + nullable: true + type: string + optional: + description: Specify whether the ConfigMap or its + key must be defined + nullable: true + type: boolean + type: object + fieldRef: + description: 'Selects a field of the pod: supports metadata.name, + metadata.namespace, `metadata.labels['''']`, `metadata.annotations['''']`, + + spec.nodeName, spec.serviceAccountName, status.hostIP, + status.podIP, status.podIPs.' + nullable: true + properties: + apiVersion: + description: Version of the schema the FieldPath is + written in terms of, defaults to "v1". + nullable: true + type: string + fieldPath: + description: Path of the field to select in the specified + API version. + nullable: true + type: string + type: object + resourceFieldRef: + description: 'Selects a resource of the container: only + resources limits and requests + + (limits.cpu, limits.memory, limits.ephemeral-storage, + requests.cpu, requests.memory and requests.ephemeral-storage) + are currently supported.' + nullable: true + properties: + containerName: + description: 'Container name: required for volumes, + optional for env vars' + nullable: true + type: string + divisor: + description: Specifies the output format of the exposed + resources, defaults to "1" + nullable: true + type: string + resource: + description: 'Required: resource to select' + nullable: true + type: string + type: object + secretKeyRef: + description: Selects a key of a secret in the pod's namespace + nullable: true + properties: + key: + description: The key of the secret to select from. Must + be a valid secret key. + nullable: true + type: string + name: + description: 'Name of the referent. + + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names + + TODO: Add other useful fields. apiVersion, kind, + uid?' + nullable: true + type: string + optional: + description: Specify whether the Secret or its key + must be defined + nullable: true + type: boolean + type: object + type: object + type: object + nullable: true + type: array + agentNamespace: + description: AgentNamespace defaults to the system namespace, e.g. + cattle-fleet-system. + nullable: true + type: string + agentResources: + description: AgentResources sets the resources for the cluster's + agent deployment. + nullable: true + properties: + claims: + description: 'Claims lists the names of resources, defined in + spec.resourceClaims, + + that are used by this container. + + + + This is an alpha field and requires enabling the + + DynamicResourceAllocation feature gate. + + + + This field is immutable. It can only be set for containers.' + items: + description: ResourceClaim references one entry in PodSpec.ResourceClaims. + properties: + name: + description: 'Name must match the name of one entry in + pod.spec.resourceClaims of + + the Pod where this field is used. It makes that resource + available + + inside a container.' + nullable: true + type: string + type: object + nullable: true + type: array + limits: + additionalProperties: + nullable: true + type: string + description: 'Limits describes the maximum amount of compute + resources allowed. + + More info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/' + nullable: true + type: object + requests: + additionalProperties: + nullable: true + type: string + description: 'Requests describes the minimum amount of compute + resources required. + + If Requests is omitted for a container, it defaults to Limits + if that is explicitly specified, + + otherwise to an implementation-defined value. Requests cannot + exceed Limits. + + More info: https://kubernetes.io/docs/concepts/configuration/manage-resources-containers/' + nullable: true + type: object + type: object + agentTolerations: + description: AgentTolerations defines an extra set of Tolerations + to be added to the Agent deployment. + items: + description: 'The pod this Toleration is attached to tolerates + any taint that matches + + the triple using the matching operator .' + properties: + effect: + description: 'Effect indicates the taint effect to match. + Empty means match all taint effects. + + When specified, allowed values are NoSchedule, PreferNoSchedule + and NoExecute.' + nullable: true + type: string + key: + description: 'Key is the taint key that the toleration applies + to. Empty means match all taint keys. + + If the key is empty, operator must be Exists; this combination + means to match all values and all keys.' + nullable: true + type: string + operator: + description: 'Operator represents a key''s relationship to + the value. + + Valid operators are Exists and Equal. Defaults to Equal. + + Exists is equivalent to wildcard for value, so that a pod + can + + tolerate all taints of a particular category.' + nullable: true + type: string + tolerationSeconds: + description: 'TolerationSeconds represents the period of time + the toleration (which must be + + of effect NoExecute, otherwise this field is ignored) tolerates + the taint. By default, + + it is not set, which means tolerate the taint forever (do + not evict). Zero and + + negative values will be treated as 0 (evict immediately) + by the system.' + maximum: 86400 + nullable: true + type: integer + value: + description: 'Value is the taint value the toleration matches + to. + + If the operator is Exists, the value should be empty, otherwise + just a regular string.' + nullable: true + type: string + type: object + nullable: true + type: array + clientID: + description: 'ClientID is a unique string that will identify the + cluster. It can + + either be predefined, or generated when importing the cluster.' + nullable: true + type: string + kubeConfigSecret: + description: 'KubeConfigSecret is the name of the secret containing + the kubeconfig for the downstream cluster. + + It can optionally contain a APIServerURL and CA to override the + + values in the fleet-controller''s configmap.' + nullable: true + type: string + kubeConfigSecretNamespace: + description: 'KubeConfigSecretNamespace is the namespace of the + secret containing the kubeconfig for the downstream cluster. + + If unset, it will be assumed the secret can be found in the namespace + that the Cluster object resides within.' + nullable: true + type: string + paused: + description: Paused if set to true, will stop any BundleDeployments + from being updated. + type: boolean + privateRepoURL: + description: PrivateRepoURL prefixes the image name and overrides + a global repo URL from the agents config. + nullable: true + type: string + redeployAgentGeneration: + description: RedeployAgentGeneration can be used to force redeploying + the agent. + type: integer + templateValues: + description: TemplateValues defines a cluster specific mapping of + values to be sent to fleet.yaml values templating. + nullable: true + type: object + x-kubernetes-preserve-unknown-fields: true + type: object + status: + properties: + agent: + description: AgentStatus contains information about the agent. + properties: + lastSeen: + description: 'LastSeen is the last time the agent checked in + to update the status + + of the cluster resource.' + nullable: true + type: string + namespace: + description: Namespace is the namespace of the agent deployment, + e.g. "cattle-fleet-system". + nullable: true + type: string + nonReadyNodeNames: + description: 'NonReadyNode contains the names of non-ready nodes. + The list is + + limited to at most 3 names.' + items: + nullable: true + type: string + nullable: true + type: array + nonReadyNodes: + description: NonReadyNodes is the number of nodes that are not + ready. + type: integer + readyNodeNames: + description: 'ReadyNodes contains the names of ready nodes. + The list is limited to + + at most 3 names.' + items: + nullable: true + type: string + nullable: true + type: array + readyNodes: + description: ReadyNodes is the number of nodes that are ready. + type: integer + type: object + agentAffinityHash: + description: 'AgentAffinityHash is a hash of the agent''s affinity + configuration, + + used to detect changes.' + nullable: true + type: string + agentConfigChanged: + description: 'AgentConfigChanged is set to true if any of the agent + configuration + + changed, like the API server URL or CA. Setting it to true will + + trigger a re-import of the cluster.' + type: boolean + agentDeployedGeneration: + description: AgentDeployedGeneration is the generation of the agent + that is currently deployed. + nullable: true + type: integer + agentEnvVarsHash: + description: AgentEnvVarsHash is a hash of the agent's env vars, + used to detect changes. + nullable: true + type: string + agentMigrated: + description: 'AgentMigrated is always set to true after importing + a cluster. If + + false, it will trigger a migration. Old agents don''t have + + this in their status.' + type: boolean + agentNamespaceMigrated: + description: 'AgentNamespaceMigrated is always set to true after + importing a + + cluster. If false, it will trigger a migration. Old Fleet agents + + don''t have this in their status.' + type: boolean + agentPrivateRepoURL: + description: AgentPrivateRepoURL is the private repo URL for the + agent that is currently used. + nullable: true + type: string + agentResourcesHash: + description: 'AgentResourcesHash is a hash of the agent''s resources + configuration, + + used to detect changes.' + nullable: true + type: string + agentTLSMode: + description: 'AgentTLSMode supports two values: `system-store` and + `strict`. If set to + + `system-store`, instructs the agent to trust CA bundles from the + operating + + system''s store. If set to `strict`, then the agent shall only + connect to a + + server which uses the exact CA configured when creating/updating + the agent.' + nullable: true + type: string + agentTolerationsHash: + description: 'AgentTolerationsHash is a hash of the agent''s tolerations + + configuration, used to detect changes.' + nullable: true + type: string + apiServerCAHash: + description: APIServerCAHash is a hash of the upstream API server + CA, used to detect changes. + nullable: true + type: string + apiServerURL: + description: 'APIServerURL is the currently used URL of the API + server that the + + cluster uses to connect to upstream.' + nullable: true + type: string + cattleNamespaceMigrated: + description: 'CattleNamespaceMigrated is always set to true after + importing a + + cluster. If false, it will trigger a migration. Old Fleet agents, + + don''t have this in their status.' + type: boolean + conditions: + items: + properties: + lastTransitionTime: + description: Last time the condition transitioned from one + status to another. + nullable: true + type: string + lastUpdateTime: + description: The last time this condition was updated. + nullable: true + type: string + message: + description: Human-readable message indicating details about + last transition + nullable: true + type: string + reason: + description: The reason for the condition's last transition. + nullable: true + type: string + status: + description: Status of the condition, one of True, False, + Unknown. + nullable: true + type: string + type: + description: Type of cluster condition. + nullable: true + type: string + type: object + nullable: true + type: array + desiredReadyGitRepos: + description: 'DesiredReadyGitRepos is the number of gitrepos for + this cluster that + + are desired to be ready.' + type: integer + display: + description: Display contains the number of ready bundles, nodes + and a summary state. + properties: + readyBundles: + description: 'ReadyBundles is a string in the form "%d/%d", + that describes the + + number of bundles that are ready vs. the number of bundles + desired + + to be ready.' + nullable: true + type: string + readyNodes: + description: 'ReadyNodes is a string in the form "%d/%d", that + describes the + + number of nodes that are ready vs. the number of expected + nodes.' + nullable: true + type: string + sampleNode: + description: 'SampleNode is the name of one of the nodes that + are ready. If no + + node is ready, it''s the name of a node that is not ready.' + nullable: true + type: string + state: + description: State of the cluster, either one of the bundle + states, or "WaitCheckIn". + nullable: true + type: string + type: object + namespace: + description: 'Namespace is the cluster namespace, it contains the + clusters service + + account as well as any bundledeployments. Example: + + "cluster-fleet-local-cluster-294db1acfa77-d9ccf852678f"' + nullable: true + type: string + readyGitRepos: + description: ReadyGitRepos is the number of gitrepos for this cluster + that are ready. + type: integer + resourceCounts: + description: ResourceCounts is an aggregate over the GitRepoResourceCounts. + properties: + desiredReady: + description: DesiredReady is the number of resources that should + be ready. + type: integer + missing: + description: Missing is the number of missing resources. + type: integer + modified: + description: Modified is the number of resources that have been + modified. + type: integer + notReady: + description: 'NotReady is the number of not ready resources. + Resources are not + + ready if they do not match any other state.' + type: integer + orphaned: + description: Orphaned is the number of orphaned resources. + type: integer + ready: + description: Ready is the number of ready resources. + type: integer + unknown: + description: Unknown is the number of resources in an unknown + state. + type: integer + waitApplied: + description: WaitApplied is the number of resources that are + waiting to be applied. + type: integer + type: object + summary: + description: 'Summary is a summary of the bundledeployments. The + resource counts + + are copied from the gitrepo resource.' + properties: + desiredReady: + description: 'DesiredReady is the number of bundle deployments + that should be + + ready.' + type: integer + errApplied: + description: 'ErrApplied is the number of bundle deployments + that have been synced + + from the Fleet controller and the downstream cluster, but + with some + + errors when deploying the bundle.' + type: integer + modified: + description: 'Modified is the number of bundle deployments that + have been deployed + + and for which all resources are ready, but where some changes + from the + + Git repository have not yet been synced.' + type: integer + nonReadyResources: + description: 'NonReadyClusters is a list of states, which is + filled for a bundle + + that is not ready.' + items: + description: 'NonReadyResource contains information about + a bundle that is not ready for a + + given state like "ErrApplied". It contains a list of non-ready + or modified + + resources and their states.' + properties: + bundleState: + description: State is the state of the resource, like + e.g. "NotReady" or "ErrApplied". + nullable: true + type: string + message: + description: Message contains information why the bundle + is not ready. + nullable: true + type: string + modifiedStatus: + description: ModifiedStatus lists the state for each modified + resource. + items: + description: 'ModifiedStatus is used to report the status + of a resource that is modified. + + It indicates if the modification was a create, a delete + or a patch.' + properties: + apiVersion: + nullable: true + type: string + delete: + type: boolean + kind: + nullable: true + type: string + missing: + type: boolean + name: + nullable: true + type: string + namespace: + nullable: true + type: string + patch: + nullable: true + type: string + type: object + nullable: true + type: array + name: + description: Name is the name of the resource. + nullable: true + type: string + nonReadyStatus: + description: NonReadyStatus lists the state for each non-ready + resource. + items: + description: NonReadyStatus is used to report the status + of a resource that is not ready. It includes a summary. + properties: + apiVersion: + nullable: true + type: string + kind: + nullable: true + type: string + name: + nullable: true + type: string + namespace: + nullable: true + type: string + summary: + properties: + error: + type: boolean + message: + items: + nullable: true + type: string + nullable: true + type: array + state: + nullable: true + type: string + transitioning: + type: boolean + type: object + uid: + description: 'UID is a type that holds unique ID + values, including UUIDs. Because we + + don''t ONLY use UUIDs, this is an alias to string. Being + a type captures + + intent and helps make sure that UIDs and names + do not get conflated.' + nullable: true + type: string + type: object + nullable: true + type: array + type: object + nullable: true + type: array + notReady: + description: 'NotReady is the number of bundle deployments that + have been deployed + + where some resources are not ready.' + type: integer + outOfSync: + description: 'OutOfSync is the number of bundle deployments + that have been synced + + from Fleet controller, but not yet by the downstream agent.' + type: integer + pending: + description: 'Pending is the number of bundle deployments that + are being processed + + by Fleet controller.' + type: integer + ready: + description: 'Ready is the number of bundle deployments that + have been deployed + + where all resources are ready.' + type: integer + waitApplied: + description: 'WaitApplied is the number of bundle deployments + that have been + + synced from Fleet controller and downstream cluster, but are + waiting + + to be deployed.' + type: integer + type: object + type: object + type: object + served: true + storage: true + subresources: + status: {} +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: contents.fleet.cattle.io +spec: + group: fleet.cattle.io + names: + kind: Content + plural: contents + singular: content + preserveUnknownFields: false + scope: Cluster + versions: + - name: v1alpha1 + schema: + openAPIV3Schema: + description: 'Content is used internally by Fleet and should not be used + directly. It + + contains the resources from a bundle for a specific target cluster.' + properties: + apiVersion: + description: 'APIVersion defines the versioned schema of this representation + of an object. + + Servers should convert recognized schemas to the latest internal value, + and + + may reject unrecognized values. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + type: string + content: + description: 'Content is a byte array, which contains the manifests + of a bundle. + + The bundle resources are copied into the bundledeployment''s content + + resource, so the downstream agent can deploy them.' + nullable: true + type: string + kind: + description: 'Kind is a string value representing the REST resource + this object represents. + + Servers may infer this from the endpoint the client submits requests + to. + + Cannot be updated. + + In CamelCase. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + type: string + metadata: + type: object + type: object + served: true + storage: true +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: gitreporestrictions.fleet.cattle.io +spec: + group: fleet.cattle.io + names: + kind: GitRepoRestriction + plural: gitreporestrictions + singular: gitreporestriction + preserveUnknownFields: false + scope: Namespaced + versions: + - additionalPrinterColumns: + - jsonPath: .defaultServiceAccount + name: Default-ServiceAccount + type: string + - jsonPath: .allowedServiceAccounts + name: Allowed-ServiceAccounts + type: string + name: v1alpha1 + schema: + openAPIV3Schema: + description: 'GitRepoRestriction is a resource that can optionally be used + to restrict + + the options of GitRepos in the same namespace.' + properties: + allowedClientSecretNames: + description: AllowedClientSecretNames is a list of client secret names + that GitRepos are allowed to use. + items: + nullable: true + type: string + nullable: true + type: array + allowedRepoPatterns: + description: 'AllowedRepoPatterns is a list of regex patterns that restrict + the + + valid values of the Repo field of a GitRepo.' + items: + nullable: true + type: string + nullable: true + type: array + allowedServiceAccounts: + description: AllowedServiceAccounts is a list of service accounts that + GitRepos are allowed to use. + items: + nullable: true + type: string + nullable: true + type: array + allowedTargetNamespaces: + description: 'AllowedTargetNamespaces restricts TargetNamespace to the + given + + namespaces. If AllowedTargetNamespaces is set, TargetNamespace must + + be set.' + items: + nullable: true + type: string + nullable: true + type: array + apiVersion: + description: 'APIVersion defines the versioned schema of this representation + of an object. + + Servers should convert recognized schemas to the latest internal value, + and + + may reject unrecognized values. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + type: string + defaultClientSecretName: + description: DefaultClientSecretName overrides the GitRepo's default + client secret. + nullable: true + type: string + defaultServiceAccount: + description: DefaultServiceAccount overrides the GitRepo's default service + account. + nullable: true + type: string + kind: + description: 'Kind is a string value representing the REST resource + this object represents. + + Servers may infer this from the endpoint the client submits requests + to. + + Cannot be updated. + + In CamelCase. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + type: string + metadata: + type: object + type: object + served: true + storage: true + subresources: + status: {} +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: gitrepos.fleet.cattle.io +spec: + group: fleet.cattle.io + names: + categories: + - fleet + kind: GitRepo + plural: gitrepos + singular: gitrepo + preserveUnknownFields: false + scope: Namespaced + versions: + - additionalPrinterColumns: + - jsonPath: .spec.repo + name: Repo + type: string + - jsonPath: .status.commit + name: Commit + type: string + - jsonPath: .status.display.readyBundleDeployments + name: BundleDeployments-Ready + type: string + - jsonPath: .status.conditions[?(@.type=="Ready")].message + name: Status + type: string + name: v1alpha1 + schema: + openAPIV3Schema: + description: 'GitRepo describes a git repository that is watched by Fleet. + + The resource contains the necessary information to deploy the repo, or + parts + + of it, to target clusters.' + properties: + apiVersion: + description: 'APIVersion defines the versioned schema of this representation + of an object. + + Servers should convert recognized schemas to the latest internal value, + and + + may reject unrecognized values. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + type: string + kind: + description: 'Kind is a string value representing the REST resource + this object represents. + + Servers may infer this from the endpoint the client submits requests + to. + + Cannot be updated. + + In CamelCase. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + type: string + metadata: + type: object + spec: + properties: + branch: + description: Branch The git branch to follow. + nullable: true + type: string + caBundle: + description: CABundle is a PEM encoded CA bundle which will be used + to validate the repo's certificate. + nullable: true + type: string + clientSecretName: + description: 'ClientSecretName is the name of the client secret + to be used to connect to the repo + + It is expected the secret be of type "kubernetes.io/basic-auth" + or "kubernetes.io/ssh-auth".' + nullable: true + type: string + correctDrift: + description: CorrectDrift specifies how drift correction should + work. + nullable: true + properties: + enabled: + description: Enabled correct drift if true. + type: boolean + force: + description: Force helm rollback with --force option will be + used if true. This will try to recreate all resources in the + release. + type: boolean + keepFailHistory: + description: KeepFailHistory keeps track of failed rollbacks + in the helm history. + type: boolean + type: object + forceSyncGeneration: + description: Increment this number to force a redeployment of contents + from Git. + type: integer + helmRepoURLRegex: + description: 'HelmRepoURLRegex Helm credentials will be used if + the helm repo matches this regex + + Credentials will always be used if this is empty or not provided.' + nullable: true + type: string + helmSecretName: + description: HelmSecretName contains the auth secret for a private + Helm repository. + nullable: true + type: string + helmSecretNameForPaths: + description: HelmSecretNameForPaths contains the auth secret for + private Helm repository for each path. + nullable: true + type: string + imageScanCommit: + description: Commit specifies how to commit to the git repo when + a new image is scanned and written back to git repo. + properties: + authorEmail: + description: AuthorEmail gives the email to provide when making + a commit + nullable: true + type: string + authorName: + description: AuthorName gives the name to provide when making + a commit + nullable: true + type: string + messageTemplate: + description: 'MessageTemplate provides a template for the commit + message, + + into which will be interpolated the details of the change + made.' + nullable: true + type: string + type: object + imageScanInterval: + description: ImageScanInterval is the interval of syncing scanned + images and writing back to git repo. + nullable: true + type: string + insecureSkipTLSVerify: + description: InsecureSkipTLSverify will use insecure HTTPS to clone + the repo. + type: boolean + keepResources: + description: KeepResources specifies if the resources created must + be kept after deleting the GitRepo. + type: boolean + paths: + description: 'Paths is the directories relative to the git repo + root that contain resources to be applied. + + Path globbing is supported, for example ["charts/*"] will match + all folders as a subdirectory of charts/ + + If empty, "/" is the default.' + items: + nullable: true + type: string + nullable: true + type: array + paused: + description: 'Paused, when true, causes changes in Git not to be + propagated down to the clusters but instead to mark + + resources as OutOfSync.' + type: boolean + pollingInterval: + description: PollingInterval is how often to check git for new updates. + nullable: true + type: string + repo: + description: Repo is a URL to a git repo to clone and index. + nullable: true + type: string + revision: + description: Revision A specific commit or tag to operate on. + nullable: true + type: string + serviceAccount: + description: ServiceAccount used in the downstream cluster for deployment. + nullable: true + type: string + targetNamespace: + description: 'Ensure that all resources are created in this namespace + + Any cluster scoped resource will be rejected if this is set + + Additionally this namespace will be created on demand.' + nullable: true + type: string + targets: + description: Targets is a list of targets this repo will deploy + to. + items: + description: GitTarget is a cluster or cluster group to deploy + to. + properties: + clusterGroup: + description: ClusterGroup is the name of a cluster group in + the same namespace as the clusters. + nullable: true + type: string + clusterGroupSelector: + description: ClusterGroupSelector is a label selector to select + cluster groups. + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of label selector + requirements. The requirements are ANDed. + items: + description: 'A label selector requirement is a selector + that contains values, a key, and an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that the selector + applies to. + nullable: true + type: string + operator: + description: 'operator represents a key''s relationship + to a set of values. + + Valid operators are In, NotIn, Exists and DoesNotExist.' + nullable: true + type: string + values: + description: 'values is an array of string values. + If the operator is In or NotIn, + + the values array must be non-empty. If the operator + is Exists or DoesNotExist, + + the values array must be empty. This array is + replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} pairs. + A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains only + "value". The requirements are ANDed.' + nullable: true + type: object + type: object + clusterName: + description: ClusterName is the name of a cluster. + nullable: true + type: string + clusterSelector: + description: ClusterSelector is a label selector to select + clusters. + nullable: true + properties: + matchExpressions: + description: matchExpressions is a list of label selector + requirements. The requirements are ANDed. + items: + description: 'A label selector requirement is a selector + that contains values, a key, and an operator that + + relates the key and values.' + properties: + key: + description: key is the label key that the selector + applies to. + nullable: true + type: string + operator: + description: 'operator represents a key''s relationship + to a set of values. + + Valid operators are In, NotIn, Exists and DoesNotExist.' + nullable: true + type: string + values: + description: 'values is an array of string values. + If the operator is In or NotIn, + + the values array must be non-empty. If the operator + is Exists or DoesNotExist, + + the values array must be empty. This array is + replaced during a strategic + + merge patch.' + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + description: 'matchLabels is a map of {key,value} pairs. + A single {key,value} in the matchLabels + + map is equivalent to an element of matchExpressions, + whose key field is "key", the + + operator is "In", and the values array contains only + "value". The requirements are ANDed.' + nullable: true + type: object + type: object + name: + description: Name is the name of this target. + nullable: true + type: string + type: object + nullable: true + type: array + type: object + status: + properties: + commit: + description: Commit is the Git commit hash from the last gitjob + run. + nullable: true + type: string + conditions: + description: 'Conditions is a list of Wrangler conditions that describe + the state + + of the GitRepo.' + items: + properties: + lastTransitionTime: + description: Last time the condition transitioned from one + status to another. + nullable: true + type: string + lastUpdateTime: + description: The last time this condition was updated. + nullable: true + type: string + message: + description: Human-readable message indicating details about + last transition + nullable: true + type: string + reason: + description: The reason for the condition's last transition. + nullable: true + type: string + status: + description: Status of the condition, one of True, False, + Unknown. + nullable: true + type: string + type: + description: Type of cluster condition. + nullable: true + type: string + type: object + nullable: true + type: array + desiredReadyClusters: + description: "DesiredReadyClusters\tis the number of clusters that\ + \ should be ready for bundles of this GitRepo." + type: integer + display: + description: Display contains a human readable summary of the status. + properties: + error: + description: Error is true if a message is present. + type: boolean + message: + description: Message contains the relevant message from the + deployment conditions. + nullable: true + type: string + readyBundleDeployments: + description: 'ReadyBundleDeployments is a string in the form + "%d/%d", that describes the + + number of ready bundledeployments over the total number of + bundledeployments.' + nullable: true + type: string + state: + description: 'State is the state of the GitRepo, e.g. "GitUpdating" + or the maximal + + BundleState according to StateRank.' + nullable: true + type: string + type: object + gitJobStatus: + description: GitJobStatus is the status of the last GitJob run, + e.g. "Current" if there was no error. + nullable: true + type: string + lastSyncedImageScanTime: + description: LastSyncedImageScanTime is the time of the last image + scan. + nullable: true + type: string + observedGeneration: + description: 'ObservedGeneration is the current generation of the + resource in the cluster. It is copied from k8s + + metadata.Generation. The value is incremented for all changes, + except for changes to .metadata or .status.' + type: integer + readyClusters: + description: 'ReadyClusters is the lowest number of clusters that + are ready over + + all the bundles of this GitRepo.' + type: integer + resourceCounts: + description: ResourceCounts contains the number of resources in + each state over all bundles. + properties: + desiredReady: + description: DesiredReady is the number of resources that should + be ready. + type: integer + missing: + description: Missing is the number of missing resources. + type: integer + modified: + description: Modified is the number of resources that have been + modified. + type: integer + notReady: + description: 'NotReady is the number of not ready resources. + Resources are not + + ready if they do not match any other state.' + type: integer + orphaned: + description: Orphaned is the number of orphaned resources. + type: integer + ready: + description: Ready is the number of ready resources. + type: integer + unknown: + description: Unknown is the number of resources in an unknown + state. + type: integer + waitApplied: + description: WaitApplied is the number of resources that are + waiting to be applied. + type: integer + type: object + resourceErrors: + description: ResourceErrors is a sorted list of errors from the + resources. + items: + nullable: true + type: string + nullable: true + type: array + resources: + description: Resources contains metadata about the resources of + each bundle. + items: + description: GitRepoResource contains metadata about the resources + of a bundle. + properties: + apiVersion: + description: APIVersion is the API version of the resource. + nullable: true + type: string + error: + description: Error is true if any Error in the PerClusterState + is true. + type: boolean + id: + description: ID is the name of the resource, e.g. "namespace1/my-config" + or "backingimagemanagers.storage.io". + nullable: true + type: string + incompleteState: + description: 'IncompleteState is true if a bundle summary + has 10 or more non-ready + + resources or a non-ready resource has more 10 or more non-ready + or + + modified states.' + type: boolean + kind: + description: Kind is the k8s kind of the resource. + nullable: true + type: string + message: + description: Message is the first message from the PerClusterStates. + nullable: true + type: string + name: + description: Name of the resource. + nullable: true + type: string + namespace: + description: Namespace of the resource. + nullable: true + type: string + perClusterState: + description: PerClusterState is a list of states for each + cluster. Derived from the summaries non-ready resources. + items: + description: ResourcePerClusterState is generated for each + non-ready resource of the bundles. + properties: + clusterId: + description: ClusterID is the id of the cluster. + nullable: true + type: string + error: + description: Error is true if the resource is in an + error state, copied from the bundle's summary for + non-ready resources. + type: boolean + message: + description: Message combines the messages from the + bundle's summary. Messages are joined with the delimiter + ';'. + nullable: true + type: string + patch: + description: Patch for modified resources. + nullable: true + type: object + x-kubernetes-preserve-unknown-fields: true + state: + description: State is the state of the resource. + nullable: true + type: string + transitioning: + description: 'Transitioning is true if the resource + is in a transitioning state, + + copied from the bundle''s summary for non-ready resources.' + type: boolean + type: object + nullable: true + type: array + state: + description: State is the state of the resource, e.g. "Unknown", + "WaitApplied", "ErrApplied" or "Ready". + nullable: true + type: string + transitioning: + description: Transitioning is true if any Transitioning in + the PerClusterState is true. + type: boolean + type: + description: Type is the type of the resource, e.g. "apiextensions.k8s.io.customresourcedefinition" + or "configmap". + nullable: true + type: string + type: object + nullable: true + type: array + summary: + description: Summary contains the number of bundle deployments in + each state and a list of non-ready resources. + properties: + desiredReady: + description: 'DesiredReady is the number of bundle deployments + that should be + + ready.' + type: integer + errApplied: + description: 'ErrApplied is the number of bundle deployments + that have been synced + + from the Fleet controller and the downstream cluster, but + with some + + errors when deploying the bundle.' + type: integer + modified: + description: 'Modified is the number of bundle deployments that + have been deployed + + and for which all resources are ready, but where some changes + from the + + Git repository have not yet been synced.' + type: integer + nonReadyResources: + description: 'NonReadyClusters is a list of states, which is + filled for a bundle + + that is not ready.' + items: + description: 'NonReadyResource contains information about + a bundle that is not ready for a + + given state like "ErrApplied". It contains a list of non-ready + or modified + + resources and their states.' + properties: + bundleState: + description: State is the state of the resource, like + e.g. "NotReady" or "ErrApplied". + nullable: true + type: string + message: + description: Message contains information why the bundle + is not ready. + nullable: true + type: string + modifiedStatus: + description: ModifiedStatus lists the state for each modified + resource. + items: + description: 'ModifiedStatus is used to report the status + of a resource that is modified. + + It indicates if the modification was a create, a delete + or a patch.' + properties: + apiVersion: + nullable: true + type: string + delete: + type: boolean + kind: + nullable: true + type: string + missing: + type: boolean + name: + nullable: true + type: string + namespace: + nullable: true + type: string + patch: + nullable: true + type: string + type: object + nullable: true + type: array + name: + description: Name is the name of the resource. + nullable: true + type: string + nonReadyStatus: + description: NonReadyStatus lists the state for each non-ready + resource. + items: + description: NonReadyStatus is used to report the status + of a resource that is not ready. It includes a summary. + properties: + apiVersion: + nullable: true + type: string + kind: + nullable: true + type: string + name: + nullable: true + type: string + namespace: + nullable: true + type: string + summary: + properties: + error: + type: boolean + message: + items: + nullable: true + type: string + nullable: true + type: array + state: + nullable: true + type: string + transitioning: + type: boolean + type: object + uid: + description: 'UID is a type that holds unique ID + values, including UUIDs. Because we + + don''t ONLY use UUIDs, this is an alias to string. Being + a type captures + + intent and helps make sure that UIDs and names + do not get conflated.' + nullable: true + type: string + type: object + nullable: true + type: array + type: object + nullable: true + type: array + notReady: + description: 'NotReady is the number of bundle deployments that + have been deployed + + where some resources are not ready.' + type: integer + outOfSync: + description: 'OutOfSync is the number of bundle deployments + that have been synced + + from Fleet controller, but not yet by the downstream agent.' + type: integer + pending: + description: 'Pending is the number of bundle deployments that + are being processed + + by Fleet controller.' + type: integer + ready: + description: 'Ready is the number of bundle deployments that + have been deployed + + where all resources are ready.' + type: integer + waitApplied: + description: 'WaitApplied is the number of bundle deployments + that have been + + synced from Fleet controller and downstream cluster, but are + waiting + + to be deployed.' + type: integer + type: object + type: object + type: object + served: true + storage: true + subresources: + status: {} +--- +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: imagescans.fleet.cattle.io +spec: + group: fleet.cattle.io + names: + categories: + - fleet + kind: ImageScan + plural: imagescans + singular: imagescan + preserveUnknownFields: false + scope: Namespaced + versions: + - additionalPrinterColumns: + - jsonPath: .spec.image + name: Repository + type: string + - jsonPath: .status.latestTag + name: Latest + type: string + name: v1alpha1 + schema: + openAPIV3Schema: + properties: + apiVersion: + description: 'APIVersion defines the versioned schema of this representation + of an object. + + Servers should convert recognized schemas to the latest internal value, + and + + may reject unrecognized values. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources' + type: string + kind: + description: 'Kind is a string value representing the REST resource + this object represents. + + Servers may infer this from the endpoint the client submits requests + to. + + Cannot be updated. + + In CamelCase. + + More info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds' + type: string + metadata: + type: object + spec: + description: API is taken from https://github.com/fluxcd/image-reflector-controller + properties: + gitrepoName: + description: GitRepo reference name + nullable: true + type: string + image: + description: Image is the name of the image repository + nullable: true + type: string + interval: + description: 'Interval is the length of time to wait between + + scans of the image repository.' + nullable: true + type: string + policy: + description: 'Policy gives the particulars of the policy to be followed + in + + selecting the most recent image' + properties: + alphabetical: + description: Alphabetical set of rules to use for alphabetical + ordering of the tags. + nullable: true + properties: + order: + description: 'Order specifies the sorting order of the tags. + Given the letters of the + + alphabet as tags, ascending order would select Z, and + descending order + + would select A.' + nullable: true + type: string + type: object + semver: + description: 'SemVer gives a semantic version range to check + against the tags + + available.' + nullable: true + properties: + range: + description: 'Range gives a semver range for the image tag; + the highest + + version within the range that''s a tag yields the latest + image.' + nullable: true + type: string + type: object + type: object + secretRef: + description: 'SecretRef can be given the name of a secret containing + + credentials to use for the image registry. The secret should be + + created with `kubectl create secret docker-registry`, or the + + equivalent.' + nullable: true + properties: + name: + description: 'Name of the referent. + + More info: https://kubernetes.io/docs/concepts/overview/working-with-objects/names/#names + + TODO: Add other useful fields. apiVersion, kind, uid?' + nullable: true + type: string + type: object + suspend: + description: 'This flag tells the controller to suspend subsequent + image scans. + + It does not apply to already started scans. Defaults to false.' + type: boolean + tagName: + description: TagName is the tag ref that needs to be put in manifest + to replace fields + nullable: true + type: string + type: object + status: + properties: + canonicalImageName: + description: 'CanonicalName is the name of the image repository + with all the + + implied bits made explicit; e.g., `docker.io/library/alpine` + + rather than `alpine`.' + nullable: true + type: string + conditions: + items: + properties: + lastTransitionTime: + description: Last time the condition transitioned from one + status to another. + nullable: true + type: string + lastUpdateTime: + description: The last time this condition was updated. + nullable: true + type: string + message: + description: Human-readable message indicating details about + last transition + nullable: true + type: string + reason: + description: The reason for the condition's last transition. + nullable: true + type: string + status: + description: Status of the condition, one of True, False, + Unknown. + nullable: true + type: string + type: + description: Type of cluster condition. + nullable: true + type: string + type: object + nullable: true + type: array + lastScanTime: + description: LastScanTime is the last time image was scanned + nullable: true + type: string + latestDigest: + description: LatestDigest is the digest of latest tag + nullable: true + type: string + latestImage: + description: 'LatestImage gives the first in the list of images + scanned by + + the image repository, when filtered and ordered according to + + the policy.' + nullable: true + type: string + latestTag: + description: Latest tag is the latest tag filtered by the policy + nullable: true + type: string + observedGeneration: + type: integer + type: object + type: object + served: true + storage: true + subresources: + status: {} diff --git a/charts/fleet-crd/103.1.10+up0.9.11/templates/gitjobs-crds.yaml b/charts/fleet-crd/103.1.10+up0.9.11/templates/gitjobs-crds.yaml new file mode 100644 index 0000000000..b5296dbaf5 --- /dev/null +++ b/charts/fleet-crd/103.1.10+up0.9.11/templates/gitjobs-crds.yaml @@ -0,0 +1,7690 @@ +{{- if .Capabilities.APIVersions.Has "apiextensions.k8s.io/v1" -}} +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: gitjobs.gitjob.cattle.io +spec: + group: gitjob.cattle.io + names: + kind: GitJob + plural: gitjobs + singular: gitjob + preserveUnknownFields: false + scope: Namespaced + versions: + - additionalPrinterColumns: + - jsonPath: .spec.git.repo + name: REPO + type: string + - jsonPath: .spec.git.branch + name: BRANCH + type: string + - jsonPath: .status.commit + name: COMMIT + type: string + - jsonPath: .status.jobStatus + name: JOBSTATUS + type: string + - jsonPath: .metadata.creationTimestamp + name: Age + type: date + name: v1 + schema: + openAPIV3Schema: + properties: + spec: + properties: + forceUpdateGeneration: + type: integer + git: + properties: + branch: + nullable: true + type: string + caBundle: + nullable: true + type: string + clientSecretName: + nullable: true + type: string + insecureSkipTLSVerify: + type: boolean + onTag: + nullable: true + type: string + provider: + nullable: true + type: string + repo: + nullable: true + type: string + revision: + nullable: true + type: string + type: object + jobSpec: + properties: + activeDeadlineSeconds: + nullable: true + type: integer + backoffLimit: + nullable: true + type: integer + backoffLimitPerIndex: + nullable: true + type: integer + completionMode: + nullable: true + type: string + completions: + nullable: true + type: integer + manualSelector: + nullable: true + type: boolean + maxFailedIndexes: + nullable: true + type: integer + parallelism: + nullable: true + type: integer + podFailurePolicy: + nullable: true + properties: + rules: + items: + properties: + action: + nullable: true + type: string + onExitCodes: + nullable: true + properties: + containerName: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + type: integer + nullable: true + type: array + type: object + onPodConditions: + items: + properties: + status: + nullable: true + type: string + type: + nullable: true + type: string + type: object + nullable: true + type: array + type: object + nullable: true + type: array + type: object + podReplacementPolicy: + nullable: true + type: string + selector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + suspend: + nullable: true + type: boolean + template: + properties: + metadata: + properties: + annotations: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + creationTimestamp: + nullable: true + type: string + deletionGracePeriodSeconds: + nullable: true + type: integer + deletionTimestamp: + nullable: true + type: string + finalizers: + items: + nullable: true + type: string + nullable: true + type: array + generateName: + nullable: true + type: string + generation: + type: integer + labels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + managedFields: + items: + properties: + apiVersion: + nullable: true + type: string + fieldsType: + nullable: true + type: string + fieldsV1: + nullable: true + type: object + manager: + nullable: true + type: string + operation: + nullable: true + type: string + subresource: + nullable: true + type: string + time: + nullable: true + type: string + type: object + nullable: true + type: array + name: + nullable: true + type: string + namespace: + nullable: true + type: string + ownerReferences: + items: + properties: + apiVersion: + nullable: true + type: string + blockOwnerDeletion: + nullable: true + type: boolean + controller: + nullable: true + type: boolean + kind: + nullable: true + type: string + name: + nullable: true + type: string + uid: + nullable: true + type: string + type: object + nullable: true + type: array + resourceVersion: + nullable: true + type: string + selfLink: + nullable: true + type: string + uid: + nullable: true + type: string + type: object + spec: + properties: + activeDeadlineSeconds: + nullable: true + type: integer + affinity: + nullable: true + properties: + nodeAffinity: + nullable: true + properties: + preferredDuringSchedulingIgnoredDuringExecution: + items: + properties: + preference: + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchFields: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + type: object + weight: + type: integer + type: object + nullable: true + type: array + requiredDuringSchedulingIgnoredDuringExecution: + nullable: true + properties: + nodeSelectorTerms: + items: + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchFields: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + type: object + nullable: true + type: array + type: object + type: object + podAffinity: + nullable: true + properties: + preferredDuringSchedulingIgnoredDuringExecution: + items: + properties: + podAffinityTerm: + properties: + labelSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + namespaceSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + namespaces: + items: + nullable: true + type: string + nullable: true + type: array + topologyKey: + nullable: true + type: string + type: object + weight: + type: integer + type: object + nullable: true + type: array + requiredDuringSchedulingIgnoredDuringExecution: + items: + properties: + labelSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + namespaceSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + namespaces: + items: + nullable: true + type: string + nullable: true + type: array + topologyKey: + nullable: true + type: string + type: object + nullable: true + type: array + type: object + podAntiAffinity: + nullable: true + properties: + preferredDuringSchedulingIgnoredDuringExecution: + items: + properties: + podAffinityTerm: + properties: + labelSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + namespaceSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + namespaces: + items: + nullable: true + type: string + nullable: true + type: array + topologyKey: + nullable: true + type: string + type: object + weight: + type: integer + type: object + nullable: true + type: array + requiredDuringSchedulingIgnoredDuringExecution: + items: + properties: + labelSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + namespaceSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + namespaces: + items: + nullable: true + type: string + nullable: true + type: array + topologyKey: + nullable: true + type: string + type: object + nullable: true + type: array + type: object + type: object + automountServiceAccountToken: + nullable: true + type: boolean + containers: + items: + properties: + args: + items: + nullable: true + type: string + nullable: true + type: array + command: + items: + nullable: true + type: string + nullable: true + type: array + env: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + valueFrom: + nullable: true + properties: + configMapKeyRef: + nullable: true + properties: + key: + nullable: true + type: string + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + fieldRef: + nullable: true + properties: + apiVersion: + nullable: true + type: string + fieldPath: + nullable: true + type: string + type: object + resourceFieldRef: + nullable: true + properties: + containerName: + nullable: true + type: string + divisor: + nullable: true + type: string + resource: + nullable: true + type: string + type: object + secretKeyRef: + nullable: true + properties: + key: + nullable: true + type: string + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + type: object + type: object + nullable: true + type: array + envFrom: + items: + properties: + configMapRef: + nullable: true + properties: + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + prefix: + nullable: true + type: string + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + type: object + nullable: true + type: array + image: + nullable: true + type: string + imagePullPolicy: + nullable: true + type: string + lifecycle: + nullable: true + properties: + postStart: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + type: object + preStop: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + type: object + type: object + livenessProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + name: + nullable: true + type: string + ports: + items: + properties: + containerPort: + type: integer + hostIP: + nullable: true + type: string + hostPort: + type: integer + name: + nullable: true + type: string + protocol: + nullable: true + type: string + type: object + nullable: true + type: array + readinessProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + resizePolicy: + items: + properties: + resourceName: + nullable: true + type: string + restartPolicy: + nullable: true + type: string + type: object + nullable: true + type: array + resources: + properties: + claims: + items: + properties: + name: + nullable: true + type: string + type: object + nullable: true + type: array + limits: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + requests: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + restartPolicy: + nullable: true + type: string + securityContext: + nullable: true + properties: + allowPrivilegeEscalation: + nullable: true + type: boolean + capabilities: + nullable: true + properties: + add: + items: + nullable: true + type: string + nullable: true + type: array + drop: + items: + nullable: true + type: string + nullable: true + type: array + type: object + privileged: + nullable: true + type: boolean + procMount: + nullable: true + type: string + readOnlyRootFilesystem: + nullable: true + type: boolean + runAsGroup: + nullable: true + type: integer + runAsNonRoot: + nullable: true + type: boolean + runAsUser: + nullable: true + type: integer + seLinuxOptions: + nullable: true + properties: + level: + nullable: true + type: string + role: + nullable: true + type: string + type: + nullable: true + type: string + user: + nullable: true + type: string + type: object + seccompProfile: + nullable: true + properties: + localhostProfile: + nullable: true + type: string + type: + nullable: true + type: string + type: object + windowsOptions: + nullable: true + properties: + gmsaCredentialSpec: + nullable: true + type: string + gmsaCredentialSpecName: + nullable: true + type: string + hostProcess: + nullable: true + type: boolean + runAsUserName: + nullable: true + type: string + type: object + type: object + startupProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + stdin: + type: boolean + stdinOnce: + type: boolean + terminationMessagePath: + nullable: true + type: string + terminationMessagePolicy: + nullable: true + type: string + tty: + type: boolean + volumeDevices: + items: + properties: + devicePath: + nullable: true + type: string + name: + nullable: true + type: string + type: object + nullable: true + type: array + volumeMounts: + items: + properties: + mountPath: + nullable: true + type: string + mountPropagation: + nullable: true + type: string + name: + nullable: true + type: string + readOnly: + type: boolean + subPath: + nullable: true + type: string + subPathExpr: + nullable: true + type: string + type: object + nullable: true + type: array + workingDir: + nullable: true + type: string + type: object + nullable: true + type: array + dnsConfig: + nullable: true + properties: + nameservers: + items: + nullable: true + type: string + nullable: true + type: array + options: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + searches: + items: + nullable: true + type: string + nullable: true + type: array + type: object + dnsPolicy: + nullable: true + type: string + enableServiceLinks: + nullable: true + type: boolean + ephemeralContainers: + items: + properties: + args: + items: + nullable: true + type: string + nullable: true + type: array + command: + items: + nullable: true + type: string + nullable: true + type: array + env: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + valueFrom: + nullable: true + properties: + configMapKeyRef: + nullable: true + properties: + key: + nullable: true + type: string + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + fieldRef: + nullable: true + properties: + apiVersion: + nullable: true + type: string + fieldPath: + nullable: true + type: string + type: object + resourceFieldRef: + nullable: true + properties: + containerName: + nullable: true + type: string + divisor: + nullable: true + type: string + resource: + nullable: true + type: string + type: object + secretKeyRef: + nullable: true + properties: + key: + nullable: true + type: string + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + type: object + type: object + nullable: true + type: array + envFrom: + items: + properties: + configMapRef: + nullable: true + properties: + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + prefix: + nullable: true + type: string + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + type: object + nullable: true + type: array + image: + nullable: true + type: string + imagePullPolicy: + nullable: true + type: string + lifecycle: + nullable: true + properties: + postStart: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + type: object + preStop: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + type: object + type: object + livenessProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + name: + nullable: true + type: string + ports: + items: + properties: + containerPort: + type: integer + hostIP: + nullable: true + type: string + hostPort: + type: integer + name: + nullable: true + type: string + protocol: + nullable: true + type: string + type: object + nullable: true + type: array + readinessProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + resizePolicy: + items: + properties: + resourceName: + nullable: true + type: string + restartPolicy: + nullable: true + type: string + type: object + nullable: true + type: array + resources: + properties: + claims: + items: + properties: + name: + nullable: true + type: string + type: object + nullable: true + type: array + limits: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + requests: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + restartPolicy: + nullable: true + type: string + securityContext: + nullable: true + properties: + allowPrivilegeEscalation: + nullable: true + type: boolean + capabilities: + nullable: true + properties: + add: + items: + nullable: true + type: string + nullable: true + type: array + drop: + items: + nullable: true + type: string + nullable: true + type: array + type: object + privileged: + nullable: true + type: boolean + procMount: + nullable: true + type: string + readOnlyRootFilesystem: + nullable: true + type: boolean + runAsGroup: + nullable: true + type: integer + runAsNonRoot: + nullable: true + type: boolean + runAsUser: + nullable: true + type: integer + seLinuxOptions: + nullable: true + properties: + level: + nullable: true + type: string + role: + nullable: true + type: string + type: + nullable: true + type: string + user: + nullable: true + type: string + type: object + seccompProfile: + nullable: true + properties: + localhostProfile: + nullable: true + type: string + type: + nullable: true + type: string + type: object + windowsOptions: + nullable: true + properties: + gmsaCredentialSpec: + nullable: true + type: string + gmsaCredentialSpecName: + nullable: true + type: string + hostProcess: + nullable: true + type: boolean + runAsUserName: + nullable: true + type: string + type: object + type: object + startupProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + stdin: + type: boolean + stdinOnce: + type: boolean + targetContainerName: + nullable: true + type: string + terminationMessagePath: + nullable: true + type: string + terminationMessagePolicy: + nullable: true + type: string + tty: + type: boolean + volumeDevices: + items: + properties: + devicePath: + nullable: true + type: string + name: + nullable: true + type: string + type: object + nullable: true + type: array + volumeMounts: + items: + properties: + mountPath: + nullable: true + type: string + mountPropagation: + nullable: true + type: string + name: + nullable: true + type: string + readOnly: + type: boolean + subPath: + nullable: true + type: string + subPathExpr: + nullable: true + type: string + type: object + nullable: true + type: array + workingDir: + nullable: true + type: string + type: object + nullable: true + type: array + hostAliases: + items: + properties: + hostnames: + items: + nullable: true + type: string + nullable: true + type: array + ip: + nullable: true + type: string + type: object + nullable: true + type: array + hostIPC: + type: boolean + hostNetwork: + type: boolean + hostPID: + type: boolean + hostUsers: + nullable: true + type: boolean + hostname: + nullable: true + type: string + imagePullSecrets: + items: + properties: + name: + nullable: true + type: string + type: object + nullable: true + type: array + initContainers: + items: + properties: + args: + items: + nullable: true + type: string + nullable: true + type: array + command: + items: + nullable: true + type: string + nullable: true + type: array + env: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + valueFrom: + nullable: true + properties: + configMapKeyRef: + nullable: true + properties: + key: + nullable: true + type: string + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + fieldRef: + nullable: true + properties: + apiVersion: + nullable: true + type: string + fieldPath: + nullable: true + type: string + type: object + resourceFieldRef: + nullable: true + properties: + containerName: + nullable: true + type: string + divisor: + nullable: true + type: string + resource: + nullable: true + type: string + type: object + secretKeyRef: + nullable: true + properties: + key: + nullable: true + type: string + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + type: object + type: object + nullable: true + type: array + envFrom: + items: + properties: + configMapRef: + nullable: true + properties: + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + prefix: + nullable: true + type: string + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + type: object + nullable: true + type: array + image: + nullable: true + type: string + imagePullPolicy: + nullable: true + type: string + lifecycle: + nullable: true + properties: + postStart: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + type: object + preStop: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + type: object + type: object + livenessProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + name: + nullable: true + type: string + ports: + items: + properties: + containerPort: + type: integer + hostIP: + nullable: true + type: string + hostPort: + type: integer + name: + nullable: true + type: string + protocol: + nullable: true + type: string + type: object + nullable: true + type: array + readinessProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + resizePolicy: + items: + properties: + resourceName: + nullable: true + type: string + restartPolicy: + nullable: true + type: string + type: object + nullable: true + type: array + resources: + properties: + claims: + items: + properties: + name: + nullable: true + type: string + type: object + nullable: true + type: array + limits: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + requests: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + restartPolicy: + nullable: true + type: string + securityContext: + nullable: true + properties: + allowPrivilegeEscalation: + nullable: true + type: boolean + capabilities: + nullable: true + properties: + add: + items: + nullable: true + type: string + nullable: true + type: array + drop: + items: + nullable: true + type: string + nullable: true + type: array + type: object + privileged: + nullable: true + type: boolean + procMount: + nullable: true + type: string + readOnlyRootFilesystem: + nullable: true + type: boolean + runAsGroup: + nullable: true + type: integer + runAsNonRoot: + nullable: true + type: boolean + runAsUser: + nullable: true + type: integer + seLinuxOptions: + nullable: true + properties: + level: + nullable: true + type: string + role: + nullable: true + type: string + type: + nullable: true + type: string + user: + nullable: true + type: string + type: object + seccompProfile: + nullable: true + properties: + localhostProfile: + nullable: true + type: string + type: + nullable: true + type: string + type: object + windowsOptions: + nullable: true + properties: + gmsaCredentialSpec: + nullable: true + type: string + gmsaCredentialSpecName: + nullable: true + type: string + hostProcess: + nullable: true + type: boolean + runAsUserName: + nullable: true + type: string + type: object + type: object + startupProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + stdin: + type: boolean + stdinOnce: + type: boolean + terminationMessagePath: + nullable: true + type: string + terminationMessagePolicy: + nullable: true + type: string + tty: + type: boolean + volumeDevices: + items: + properties: + devicePath: + nullable: true + type: string + name: + nullable: true + type: string + type: object + nullable: true + type: array + volumeMounts: + items: + properties: + mountPath: + nullable: true + type: string + mountPropagation: + nullable: true + type: string + name: + nullable: true + type: string + readOnly: + type: boolean + subPath: + nullable: true + type: string + subPathExpr: + nullable: true + type: string + type: object + nullable: true + type: array + workingDir: + nullable: true + type: string + type: object + nullable: true + type: array + nodeName: + nullable: true + type: string + nodeSelector: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + os: + nullable: true + properties: + name: + nullable: true + type: string + type: object + overhead: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + preemptionPolicy: + nullable: true + type: string + priority: + nullable: true + type: integer + priorityClassName: + nullable: true + type: string + readinessGates: + items: + properties: + conditionType: + nullable: true + type: string + type: object + nullable: true + type: array + resourceClaims: + items: + properties: + name: + nullable: true + type: string + source: + properties: + resourceClaimName: + nullable: true + type: string + resourceClaimTemplateName: + nullable: true + type: string + type: object + type: object + nullable: true + type: array + restartPolicy: + nullable: true + type: string + runtimeClassName: + nullable: true + type: string + schedulerName: + nullable: true + type: string + schedulingGates: + items: + properties: + name: + nullable: true + type: string + type: object + nullable: true + type: array + securityContext: + nullable: true + properties: + fsGroup: + nullable: true + type: integer + fsGroupChangePolicy: + nullable: true + type: string + runAsGroup: + nullable: true + type: integer + runAsNonRoot: + nullable: true + type: boolean + runAsUser: + nullable: true + type: integer + seLinuxOptions: + nullable: true + properties: + level: + nullable: true + type: string + role: + nullable: true + type: string + type: + nullable: true + type: string + user: + nullable: true + type: string + type: object + seccompProfile: + nullable: true + properties: + localhostProfile: + nullable: true + type: string + type: + nullable: true + type: string + type: object + supplementalGroups: + items: + type: integer + nullable: true + type: array + sysctls: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + windowsOptions: + nullable: true + properties: + gmsaCredentialSpec: + nullable: true + type: string + gmsaCredentialSpecName: + nullable: true + type: string + hostProcess: + nullable: true + type: boolean + runAsUserName: + nullable: true + type: string + type: object + type: object + serviceAccount: + nullable: true + type: string + serviceAccountName: + nullable: true + type: string + setHostnameAsFQDN: + nullable: true + type: boolean + shareProcessNamespace: + nullable: true + type: boolean + subdomain: + nullable: true + type: string + terminationGracePeriodSeconds: + nullable: true + type: integer + tolerations: + items: + properties: + effect: + nullable: true + type: string + key: + nullable: true + type: string + operator: + nullable: true + type: string + tolerationSeconds: + nullable: true + type: integer + value: + nullable: true + type: string + type: object + nullable: true + type: array + topologySpreadConstraints: + items: + properties: + labelSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + matchLabelKeys: + items: + nullable: true + type: string + nullable: true + type: array + maxSkew: + type: integer + minDomains: + nullable: true + type: integer + nodeAffinityPolicy: + nullable: true + type: string + nodeTaintsPolicy: + nullable: true + type: string + topologyKey: + nullable: true + type: string + whenUnsatisfiable: + nullable: true + type: string + type: object + nullable: true + type: array + volumes: + items: + properties: + awsElasticBlockStore: + nullable: true + properties: + fsType: + nullable: true + type: string + partition: + type: integer + readOnly: + type: boolean + volumeID: + nullable: true + type: string + type: object + azureDisk: + nullable: true + properties: + cachingMode: + nullable: true + type: string + diskName: + nullable: true + type: string + diskURI: + nullable: true + type: string + fsType: + nullable: true + type: string + kind: + nullable: true + type: string + readOnly: + nullable: true + type: boolean + type: object + azureFile: + nullable: true + properties: + readOnly: + type: boolean + secretName: + nullable: true + type: string + shareName: + nullable: true + type: string + type: object + cephfs: + nullable: true + properties: + monitors: + items: + nullable: true + type: string + nullable: true + type: array + path: + nullable: true + type: string + readOnly: + type: boolean + secretFile: + nullable: true + type: string + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + type: object + user: + nullable: true + type: string + type: object + cinder: + nullable: true + properties: + fsType: + nullable: true + type: string + readOnly: + type: boolean + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + type: object + volumeID: + nullable: true + type: string + type: object + configMap: + nullable: true + properties: + defaultMode: + nullable: true + type: integer + items: + items: + properties: + key: + nullable: true + type: string + mode: + nullable: true + type: integer + path: + nullable: true + type: string + type: object + nullable: true + type: array + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + csi: + nullable: true + properties: + driver: + nullable: true + type: string + fsType: + nullable: true + type: string + nodePublishSecretRef: + nullable: true + properties: + name: + nullable: true + type: string + type: object + readOnly: + nullable: true + type: boolean + volumeAttributes: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + downwardAPI: + nullable: true + properties: + defaultMode: + nullable: true + type: integer + items: + items: + properties: + fieldRef: + nullable: true + properties: + apiVersion: + nullable: true + type: string + fieldPath: + nullable: true + type: string + type: object + mode: + nullable: true + type: integer + path: + nullable: true + type: string + resourceFieldRef: + nullable: true + properties: + containerName: + nullable: true + type: string + divisor: + nullable: true + type: string + resource: + nullable: true + type: string + type: object + type: object + nullable: true + type: array + type: object + emptyDir: + nullable: true + properties: + medium: + nullable: true + type: string + sizeLimit: + nullable: true + type: string + type: object + ephemeral: + nullable: true + properties: + volumeClaimTemplate: + nullable: true + properties: + metadata: + properties: + annotations: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + creationTimestamp: + nullable: true + type: string + deletionGracePeriodSeconds: + nullable: true + type: integer + deletionTimestamp: + nullable: true + type: string + finalizers: + items: + nullable: true + type: string + nullable: true + type: array + generateName: + nullable: true + type: string + generation: + type: integer + labels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + managedFields: + items: + properties: + apiVersion: + nullable: true + type: string + fieldsType: + nullable: true + type: string + fieldsV1: + nullable: true + type: object + manager: + nullable: true + type: string + operation: + nullable: true + type: string + subresource: + nullable: true + type: string + time: + nullable: true + type: string + type: object + nullable: true + type: array + name: + nullable: true + type: string + namespace: + nullable: true + type: string + ownerReferences: + items: + properties: + apiVersion: + nullable: true + type: string + blockOwnerDeletion: + nullable: true + type: boolean + controller: + nullable: true + type: boolean + kind: + nullable: true + type: string + name: + nullable: true + type: string + uid: + nullable: true + type: string + type: object + nullable: true + type: array + resourceVersion: + nullable: true + type: string + selfLink: + nullable: true + type: string + uid: + nullable: true + type: string + type: object + spec: + properties: + accessModes: + items: + nullable: true + type: string + nullable: true + type: array + dataSource: + nullable: true + properties: + apiGroup: + nullable: true + type: string + kind: + nullable: true + type: string + name: + nullable: true + type: string + type: object + dataSourceRef: + nullable: true + properties: + apiGroup: + nullable: true + type: string + kind: + nullable: true + type: string + name: + nullable: true + type: string + namespace: + nullable: true + type: string + type: object + resources: + properties: + claims: + items: + properties: + name: + nullable: true + type: string + type: object + nullable: true + type: array + limits: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + requests: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + selector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + storageClassName: + nullable: true + type: string + volumeMode: + nullable: true + type: string + volumeName: + nullable: true + type: string + type: object + type: object + type: object + fc: + nullable: true + properties: + fsType: + nullable: true + type: string + lun: + nullable: true + type: integer + readOnly: + type: boolean + targetWWNs: + items: + nullable: true + type: string + nullable: true + type: array + wwids: + items: + nullable: true + type: string + nullable: true + type: array + type: object + flexVolume: + nullable: true + properties: + driver: + nullable: true + type: string + fsType: + nullable: true + type: string + options: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + readOnly: + type: boolean + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + type: object + type: object + flocker: + nullable: true + properties: + datasetName: + nullable: true + type: string + datasetUUID: + nullable: true + type: string + type: object + gcePersistentDisk: + nullable: true + properties: + fsType: + nullable: true + type: string + partition: + type: integer + pdName: + nullable: true + type: string + readOnly: + type: boolean + type: object + gitRepo: + nullable: true + properties: + directory: + nullable: true + type: string + repository: + nullable: true + type: string + revision: + nullable: true + type: string + type: object + glusterfs: + nullable: true + properties: + endpoints: + nullable: true + type: string + path: + nullable: true + type: string + readOnly: + type: boolean + type: object + hostPath: + nullable: true + properties: + path: + nullable: true + type: string + type: + nullable: true + type: string + type: object + iscsi: + nullable: true + properties: + chapAuthDiscovery: + type: boolean + chapAuthSession: + type: boolean + fsType: + nullable: true + type: string + initiatorName: + nullable: true + type: string + iqn: + nullable: true + type: string + iscsiInterface: + nullable: true + type: string + lun: + type: integer + portals: + items: + nullable: true + type: string + nullable: true + type: array + readOnly: + type: boolean + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + type: object + targetPortal: + nullable: true + type: string + type: object + name: + nullable: true + type: string + nfs: + nullable: true + properties: + path: + nullable: true + type: string + readOnly: + type: boolean + server: + nullable: true + type: string + type: object + persistentVolumeClaim: + nullable: true + properties: + claimName: + nullable: true + type: string + readOnly: + type: boolean + type: object + photonPersistentDisk: + nullable: true + properties: + fsType: + nullable: true + type: string + pdID: + nullable: true + type: string + type: object + portworxVolume: + nullable: true + properties: + fsType: + nullable: true + type: string + readOnly: + type: boolean + volumeID: + nullable: true + type: string + type: object + projected: + nullable: true + properties: + defaultMode: + nullable: true + type: integer + sources: + items: + properties: + configMap: + nullable: true + properties: + items: + items: + properties: + key: + nullable: true + type: string + mode: + nullable: true + type: integer + path: + nullable: true + type: string + type: object + nullable: true + type: array + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + downwardAPI: + nullable: true + properties: + items: + items: + properties: + fieldRef: + nullable: true + properties: + apiVersion: + nullable: true + type: string + fieldPath: + nullable: true + type: string + type: object + mode: + nullable: true + type: integer + path: + nullable: true + type: string + resourceFieldRef: + nullable: true + properties: + containerName: + nullable: true + type: string + divisor: + nullable: true + type: string + resource: + nullable: true + type: string + type: object + type: object + nullable: true + type: array + type: object + secret: + nullable: true + properties: + items: + items: + properties: + key: + nullable: true + type: string + mode: + nullable: true + type: integer + path: + nullable: true + type: string + type: object + nullable: true + type: array + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + serviceAccountToken: + nullable: true + properties: + audience: + nullable: true + type: string + expirationSeconds: + nullable: true + type: integer + path: + nullable: true + type: string + type: object + type: object + nullable: true + type: array + type: object + quobyte: + nullable: true + properties: + group: + nullable: true + type: string + readOnly: + type: boolean + registry: + nullable: true + type: string + tenant: + nullable: true + type: string + user: + nullable: true + type: string + volume: + nullable: true + type: string + type: object + rbd: + nullable: true + properties: + fsType: + nullable: true + type: string + image: + nullable: true + type: string + keyring: + nullable: true + type: string + monitors: + items: + nullable: true + type: string + nullable: true + type: array + pool: + nullable: true + type: string + readOnly: + type: boolean + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + type: object + user: + nullable: true + type: string + type: object + scaleIO: + nullable: true + properties: + fsType: + nullable: true + type: string + gateway: + nullable: true + type: string + protectionDomain: + nullable: true + type: string + readOnly: + type: boolean + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + type: object + sslEnabled: + type: boolean + storageMode: + nullable: true + type: string + storagePool: + nullable: true + type: string + system: + nullable: true + type: string + volumeName: + nullable: true + type: string + type: object + secret: + nullable: true + properties: + defaultMode: + nullable: true + type: integer + items: + items: + properties: + key: + nullable: true + type: string + mode: + nullable: true + type: integer + path: + nullable: true + type: string + type: object + nullable: true + type: array + optional: + nullable: true + type: boolean + secretName: + nullable: true + type: string + type: object + storageos: + nullable: true + properties: + fsType: + nullable: true + type: string + readOnly: + type: boolean + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + type: object + volumeName: + nullable: true + type: string + volumeNamespace: + nullable: true + type: string + type: object + vsphereVolume: + nullable: true + properties: + fsType: + nullable: true + type: string + storagePolicyID: + nullable: true + type: string + storagePolicyName: + nullable: true + type: string + volumePath: + nullable: true + type: string + type: object + type: object + nullable: true + type: array + type: object + type: object + ttlSecondsAfterFinished: + nullable: true + type: integer + type: object + syncInterval: + type: integer + type: object + status: + properties: + commit: + nullable: true + type: string + conditions: + items: + properties: + lastTransitionTime: + nullable: true + type: string + lastUpdateTime: + nullable: true + type: string + message: + nullable: true + type: string + reason: + nullable: true + type: string + status: + nullable: true + type: string + type: + nullable: true + type: string + type: object + nullable: true + type: array + event: + nullable: true + type: string + hookId: + nullable: true + type: string + jobStatus: + nullable: true + type: string + lastExecutedCommit: + nullable: true + type: string + lastSyncedTime: + nullable: true + type: string + observedGeneration: + type: integer + secretToken: + nullable: true + type: string + updateGeneration: + type: integer + type: object + type: object + served: true + storage: true + subresources: + status: {} +{{- else -}} +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + name: gitjobs.gitjob.cattle.io +spec: + additionalPrinterColumns: + - JSONPath: .spec.git.repo + name: REPO + type: string + - JSONPath: .spec.git.branch + name: BRANCH + type: string + - JSONPath: .status.commit + name: COMMIT + type: string + - JSONPath: .status.jobStatus + name: JOBSTATUS + type: string + - JSONPath: .metadata.creationTimestamp + name: Age + type: date + group: gitjob.cattle.io + names: + kind: GitJob + plural: gitjobs + singular: gitjob + preserveUnknownFields: false + scope: Namespaced + subresources: + status: {} + validation: + openAPIV3Schema: + properties: + spec: + properties: + forceUpdateGeneration: + type: integer + git: + properties: + branch: + nullable: true + type: string + caBundle: + nullable: true + type: string + clientSecretName: + nullable: true + type: string + insecureSkipTLSVerify: + type: boolean + onTag: + nullable: true + type: string + provider: + nullable: true + type: string + repo: + nullable: true + type: string + revision: + nullable: true + type: string + type: object + jobSpec: + properties: + activeDeadlineSeconds: + nullable: true + type: integer + backoffLimit: + nullable: true + type: integer + backoffLimitPerIndex: + nullable: true + type: integer + completionMode: + nullable: true + type: string + completions: + nullable: true + type: integer + manualSelector: + nullable: true + type: boolean + maxFailedIndexes: + nullable: true + type: integer + parallelism: + nullable: true + type: integer + podFailurePolicy: + nullable: true + properties: + rules: + items: + properties: + action: + nullable: true + type: string + onExitCodes: + nullable: true + properties: + containerName: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + type: integer + nullable: true + type: array + type: object + onPodConditions: + items: + properties: + status: + nullable: true + type: string + type: + nullable: true + type: string + type: object + nullable: true + type: array + type: object + nullable: true + type: array + type: object + podReplacementPolicy: + nullable: true + type: string + selector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + suspend: + nullable: true + type: boolean + template: + properties: + metadata: + properties: + annotations: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + creationTimestamp: + nullable: true + type: string + deletionGracePeriodSeconds: + nullable: true + type: integer + deletionTimestamp: + nullable: true + type: string + finalizers: + items: + nullable: true + type: string + nullable: true + type: array + generateName: + nullable: true + type: string + generation: + type: integer + labels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + managedFields: + items: + properties: + apiVersion: + nullable: true + type: string + fieldsType: + nullable: true + type: string + fieldsV1: + nullable: true + type: object + manager: + nullable: true + type: string + operation: + nullable: true + type: string + subresource: + nullable: true + type: string + time: + nullable: true + type: string + type: object + nullable: true + type: array + name: + nullable: true + type: string + namespace: + nullable: true + type: string + ownerReferences: + items: + properties: + apiVersion: + nullable: true + type: string + blockOwnerDeletion: + nullable: true + type: boolean + controller: + nullable: true + type: boolean + kind: + nullable: true + type: string + name: + nullable: true + type: string + uid: + nullable: true + type: string + type: object + nullable: true + type: array + resourceVersion: + nullable: true + type: string + selfLink: + nullable: true + type: string + uid: + nullable: true + type: string + type: object + spec: + properties: + activeDeadlineSeconds: + nullable: true + type: integer + affinity: + nullable: true + properties: + nodeAffinity: + nullable: true + properties: + preferredDuringSchedulingIgnoredDuringExecution: + items: + properties: + preference: + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchFields: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + type: object + weight: + type: integer + type: object + nullable: true + type: array + requiredDuringSchedulingIgnoredDuringExecution: + nullable: true + properties: + nodeSelectorTerms: + items: + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchFields: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + type: object + nullable: true + type: array + type: object + type: object + podAffinity: + nullable: true + properties: + preferredDuringSchedulingIgnoredDuringExecution: + items: + properties: + podAffinityTerm: + properties: + labelSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + namespaceSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + namespaces: + items: + nullable: true + type: string + nullable: true + type: array + topologyKey: + nullable: true + type: string + type: object + weight: + type: integer + type: object + nullable: true + type: array + requiredDuringSchedulingIgnoredDuringExecution: + items: + properties: + labelSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + namespaceSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + namespaces: + items: + nullable: true + type: string + nullable: true + type: array + topologyKey: + nullable: true + type: string + type: object + nullable: true + type: array + type: object + podAntiAffinity: + nullable: true + properties: + preferredDuringSchedulingIgnoredDuringExecution: + items: + properties: + podAffinityTerm: + properties: + labelSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + namespaceSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + namespaces: + items: + nullable: true + type: string + nullable: true + type: array + topologyKey: + nullable: true + type: string + type: object + weight: + type: integer + type: object + nullable: true + type: array + requiredDuringSchedulingIgnoredDuringExecution: + items: + properties: + labelSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + namespaceSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + namespaces: + items: + nullable: true + type: string + nullable: true + type: array + topologyKey: + nullable: true + type: string + type: object + nullable: true + type: array + type: object + type: object + automountServiceAccountToken: + nullable: true + type: boolean + containers: + items: + properties: + args: + items: + nullable: true + type: string + nullable: true + type: array + command: + items: + nullable: true + type: string + nullable: true + type: array + env: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + valueFrom: + nullable: true + properties: + configMapKeyRef: + nullable: true + properties: + key: + nullable: true + type: string + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + fieldRef: + nullable: true + properties: + apiVersion: + nullable: true + type: string + fieldPath: + nullable: true + type: string + type: object + resourceFieldRef: + nullable: true + properties: + containerName: + nullable: true + type: string + divisor: + nullable: true + type: string + resource: + nullable: true + type: string + type: object + secretKeyRef: + nullable: true + properties: + key: + nullable: true + type: string + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + type: object + type: object + nullable: true + type: array + envFrom: + items: + properties: + configMapRef: + nullable: true + properties: + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + prefix: + nullable: true + type: string + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + type: object + nullable: true + type: array + image: + nullable: true + type: string + imagePullPolicy: + nullable: true + type: string + lifecycle: + nullable: true + properties: + postStart: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + type: object + preStop: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + type: object + type: object + livenessProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + name: + nullable: true + type: string + ports: + items: + properties: + containerPort: + type: integer + hostIP: + nullable: true + type: string + hostPort: + type: integer + name: + nullable: true + type: string + protocol: + nullable: true + type: string + type: object + nullable: true + type: array + readinessProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + resizePolicy: + items: + properties: + resourceName: + nullable: true + type: string + restartPolicy: + nullable: true + type: string + type: object + nullable: true + type: array + resources: + properties: + claims: + items: + properties: + name: + nullable: true + type: string + type: object + nullable: true + type: array + limits: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + requests: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + restartPolicy: + nullable: true + type: string + securityContext: + nullable: true + properties: + allowPrivilegeEscalation: + nullable: true + type: boolean + capabilities: + nullable: true + properties: + add: + items: + nullable: true + type: string + nullable: true + type: array + drop: + items: + nullable: true + type: string + nullable: true + type: array + type: object + privileged: + nullable: true + type: boolean + procMount: + nullable: true + type: string + readOnlyRootFilesystem: + nullable: true + type: boolean + runAsGroup: + nullable: true + type: integer + runAsNonRoot: + nullable: true + type: boolean + runAsUser: + nullable: true + type: integer + seLinuxOptions: + nullable: true + properties: + level: + nullable: true + type: string + role: + nullable: true + type: string + type: + nullable: true + type: string + user: + nullable: true + type: string + type: object + seccompProfile: + nullable: true + properties: + localhostProfile: + nullable: true + type: string + type: + nullable: true + type: string + type: object + windowsOptions: + nullable: true + properties: + gmsaCredentialSpec: + nullable: true + type: string + gmsaCredentialSpecName: + nullable: true + type: string + hostProcess: + nullable: true + type: boolean + runAsUserName: + nullable: true + type: string + type: object + type: object + startupProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + stdin: + type: boolean + stdinOnce: + type: boolean + terminationMessagePath: + nullable: true + type: string + terminationMessagePolicy: + nullable: true + type: string + tty: + type: boolean + volumeDevices: + items: + properties: + devicePath: + nullable: true + type: string + name: + nullable: true + type: string + type: object + nullable: true + type: array + volumeMounts: + items: + properties: + mountPath: + nullable: true + type: string + mountPropagation: + nullable: true + type: string + name: + nullable: true + type: string + readOnly: + type: boolean + subPath: + nullable: true + type: string + subPathExpr: + nullable: true + type: string + type: object + nullable: true + type: array + workingDir: + nullable: true + type: string + type: object + nullable: true + type: array + dnsConfig: + nullable: true + properties: + nameservers: + items: + nullable: true + type: string + nullable: true + type: array + options: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + searches: + items: + nullable: true + type: string + nullable: true + type: array + type: object + dnsPolicy: + nullable: true + type: string + enableServiceLinks: + nullable: true + type: boolean + ephemeralContainers: + items: + properties: + args: + items: + nullable: true + type: string + nullable: true + type: array + command: + items: + nullable: true + type: string + nullable: true + type: array + env: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + valueFrom: + nullable: true + properties: + configMapKeyRef: + nullable: true + properties: + key: + nullable: true + type: string + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + fieldRef: + nullable: true + properties: + apiVersion: + nullable: true + type: string + fieldPath: + nullable: true + type: string + type: object + resourceFieldRef: + nullable: true + properties: + containerName: + nullable: true + type: string + divisor: + nullable: true + type: string + resource: + nullable: true + type: string + type: object + secretKeyRef: + nullable: true + properties: + key: + nullable: true + type: string + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + type: object + type: object + nullable: true + type: array + envFrom: + items: + properties: + configMapRef: + nullable: true + properties: + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + prefix: + nullable: true + type: string + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + type: object + nullable: true + type: array + image: + nullable: true + type: string + imagePullPolicy: + nullable: true + type: string + lifecycle: + nullable: true + properties: + postStart: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + type: object + preStop: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + type: object + type: object + livenessProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + name: + nullable: true + type: string + ports: + items: + properties: + containerPort: + type: integer + hostIP: + nullable: true + type: string + hostPort: + type: integer + name: + nullable: true + type: string + protocol: + nullable: true + type: string + type: object + nullable: true + type: array + readinessProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + resizePolicy: + items: + properties: + resourceName: + nullable: true + type: string + restartPolicy: + nullable: true + type: string + type: object + nullable: true + type: array + resources: + properties: + claims: + items: + properties: + name: + nullable: true + type: string + type: object + nullable: true + type: array + limits: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + requests: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + restartPolicy: + nullable: true + type: string + securityContext: + nullable: true + properties: + allowPrivilegeEscalation: + nullable: true + type: boolean + capabilities: + nullable: true + properties: + add: + items: + nullable: true + type: string + nullable: true + type: array + drop: + items: + nullable: true + type: string + nullable: true + type: array + type: object + privileged: + nullable: true + type: boolean + procMount: + nullable: true + type: string + readOnlyRootFilesystem: + nullable: true + type: boolean + runAsGroup: + nullable: true + type: integer + runAsNonRoot: + nullable: true + type: boolean + runAsUser: + nullable: true + type: integer + seLinuxOptions: + nullable: true + properties: + level: + nullable: true + type: string + role: + nullable: true + type: string + type: + nullable: true + type: string + user: + nullable: true + type: string + type: object + seccompProfile: + nullable: true + properties: + localhostProfile: + nullable: true + type: string + type: + nullable: true + type: string + type: object + windowsOptions: + nullable: true + properties: + gmsaCredentialSpec: + nullable: true + type: string + gmsaCredentialSpecName: + nullable: true + type: string + hostProcess: + nullable: true + type: boolean + runAsUserName: + nullable: true + type: string + type: object + type: object + startupProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + stdin: + type: boolean + stdinOnce: + type: boolean + targetContainerName: + nullable: true + type: string + terminationMessagePath: + nullable: true + type: string + terminationMessagePolicy: + nullable: true + type: string + tty: + type: boolean + volumeDevices: + items: + properties: + devicePath: + nullable: true + type: string + name: + nullable: true + type: string + type: object + nullable: true + type: array + volumeMounts: + items: + properties: + mountPath: + nullable: true + type: string + mountPropagation: + nullable: true + type: string + name: + nullable: true + type: string + readOnly: + type: boolean + subPath: + nullable: true + type: string + subPathExpr: + nullable: true + type: string + type: object + nullable: true + type: array + workingDir: + nullable: true + type: string + type: object + nullable: true + type: array + hostAliases: + items: + properties: + hostnames: + items: + nullable: true + type: string + nullable: true + type: array + ip: + nullable: true + type: string + type: object + nullable: true + type: array + hostIPC: + type: boolean + hostNetwork: + type: boolean + hostPID: + type: boolean + hostUsers: + nullable: true + type: boolean + hostname: + nullable: true + type: string + imagePullSecrets: + items: + properties: + name: + nullable: true + type: string + type: object + nullable: true + type: array + initContainers: + items: + properties: + args: + items: + nullable: true + type: string + nullable: true + type: array + command: + items: + nullable: true + type: string + nullable: true + type: array + env: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + valueFrom: + nullable: true + properties: + configMapKeyRef: + nullable: true + properties: + key: + nullable: true + type: string + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + fieldRef: + nullable: true + properties: + apiVersion: + nullable: true + type: string + fieldPath: + nullable: true + type: string + type: object + resourceFieldRef: + nullable: true + properties: + containerName: + nullable: true + type: string + divisor: + nullable: true + type: string + resource: + nullable: true + type: string + type: object + secretKeyRef: + nullable: true + properties: + key: + nullable: true + type: string + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + type: object + type: object + nullable: true + type: array + envFrom: + items: + properties: + configMapRef: + nullable: true + properties: + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + prefix: + nullable: true + type: string + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + type: object + nullable: true + type: array + image: + nullable: true + type: string + imagePullPolicy: + nullable: true + type: string + lifecycle: + nullable: true + properties: + postStart: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + type: object + preStop: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + type: object + type: object + livenessProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + name: + nullable: true + type: string + ports: + items: + properties: + containerPort: + type: integer + hostIP: + nullable: true + type: string + hostPort: + type: integer + name: + nullable: true + type: string + protocol: + nullable: true + type: string + type: object + nullable: true + type: array + readinessProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + resizePolicy: + items: + properties: + resourceName: + nullable: true + type: string + restartPolicy: + nullable: true + type: string + type: object + nullable: true + type: array + resources: + properties: + claims: + items: + properties: + name: + nullable: true + type: string + type: object + nullable: true + type: array + limits: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + requests: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + restartPolicy: + nullable: true + type: string + securityContext: + nullable: true + properties: + allowPrivilegeEscalation: + nullable: true + type: boolean + capabilities: + nullable: true + properties: + add: + items: + nullable: true + type: string + nullable: true + type: array + drop: + items: + nullable: true + type: string + nullable: true + type: array + type: object + privileged: + nullable: true + type: boolean + procMount: + nullable: true + type: string + readOnlyRootFilesystem: + nullable: true + type: boolean + runAsGroup: + nullable: true + type: integer + runAsNonRoot: + nullable: true + type: boolean + runAsUser: + nullable: true + type: integer + seLinuxOptions: + nullable: true + properties: + level: + nullable: true + type: string + role: + nullable: true + type: string + type: + nullable: true + type: string + user: + nullable: true + type: string + type: object + seccompProfile: + nullable: true + properties: + localhostProfile: + nullable: true + type: string + type: + nullable: true + type: string + type: object + windowsOptions: + nullable: true + properties: + gmsaCredentialSpec: + nullable: true + type: string + gmsaCredentialSpecName: + nullable: true + type: string + hostProcess: + nullable: true + type: boolean + runAsUserName: + nullable: true + type: string + type: object + type: object + startupProbe: + nullable: true + properties: + exec: + nullable: true + properties: + command: + items: + nullable: true + type: string + nullable: true + type: array + type: object + failureThreshold: + type: integer + grpc: + nullable: true + properties: + port: + type: integer + service: + nullable: true + type: string + type: object + httpGet: + nullable: true + properties: + host: + nullable: true + type: string + httpHeaders: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + path: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + scheme: + nullable: true + type: string + type: object + initialDelaySeconds: + type: integer + periodSeconds: + type: integer + successThreshold: + type: integer + tcpSocket: + nullable: true + properties: + host: + nullable: true + type: string + port: + x-kubernetes-int-or-string: true + type: object + terminationGracePeriodSeconds: + nullable: true + type: integer + timeoutSeconds: + type: integer + type: object + stdin: + type: boolean + stdinOnce: + type: boolean + terminationMessagePath: + nullable: true + type: string + terminationMessagePolicy: + nullable: true + type: string + tty: + type: boolean + volumeDevices: + items: + properties: + devicePath: + nullable: true + type: string + name: + nullable: true + type: string + type: object + nullable: true + type: array + volumeMounts: + items: + properties: + mountPath: + nullable: true + type: string + mountPropagation: + nullable: true + type: string + name: + nullable: true + type: string + readOnly: + type: boolean + subPath: + nullable: true + type: string + subPathExpr: + nullable: true + type: string + type: object + nullable: true + type: array + workingDir: + nullable: true + type: string + type: object + nullable: true + type: array + nodeName: + nullable: true + type: string + nodeSelector: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + os: + nullable: true + properties: + name: + nullable: true + type: string + type: object + overhead: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + preemptionPolicy: + nullable: true + type: string + priority: + nullable: true + type: integer + priorityClassName: + nullable: true + type: string + readinessGates: + items: + properties: + conditionType: + nullable: true + type: string + type: object + nullable: true + type: array + resourceClaims: + items: + properties: + name: + nullable: true + type: string + source: + properties: + resourceClaimName: + nullable: true + type: string + resourceClaimTemplateName: + nullable: true + type: string + type: object + type: object + nullable: true + type: array + restartPolicy: + nullable: true + type: string + runtimeClassName: + nullable: true + type: string + schedulerName: + nullable: true + type: string + schedulingGates: + items: + properties: + name: + nullable: true + type: string + type: object + nullable: true + type: array + securityContext: + nullable: true + properties: + fsGroup: + nullable: true + type: integer + fsGroupChangePolicy: + nullable: true + type: string + runAsGroup: + nullable: true + type: integer + runAsNonRoot: + nullable: true + type: boolean + runAsUser: + nullable: true + type: integer + seLinuxOptions: + nullable: true + properties: + level: + nullable: true + type: string + role: + nullable: true + type: string + type: + nullable: true + type: string + user: + nullable: true + type: string + type: object + seccompProfile: + nullable: true + properties: + localhostProfile: + nullable: true + type: string + type: + nullable: true + type: string + type: object + supplementalGroups: + items: + type: integer + nullable: true + type: array + sysctls: + items: + properties: + name: + nullable: true + type: string + value: + nullable: true + type: string + type: object + nullable: true + type: array + windowsOptions: + nullable: true + properties: + gmsaCredentialSpec: + nullable: true + type: string + gmsaCredentialSpecName: + nullable: true + type: string + hostProcess: + nullable: true + type: boolean + runAsUserName: + nullable: true + type: string + type: object + type: object + serviceAccount: + nullable: true + type: string + serviceAccountName: + nullable: true + type: string + setHostnameAsFQDN: + nullable: true + type: boolean + shareProcessNamespace: + nullable: true + type: boolean + subdomain: + nullable: true + type: string + terminationGracePeriodSeconds: + nullable: true + type: integer + tolerations: + items: + properties: + effect: + nullable: true + type: string + key: + nullable: true + type: string + operator: + nullable: true + type: string + tolerationSeconds: + nullable: true + type: integer + value: + nullable: true + type: string + type: object + nullable: true + type: array + topologySpreadConstraints: + items: + properties: + labelSelector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + matchLabelKeys: + items: + nullable: true + type: string + nullable: true + type: array + maxSkew: + type: integer + minDomains: + nullable: true + type: integer + nodeAffinityPolicy: + nullable: true + type: string + nodeTaintsPolicy: + nullable: true + type: string + topologyKey: + nullable: true + type: string + whenUnsatisfiable: + nullable: true + type: string + type: object + nullable: true + type: array + volumes: + items: + properties: + awsElasticBlockStore: + nullable: true + properties: + fsType: + nullable: true + type: string + partition: + type: integer + readOnly: + type: boolean + volumeID: + nullable: true + type: string + type: object + azureDisk: + nullable: true + properties: + cachingMode: + nullable: true + type: string + diskName: + nullable: true + type: string + diskURI: + nullable: true + type: string + fsType: + nullable: true + type: string + kind: + nullable: true + type: string + readOnly: + nullable: true + type: boolean + type: object + azureFile: + nullable: true + properties: + readOnly: + type: boolean + secretName: + nullable: true + type: string + shareName: + nullable: true + type: string + type: object + cephfs: + nullable: true + properties: + monitors: + items: + nullable: true + type: string + nullable: true + type: array + path: + nullable: true + type: string + readOnly: + type: boolean + secretFile: + nullable: true + type: string + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + type: object + user: + nullable: true + type: string + type: object + cinder: + nullable: true + properties: + fsType: + nullable: true + type: string + readOnly: + type: boolean + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + type: object + volumeID: + nullable: true + type: string + type: object + configMap: + nullable: true + properties: + defaultMode: + nullable: true + type: integer + items: + items: + properties: + key: + nullable: true + type: string + mode: + nullable: true + type: integer + path: + nullable: true + type: string + type: object + nullable: true + type: array + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + csi: + nullable: true + properties: + driver: + nullable: true + type: string + fsType: + nullable: true + type: string + nodePublishSecretRef: + nullable: true + properties: + name: + nullable: true + type: string + type: object + readOnly: + nullable: true + type: boolean + volumeAttributes: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + downwardAPI: + nullable: true + properties: + defaultMode: + nullable: true + type: integer + items: + items: + properties: + fieldRef: + nullable: true + properties: + apiVersion: + nullable: true + type: string + fieldPath: + nullable: true + type: string + type: object + mode: + nullable: true + type: integer + path: + nullable: true + type: string + resourceFieldRef: + nullable: true + properties: + containerName: + nullable: true + type: string + divisor: + nullable: true + type: string + resource: + nullable: true + type: string + type: object + type: object + nullable: true + type: array + type: object + emptyDir: + nullable: true + properties: + medium: + nullable: true + type: string + sizeLimit: + nullable: true + type: string + type: object + ephemeral: + nullable: true + properties: + volumeClaimTemplate: + nullable: true + properties: + metadata: + properties: + annotations: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + creationTimestamp: + nullable: true + type: string + deletionGracePeriodSeconds: + nullable: true + type: integer + deletionTimestamp: + nullable: true + type: string + finalizers: + items: + nullable: true + type: string + nullable: true + type: array + generateName: + nullable: true + type: string + generation: + type: integer + labels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + managedFields: + items: + properties: + apiVersion: + nullable: true + type: string + fieldsType: + nullable: true + type: string + fieldsV1: + nullable: true + type: object + manager: + nullable: true + type: string + operation: + nullable: true + type: string + subresource: + nullable: true + type: string + time: + nullable: true + type: string + type: object + nullable: true + type: array + name: + nullable: true + type: string + namespace: + nullable: true + type: string + ownerReferences: + items: + properties: + apiVersion: + nullable: true + type: string + blockOwnerDeletion: + nullable: true + type: boolean + controller: + nullable: true + type: boolean + kind: + nullable: true + type: string + name: + nullable: true + type: string + uid: + nullable: true + type: string + type: object + nullable: true + type: array + resourceVersion: + nullable: true + type: string + selfLink: + nullable: true + type: string + uid: + nullable: true + type: string + type: object + spec: + properties: + accessModes: + items: + nullable: true + type: string + nullable: true + type: array + dataSource: + nullable: true + properties: + apiGroup: + nullable: true + type: string + kind: + nullable: true + type: string + name: + nullable: true + type: string + type: object + dataSourceRef: + nullable: true + properties: + apiGroup: + nullable: true + type: string + kind: + nullable: true + type: string + name: + nullable: true + type: string + namespace: + nullable: true + type: string + type: object + resources: + properties: + claims: + items: + properties: + name: + nullable: true + type: string + type: object + nullable: true + type: array + limits: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + requests: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + selector: + nullable: true + properties: + matchExpressions: + items: + properties: + key: + nullable: true + type: string + operator: + nullable: true + type: string + values: + items: + nullable: true + type: string + nullable: true + type: array + type: object + nullable: true + type: array + matchLabels: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + type: object + storageClassName: + nullable: true + type: string + volumeMode: + nullable: true + type: string + volumeName: + nullable: true + type: string + type: object + type: object + type: object + fc: + nullable: true + properties: + fsType: + nullable: true + type: string + lun: + nullable: true + type: integer + readOnly: + type: boolean + targetWWNs: + items: + nullable: true + type: string + nullable: true + type: array + wwids: + items: + nullable: true + type: string + nullable: true + type: array + type: object + flexVolume: + nullable: true + properties: + driver: + nullable: true + type: string + fsType: + nullable: true + type: string + options: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + readOnly: + type: boolean + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + type: object + type: object + flocker: + nullable: true + properties: + datasetName: + nullable: true + type: string + datasetUUID: + nullable: true + type: string + type: object + gcePersistentDisk: + nullable: true + properties: + fsType: + nullable: true + type: string + partition: + type: integer + pdName: + nullable: true + type: string + readOnly: + type: boolean + type: object + gitRepo: + nullable: true + properties: + directory: + nullable: true + type: string + repository: + nullable: true + type: string + revision: + nullable: true + type: string + type: object + glusterfs: + nullable: true + properties: + endpoints: + nullable: true + type: string + path: + nullable: true + type: string + readOnly: + type: boolean + type: object + hostPath: + nullable: true + properties: + path: + nullable: true + type: string + type: + nullable: true + type: string + type: object + iscsi: + nullable: true + properties: + chapAuthDiscovery: + type: boolean + chapAuthSession: + type: boolean + fsType: + nullable: true + type: string + initiatorName: + nullable: true + type: string + iqn: + nullable: true + type: string + iscsiInterface: + nullable: true + type: string + lun: + type: integer + portals: + items: + nullable: true + type: string + nullable: true + type: array + readOnly: + type: boolean + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + type: object + targetPortal: + nullable: true + type: string + type: object + name: + nullable: true + type: string + nfs: + nullable: true + properties: + path: + nullable: true + type: string + readOnly: + type: boolean + server: + nullable: true + type: string + type: object + persistentVolumeClaim: + nullable: true + properties: + claimName: + nullable: true + type: string + readOnly: + type: boolean + type: object + photonPersistentDisk: + nullable: true + properties: + fsType: + nullable: true + type: string + pdID: + nullable: true + type: string + type: object + portworxVolume: + nullable: true + properties: + fsType: + nullable: true + type: string + readOnly: + type: boolean + volumeID: + nullable: true + type: string + type: object + projected: + nullable: true + properties: + defaultMode: + nullable: true + type: integer + sources: + items: + properties: + configMap: + nullable: true + properties: + items: + items: + properties: + key: + nullable: true + type: string + mode: + nullable: true + type: integer + path: + nullable: true + type: string + type: object + nullable: true + type: array + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + downwardAPI: + nullable: true + properties: + items: + items: + properties: + fieldRef: + nullable: true + properties: + apiVersion: + nullable: true + type: string + fieldPath: + nullable: true + type: string + type: object + mode: + nullable: true + type: integer + path: + nullable: true + type: string + resourceFieldRef: + nullable: true + properties: + containerName: + nullable: true + type: string + divisor: + nullable: true + type: string + resource: + nullable: true + type: string + type: object + type: object + nullable: true + type: array + type: object + secret: + nullable: true + properties: + items: + items: + properties: + key: + nullable: true + type: string + mode: + nullable: true + type: integer + path: + nullable: true + type: string + type: object + nullable: true + type: array + name: + nullable: true + type: string + optional: + nullable: true + type: boolean + type: object + serviceAccountToken: + nullable: true + properties: + audience: + nullable: true + type: string + expirationSeconds: + nullable: true + type: integer + path: + nullable: true + type: string + type: object + type: object + nullable: true + type: array + type: object + quobyte: + nullable: true + properties: + group: + nullable: true + type: string + readOnly: + type: boolean + registry: + nullable: true + type: string + tenant: + nullable: true + type: string + user: + nullable: true + type: string + volume: + nullable: true + type: string + type: object + rbd: + nullable: true + properties: + fsType: + nullable: true + type: string + image: + nullable: true + type: string + keyring: + nullable: true + type: string + monitors: + items: + nullable: true + type: string + nullable: true + type: array + pool: + nullable: true + type: string + readOnly: + type: boolean + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + type: object + user: + nullable: true + type: string + type: object + scaleIO: + nullable: true + properties: + fsType: + nullable: true + type: string + gateway: + nullable: true + type: string + protectionDomain: + nullable: true + type: string + readOnly: + type: boolean + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + type: object + sslEnabled: + type: boolean + storageMode: + nullable: true + type: string + storagePool: + nullable: true + type: string + system: + nullable: true + type: string + volumeName: + nullable: true + type: string + type: object + secret: + nullable: true + properties: + defaultMode: + nullable: true + type: integer + items: + items: + properties: + key: + nullable: true + type: string + mode: + nullable: true + type: integer + path: + nullable: true + type: string + type: object + nullable: true + type: array + optional: + nullable: true + type: boolean + secretName: + nullable: true + type: string + type: object + storageos: + nullable: true + properties: + fsType: + nullable: true + type: string + readOnly: + type: boolean + secretRef: + nullable: true + properties: + name: + nullable: true + type: string + type: object + volumeName: + nullable: true + type: string + volumeNamespace: + nullable: true + type: string + type: object + vsphereVolume: + nullable: true + properties: + fsType: + nullable: true + type: string + storagePolicyID: + nullable: true + type: string + storagePolicyName: + nullable: true + type: string + volumePath: + nullable: true + type: string + type: object + type: object + nullable: true + type: array + type: object + type: object + ttlSecondsAfterFinished: + nullable: true + type: integer + type: object + syncInterval: + type: integer + type: object + status: + properties: + commit: + nullable: true + type: string + conditions: + items: + properties: + lastTransitionTime: + nullable: true + type: string + lastUpdateTime: + nullable: true + type: string + message: + nullable: true + type: string + reason: + nullable: true + type: string + status: + nullable: true + type: string + type: + nullable: true + type: string + type: object + nullable: true + type: array + event: + nullable: true + type: string + hookId: + nullable: true + type: string + jobStatus: + nullable: true + type: string + lastExecutedCommit: + nullable: true + type: string + lastSyncedTime: + nullable: true + type: string + observedGeneration: + type: integer + secretToken: + nullable: true + type: string + updateGeneration: + type: integer + type: object + type: object + version: v1 + versions: + - name: v1 + served: true + storage: true +{{- end -}} diff --git a/charts/fleet-crd/103.1.10+up0.9.11/values.yaml b/charts/fleet-crd/103.1.10+up0.9.11/values.yaml new file mode 100644 index 0000000000..d41d3a2444 --- /dev/null +++ b/charts/fleet-crd/103.1.10+up0.9.11/values.yaml @@ -0,0 +1 @@ +# This file is intentionally empty diff --git a/charts/fleet/103.1.10+up0.9.11/Chart.yaml b/charts/fleet/103.1.10+up0.9.11/Chart.yaml new file mode 100644 index 0000000000..8c37be202d --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/Chart.yaml @@ -0,0 +1,22 @@ +annotations: + catalog.cattle.io/auto-install: fleet-crd=match + catalog.cattle.io/certified: rancher + catalog.cattle.io/experimental: "true" + catalog.cattle.io/hidden: "true" + catalog.cattle.io/kube-version: '>= 1.23.0-0 < 1.29.0-0' + catalog.cattle.io/namespace: cattle-fleet-system + catalog.cattle.io/os: linux + catalog.cattle.io/permits-os: linux,windows + catalog.cattle.io/provides-gvr: clusters.fleet.cattle.io/v1alpha1 + catalog.cattle.io/rancher-version: '>= 2.8.0-0 < 2.9.0-0' + catalog.cattle.io/release-name: fleet +apiVersion: v2 +appVersion: 0.9.11 +dependencies: +- condition: gitops.enabled + name: gitjob + repository: file://./charts/gitjob +description: Fleet Manager - GitOps at Scale +icon: https://charts.rancher.io/assets/logos/fleet.svg +name: fleet +version: 103.1.10+up0.9.11 diff --git a/charts/fleet/103.1.10+up0.9.11/README.md b/charts/fleet/103.1.10+up0.9.11/README.md new file mode 100644 index 0000000000..2f2a4c302a --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/README.md @@ -0,0 +1,30 @@ +# Fleet Helm Chart + +Fleet is GitOps at scale. Fleet is designed to manage multiple clusters. + +## What is Fleet? + +* Cluster engine: Fleet is a container management and deployment engine designed to offer users more control on the local cluster and constant monitoring through GitOps. Fleet focuses not only on the ability to scale, but it also gives users a high degree of control and visibility to monitor exactly what is installed on the cluster. + +* Deployment management: Fleet can manage deployments from git of raw Kubernetes YAML, Helm charts, Kustomize, or any combination of the three. Regardless of the source, all resources are dynamically turned into Helm charts, and Helm is used as the engine to deploy all resources in the cluster. As a result, users can enjoy a high degree of control, consistency, and auditability of their clusters. + +## Introduction + +This chart deploys Fleet on a Kubernetes cluster. It also deploys some of its dependencies as subcharts. + +The documentation is centralized in the [doc website](https://fleet.rancher.io/). + +## Prerequisites + +Get helm if you don't have it. Helm 3 is just a CLI. + + +## Install Fleet + +Install the Fleet Helm charts (there are two because we separate out CRDs for ultimate flexibility.): + +``` +$ helm repo add fleet https://rancher.github.io/fleet-helm-charts/ +$ helm -n cattle-fleet-system install --create-namespace --wait fleet-crd fleet/fleet-crd +$ helm -n cattle-fleet-system install --create-namespace --wait fleet fleet/fleet +``` \ No newline at end of file diff --git a/charts/fleet/103.1.10+up0.9.11/charts/gitjob/.helmignore b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/.helmignore new file mode 100644 index 0000000000..691fa13d6a --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/.helmignore @@ -0,0 +1,23 @@ +# Patterns to ignore when building packages. +# This supports shell glob matching, relative path matching, and +# negation (prefixed with !). Only one pattern per line. +.DS_Store +# Common VCS dirs +.git/ +.gitignore +.bzr/ +.bzrignore +.hg/ +.hgignore +.svn/ +# Common backup files +*.swp +*.bak +*.tmp +*.orig +*~ +# Various IDEs +.project +.idea/ +*.tmproj +.vscode/ \ No newline at end of file diff --git a/charts/fleet/103.1.10+up0.9.11/charts/gitjob/Chart.yaml b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/Chart.yaml new file mode 100644 index 0000000000..c911624309 --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/Chart.yaml @@ -0,0 +1,5 @@ +apiVersion: v2 +appVersion: 0.9.17 +description: Controller that run jobs based on git events +name: gitjob +version: 0.9.17 diff --git a/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/_helpers.tpl b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/_helpers.tpl new file mode 100644 index 0000000000..f652b5643d --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/_helpers.tpl @@ -0,0 +1,7 @@ +{{- define "system_default_registry" -}} +{{- if .Values.global.cattle.systemDefaultRegistry -}} +{{- printf "%s/" .Values.global.cattle.systemDefaultRegistry -}} +{{- else -}} +{{- "" -}} +{{- end -}} +{{- end -}} \ No newline at end of file diff --git a/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/clusterrole.yaml b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/clusterrole.yaml new file mode 100644 index 0000000000..bcad90164f --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/clusterrole.yaml @@ -0,0 +1,38 @@ +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + name: gitjob +rules: + - apiGroups: + - "batch" + resources: + - 'jobs' + verbs: + - '*' + - apiGroups: + - "" + resources: + - 'pods' + verbs: + - 'list' + - 'get' + - 'watch' + - apiGroups: + - "" + resources: + - 'secrets' + verbs: + - '*' + - apiGroups: + - "" + resources: + - 'configmaps' + verbs: + - '*' + - apiGroups: + - "gitjob.cattle.io" + resources: + - "gitjobs" + - "gitjobs/status" + verbs: + - "*" \ No newline at end of file diff --git a/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/clusterrolebinding.yaml b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/clusterrolebinding.yaml new file mode 100644 index 0000000000..0bf07c4ef8 --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/clusterrolebinding.yaml @@ -0,0 +1,12 @@ +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: gitjob-binding +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: gitjob +subjects: + - kind: ServiceAccount + name: gitjob + namespace: {{ .Release.Namespace }} \ No newline at end of file diff --git a/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/deployment.yaml b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/deployment.yaml new file mode 100644 index 0000000000..7771db512c --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/deployment.yaml @@ -0,0 +1,52 @@ +apiVersion: apps/v1 +kind: Deployment +metadata: + name: gitjob +spec: + selector: + matchLabels: + app: "gitjob" + template: + metadata: + labels: + app: "gitjob" + spec: + serviceAccountName: gitjob + containers: + - image: "{{ template "system_default_registry" . }}{{ .Values.gitjob.repository }}:{{ .Values.gitjob.tag }}" + name: gitjob + args: + - gitjob + - --gitjob-image + - "{{ template "system_default_registry" . }}{{ .Values.gitjob.repository }}:{{ .Values.gitjob.tag }}" + {{- if .Values.debug }} + - --debug + {{- end }} + env: + - name: NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + {{- if .Values.proxy }} + - name: HTTP_PROXY + value: {{ .Values.proxy }} + - name: HTTPS_PROXY + value: {{ .Values.proxy }} + - name: NO_PROXY + value: {{ .Values.noProxy }} + {{- end }} + {{- if .Values.debug }} + - name: CATTLE_DEV_MODE + value: "true" + {{- end }} + {{- with .Values.tolerations }} + tolerations: + {{- toYaml . | nindent 8 }} + {{- end }} + {{- with .Values.nodeSelector }} + nodeSelector: + {{- toYaml . | nindent 8 }} + {{- end }} + {{- if .Values.priorityClassName }} + priorityClassName: "{{.Values.priorityClassName}}" + {{- end }} diff --git a/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/leases.yaml b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/leases.yaml new file mode 100644 index 0000000000..51f9339509 --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/leases.yaml @@ -0,0 +1,23 @@ +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: gitjob +rules: + - apiGroups: + - "coordination.k8s.io" + resources: + - "leases" + verbs: + - "*" +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: gitjob +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: gitjob +subjects: + - kind: ServiceAccount + name: gitjob diff --git a/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/service.yaml b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/service.yaml new file mode 100644 index 0000000000..bf57c1b55c --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/service.yaml @@ -0,0 +1,12 @@ +apiVersion: v1 +kind: Service +metadata: + name: gitjob +spec: + ports: + - name: http-80 + port: 80 + protocol: TCP + targetPort: 8080 + selector: + app: "gitjob" \ No newline at end of file diff --git a/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/serviceaccount.yaml b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/serviceaccount.yaml new file mode 100644 index 0000000000..5f8aecb045 --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/templates/serviceaccount.yaml @@ -0,0 +1,4 @@ +apiVersion: v1 +kind: ServiceAccount +metadata: + name: gitjob diff --git a/charts/fleet/103.1.10+up0.9.11/charts/gitjob/values.yaml b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/values.yaml new file mode 100644 index 0000000000..92da006e38 --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/charts/gitjob/values.yaml @@ -0,0 +1,27 @@ +gitjob: + repository: rancher/gitjob + tag: v0.9.17 + +global: + cattle: + systemDefaultRegistry: "" + +# http[s] proxy server +# proxy: http://@:: + +# comma separated list of domains or ip addresses that will not use the proxy +noProxy: 127.0.0.0/8,10.0.0.0/8,172.16.0.0/12,192.168.0.0/16,.svc,.cluster.local + +nodeSelector: + kubernetes.io/os: linux + +tolerations: + - key: cattle.io/os + operator: "Equal" + value: "linux" + effect: NoSchedule + +# PriorityClassName assigned to deployment. +priorityClassName: "" + +debug: false diff --git a/charts/fleet/103.1.10+up0.9.11/templates/_helpers.tpl b/charts/fleet/103.1.10+up0.9.11/templates/_helpers.tpl new file mode 100644 index 0000000000..6cd96c3ace --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/templates/_helpers.tpl @@ -0,0 +1,22 @@ +{{- define "system_default_registry" -}} +{{- if .Values.global.cattle.systemDefaultRegistry -}} +{{- printf "%s/" .Values.global.cattle.systemDefaultRegistry -}} +{{- else -}} +{{- "" -}} +{{- end -}} +{{- end -}} + +{{/* +Windows cluster will add default taint for linux nodes, +add below linux tolerations to workloads could be scheduled to those linux nodes +*/}} +{{- define "linux-node-tolerations" -}} +- key: "cattle.io/os" + value: "linux" + effect: "NoSchedule" + operator: "Equal" +{{- end -}} + +{{- define "linux-node-selector" -}} +kubernetes.io/os: linux +{{- end -}} \ No newline at end of file diff --git a/charts/fleet/103.1.10+up0.9.11/templates/configmap.yaml b/charts/fleet/103.1.10+up0.9.11/templates/configmap.yaml new file mode 100644 index 0000000000..3fd0b15cf8 --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/templates/configmap.yaml @@ -0,0 +1,26 @@ +apiVersion: v1 +kind: ConfigMap +metadata: + name: fleet-controller +data: + config: | + { + "systemDefaultRegistry": "{{ template "system_default_registry" . }}", + "agentImage": "{{ template "system_default_registry" . }}{{.Values.agentImage.repository}}:{{.Values.agentImage.tag}}", + "agentImagePullPolicy": "{{ .Values.agentImage.imagePullPolicy }}", + "apiServerURL": "{{.Values.apiServerURL}}", + "apiServerCA": "{{b64enc .Values.apiServerCA}}", + "agentCheckinInterval": "{{.Values.agentCheckinInterval}}", + "agentTLSMode": "{{.Values.agentTLSMode}}", + "ignoreClusterRegistrationLabels": {{.Values.ignoreClusterRegistrationLabels}}, + "bootstrap": { + "paths": "{{.Values.bootstrap.paths}}", + "repo": "{{.Values.bootstrap.repo}}", + "secret": "{{.Values.bootstrap.secret}}", + "branch": "{{.Values.bootstrap.branch}}", + "namespace": "{{.Values.bootstrap.namespace}}", + "agentNamespace": "{{.Values.bootstrap.agentNamespace}}", + }, + "webhookReceiverURL": "{{.Values.webhookReceiverURL}}", + "githubURLPrefix": "{{.Values.githubURLPrefix}}" + } diff --git a/charts/fleet/103.1.10+up0.9.11/templates/deployment.yaml b/charts/fleet/103.1.10+up0.9.11/templates/deployment.yaml new file mode 100644 index 0000000000..164340c444 --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/templates/deployment.yaml @@ -0,0 +1,102 @@ +apiVersion: apps/v1 +kind: Deployment +metadata: + name: fleet-controller +spec: + selector: + matchLabels: + app: fleet-controller + template: + metadata: + labels: + app: fleet-controller + spec: + containers: + - env: + - name: NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + - name: FLEET_PROPAGATE_DEBUG_SETTINGS_TO_AGENTS + value: {{ quote .Values.propagateDebugSettingsToAgents }} + {{- if .Values.clusterEnqueueDelay }} + - name: FLEET_CLUSTER_ENQUEUE_DELAY + value: {{ .Values.clusterEnqueueDelay }} + {{- end }} + {{- if .Values.proxy }} + - name: HTTP_PROXY + value: {{ .Values.proxy }} + - name: HTTPS_PROXY + value: {{ .Values.proxy }} + - name: NO_PROXY + value: {{ .Values.noProxy }} + {{- end }} + {{- if .Values.cpuPprof }} + - name: FLEET_CPU_PPROF_DIR + value: /tmp/pprof/ + {{- end }} + {{- if .Values.cpuPprof }} + - name: FLEET_CPU_PPROF_PERIOD + value: {{ quote .Values.cpuPprof.period }} + {{- end }} + {{- if .Values.debug }} + - name: CATTLE_DEV_MODE + value: "true" + {{- end }} + image: '{{ template "system_default_registry" . }}{{ .Values.image.repository }}:{{ .Values.image.tag }}' + name: fleet-controller + imagePullPolicy: "{{ .Values.image.imagePullPolicy }}" + command: + - fleetcontroller + {{- if not .Values.gitops.enabled }} + - --disable-gitops + {{- end }} + {{- if not .Values.bootstrap.enabled }} + - --disable-bootstrap + {{- end }} + {{- if .Values.debug }} + - --debug + - --debug-level + - {{ quote .Values.debugLevel }} + {{- else }} + securityContext: + allowPrivilegeEscalation: false + readOnlyRootFilesystem: true + privileged: false + capabilities: + drop: + - ALL + {{- end }} + volumeMounts: + - mountPath: /tmp + name: tmp + {{- if .Values.cpuPprof }} + - mountPath: /tmp/pprof + name: pprof + {{- end }} + volumes: + - name: tmp + emptyDir: {} + {{- if .Values.cpuPprof }} + - name: pprof {{ toYaml .Values.cpuPprof.volumeConfiguration | nindent 10 }} + {{- end }} + + serviceAccountName: fleet-controller + nodeSelector: {{ include "linux-node-selector" . | nindent 8 }} +{{- if .Values.nodeSelector }} +{{ toYaml .Values.nodeSelector | indent 8 }} +{{- end }} + tolerations: {{ include "linux-node-tolerations" . | nindent 8 }} +{{- if .Values.tolerations }} +{{ toYaml .Values.tolerations | indent 8 }} +{{- end }} + {{- if .Values.priorityClassName }} + priorityClassName: "{{.Values.priorityClassName}}" + {{- end }} + +{{- if not .Values.debug }} + securityContext: + runAsNonRoot: true + runAsUser: 1000 + runAsGroup: 1000 +{{- end }} diff --git a/charts/fleet/103.1.10+up0.9.11/templates/job_cleanup_clusterregistrations.yaml b/charts/fleet/103.1.10+up0.9.11/templates/job_cleanup_clusterregistrations.yaml new file mode 100644 index 0000000000..17d1ba7864 --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/templates/job_cleanup_clusterregistrations.yaml @@ -0,0 +1,40 @@ +{{- if .Values.migrations.clusterRegistrationCleanup }} +--- +apiVersion: batch/v1 +kind: Job +metadata: + name: fleet-cleanup-clusterregistrations + annotations: + "helm.sh/hook": post-install, post-upgrade + "helm.sh/hook-delete-policy": hook-succeeded, before-hook-creation +spec: + template: + metadata: + labels: + app: fleet-job + spec: + serviceAccountName: fleet-controller + restartPolicy: Never + securityContext: + runAsNonRoot: true + runAsGroup: 1000 + runAsUser: 1000 + containers: + - name: cleanup + image: "{{ template "system_default_registry" . }}{{.Values.agentImage.repository}}:{{.Values.agentImage.tag}}" + imagePullPolicy: {{ .Values.global.imagePullPolicy }} + securityContext: + allowPrivilegeEscalation: false + capabilities: + drop: + - ALL + readOnlyRootFilesystem: false + privileged: false + command: + - fleet + args: + - cleanup + nodeSelector: {{ include "linux-node-selector" . | nindent 8 }} + tolerations: {{ include "linux-node-tolerations" . | nindent 8 }} + backoffLimit: 1 +{{- end }} diff --git a/charts/fleet/103.1.10+up0.9.11/templates/rbac.yaml b/charts/fleet/103.1.10+up0.9.11/templates/rbac.yaml new file mode 100644 index 0000000000..361d68c08b --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/templates/rbac.yaml @@ -0,0 +1,114 @@ +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + name: fleet-controller +rules: +- apiGroups: + - gitjob.cattle.io + resources: + - '*' + verbs: + - '*' +- apiGroups: + - fleet.cattle.io + resources: + - '*' + verbs: + - '*' +- apiGroups: + - "" + resources: + - namespaces + - serviceaccounts + verbs: + - '*' +- apiGroups: + - "" + resources: + - secrets + - configmaps + verbs: + - '*' +- apiGroups: + - rbac.authorization.k8s.io + resources: + - clusterroles + - clusterrolebindings + - roles + - rolebindings + verbs: + - '*' + +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: fleet-controller +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: fleet-controller +subjects: +- kind: ServiceAccount + name: fleet-controller + namespace: {{.Release.Namespace}} + +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: fleet-controller +rules: +- apiGroups: + - "" + resources: + - configmaps + verbs: + - '*' +- apiGroups: + - coordination.k8s.io + resources: + - leases + verbs: + - '*' + +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: fleet-controller +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: fleet-controller +subjects: +- kind: ServiceAccount + name: fleet-controller + +{{- if .Values.bootstrap.enabled }} +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + name: fleet-controller-bootstrap +rules: +- apiGroups: + - '*' + resources: + - '*' + verbs: + - '*' +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: fleet-controller-bootstrap +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: fleet-controller-bootstrap +subjects: +- kind: ServiceAccount + name: fleet-controller-bootstrap + namespace: {{.Release.Namespace}} +{{- end }} diff --git a/charts/fleet/103.1.10+up0.9.11/templates/serviceaccount.yaml b/charts/fleet/103.1.10+up0.9.11/templates/serviceaccount.yaml new file mode 100644 index 0000000000..ba27c748d7 --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/templates/serviceaccount.yaml @@ -0,0 +1,12 @@ +apiVersion: v1 +kind: ServiceAccount +metadata: + name: fleet-controller + +{{- if .Values.bootstrap.enabled }} +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: fleet-controller-bootstrap +{{- end }} diff --git a/charts/fleet/103.1.10+up0.9.11/values.yaml b/charts/fleet/103.1.10+up0.9.11/values.yaml new file mode 100644 index 0000000000..bd057c9778 --- /dev/null +++ b/charts/fleet/103.1.10+up0.9.11/values.yaml @@ -0,0 +1,87 @@ +image: + repository: rancher/fleet + tag: v0.9.11 + imagePullPolicy: IfNotPresent + +agentImage: + repository: rancher/fleet-agent + tag: v0.9.11 + imagePullPolicy: IfNotPresent + +# For cluster registration the public URL of the Kubernetes API server must be set here +# Example: https://example.com:6443 +apiServerURL: "" + +# For cluster registration the pem encoded value of the CA of the Kubernetes API server must be set here +# If left empty it is assumed this Kubernetes API TLS is signed by a well known CA. +apiServerCA: "" + +# Determines whether the agent should trust CA bundles from the operating system's trust store when connecting to a +# management cluster. True in `system-store` mode, false in `strict` mode. +agentTLSMode: "system-store" + +# A duration string for how often agents should report a heartbeat +agentCheckinInterval: "15m" + +# Whether you want to allow cluster upon registration to specify their labels. +ignoreClusterRegistrationLabels: false + +# Counts from gitrepo are out of sync with bundleDeployment state. +# Just retry in a number of seconds as there is no great way to trigger an event that doesn't cause a loop. +# If not set default is 15 seconds. +# clusterEnqueueDelay: 120s + +# http[s] proxy server +# proxy: http://@:: + +# comma separated list of domains or ip addresses that will not use the proxy +noProxy: 127.0.0.0/8,10.0.0.0/8,172.16.0.0/12,192.168.0.0/16,.svc,.cluster.local + +bootstrap: + enabled: true + # The namespace that will be autocreated and the local cluster will be registered in + namespace: fleet-local + # The namespace where the fleet agent for the local cluster will be ran, if empty + # this will default to cattle-fleet-system + agentNamespace: "" + # A repo to add at install time that will deploy to the local cluster. This allows + # one to fully bootstrap fleet, its configuration and all its downstream clusters + # in one shot. + repo: "" + secret: "" + branch: master + paths: "" + + +global: + cattle: + systemDefaultRegistry: "" + +## Node labels for pod assignment +## Ref: https://kubernetes.io/docs/user-guide/node-selection/ +## +nodeSelector: {} +## List of node taints to tolerate (requires Kubernetes >= 1.6) +tolerations: [] + +## PriorityClassName assigned to deployment. +priorityClassName: "" + +gitops: + enabled: true + +debug: false +debugLevel: 0 +propagateDebugSettingsToAgents: true + +## Optional CPU pprof configuration. Profiles are collected continuously and saved every period +## Any valid volume configuration can be provided, the example below uses hostPath +#cpuPprof: +# period: "60s" +# volumeConfiguration: +# hostPath: +# path: /tmp/pprof +# type: DirectoryOrCreate + +migrations: + clusterRegistrationCleanup: true diff --git a/charts/rancher-cis-benchmark-crd/5.6.0/Chart.yaml b/charts/rancher-cis-benchmark-crd/5.6.0/Chart.yaml new file mode 100644 index 0000000000..cc5079bba4 --- /dev/null +++ b/charts/rancher-cis-benchmark-crd/5.6.0/Chart.yaml @@ -0,0 +1,10 @@ +annotations: + catalog.cattle.io/certified: rancher + catalog.cattle.io/hidden: "true" + catalog.cattle.io/namespace: cis-operator-system + catalog.cattle.io/release-name: rancher-cis-benchmark-crd +apiVersion: v1 +description: Installs the CRDs for rancher-cis-benchmark. +name: rancher-cis-benchmark-crd +type: application +version: 5.6.0 diff --git a/charts/rancher-cis-benchmark-crd/5.6.0/README.md b/charts/rancher-cis-benchmark-crd/5.6.0/README.md new file mode 100644 index 0000000000..f6d9ef621f --- /dev/null +++ b/charts/rancher-cis-benchmark-crd/5.6.0/README.md @@ -0,0 +1,2 @@ +# rancher-cis-benchmark-crd +A Rancher chart that installs the CRDs used by rancher-cis-benchmark. diff --git a/charts/rancher-cis-benchmark-crd/5.6.0/templates/clusterscan.yaml b/charts/rancher-cis-benchmark-crd/5.6.0/templates/clusterscan.yaml new file mode 100644 index 0000000000..3cbb0ffcd3 --- /dev/null +++ b/charts/rancher-cis-benchmark-crd/5.6.0/templates/clusterscan.yaml @@ -0,0 +1,148 @@ +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: clusterscans.cis.cattle.io +spec: + group: cis.cattle.io + names: + kind: ClusterScan + plural: clusterscans + scope: Cluster + versions: + - name: v1 + served: true + storage: true + additionalPrinterColumns: + - jsonPath: .status.lastRunScanProfileName + name: ClusterScanProfile + type: string + - jsonPath: .status.summary.total + name: Total + type: string + - jsonPath: .status.summary.pass + name: Pass + type: string + - jsonPath: .status.summary.fail + name: Fail + type: string + - jsonPath: .status.summary.skip + name: Skip + type: string + - jsonPath: .status.summary.warn + name: Warn + type: string + - jsonPath: .status.summary.notApplicable + name: Not Applicable + type: string + - jsonPath: .status.lastRunTimestamp + name: LastRunTimestamp + type: string + - jsonPath: .spec.scheduledScanConfig.cronSchedule + name: CronSchedule + type: string + subresources: + status: {} + schema: + openAPIV3Schema: + properties: + spec: + properties: + scanProfileName: + nullable: true + type: string + scheduledScanConfig: + nullable: true + properties: + cronSchedule: + nullable: true + type: string + retentionCount: + type: integer + scanAlertRule: + nullable: true + properties: + alertOnComplete: + type: boolean + alertOnFailure: + type: boolean + type: object + type: object + scoreWarning: + enum: + - pass + - fail + nullable: true + type: string + type: object + status: + properties: + NextScanAt: + nullable: true + type: string + ScanAlertingRuleName: + nullable: true + type: string + conditions: + items: + properties: + lastTransitionTime: + nullable: true + type: string + lastUpdateTime: + nullable: true + type: string + message: + nullable: true + type: string + reason: + nullable: true + type: string + status: + nullable: true + type: string + type: + nullable: true + type: string + type: object + nullable: true + type: array + display: + nullable: true + properties: + error: + type: boolean + message: + nullable: true + type: string + state: + nullable: true + type: string + transitioning: + type: boolean + type: object + lastRunScanProfileName: + nullable: true + type: string + lastRunTimestamp: + nullable: true + type: string + observedGeneration: + type: integer + summary: + nullable: true + properties: + fail: + type: integer + notApplicable: + type: integer + pass: + type: integer + skip: + type: integer + total: + type: integer + warn: + type: integer + type: object + type: object + type: object diff --git a/charts/rancher-cis-benchmark-crd/5.6.0/templates/clusterscanbenchmark.yaml b/charts/rancher-cis-benchmark-crd/5.6.0/templates/clusterscanbenchmark.yaml new file mode 100644 index 0000000000..fd291f8c33 --- /dev/null +++ b/charts/rancher-cis-benchmark-crd/5.6.0/templates/clusterscanbenchmark.yaml @@ -0,0 +1,54 @@ +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: clusterscanbenchmarks.cis.cattle.io +spec: + group: cis.cattle.io + names: + kind: ClusterScanBenchmark + plural: clusterscanbenchmarks + scope: Cluster + versions: + - name: v1 + served: true + storage: true + additionalPrinterColumns: + - jsonPath: .spec.clusterProvider + name: ClusterProvider + type: string + - jsonPath: .spec.minKubernetesVersion + name: MinKubernetesVersion + type: string + - jsonPath: .spec.maxKubernetesVersion + name: MaxKubernetesVersion + type: string + - jsonPath: .spec.customBenchmarkConfigMapName + name: customBenchmarkConfigMapName + type: string + - jsonPath: .spec.customBenchmarkConfigMapNamespace + name: customBenchmarkConfigMapNamespace + type: string + subresources: + status: {} + schema: + openAPIV3Schema: + properties: + spec: + properties: + clusterProvider: + nullable: true + type: string + customBenchmarkConfigMapName: + nullable: true + type: string + customBenchmarkConfigMapNamespace: + nullable: true + type: string + maxKubernetesVersion: + nullable: true + type: string + minKubernetesVersion: + nullable: true + type: string + type: object + type: object diff --git a/charts/rancher-cis-benchmark-crd/5.6.0/templates/clusterscanprofile.yaml b/charts/rancher-cis-benchmark-crd/5.6.0/templates/clusterscanprofile.yaml new file mode 100644 index 0000000000..1e75501b7c --- /dev/null +++ b/charts/rancher-cis-benchmark-crd/5.6.0/templates/clusterscanprofile.yaml @@ -0,0 +1,36 @@ +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: clusterscanprofiles.cis.cattle.io +spec: + group: cis.cattle.io + names: + kind: ClusterScanProfile + plural: clusterscanprofiles + scope: Cluster + versions: + - name: v1 + served: true + storage: true + subresources: + status: {} + schema: + openAPIV3Schema: + properties: + spec: + properties: + benchmarkVersion: + nullable: true + type: string + skipTests: + items: + nullable: true + type: string + nullable: true + type: array + type: object + type: object + additionalPrinterColumns: + - jsonPath: .spec.benchmarkVersion + name: BenchmarkVersion + type: string diff --git a/charts/rancher-cis-benchmark-crd/5.6.0/templates/clusterscanreport.yaml b/charts/rancher-cis-benchmark-crd/5.6.0/templates/clusterscanreport.yaml new file mode 100644 index 0000000000..6e8c0b7de5 --- /dev/null +++ b/charts/rancher-cis-benchmark-crd/5.6.0/templates/clusterscanreport.yaml @@ -0,0 +1,39 @@ +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: clusterscanreports.cis.cattle.io +spec: + group: cis.cattle.io + names: + kind: ClusterScanReport + plural: clusterscanreports + scope: Cluster + versions: + - name: v1 + served: true + storage: true + additionalPrinterColumns: + - jsonPath: .spec.lastRunTimestamp + name: LastRunTimestamp + type: string + - jsonPath: .spec.benchmarkVersion + name: BenchmarkVersion + type: string + subresources: + status: {} + schema: + openAPIV3Schema: + properties: + spec: + properties: + benchmarkVersion: + nullable: true + type: string + lastRunTimestamp: + nullable: true + type: string + reportJSON: + nullable: true + type: string + type: object + type: object \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/Chart.yaml b/charts/rancher-cis-benchmark/5.6.0/Chart.yaml new file mode 100644 index 0000000000..36f60cf35d --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/Chart.yaml @@ -0,0 +1,22 @@ +annotations: + catalog.cattle.io/auto-install: rancher-cis-benchmark-crd=match + catalog.cattle.io/certified: rancher + catalog.cattle.io/display-name: CIS Benchmark + catalog.cattle.io/kube-version: '>= 1.25.0-0 < 1.29.0-0' + catalog.cattle.io/namespace: cis-operator-system + catalog.cattle.io/os: linux + catalog.cattle.io/permits-os: linux,windows + catalog.cattle.io/provides-gvr: cis.cattle.io.clusterscans/v1 + catalog.cattle.io/rancher-version: '>= 2.8.0-0 < 2.9.0-0' + catalog.cattle.io/release-name: rancher-cis-benchmark + catalog.cattle.io/type: cluster-tool + catalog.cattle.io/ui-component: rancher-cis-benchmark +apiVersion: v1 +appVersion: v5.6.0 +description: The cis-operator enables running CIS benchmark security scans on a kubernetes + cluster +icon: https://charts.rancher.io/assets/logos/cis-kube-bench.svg +keywords: +- security +name: rancher-cis-benchmark +version: 5.6.0 diff --git a/charts/rancher-cis-benchmark/5.6.0/README.md b/charts/rancher-cis-benchmark/5.6.0/README.md new file mode 100644 index 0000000000..50beab58ba --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/README.md @@ -0,0 +1,9 @@ +# Rancher CIS Benchmark Chart + +The cis-operator enables running CIS benchmark security scans on a kubernetes cluster and generate compliance reports that can be downloaded. + +# Installation + +``` +helm install rancher-cis-benchmark ./ --create-namespace -n cis-operator-system +``` diff --git a/charts/rancher-cis-benchmark/5.6.0/app-readme.md b/charts/rancher-cis-benchmark/5.6.0/app-readme.md new file mode 100644 index 0000000000..d240859273 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/app-readme.md @@ -0,0 +1,55 @@ +# Rancher CIS Benchmarks + +This chart enables security scanning of the cluster using [CIS (Center for Internet Security) benchmarks](https://www.cisecurity.org/benchmark/kubernetes/). + +For more information on how to use the feature, refer to our [docs](https://ranchermanager.docs.rancher.com/how-to-guides/advanced-user-guides/cis-scan-guides). + +This chart installs the following components: + +- [cis-operator](https://github.com/rancher/cis-operator) - The cis-operator handles launching the [kube-bench](https://github.com/aquasecurity/kube-bench) tool that runs a suite of CIS tests on the nodes of your Kubernetes cluster. After scans finish, the cis-operator generates a compliance report that can be downloaded. +- Scans - A scan is a CRD (`ClusterScan`) that defines when to trigger CIS scans on the cluster based on the defined profile. A report is created after the scan is completed. +- Profiles - A profile is a CRD (`ClusterScanProfile`) that defines the configuration for the CIS scan, which is the benchmark versions to use and any specific tests to skip in that benchmark. This chart installs a few default `ClusterScanProfile` custom resources with no skipped tests, which can immediately be used to launch CIS scans. +- Benchmark Versions - A benchmark version is a CRD (`ClusterScanBenchmark`) that defines the CIS benchmark version to run using kube-bench as well as the valid configuration parameters for that benchmark. This chart installs a few default `ClusterScanBenchmark` custom resources. +- Alerting Resources - Rancher's CIS Benchmark application lets you run a cluster scan on a schedule, and send alerts when scans finish. + - If you want to enable alerts to be delivered when a cluster scan completes, you need to ensure that [Rancher's Monitoring and Alerting](https://rancher.com/docs/rancher/v2.x/en/monitoring-alerting/v2.5/) application is pre-installed and the [Receivers and Routes](https://rancher.com/docs/rancher/v2.x/en/monitoring-alerting/v2.5/configuration/#alertmanager-config) are configured to send out alerts. + - Additionally, you need to set `alerts: true` in the Values YAML while installing or upgrading this chart. + +## CIS Kubernetes Benchmark support + +| Source | Kubernetes distribution | scan profile | Kubernetes versions | +|--------|-------------------------|--------------------------------------------------------------------------------------------------------------------|---------------------| +| CIS | any | [cis-1.7](https://github.com/rancher/security-scan/tree/master/package/cfg/cis-1.7) | v1.25 | +| CIS | any | [cis-1.8](https://github.com/rancher/security-scan/tree/master/package/cfg/cis-1.8) | v1.26+ | +| CIS | rke | [rke-cis-1.7-permissive](https://github.com/rancher/security-scan/tree/master/package/cfg/rke-cis-1.7-permissive) | rke1-v1.25 | +| CIS | rke | [rke-cis-1.7-hardened](https://github.com/rancher/security-scan/tree/master/package/cfg/rke-cis-1.7-hardened) | rke1-v1.25 | +| CIS | rke | [rke-cis-1.8-permissive](https://github.com/rancher/security-scan/tree/master/package/cfg/rke-cis-1.8-permissive) | rke1-v1.26+ | +| CIS | rke | [rke-cis-1.8-hardened](https://github.com/rancher/security-scan/tree/master/package/cfg/rke-cis-1.8-hardened) | rke1-v1.26+ | +| CIS | rke2 | [rke2-cis-1.7-permissive](https://github.com/rancher/security-scan/tree/master/package/cfg/rke2-cis-1.7-permissive)| rke2-v1.25 | +| CIS | rke2 | [rke2-cis-1.7-hardened](https://github.com/rancher/security-scan/tree/master/package/cfg/rke2-cis-1.7-hardened) | rke2-v1.25 | +| CIS | rke2 | [rke2-cis-1.8-permissive](https://github.com/rancher/security-scan/tree/master/package/cfg/rke2-cis-1.8-permissive)| rke2-v1.26+ | +| CIS | rke2 | [rke2-cis-1.8-hardened](https://github.com/rancher/security-scan/tree/master/package/cfg/rke2-cis-1.8-hardened) | rke2-v1.26+ | +| CIS | k3s | [k3s-cis-1.7-permissive](https://github.com/rancher/security-scan/tree/master/package/cfg/k3s-cis-1.7-permissive) | k3s-v1.25 | +| CIS | k3s | [k3s-cis-1.7-hardened](https://github.com/rancher/security-scan/tree/master/package/cfg/k3s-cis-1.7-hardened) | k3s-v1.25 | +| CIS | k3s | [k3s-cis-1.8-permissive](https://github.com/rancher/security-scan/tree/master/package/cfg/k3s-cis-1.8-permissive) | k3s-v1.26+ | +| CIS | k3s | [k3s-cis-1.8-hardened](https://github.com/rancher/security-scan/tree/master/package/cfg/k3s-cis-1.8-hardened) | k3s-v1.26+ | +| CIS | eks | eks-1.2.0 | eks | +| CIS | aks | aks-1.0 | aks | +| CIS | gke | gke-1.2.0 | gke | + +## Upgrading to Kubernetes v1.25+ + +Starting in Kubernetes v1.25, [Pod Security Policies](https://kubernetes.io/docs/concepts/security/pod-security-policy/) have been removed from the Kubernetes API. + +As a result, **before upgrading to Kubernetes v1.25** (or on a fresh install in a Kubernetes v1.25+ cluster), users are expected to perform an in-place upgrade of this chart with `global.cattle.psp.enabled` set to `false` if it has been previously set to `true`. + +> **Note:** +> In this chart release, any previous field that was associated with any PSP resources have been removed in favor of a single global field: `global.cattle.psp.enabled`. + +> **Note:** +> If you upgrade your cluster to Kubernetes v1.25+ before removing PSPs via a `helm upgrade` (even if you manually clean up resources), **it will leave the Helm release in a broken state within the cluster such that further Helm operations will not work (`helm uninstall`, `helm upgrade`, etc.).** +> +> If your charts get stuck in this state, please consult the Rancher docs on how to clean up your Helm release secrets. + +Upon setting `global.cattle.psp.enabled` to false, the chart will remove any PSP resources deployed on its behalf from the cluster. This is the default setting for this chart. + +As a replacement for PSPs, [Pod Security Admission](https://kubernetes.io/docs/concepts/security/pod-security-admission/) should be used. Please consult the Rancher docs for more details on how to configure your chart release namespaces to work with the new Pod Security Admission and apply Pod Security Standards. diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/_helpers.tpl b/charts/rancher-cis-benchmark/5.6.0/templates/_helpers.tpl new file mode 100644 index 0000000000..b7bb000422 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/_helpers.tpl @@ -0,0 +1,27 @@ +{{/* Ensure namespace is set the same everywhere */}} +{{- define "cis.namespace" -}} + {{- .Release.Namespace | default "cis-operator-system" -}} +{{- end -}} + +{{- define "system_default_registry" -}} +{{- if .Values.global.cattle.systemDefaultRegistry -}} +{{- printf "%s/" .Values.global.cattle.systemDefaultRegistry -}} +{{- else -}} +{{- "" -}} +{{- end -}} +{{- end -}} + +{{/* +Windows cluster will add default taint for linux nodes, +add below linux tolerations to workloads could be scheduled to those linux nodes +*/}} +{{- define "linux-node-tolerations" -}} +- key: "cattle.io/os" + value: "linux" + effect: "NoSchedule" + operator: "Equal" +{{- end -}} + +{{- define "linux-node-selector" -}} +kubernetes.io/os: linux +{{- end -}} diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/alertingrule.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/alertingrule.yaml new file mode 100644 index 0000000000..1787c88a07 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/alertingrule.yaml @@ -0,0 +1,14 @@ +{{- if .Values.alerts.enabled -}} +--- +apiVersion: monitoring.coreos.com/v1 +kind: PodMonitor +metadata: + name: rancher-cis-pod-monitor + namespace: {{ template "cis.namespace" . }} +spec: + selector: + matchLabels: + cis.cattle.io/operator: cis-operator + podMetricsEndpoints: + - port: cismetrics +{{- end }} diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-aks-1.0.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-aks-1.0.yaml new file mode 100644 index 0000000000..1ac866253f --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-aks-1.0.yaml @@ -0,0 +1,8 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanBenchmark +metadata: + name: aks-1.0 +spec: + clusterProvider: aks + minKubernetesVersion: "1.15.0" diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-cis-1.7.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-cis-1.7.yaml new file mode 100644 index 0000000000..fa8dfd8eb9 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-cis-1.7.yaml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanBenchmark +metadata: + name: cis-1.7 +spec: + clusterProvider: "" + minKubernetesVersion: "1.25.0" + maxKubernetesVersion: "1.25.x" diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-cis-1.8.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-cis-1.8.yaml new file mode 100644 index 0000000000..f9fa2853e9 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-cis-1.8.yaml @@ -0,0 +1,8 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanBenchmark +metadata: + name: cis-1.8 +spec: + clusterProvider: "" + minKubernetesVersion: "1.26.0" \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-eks-1.2.0.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-eks-1.2.0.yaml new file mode 100644 index 0000000000..c1bdd9ed5e --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-eks-1.2.0.yaml @@ -0,0 +1,8 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanBenchmark +metadata: + name: eks-1.2.0 +spec: + clusterProvider: eks + minKubernetesVersion: "1.15.0" diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-gke-1.2.0.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-gke-1.2.0.yaml new file mode 100644 index 0000000000..106ff7b0de --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-gke-1.2.0.yaml @@ -0,0 +1,8 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanBenchmark +metadata: + name: gke-1.2.0 +spec: + clusterProvider: gke + minKubernetesVersion: "1.15.0" \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-k3s-cis-1.7-hardened.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-k3s-cis-1.7-hardened.yaml new file mode 100644 index 0000000000..6fb369360c --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-k3s-cis-1.7-hardened.yaml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanBenchmark +metadata: + name: k3s-cis-1.7-hardened +spec: + clusterProvider: k3s + minKubernetesVersion: "1.25.0" + maxKubernetesVersion: "1.25.x" diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-k3s-cis-1.7-permissive.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-k3s-cis-1.7-permissive.yaml new file mode 100644 index 0000000000..b556d70fe5 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-k3s-cis-1.7-permissive.yaml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanBenchmark +metadata: + name: k3s-cis-1.7-permissive +spec: + clusterProvider: k3s + minKubernetesVersion: "1.25.0" + maxKubernetesVersion: "1.25.x" diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-k3s-cis-1.8-hardened.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-k3s-cis-1.8-hardened.yaml new file mode 100644 index 0000000000..3f6ac5c159 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-k3s-cis-1.8-hardened.yaml @@ -0,0 +1,8 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanBenchmark +metadata: + name: k3s-cis-1.8-hardened +spec: + clusterProvider: k3s + minKubernetesVersion: "1.26.0" \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-k3s-cis-1.8-permissive.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-k3s-cis-1.8-permissive.yaml new file mode 100644 index 0000000000..26f1cdba98 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-k3s-cis-1.8-permissive.yaml @@ -0,0 +1,8 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanBenchmark +metadata: + name: k3s-cis-1.8-permissive +spec: + clusterProvider: k3s + minKubernetesVersion: "1.26.0" \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke-cis-1.7-hardened.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke-cis-1.7-hardened.yaml new file mode 100644 index 0000000000..39bac7833c --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke-cis-1.7-hardened.yaml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanBenchmark +metadata: + name: rke-cis-1.7-hardened +spec: + clusterProvider: rke + minKubernetesVersion: "1.25.0" + maxKubernetesVersion: "1.25.x" diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke-cis-1.7-permissive.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke-cis-1.7-permissive.yaml new file mode 100644 index 0000000000..2e2f09ac74 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke-cis-1.7-permissive.yaml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanBenchmark +metadata: + name: rke-cis-1.7-permissive +spec: + clusterProvider: rke + minKubernetesVersion: "1.25.0" + maxKubernetesVersion: "1.25.x" diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke-cis-1.8-hardened.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke-cis-1.8-hardened.yaml new file mode 100644 index 0000000000..4dbf8b4522 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke-cis-1.8-hardened.yaml @@ -0,0 +1,8 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanBenchmark +metadata: + name: rke-cis-1.8-hardened +spec: + clusterProvider: rke + minKubernetesVersion: "1.26.0" \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke-cis-1.8-permissive.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke-cis-1.8-permissive.yaml new file mode 100644 index 0000000000..2aa0c85ac4 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke-cis-1.8-permissive.yaml @@ -0,0 +1,8 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanBenchmark +metadata: + name: rke-cis-1.8-permissive +spec: + clusterProvider: rke + minKubernetesVersion: "1.26.0" \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke2-cis-1.7-hardened.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke2-cis-1.7-hardened.yaml new file mode 100644 index 0000000000..6306e9601a --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke2-cis-1.7-hardened.yaml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanBenchmark +metadata: + name: rke2-cis-1.7-hardened +spec: + clusterProvider: rke2 + minKubernetesVersion: "1.25.0" + maxKubernetesVersion: "1.25.x" diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke2-cis-1.7-permissive.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke2-cis-1.7-permissive.yaml new file mode 100644 index 0000000000..76236e11af --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke2-cis-1.7-permissive.yaml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanBenchmark +metadata: + name: rke2-cis-1.7-permissive +spec: + clusterProvider: rke2 + minKubernetesVersion: "1.25.0" + maxKubernetesVersion: "1.25.x" diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke2-cis-1.8-hardened.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke2-cis-1.8-hardened.yaml new file mode 100644 index 0000000000..bf8ee31f7b --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke2-cis-1.8-hardened.yaml @@ -0,0 +1,8 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanBenchmark +metadata: + name: rke2-cis-1.8-hardened +spec: + clusterProvider: rke2 + minKubernetesVersion: "1.26.0" \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke2-cis-1.8-permissive.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke2-cis-1.8-permissive.yaml new file mode 100644 index 0000000000..bd396f9df5 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/benchmark-rke2-cis-1.8-permissive.yaml @@ -0,0 +1,8 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanBenchmark +metadata: + name: rke2-cis-1.8-permissive +spec: + clusterProvider: rke2 + minKubernetesVersion: "1.26.0" \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/cis-roles.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/cis-roles.yaml new file mode 100644 index 0000000000..23c93dc659 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/cis-roles.yaml @@ -0,0 +1,49 @@ +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + name: cis-admin +rules: + - apiGroups: + - cis.cattle.io + resources: + - clusterscanbenchmarks + - clusterscanprofiles + - clusterscans + - clusterscanreports + verbs: ["create", "update", "delete", "patch","get", "watch", "list"] + - apiGroups: + - catalog.cattle.io + resources: ["apps"] + resourceNames: ["rancher-cis-benchmark"] + verbs: ["get", "watch", "list"] + - apiGroups: + - "" + resources: + - configmaps + verbs: + - '*' +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + name: cis-view +rules: + - apiGroups: + - cis.cattle.io + resources: + - clusterscanbenchmarks + - clusterscanprofiles + - clusterscans + - clusterscanreports + verbs: ["get", "watch", "list"] + - apiGroups: + - catalog.cattle.io + resources: ["apps"] + resourceNames: ["rancher-cis-benchmark"] + verbs: ["get", "watch", "list"] + - apiGroups: + - "" + resources: + - configmaps + verbs: ["get", "watch", "list"] diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/configmap.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/configmap.yaml new file mode 100644 index 0000000000..32e6d6e550 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/configmap.yaml @@ -0,0 +1,18 @@ +kind: ConfigMap +apiVersion: v1 +metadata: + name: default-clusterscanprofiles + namespace: {{ template "cis.namespace" . }} +data: + # Default ClusterScanProfiles per cluster provider type + rke: |- + <1.21.0: rke-profile-permissive-1.20 + >=1.21.0: rke-profile-permissive-1.8 + rke2: |- + <1.21.0: rke2-cis-1.20-profile-permissive + >=1.21.0: rke2-cis-1.8-profile-permissive + eks: "eks-profile" + gke: "gke-profile" + aks: "aks-profile" + k3s: "k3s-cis-1.8-profile-permissive" + default: "cis-1.8-profile" \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/deployment.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/deployment.yaml new file mode 100644 index 0000000000..8c9f72f5de --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/deployment.yaml @@ -0,0 +1,61 @@ +apiVersion: apps/v1 +kind: Deployment +metadata: + name: cis-operator + namespace: {{ template "cis.namespace" . }} + labels: + cis.cattle.io/operator: cis-operator +spec: + selector: + matchLabels: + cis.cattle.io/operator: cis-operator + template: + metadata: + labels: + cis.cattle.io/operator: cis-operator + spec: + serviceAccountName: cis-operator-serviceaccount + containers: + - name: cis-operator + image: '{{ template "system_default_registry" . }}{{ .Values.image.cisoperator.repository }}:{{ .Values.image.cisoperator.tag }}' + imagePullPolicy: IfNotPresent + ports: + - name: cismetrics + containerPort: {{ .Values.alerts.metricsPort }} + env: + - name: SECURITY_SCAN_IMAGE + value: {{ template "system_default_registry" . }}{{ .Values.image.securityScan.repository }} + - name: SECURITY_SCAN_IMAGE_TAG + value: {{ .Values.image.securityScan.tag }} + - name: SONOBUOY_IMAGE + value: {{ template "system_default_registry" . }}{{ .Values.image.sonobuoy.repository }} + - name: SONOBUOY_IMAGE_TAG + value: {{ .Values.image.sonobuoy.tag }} + - name: CIS_ALERTS_METRICS_PORT + value: '{{ .Values.alerts.metricsPort }}' + - name: CIS_ALERTS_SEVERITY + value: {{ .Values.alerts.severity }} + - name: CIS_ALERTS_ENABLED + value: {{ .Values.alerts.enabled | default "false" | quote }} + - name: CLUSTER_NAME + value: '{{ .Values.global.cattle.clusterName }}' + - name: CIS_OPERATOR_DEBUG + value: '{{ .Values.image.cisoperator.debug }}' + {{- if .Values.securityScanJob.overrideTolerations }} + - name: SECURITY_SCAN_JOB_TOLERATIONS + value: '{{ .Values.securityScanJob.tolerations | toJson }}' + {{- end }} + resources: + {{- toYaml .Values.resources | nindent 12 }} + nodeSelector: {{ include "linux-node-selector" . | nindent 8 }} +{{- if .Values.nodeSelector }} +{{ toYaml .Values.nodeSelector | indent 8 }} +{{- end }} + tolerations: {{ include "linux-node-tolerations" . | nindent 8 }} +{{- if .Values.tolerations }} +{{ toYaml .Values.tolerations | indent 8 }} +{{- end }} + {{- with .Values.affinity }} + affinity: + {{- toYaml . | nindent 8 }} + {{- end }} diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/network_policy_allow_all.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/network_policy_allow_all.yaml new file mode 100644 index 0000000000..6ed5d645ea --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/network_policy_allow_all.yaml @@ -0,0 +1,15 @@ +--- +apiVersion: networking.k8s.io/v1 +kind: NetworkPolicy +metadata: + name: default-allow-all + namespace: {{ template "cis.namespace" . }} +spec: + podSelector: {} + ingress: + - {} + egress: + - {} + policyTypes: + - Ingress + - Egress diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/patch_default_serviceaccount.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/patch_default_serviceaccount.yaml new file mode 100644 index 0000000000..e78a6bd08a --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/patch_default_serviceaccount.yaml @@ -0,0 +1,29 @@ +--- +apiVersion: batch/v1 +kind: Job +metadata: + name: patch-sa + annotations: + "helm.sh/hook": post-install, post-upgrade + "helm.sh/hook-delete-policy": hook-succeeded, before-hook-creation +spec: + template: + spec: + serviceAccountName: cis-operator-serviceaccount + nodeSelector: {{ include "linux-node-selector" . | nindent 8 }} +{{- if .Values.nodeSelector }} +{{ toYaml .Values.nodeSelector | indent 8 }} +{{- end }} + tolerations: {{ include "linux-node-tolerations" . | nindent 8 }} +{{- if .Values.tolerations }} +{{ toYaml .Values.tolerations | indent 8 }} +{{- end }} + restartPolicy: Never + containers: + - name: sa + image: "{{ template "system_default_registry" . }}{{ .Values.global.kubectl.repository }}:{{ .Values.global.kubectl.tag }}" + imagePullPolicy: {{ .Values.global.imagePullPolicy }} + command: ["kubectl", "patch", "serviceaccount", "default", "-p", "{\"automountServiceAccountToken\": false}"] + args: ["-n", {{ template "cis.namespace" . }}] + + backoffLimit: 1 diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/psp.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/psp.yaml new file mode 100644 index 0000000000..9b8a5995ee --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/psp.yaml @@ -0,0 +1,59 @@ +{{- if .Values.global.cattle.psp.enabled }} +apiVersion: policy/v1beta1 +kind: PodSecurityPolicy +metadata: + name: cis-psp +spec: + allowPrivilegeEscalation: true + allowedCapabilities: + - '*' + fsGroup: + rule: RunAsAny + hostIPC: true + hostNetwork: true + hostPID: true + hostPorts: + - max: 65535 + min: 0 + privileged: true + runAsUser: + rule: RunAsAny + seLinux: + rule: RunAsAny + supplementalGroups: + rule: RunAsAny + volumes: + - '*' +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: cis-psp-role + namespace: {{ template "cis.namespace" . }} +rules: +- apiGroups: + - policy + resourceNames: + - cis-psp + resources: + - podsecuritypolicies + verbs: + - use +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: cis-psp-rolebinding + namespace: {{ template "cis.namespace" . }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: cis-psp-role +subjects: +- kind: ServiceAccount + name: cis-serviceaccount + namespace: {{ template "cis.namespace" . }} +- kind: ServiceAccount + name: cis-operator-serviceaccount + namespace: {{ template "cis.namespace" . }} +{{- end }} diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/rbac.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/rbac.yaml new file mode 100644 index 0000000000..33fb93f04c --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/rbac.yaml @@ -0,0 +1,219 @@ +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + labels: + app.kubernetes.io/name: rancher-cis-benchmark + app.kubernetes.io/instance: release-name + name: cis-operator-clusterrole +rules: +- apiGroups: + - "cis.cattle.io" + resources: + - "*" + verbs: + - "*" +- apiGroups: + - "" + resources: + - "pods" + - "services" + - "configmaps" + - "nodes" + - "serviceaccounts" + verbs: + - "get" + - "list" + - "create" + - "update" + - "watch" + - "patch" +- apiGroups: + - "rbac.authorization.k8s.io" + resources: + - "rolebindings" + - "clusterrolebindings" + - "clusterroles" + verbs: + - "get" + - "list" +- apiGroups: + - "batch" + resources: + - "jobs" + verbs: + - "list" + - "create" + - "patch" + - "update" + - "watch" +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + labels: + app.kubernetes.io/name: rancher-cis-benchmark + app.kubernetes.io/instance: release-name + name: cis-scan-ns +rules: +{{- if .Values.global.cattle.psp.enabled }} +- apiGroups: + - "*" + resources: + - "podsecuritypolicies" + verbs: + - "get" + - "list" + - "watch" +{{- end }} +- apiGroups: + - "" + resources: + - "namespaces" + - "nodes" + - "pods" + - "serviceaccounts" + - "services" + - "replicationcontrollers" + verbs: + - "get" + - "list" + - "watch" +- apiGroups: + - "rbac.authorization.k8s.io" + resources: + - "rolebindings" + - "clusterrolebindings" + - "clusterroles" + verbs: + - "get" + - "list" +- apiGroups: + - "batch" + resources: + - "jobs" + - "cronjobs" + verbs: + - "list" +- apiGroups: + - "apps" + resources: + - "daemonsets" + - "deployments" + - "replicasets" + - "statefulsets" + verbs: + - "list" +- apiGroups: + - "autoscaling" + resources: + - "horizontalpodautoscalers" + verbs: + - "list" +- apiGroups: + - "networking.k8s.io" + resources: + - "networkpolicies" + verbs: + - "get" + - "list" + - "watch" +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: cis-operator-role + labels: + app.kubernetes.io/name: rancher-cis-benchmark + app.kubernetes.io/instance: release-name + namespace: {{ template "cis.namespace" . }} +rules: +- apiGroups: + - "" + resources: + - "services" + verbs: + - "watch" + - "list" + - "get" + - "patch" +- apiGroups: + - "batch" + resources: + - "jobs" + verbs: + - "watch" + - "list" + - "get" + - "delete" +- apiGroups: + - "" + resources: + - "configmaps" + - "pods" + - "secrets" + verbs: + - "*" +- apiGroups: + - "apps" + resources: + - "daemonsets" + verbs: + - "*" +- apiGroups: + - monitoring.coreos.com + resources: + - prometheusrules + verbs: + - create +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + labels: + app.kubernetes.io/name: rancher-cis-benchmark + app.kubernetes.io/instance: release-name + name: cis-operator-clusterrolebinding +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: cis-operator-clusterrole +subjects: +- kind: ServiceAccount + name: cis-operator-serviceaccount + namespace: {{ template "cis.namespace" . }} +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: cis-scan-ns + labels: + app.kubernetes.io/name: rancher-cis-benchmark + app.kubernetes.io/instance: release-name +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: cis-scan-ns +subjects: +- kind: ServiceAccount + name: cis-serviceaccount + namespace: {{ template "cis.namespace" . }} +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + labels: + app.kubernetes.io/name: rancher-cis-benchmark + app.kubernetes.io/instance: release-name + name: cis-operator-rolebinding + namespace: {{ template "cis.namespace" . }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: cis-operator-role +subjects: +- kind: ServiceAccount + name: cis-serviceaccount + namespace: {{ template "cis.namespace" . }} +- kind: ServiceAccount + name: cis-operator-serviceaccount + namespace: {{ template "cis.namespace" . }} diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-cis-1.7.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-cis-1.7.yaml new file mode 100644 index 0000000000..edac79e2a3 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-cis-1.7.yaml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanProfile +metadata: + name: cis-1.7-profile + annotations: + clusterscanprofile.cis.cattle.io/builtin: "true" +spec: + benchmarkVersion: cis-1.7 \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-cis-1.8.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-cis-1.8.yaml new file mode 100644 index 0000000000..bf68d6ec17 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-cis-1.8.yaml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanProfile +metadata: + name: cis-1.8-profile + annotations: + clusterscanprofile.cis.cattle.io/builtin: "true" +spec: + benchmarkVersion: cis-1.8 \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-k3s-cis-1.7-hardened.yml b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-k3s-cis-1.7-hardened.yml new file mode 100644 index 0000000000..51fd6baf00 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-k3s-cis-1.7-hardened.yml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanProfile +metadata: + name: k3s-cis-1.7-profile-hardened + annotations: + clusterscanprofile.cis.cattle.io/builtin: "true" +spec: + benchmarkVersion: k3s-cis-1.7-hardened \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-k3s-cis-1.7-permissive.yml b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-k3s-cis-1.7-permissive.yml new file mode 100644 index 0000000000..0c1baf774a --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-k3s-cis-1.7-permissive.yml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanProfile +metadata: + name: k3s-cis-1.7-profile-permissive + annotations: + clusterscanprofile.cis.cattle.io/builtin: "true" +spec: + benchmarkVersion: k3s-cis-1.7-permissive \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-k3s-cis-1.8-hardened.yml b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-k3s-cis-1.8-hardened.yml new file mode 100644 index 0000000000..8a78b2a964 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-k3s-cis-1.8-hardened.yml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanProfile +metadata: + name: k3s-cis-1.8-profile-hardened + annotations: + clusterscanprofile.cis.cattle.io/builtin: "true" +spec: + benchmarkVersion: k3s-cis-1.8-hardened \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-k3s-cis-1.8-permissive.yml b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-k3s-cis-1.8-permissive.yml new file mode 100644 index 0000000000..3bbf94335c --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-k3s-cis-1.8-permissive.yml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanProfile +metadata: + name: k3s-cis-1.8-profile-permissive + annotations: + clusterscanprofile.cis.cattle.io/builtin: "true" +spec: + benchmarkVersion: k3s-cis-1.8-permissive \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke-1.7-hardened.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke-1.7-hardened.yaml new file mode 100644 index 0000000000..e488eaedf0 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke-1.7-hardened.yaml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanProfile +metadata: + name: rke-profile-hardened-1.7 + annotations: + clusterscanprofile.cis.cattle.io/builtin: "true" +spec: + benchmarkVersion: rke-cis-1.7-hardened \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke-1.7-permissive.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke-1.7-permissive.yaml new file mode 100644 index 0000000000..8e6df750d6 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke-1.7-permissive.yaml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanProfile +metadata: + name: rke-profile-permissive-1.7 + annotations: + clusterscanprofile.cis.cattle.io/builtin: "true" +spec: + benchmarkVersion: rke-cis-1.7-permissive \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke-1.8-hardened.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke-1.8-hardened.yaml new file mode 100644 index 0000000000..24a1250c06 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke-1.8-hardened.yaml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanProfile +metadata: + name: rke-profile-hardened-1.8 + annotations: + clusterscanprofile.cis.cattle.io/builtin: "true" +spec: + benchmarkVersion: rke-cis-1.8-hardened \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke-1.8-permissive.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke-1.8-permissive.yaml new file mode 100644 index 0000000000..4472913c64 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke-1.8-permissive.yaml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanProfile +metadata: + name: rke-profile-permissive-1.8 + annotations: + clusterscanprofile.cis.cattle.io/builtin: "true" +spec: + benchmarkVersion: rke-cis-1.8-permissive \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke2-cis-1.7-hardened.yml b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke2-cis-1.7-hardened.yml new file mode 100644 index 0000000000..9e90d769ac --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke2-cis-1.7-hardened.yml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanProfile +metadata: + name: rke2-cis-1.7-profile-hardened + annotations: + clusterscanprofile.cis.cattle.io/builtin: "true" +spec: + benchmarkVersion: rke2-cis-1.7-hardened \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke2-cis-1.7-permissive.yml b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke2-cis-1.7-permissive.yml new file mode 100644 index 0000000000..4363d3afab --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke2-cis-1.7-permissive.yml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanProfile +metadata: + name: rke2-cis-1.7-profile-permissive + annotations: + clusterscanprofile.cis.cattle.io/builtin: "true" +spec: + benchmarkVersion: rke2-cis-1.7-permissive \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke2-cis-1.8-hardened.yml b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke2-cis-1.8-hardened.yml new file mode 100644 index 0000000000..05fc5d8d33 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke2-cis-1.8-hardened.yml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanProfile +metadata: + name: rke2-cis-1.8-profile-hardened + annotations: + clusterscanprofile.cis.cattle.io/builtin: "true" +spec: + benchmarkVersion: rke2-cis-1.8-hardened \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke2-cis-1.8-permissive.yml b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke2-cis-1.8-permissive.yml new file mode 100644 index 0000000000..a83409c02e --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofile-rke2-cis-1.8-permissive.yml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanProfile +metadata: + name: rke2-cis-1.8-profile-permissive + annotations: + clusterscanprofile.cis.cattle.io/builtin: "true" +spec: + benchmarkVersion: rke2-cis-1.8-permissive \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/scanprofileaks.yml b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofileaks.yml new file mode 100644 index 0000000000..ea7b25b404 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofileaks.yml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanProfile +metadata: + name: aks-profile + annotations: + clusterscanprofile.cis.cattle.io/builtin: "true" +spec: + benchmarkVersion: aks-1.0 \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/scanprofileeks.yml b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofileeks.yml new file mode 100644 index 0000000000..de4500acd9 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofileeks.yml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanProfile +metadata: + name: eks-profile + annotations: + clusterscanprofile.cis.cattle.io/builtin: "true" +spec: + benchmarkVersion: eks-1.2.0 \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/scanprofilegke.yml b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofilegke.yml new file mode 100644 index 0000000000..3e5e2439ac --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/scanprofilegke.yml @@ -0,0 +1,9 @@ +--- +apiVersion: cis.cattle.io/v1 +kind: ClusterScanProfile +metadata: + name: gke-profile + annotations: + clusterscanprofile.cis.cattle.io/builtin: "true" +spec: + benchmarkVersion: gke-1.2.0 \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/serviceaccount.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/serviceaccount.yaml new file mode 100644 index 0000000000..ec48ec6224 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/serviceaccount.yaml @@ -0,0 +1,14 @@ +apiVersion: v1 +kind: ServiceAccount +metadata: + namespace: {{ template "cis.namespace" . }} + name: cis-operator-serviceaccount +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + namespace: {{ template "cis.namespace" . }} + labels: + app.kubernetes.io/name: rancher-cis-benchmark + app.kubernetes.io/instance: release-name + name: cis-serviceaccount diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/validate-install-crd.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/validate-install-crd.yaml new file mode 100644 index 0000000000..562295791b --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/validate-install-crd.yaml @@ -0,0 +1,17 @@ +#{{- if gt (len (lookup "rbac.authorization.k8s.io/v1" "ClusterRole" "" "")) 0 -}} +# {{- $found := dict -}} +# {{- set $found "cis.cattle.io/v1/ClusterScan" false -}} +# {{- set $found "cis.cattle.io/v1/ClusterScanBenchmark" false -}} +# {{- set $found "cis.cattle.io/v1/ClusterScanProfile" false -}} +# {{- set $found "cis.cattle.io/v1/ClusterScanReport" false -}} +# {{- range .Capabilities.APIVersions -}} +# {{- if hasKey $found (toString .) -}} +# {{- set $found (toString .) true -}} +# {{- end -}} +# {{- end -}} +# {{- range $_, $exists := $found -}} +# {{- if (eq $exists false) -}} +# {{- required "Required CRDs are missing. Please install the corresponding CRD chart before installing this chart." "" -}} +# {{- end -}} +# {{- end -}} +#{{- end -}} \ No newline at end of file diff --git a/charts/rancher-cis-benchmark/5.6.0/templates/validate-psp-install.yaml b/charts/rancher-cis-benchmark/5.6.0/templates/validate-psp-install.yaml new file mode 100644 index 0000000000..a30c59d3b7 --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/templates/validate-psp-install.yaml @@ -0,0 +1,7 @@ +#{{- if gt (len (lookup "rbac.authorization.k8s.io/v1" "ClusterRole" "" "")) 0 -}} +#{{- if .Values.global.cattle.psp.enabled }} +#{{- if not (.Capabilities.APIVersions.Has "policy/v1beta1/PodSecurityPolicy") }} +#{{- fail "The target cluster does not have the PodSecurityPolicy API resource. Please disable PSPs in this chart before proceeding." -}} +#{{- end }} +#{{- end }} +#{{- end }} diff --git a/charts/rancher-cis-benchmark/5.6.0/values.yaml b/charts/rancher-cis-benchmark/5.6.0/values.yaml new file mode 100644 index 0000000000..550b652a9c --- /dev/null +++ b/charts/rancher-cis-benchmark/5.6.0/values.yaml @@ -0,0 +1,55 @@ +# Default values for rancher-cis-benchmark. +# This is a YAML-formatted file. +# Declare variables to be passed into your templates. + +image: + cisoperator: + repository: rancher/cis-operator + tag: v1.1.0 + securityScan: + repository: rancher/security-scan + tag: v0.3.0 + sonobuoy: + repository: rancher/mirrored-sonobuoy-sonobuoy + tag: v0.57.2 + +resources: {} + # We usually recommend not to specify default resources and to leave this as a conscious + # choice for the user. This also increases chances charts run on environments with little + # resources, such as Minikube. If you do want to specify resources, uncomment the following + # lines, adjust them as necessary, and remove the curly braces after 'resources:'. + # limits: + # cpu: 100m + # memory: 128Mi + # requests: + # cpu: 100m + # memory: 128Mi + +## Node labels for pod assignment +## Ref: https://kubernetes.io/docs/user-guide/node-selection/ +## +nodeSelector: {} + +## List of node taints to tolerate (requires Kubernetes >= 1.6) +tolerations: [] + +securityScanJob: + overrideTolerations: false + tolerations: [] + +affinity: {} + +global: + cattle: + systemDefaultRegistry: "" + clusterName: "" + psp: + enabled: false + kubectl: + repository: rancher/kubectl + tag: v1.28.12 + +alerts: + enabled: false + severity: warning + metricsPort: 8080 diff --git a/charts/rancher-webhook/103.0.12+up0.4.13/Chart.yaml b/charts/rancher-webhook/103.0.12+up0.4.13/Chart.yaml new file mode 100644 index 0000000000..f1e2ec31d0 --- /dev/null +++ b/charts/rancher-webhook/103.0.12+up0.4.13/Chart.yaml @@ -0,0 +1,14 @@ +annotations: + catalog.cattle.io/certified: rancher + catalog.cattle.io/hidden: "true" + catalog.cattle.io/kube-version: '>= 1.23.0-0 < 1.29.0-0' + catalog.cattle.io/namespace: cattle-system + catalog.cattle.io/os: linux + catalog.cattle.io/permits-os: linux,windows + catalog.cattle.io/rancher-version: '>= 2.8.0-0 < 2.9.0-0' + catalog.cattle.io/release-name: rancher-webhook +apiVersion: v2 +appVersion: 0.4.13 +description: ValidatingAdmissionWebhook for Rancher types +name: rancher-webhook +version: 103.0.12+up0.4.13 diff --git a/charts/rancher-webhook/103.0.12+up0.4.13/templates/_helpers.tpl b/charts/rancher-webhook/103.0.12+up0.4.13/templates/_helpers.tpl new file mode 100644 index 0000000000..c37a65c6f3 --- /dev/null +++ b/charts/rancher-webhook/103.0.12+up0.4.13/templates/_helpers.tpl @@ -0,0 +1,22 @@ +{{- define "system_default_registry" -}} +{{- if .Values.global.cattle.systemDefaultRegistry -}} +{{- printf "%s/" .Values.global.cattle.systemDefaultRegistry -}} +{{- else -}} +{{- "" -}} +{{- end -}} +{{- end -}} + +{{- define "rancher-webhook.labels" -}} +app: rancher-webhook +{{- end }} + +{{- define "linux-node-tolerations" -}} +- key: "cattle.io/os" + value: "linux" + effect: "NoSchedule" + operator: "Equal" +{{- end -}} + +{{- define "linux-node-selector" -}} +kubernetes.io/os: linux +{{- end -}} \ No newline at end of file diff --git a/charts/rancher-webhook/103.0.12+up0.4.13/templates/deployment.yaml b/charts/rancher-webhook/103.0.12+up0.4.13/templates/deployment.yaml new file mode 100644 index 0000000000..b8a7201dac --- /dev/null +++ b/charts/rancher-webhook/103.0.12+up0.4.13/templates/deployment.yaml @@ -0,0 +1,82 @@ +{{- $auth := .Values.auth | default dict }} +apiVersion: apps/v1 +kind: Deployment +metadata: + name: rancher-webhook +spec: + selector: + matchLabels: + app: rancher-webhook + template: + metadata: + labels: + app: rancher-webhook + spec: + {{- if $auth.clientCA }} + volumes: + - name: client-ca + secret: + secretName: client-ca + {{- end }} + {{- if .Values.global.hostNetwork }} + hostNetwork: true + {{- end }} + nodeSelector: {{ include "linux-node-selector" . | nindent 8 }} + {{- if .Values.nodeSelector }} +{{ toYaml .Values.nodeSelector | indent 8 }} + {{- end }} + tolerations: {{ include "linux-node-tolerations" . | nindent 6 }} + {{- if .Values.tolerations }} +{{ toYaml .Values.tolerations | indent 6 }} + {{- end }} + containers: + - env: + - name: STAMP + value: "{{.Values.stamp}}" + - name: ENABLE_MCM + value: "{{.Values.mcm.enabled}}" + - name: CATTLE_PORT + value: {{.Values.port | default 9443 | quote}} + - name: NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + {{- if $auth.allowedCNs }} + - name: ALLOWED_CNS + value: '{{ join "," $auth.allowedCNs }}' + {{- end }} + image: '{{ template "system_default_registry" . }}{{ .Values.image.repository }}:{{ .Values.image.tag }}' + name: rancher-webhook + imagePullPolicy: "{{ .Values.image.imagePullPolicy }}" + ports: + - name: https + containerPort: {{ .Values.port | default 9443 }} + startupProbe: + httpGet: + path: "/healthz" + port: "https" + scheme: "HTTPS" + failureThreshold: 60 + periodSeconds: 5 + livenessProbe: + httpGet: + path: "/healthz" + port: "https" + scheme: "HTTPS" + periodSeconds: 5 + {{- if $auth.clientCA }} + volumeMounts: + - name: client-ca + mountPath: /tmp/k8s-webhook-server/client-ca + readOnly: true + {{- end }} + {{- if .Values.capNetBindService }} + securityContext: + capabilities: + add: + - NET_BIND_SERVICE + {{- end }} + serviceAccountName: rancher-webhook + {{- if .Values.priorityClassName }} + priorityClassName: "{{.Values.priorityClassName}}" + {{- end }} diff --git a/charts/rancher-webhook/103.0.12+up0.4.13/templates/rbac.yaml b/charts/rancher-webhook/103.0.12+up0.4.13/templates/rbac.yaml new file mode 100644 index 0000000000..f4364995c0 --- /dev/null +++ b/charts/rancher-webhook/103.0.12+up0.4.13/templates/rbac.yaml @@ -0,0 +1,12 @@ +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: rancher-webhook +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: cluster-admin +subjects: +- kind: ServiceAccount + name: rancher-webhook + namespace: {{.Release.Namespace}} \ No newline at end of file diff --git a/charts/rancher-webhook/103.0.12+up0.4.13/templates/secret.yaml b/charts/rancher-webhook/103.0.12+up0.4.13/templates/secret.yaml new file mode 100644 index 0000000000..9fd331dc1e --- /dev/null +++ b/charts/rancher-webhook/103.0.12+up0.4.13/templates/secret.yaml @@ -0,0 +1,11 @@ +{{- $auth := .Values.auth | default dict }} +{{- if $auth.clientCA }} +apiVersion: v1 +data: + ca.crt: {{ $auth.clientCA }} +kind: Secret +metadata: + name: client-ca + namespace: cattle-system +type: Opaque +{{- end }} diff --git a/charts/rancher-webhook/103.0.12+up0.4.13/templates/service.yaml b/charts/rancher-webhook/103.0.12+up0.4.13/templates/service.yaml new file mode 100644 index 0000000000..220afebeae --- /dev/null +++ b/charts/rancher-webhook/103.0.12+up0.4.13/templates/service.yaml @@ -0,0 +1,13 @@ +kind: Service +apiVersion: v1 +metadata: + name: rancher-webhook + namespace: cattle-system +spec: + ports: + - port: 443 + targetPort: {{ .Values.port | default 9443 }} + protocol: TCP + name: https + selector: + app: rancher-webhook diff --git a/charts/rancher-webhook/103.0.12+up0.4.13/templates/serviceaccount.yaml b/charts/rancher-webhook/103.0.12+up0.4.13/templates/serviceaccount.yaml new file mode 100644 index 0000000000..9e7ad7e1fe --- /dev/null +++ b/charts/rancher-webhook/103.0.12+up0.4.13/templates/serviceaccount.yaml @@ -0,0 +1,11 @@ +apiVersion: v1 +kind: ServiceAccount +metadata: + name: rancher-webhook +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: rancher-webhook-sudo + annotations: + cattle.io/description: "SA which can be impersonated to bypass rancher-webhook validation" \ No newline at end of file diff --git a/charts/rancher-webhook/103.0.12+up0.4.13/templates/webhook.yaml b/charts/rancher-webhook/103.0.12+up0.4.13/templates/webhook.yaml new file mode 100644 index 0000000000..53a0687b6f --- /dev/null +++ b/charts/rancher-webhook/103.0.12+up0.4.13/templates/webhook.yaml @@ -0,0 +1,9 @@ +apiVersion: admissionregistration.k8s.io/v1 +kind: ValidatingWebhookConfiguration +metadata: + name: rancher.cattle.io +--- +apiVersion: admissionregistration.k8s.io/v1 +kind: MutatingWebhookConfiguration +metadata: + name: rancher.cattle.io diff --git a/charts/rancher-webhook/103.0.12+up0.4.13/tests/README.md b/charts/rancher-webhook/103.0.12+up0.4.13/tests/README.md new file mode 100644 index 0000000000..6d3059a005 --- /dev/null +++ b/charts/rancher-webhook/103.0.12+up0.4.13/tests/README.md @@ -0,0 +1,16 @@ + +## local dev testing instructions + +Option 1: Full chart CI run with a live cluster + +```bash +./scripts/charts/ci +``` + +Option 2: Test runs against the chart only + +```bash +# install the helm plugin first - helm plugin install https://github.com/helm-unittest/helm-unittest.git +bash dev-scripts/helm-unittest.sh +``` + diff --git a/charts/rancher-webhook/103.0.12+up0.4.13/tests/deployment_test.yaml b/charts/rancher-webhook/103.0.12+up0.4.13/tests/deployment_test.yaml new file mode 100644 index 0000000000..bbd6e30444 --- /dev/null +++ b/charts/rancher-webhook/103.0.12+up0.4.13/tests/deployment_test.yaml @@ -0,0 +1,73 @@ +suite: Test Deployment +templates: + - deployment.yaml + +tests: + - it: should set webhook default port values + asserts: + - equal: + path: spec.template.spec.containers[0].ports[0].containerPort + value: 9443 + - contains: + path: spec.template.spec.containers[0].env + content: + name: CATTLE_PORT + value: "9443" + + - it: should set updated webhook port + set: + port: 2319 + asserts: + - equal: + path: spec.template.spec.containers[0].ports[0].containerPort + value: 2319 + - contains: + path: spec.template.spec.containers[0].env + content: + name: CATTLE_PORT + value: "2319" + + - it: should not set capabilities by default. + asserts: + - isNull: + path: spec.template.spec.containers[0].securityContext + + - it: should set net capabilities when capNetBindService is true. + set: + capNetBindService: true + asserts: + - contains: + path: spec.template.spec.containers[0].securityContext.capabilities.add + content: NET_BIND_SERVICE + + - it: should not set volumes or volumeMounts by default + asserts: + - isNull: + path: spec.template.spec.volumes + - isNull: + path: spec.template.spec.volumeMounts + + - it: should set CA fields when CA options are set + set: + auth.clientCA: base64-encoded-cert + auth.allowedCNs: + - kube-apiserver + - joe + asserts: + - contains: + path: spec.template.spec.volumes + content: + name: client-ca + secret: + secretName: client-ca + - contains: + path: spec.template.spec.containers[0].volumeMounts + content: + name: client-ca + mountPath: /tmp/k8s-webhook-server/client-ca + readOnly: true + - contains: + path: spec.template.spec.containers[0].env + content: + name: ALLOWED_CNS + value: kube-apiserver,joe diff --git a/charts/rancher-webhook/103.0.12+up0.4.13/tests/service_test.yaml b/charts/rancher-webhook/103.0.12+up0.4.13/tests/service_test.yaml new file mode 100644 index 0000000000..03172ad033 --- /dev/null +++ b/charts/rancher-webhook/103.0.12+up0.4.13/tests/service_test.yaml @@ -0,0 +1,18 @@ +suite: Test Service +templates: + - service.yaml + +tests: + - it: should set webhook default port values + asserts: + - equal: + path: spec.ports[0].targetPort + value: 9443 + + - it: should set updated target port + set: + port: 2319 + asserts: + - equal: + path: spec.ports[0].targetPort + value: 2319 diff --git a/charts/rancher-webhook/103.0.12+up0.4.13/values.yaml b/charts/rancher-webhook/103.0.12+up0.4.13/values.yaml new file mode 100644 index 0000000000..230a7d4dbc --- /dev/null +++ b/charts/rancher-webhook/103.0.12+up0.4.13/values.yaml @@ -0,0 +1,30 @@ +image: + repository: rancher/rancher-webhook + tag: v0.4.13 + imagePullPolicy: IfNotPresent + +global: + cattle: + systemDefaultRegistry: "" + hostNetwork: false + +mcm: + enabled: true + +# tolerations for the webhook deployment. See https://kubernetes.io/docs/concepts/scheduling-eviction/taint-and-toleration/ for more info +tolerations: [] +nodeSelector: {} + +## PriorityClassName assigned to deployment. +priorityClassName: "" + +# port assigns which port to use when running rancher-webhook +port: 9443 + +# Parameters for authenticating the kube-apiserver. +auth: + # CA for authenticating kube-apiserver client certs. If empty, client connections will not be authenticated. + # Must be base64-encoded. + clientCA: "" + # Allowlist of CNs for kube-apiserver client certs. If empty, any cert signed by the CA provided in clientCA will be accepted. + allowedCNs: [] diff --git a/charts/ui-plugin-operator-crd/103.0.3+up0.2.2/Chart.yaml b/charts/ui-plugin-operator-crd/103.0.3+up0.2.2/Chart.yaml new file mode 100644 index 0000000000..4ed9d53942 --- /dev/null +++ b/charts/ui-plugin-operator-crd/103.0.3+up0.2.2/Chart.yaml @@ -0,0 +1,10 @@ +annotations: + catalog.cattle.io/certified: rancher + catalog.cattle.io/hidden: "true" + catalog.cattle.io/namespace: cattle-ui-plugin-system + catalog.cattle.io/release-name: ui-plugin-operator-crd +apiVersion: v1 +description: Installs the CRDs for ui-plugin-operator. +name: ui-plugin-operator-crd +type: application +version: 103.0.3+up0.2.2 diff --git a/charts/ui-plugin-operator-crd/103.0.3+up0.2.2/README.md b/charts/ui-plugin-operator-crd/103.0.3+up0.2.2/README.md new file mode 100644 index 0000000000..a68add8280 --- /dev/null +++ b/charts/ui-plugin-operator-crd/103.0.3+up0.2.2/README.md @@ -0,0 +1,2 @@ +# ui-plugin-operator-crd +A Rancher chart that installs the CRDs used by ui-plugin-operator. diff --git a/charts/ui-plugin-operator-crd/103.0.3+up0.2.2/templates/crds.yaml b/charts/ui-plugin-operator-crd/103.0.3+up0.2.2/templates/crds.yaml new file mode 100644 index 0000000000..18b71d5b01 --- /dev/null +++ b/charts/ui-plugin-operator-crd/103.0.3+up0.2.2/templates/crds.yaml @@ -0,0 +1,61 @@ +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: uiplugins.catalog.cattle.io +spec: + group: catalog.cattle.io + names: + kind: UIPlugin + plural: uiplugins + singular: uiplugin + preserveUnknownFields: false + scope: Namespaced + versions: + - additionalPrinterColumns: + - jsonPath: .spec.release.name + name: Plugin Name + type: string + - jsonPath: .status.version + name: Version + type: string + - jsonPath: .status.state + name: State + type: string + name: v1 + schema: + openAPIV3Schema: + properties: + spec: + properties: + plugin: + properties: + endpoint: + nullable: true + type: string + metadata: + additionalProperties: + nullable: true + type: string + nullable: true + type: object + name: + nullable: true + type: string + noCache: + type: boolean + version: + nullable: true + type: string + type: object + type: object + status: + properties: + cacheState: + nullable: true + type: string + type: object + type: object + served: true + storage: true + subresources: + status: {} diff --git a/charts/ui-plugin-operator/103.0.3+up0.2.2/Chart.yaml b/charts/ui-plugin-operator/103.0.3+up0.2.2/Chart.yaml new file mode 100644 index 0000000000..a3f9910c5b --- /dev/null +++ b/charts/ui-plugin-operator/103.0.3+up0.2.2/Chart.yaml @@ -0,0 +1,19 @@ +annotations: + catalog.cattle.io/auto-install: ui-plugin-operator-crd=match + catalog.cattle.io/certified: rancher + catalog.cattle.io/display-name: UI Plugin Operator + catalog.cattle.io/kube-version: '>= 1.16.0-0 < 1.29.0-0' + catalog.cattle.io/namespace: cattle-ui-plugin-system + catalog.cattle.io/os: linux + catalog.cattle.io/permits-os: linux, windows + catalog.cattle.io/rancher-version: '>= 2.8.0-0 < 2.9.0-0' + catalog.cattle.io/release-name: ui-plugin-operator +apiVersion: v1 +appVersion: 0.1.3 +description: A UI Plugin Operator Chart for plugin management in Rancher +keywords: +- applications +- infrastructure +name: ui-plugin-operator +type: application +version: 103.0.3+up0.2.2 diff --git a/charts/ui-plugin-operator/103.0.3+up0.2.2/app-readme.md b/charts/ui-plugin-operator/103.0.3+up0.2.2/app-readme.md new file mode 100644 index 0000000000..3473271768 --- /dev/null +++ b/charts/ui-plugin-operator/103.0.3+up0.2.2/app-readme.md @@ -0,0 +1,21 @@ +# Rancher UI Plugin Operator + +This chart works together with the Rancher UI extensions feature to enable the ability to install UI extensions in your cluster. + +## Upgrading to Kubernetes v1.25+ + ​ +Starting in Kubernetes v1.25, [Pod Security Policies](https://kubernetes.io/docs/concepts/security/pod-security-policy/) have been removed from the Kubernetes API. + ​ +As a result, **before upgrading to Kubernetes v1.25** (or on a fresh install in a Kubernetes v1.25+ cluster), users are expected to perform an in-place upgrade of this chart with `global.cattle.psp.enabled` set to `false` if it has been previously set to `true`. +​ +> **Note:** +> In this chart release, any previous field that was associated with any PSP resources have been removed in favor of a single global field: `global.cattle.psp.enabled`. + ​ +> **Note:** +> If you upgrade your cluster to Kubernetes v1.25+ before removing PSPs via a `helm upgrade` (even if you manually clean up resources), **it will leave the Helm release in a broken state within the cluster such that further Helm operations will not work (`helm uninstall`, `helm upgrade`, etc.).** +> +> If your charts get stuck in this state, please consult the Rancher docs on how to clean up your Helm release secrets. +​ +Upon setting `global.cattle.psp.enabled` to false, the chart will remove any PSP resources deployed on its behalf from the cluster. This is the default setting for this chart. +​ +As a replacement for PSPs, [Pod Security Admission](https://kubernetes.io/docs/concepts/security/pod-security-admission/) should be used. Please consult the Rancher docs for more details on how to configure your chart release namespaces to work with the new Pod Security Admission and apply Pod Security Standards. diff --git a/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/_helpers.tpl b/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/_helpers.tpl new file mode 100644 index 0000000000..0d41d827fc --- /dev/null +++ b/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/_helpers.tpl @@ -0,0 +1,89 @@ +{{/* +Expand the name of the chart. +*/}} +{{- define "ui-plugin-operator.name" -}} +{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" }} +{{- end }} + +{{/* +Create a default fully qualified app name. +We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). +If release name contains chart name it will be used as a full name. +*/}} +{{- define "ui-plugin-operator.fullname" -}} +{{- if .Values.fullnameOverride }} +{{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" }} +{{- else }} +{{- $name := default .Chart.Name .Values.nameOverride }} +{{- if contains $name .Release.Name }} +{{- .Release.Name | trunc 63 | trimSuffix "-" }} +{{- else }} +{{- printf "%s-%s" .Release.Name $name | trunc 63 | trimSuffix "-" }} +{{- end }} +{{- end }} +{{- end }} + +{{/* +Create chart name and version as used by the chart label. +*/}} +{{- define "ui-plugin-operator.chart" -}} +{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" }} +{{- end }} + +{{/* +Common labels +*/}} +{{- define "ui-plugin-operator.labels" -}} +helm.sh/chart: {{ include "ui-plugin-operator.chart" . }} +{{ include "ui-plugin-operator.selectorLabels" . }} +{{- if .Chart.AppVersion }} +app.kubernetes.io/version: {{ .Chart.AppVersion | quote }} +{{- end }} +app.kubernetes.io/managed-by: {{ .Release.Service }} +{{- end }} + +{{/* +Selector labels +*/}} +{{- define "ui-plugin-operator.selectorLabels" -}} +app.kubernetes.io/name: {{ include "ui-plugin-operator.name" . }} +app.kubernetes.io/instance: {{ .Release.Name }} +{{- end }} + +{{/* +Create the name of the service account to use +*/}} +{{- define "ui-plugin-operator.serviceAccountName" -}} +{{- if .Values.serviceAccount.create }} +{{- default (include "ui-plugin-operator.fullname" .) .Values.serviceAccount.name }} +{{- else }} +{{- default "default" .Values.serviceAccount.name }} +{{- end }} +{{- end }} + +{{- define "system_default_registry" -}} +{{- if .Values.global.cattle.systemDefaultRegistry -}} +{{- printf "%s/" .Values.global.cattle.systemDefaultRegistry -}} +{{- else -}} +{{- "" -}} +{{- end -}} +{{- end -}} + +{{/* +Windows cluster will add default taint for linux nodes, +add below linux tolerations to workloads could be scheduled to those linux nodes +*/}} +{{- define "linux-node-tolerations" -}} +- key: "cattle.io/os" + value: "linux" + effect: "NoSchedule" + operator: "Equal" +{{- end -}} + +{{- define "linux-node-selector" -}} +{{- if semverCompare "<1.14-0" .Capabilities.KubeVersion.GitVersion -}} +beta.kubernetes.io/os: linux +{{- else -}} +kubernetes.io/os: linux +{{- end -}} +{{- end -}} diff --git a/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/dashboardrole.yaml b/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/dashboardrole.yaml new file mode 100644 index 0000000000..e8b7c456cf --- /dev/null +++ b/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/dashboardrole.yaml @@ -0,0 +1,33 @@ +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: {{ .Chart.Name }}-dashboard + namespace: {{ .Release.Namespace }} + labels: + app: {{ .Chart.Name }} +rules: +- apiGroups: + - "" + resources: + - services/proxy + resourceNames: + - "http:{{ .Chart.Name }}:{{ .Values.service.port }}" + - "https:{{ .Chart.Name }}:{{ .Values.service.port }}" + verbs: + - '*' +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: {{ .Chart.Name }}-dashboard + namespace: {{ .Release.Namespace }} + labels: + app: {{ .Chart.Name }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: {{ .Chart.Name }}-dashboard +subjects: +- kind: Group + name: system:authenticated + apiGroup: rbac.authorization.k8s.io diff --git a/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/deployment.yaml b/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/deployment.yaml new file mode 100644 index 0000000000..7cf9e5dc7e --- /dev/null +++ b/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/deployment.yaml @@ -0,0 +1,67 @@ +apiVersion: apps/v1 +kind: Deployment +metadata: + name: {{ .Chart.Name }} + labels: + {{- include "ui-plugin-operator.labels" . | nindent 4 }} +spec: + {{- if not .Values.autoscaling.enabled }} + replicas: {{ .Values.replicas }} + {{- end }} + selector: + matchLabels: + {{- include "ui-plugin-operator.selectorLabels" . | nindent 6 }} + template: + metadata: + {{- with .Values.podAnnotations }} + annotations: + {{- toYaml . | nindent 8 }} + {{- end }} + labels: + {{- include "ui-plugin-operator.selectorLabels" . | nindent 8 }} + spec: + {{- with .Values.imagePullSecrets }} + imagePullSecrets: + {{- toYaml . | nindent 8 }} + {{- end }} + nodeSelector: {{ include "linux-node-selector" . | nindent 8 }} +{{- if .Values.nodeSelector }} +{{ toYaml .Values.nodeSelector | indent 8 }} +{{- end }} + tolerations: {{ include "linux-node-tolerations" . | nindent 8 }} +{{- if .Values.tolerations }} +{{ toYaml .Values.tolerations | indent 8 }} +{{- end }} + serviceAccountName: {{ .Chart.Name }} + containers: + - name: {{ .Chart.Name }} + securityContext: + {{- toYaml .Values.securityContext | nindent 12 }} + image: "{{ template "system_default_registry" . }}{{ .Values.image.repository }}:{{ .Values.image.tag | default .Chart.AppVersion }}" + imagePullPolicy: {{ .Values.image.pullPolicy }} + ports: + - name: http + containerPort: 80 + protocol: TCP + args: + - {{ template "ui-plugin-operator.name" . }} +{{- if .Values.debug }} + - --debug + - --debug-level={{ .Values.debugLevel }} +{{- end }} +{{- if .Values.additionalArgs }} +{{- toYaml .Values.additionalArgs | nindent 10 }} +{{- end }} + # livenessProbe: + # httpGet: + # path: / + # port: http + # readinessProbe: + # httpGet: + # path: / + # port: http + resources: + {{- with .Values.affinity }} + affinity: + {{- toYaml . | nindent 8 }} + {{- end }} diff --git a/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/hardened.yaml b/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/hardened.yaml new file mode 100644 index 0000000000..9d11df86cc --- /dev/null +++ b/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/hardened.yaml @@ -0,0 +1,123 @@ +{{- $namespaces := dict "_0" .Release.Namespace -}} +apiVersion: batch/v1 +kind: Job +metadata: + name: {{ .Chart.Name }}-patch-sa + namespace: {{ .Release.Namespace }} + labels: + app: {{ .Chart.Name }}-patch-sa + annotations: + "helm.sh/hook": post-install, post-upgrade + "helm.sh/hook-delete-policy": hook-succeeded, before-hook-creation +spec: + template: + metadata: + name: {{ .Chart.Name }}-patch-sa + labels: + app: {{ .Chart.Name }}-patch-sa + spec: + serviceAccountName: {{ .Chart.Name }}-patch-sa + securityContext: + runAsNonRoot: true + runAsUser: 1000 + restartPolicy: Never + containers: + {{- range $_, $ns := $namespaces }} + - name: patch-sa-{{ $ns }} + image: {{ template "system_default_registry" $ }}{{ $.Values.global.kubectl.repository }}:{{ $.Values.global.kubectl.tag }} + imagePullPolicy: {{ $.Values.global.kubectl.pullPolicy }} + command: ["kubectl", "patch", "serviceaccount", "default", "-p", "{\"automountServiceAccountToken\": false}"] + args: ["-n", "{{ $ns }}"] + {{- end }} +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + name: {{ .Chart.Name }}-patch-sa + labels: + app: {{ .Chart.Name }}-patch-sa +rules: +- apiGroups: + - "" + resources: + - serviceaccounts + verbs: ['get', 'patch'] +{{- if .Values.global.cattle.psp.enabled }} +- apiGroups: ['policy'] + resources: ['podsecuritypolicies'] + verbs: ['use'] + resourceNames: + - {{ .Chart.Name }}-patch-sa +{{- end }} +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: {{ .Chart.Name }}-patch-sa + labels: + app: {{ .Chart.Name }}-patch-sa +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: {{ .Chart.Name }}-patch-sa +subjects: +- kind: ServiceAccount + name: {{ .Chart.Name }}-patch-sa + namespace: {{ .Release.Namespace }} +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: {{ .Chart.Name }}-patch-sa + namespace: {{ .Release.Namespace }} + labels: + app: {{ .Chart.Name }}-patch-sa +--- +{{- if .Capabilities.APIVersions.Has "policy/v1beta1/PodSecurityPolicies" }} +apiVersion: policy/v1beta1 +kind: PodSecurityPolicy +metadata: + name: {{ .Chart.Name }}-patch-sa + namespace: {{ .Release.Namespace }} + labels: + app: {{ .Chart.Name }}-patch-sa +spec: + privileged: false + hostNetwork: false + hostIPC: false + hostPID: false + runAsUser: + rule: 'MustRunAsNonRoot' + seLinux: + rule: 'RunAsAny' + supplementalGroups: + rule: 'MustRunAs' + ranges: + - min: 1 + max: 65535 + fsGroup: + rule: 'MustRunAs' + ranges: + - min: 1 + max: 65535 + readOnlyRootFilesystem: false + volumes: + - 'secret' +{{- end }} +{{- range $_, $ns := $namespaces }} +--- +apiVersion: networking.k8s.io/v1 +kind: NetworkPolicy +metadata: + name: default-allow-all + namespace: {{ $ns }} +spec: + podSelector: {} + ingress: + - {} + egress: + - {} + policyTypes: + - Ingress + - Egress +{{- end }} diff --git a/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/service.yaml b/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/service.yaml new file mode 100644 index 0000000000..7c4e735e9d --- /dev/null +++ b/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/service.yaml @@ -0,0 +1,15 @@ +apiVersion: v1 +kind: Service +metadata: + name: {{ .Chart.Name }} + labels: + {{- include "ui-plugin-operator.labels" . | nindent 4 }} +spec: + type: {{ .Values.service.type }} + ports: + - port: {{ .Values.service.port }} + targetPort: {{ .Values.service.targetPort }} + protocol: TCP + name: http + selector: + {{- include "ui-plugin-operator.selectorLabels" . | nindent 4 }} diff --git a/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/serviceaccount.yaml b/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/serviceaccount.yaml new file mode 100644 index 0000000000..d43d0492b0 --- /dev/null +++ b/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/serviceaccount.yaml @@ -0,0 +1,101 @@ +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: {{ .Chart.Name }} + namespace: {{ .Release.Namespace }} + labels: + app: {{ .Chart.Name }} +rules: +- apiGroups: [""] + resources: ["configmaps"] + verbs: ["*"] +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: {{ .Chart.Name }} + namespace: {{ .Release.Namespace }} + labels: + app: {{ .Chart.Name }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: {{ .Chart.Name }} +subjects: +- kind: ServiceAccount + name: {{ .Chart.Name }} + namespace: {{ .Release.Namespace }} +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + name: {{ .Chart.Name }} + namespace: {{ .Release.Namespace }} + labels: + app: {{ .Chart.Name }} +rules: +- apiGroups: ["catalog.cattle.io"] + resources: + - uiplugins + - uiplugins/status + verbs: ["*"] +- apiGroups: ["coordination.k8s.io"] + resources: + - leases + verbs: ["*"] +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: {{ .Chart.Name }} + namespace: {{ .Release.Namespace }} + labels: + app: {{ .Chart.Name }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: {{ .Chart.Name }} +subjects: +- kind: ServiceAccount + name: {{ .Chart.Name }} + namespace: {{ .Release.Namespace }} +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: {{ .Chart.Name }} + namespace: {{ .Release.Namespace }} + labels: + app: {{ .Chart.Name }} +--- +{{- if .Values.global.cattle.psp.enabled }} +apiVersion: policy/v1beta1 +kind: PodSecurityPolicy +metadata: + name: {{ .Chart.Name }} + namespace: {{ .Release.Namespace }} + labels: + app: {{ .Chart.Name }} +spec: + privileged: false + hostNetwork: false + hostIPC: false + hostPID: false + runAsUser: + rule: 'MustRunAsNonRoot' + seLinux: + rule: 'RunAsAny' + supplementalGroups: + rule: 'MustRunAs' + ranges: + - min: 1 + max: 65535 + fsGroup: + rule: 'MustRunAs' + ranges: + - min: 1 + max: 65535 + readOnlyRootFilesystem: false + volumes: + - 'secret' +{{- end }} diff --git a/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/validate-psp-install.yaml b/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/validate-psp-install.yaml new file mode 100644 index 0000000000..a30c59d3b7 --- /dev/null +++ b/charts/ui-plugin-operator/103.0.3+up0.2.2/templates/validate-psp-install.yaml @@ -0,0 +1,7 @@ +#{{- if gt (len (lookup "rbac.authorization.k8s.io/v1" "ClusterRole" "" "")) 0 -}} +#{{- if .Values.global.cattle.psp.enabled }} +#{{- if not (.Capabilities.APIVersions.Has "policy/v1beta1/PodSecurityPolicy") }} +#{{- fail "The target cluster does not have the PodSecurityPolicy API resource. Please disable PSPs in this chart before proceeding." -}} +#{{- end }} +#{{- end }} +#{{- end }} diff --git a/charts/ui-plugin-operator/103.0.3+up0.2.2/values.yaml b/charts/ui-plugin-operator/103.0.3+up0.2.2/values.yaml new file mode 100644 index 0000000000..ef014b63a7 --- /dev/null +++ b/charts/ui-plugin-operator/103.0.3+up0.2.2/values.yaml @@ -0,0 +1,69 @@ +# Default values for sample. +# This is a YAML-formatted file. +# Declare variables to be passed into your templates. + +replicaCount: 1 + +image: + repository: rancher/ui-plugin-operator + pullPolicy: Always + tag: "v0.1.3" + +imagePullSecrets: [] +nameOverride: "" +fullnameOverride: "" + +service: + type: ClusterIP + port: 80 + targetPort: 8080 + +autoscaling: + enabled: false + minReplicas: 1 + maxReplicas: 100 + targetCPUUtilizationPercentage: 80 + +replicas: 1 + +resources: {} + +securityContext: + runAsNonRoot: true + runAsUser: 1000 + +nodeSelector: {} + +tolerations: [] + +affinity: {} + +podAnnotations: [] + +additionalArgs: [] + +global: + cattle: + systemDefaultRegistry: "" + psp: + enabled: false # PSP enablement should default to false + kubectl: + repository: rancher/kubectl + tag: v1.20.2 + pullPolicy: IfNotPresent + rbac: + ## Create RBAC resources for ServiceAccounts and users + ## + enabled: false + # create: true + # userRoles: + # ## Create default user ClusterRoles to allow users to interact with Prometheus CRs, ConfigMaps, and Secrets + # create: true + # ## Aggregate default user ClusterRoles into default k8s ClusterRoles + # aggregateToDefaultRoles: true + + # pspEnabled: true + # pspAnnotations: {} + +debug: false +debugLevel: 0 diff --git a/index.yaml b/index.yaml index c6b9261223..e495098363 100755 --- a/index.yaml +++ b/index.yaml @@ -121,6 +121,30 @@ entries: urls: - assets/elemental/elemental-104.0.0+up1.4.3.tgz version: 104.0.0+up1.4.3 + - annotations: + catalog.cattle.io/auto-install: elemental-crd=match + catalog.cattle.io/certified: rancher + catalog.cattle.io/display-name: Elemental + catalog.cattle.io/kube-version: '>= 1.23.0-0' + catalog.cattle.io/namespace: cattle-elemental-system + catalog.cattle.io/os: linux + catalog.cattle.io/permits-os: linux + catalog.cattle.io/provides-gvr: elemental.cattle.io/v1beta1 + catalog.cattle.io/rancher-version: '>= 2.8.0-0 < 2.9.0-0' + catalog.cattle.io/release-name: elemental-operator + catalog.cattle.io/scope: management + catalog.cattle.io/type: cluster-tool + catalog.cattle.io/upstream-version: 1.6.5 + apiVersion: v2 + appVersion: 1.6.5 + created: "2024-11-11T18:18:02.645696966-03:00" + description: Elemental provides Cloud Native OS Management for Cluster Nodes. + digest: e01ba212904a0037ac5c1a84b27365f43a883d20ba9e4c3b7c6d757846910ca4 + icon: https://raw.githubusercontent.com/rancher/elemental/main/logo/icon-elemental.svg + name: elemental + urls: + - assets/elemental/elemental-103.4.1+up1.6.5.tgz + version: 103.4.1+up1.6.5 - annotations: catalog.cattle.io/auto-install: elemental-crd=match catalog.cattle.io/certified: rancher @@ -341,6 +365,21 @@ entries: urls: - assets/elemental-crd/elemental-crd-104.0.0+up1.4.3.tgz version: 104.0.0+up1.4.3 + - annotations: + catalog.cattle.io/certified: rancher + catalog.cattle.io/hidden: "true" + catalog.cattle.io/namespace: cattle-elemental-system + catalog.cattle.io/release-name: elemental-operator-crds + apiVersion: v2 + appVersion: 1.6.5 + created: "2024-11-11T18:18:06.850604413-03:00" + description: A Helm chart for deploying Rancher Elemental Operator CRDs + digest: 5aa44ef0c1e144b5a203e49dde264de2164b48603fab4a3bf3561849b0f92fe1 + name: elemental-crd + type: application + urls: + - assets/elemental-crd/elemental-crd-103.4.1+up1.6.5.tgz + version: 103.4.1+up1.6.5 - annotations: catalog.cattle.io/certified: rancher catalog.cattle.io/hidden: "true" @@ -977,6 +1016,32 @@ entries: urls: - assets/fleet/fleet-104.0.0+up0.10.0.tgz version: 104.0.0+up0.10.0 + - annotations: + catalog.cattle.io/auto-install: fleet-crd=match + catalog.cattle.io/certified: rancher + catalog.cattle.io/experimental: "true" + catalog.cattle.io/hidden: "true" + catalog.cattle.io/kube-version: '>= 1.23.0-0 < 1.29.0-0' + catalog.cattle.io/namespace: cattle-fleet-system + catalog.cattle.io/os: linux + catalog.cattle.io/permits-os: linux,windows + catalog.cattle.io/provides-gvr: clusters.fleet.cattle.io/v1alpha1 + catalog.cattle.io/rancher-version: '>= 2.8.0-0 < 2.9.0-0' + catalog.cattle.io/release-name: fleet + apiVersion: v2 + appVersion: 0.9.11 + created: "2024-11-11T18:18:22.616889473-03:00" + dependencies: + - condition: gitops.enabled + name: gitjob + repository: file://./charts/gitjob + description: Fleet Manager - GitOps at Scale + digest: 8d6c9be8dd468a45d66a6d32bce1caf1dd1318b1d4e783959f805930a4718942 + icon: https://charts.rancher.io/assets/logos/fleet.svg + name: fleet + urls: + - assets/fleet/fleet-103.1.10+up0.9.11.tgz + version: 103.1.10+up0.9.11 - annotations: catalog.cattle.io/auto-install: fleet-crd=match catalog.cattle.io/certified: rancher @@ -2059,6 +2124,25 @@ entries: urls: - assets/fleet-agent/fleet-agent-104.0.0+up0.10.0.tgz version: 104.0.0+up0.10.0 + - annotations: + catalog.cattle.io/certified: rancher + catalog.cattle.io/hidden: "true" + catalog.cattle.io/kube-version: '>= 1.23.0-0 < 1.29.0-0' + catalog.cattle.io/namespace: cattle-fleet-system + catalog.cattle.io/os: linux + catalog.cattle.io/permits-os: linux,windows + catalog.cattle.io/rancher-version: '>= 2.8.0-0 < 2.9.0-0' + catalog.cattle.io/release-name: fleet-agent + apiVersion: v2 + appVersion: 0.9.11 + created: "2024-11-11T18:18:30.680138726-03:00" + description: Fleet Manager Agent - GitOps at Scale + digest: 9470433d47dbd0ea99710a53e82e1589bfcb2dd930c235d31d2207b8cca09beb + icon: https://charts.rancher.io/assets/logos/fleet.svg + name: fleet-agent + urls: + - assets/fleet-agent/fleet-agent-103.1.10+up0.9.11.tgz + version: 103.1.10+up0.9.11 - annotations: catalog.cattle.io/certified: rancher catalog.cattle.io/hidden: "true" @@ -2878,6 +2962,23 @@ entries: urls: - assets/fleet-crd/fleet-crd-104.0.0+up0.10.0.tgz version: 104.0.0+up0.10.0 + - annotations: + catalog.cattle.io/certified: rancher + catalog.cattle.io/hidden: "true" + catalog.cattle.io/namespace: cattle-fleet-system + catalog.cattle.io/os: linux + catalog.cattle.io/permits-os: linux,windows + catalog.cattle.io/release-name: fleet-crd + apiVersion: v2 + appVersion: 0.9.11 + created: "2024-11-11T18:18:26.218070958-03:00" + description: Fleet Manager CustomResourceDefinitions + digest: 102a6e8e1421ff4f48520b72aa812e7b689ef81010d3133795a97d154e5cb1ee + icon: https://charts.rancher.io/assets/logos/fleet.svg + name: fleet-crd + urls: + - assets/fleet-crd/fleet-crd-103.1.10+up0.9.11.tgz + version: 103.1.10+up0.9.11 - annotations: catalog.cattle.io/certified: rancher catalog.cattle.io/hidden: "true" @@ -13024,6 +13125,32 @@ entries: urls: - assets/rancher-cis-benchmark/rancher-cis-benchmark-6.0.0.tgz version: 6.0.0 + - annotations: + catalog.cattle.io/auto-install: rancher-cis-benchmark-crd=match + catalog.cattle.io/certified: rancher + catalog.cattle.io/display-name: CIS Benchmark + catalog.cattle.io/kube-version: '>= 1.25.0-0 < 1.29.0-0' + catalog.cattle.io/namespace: cis-operator-system + catalog.cattle.io/os: linux + catalog.cattle.io/permits-os: linux,windows + catalog.cattle.io/provides-gvr: cis.cattle.io.clusterscans/v1 + catalog.cattle.io/rancher-version: '>= 2.8.0-0 < 2.9.0-0' + catalog.cattle.io/release-name: rancher-cis-benchmark + catalog.cattle.io/type: cluster-tool + catalog.cattle.io/ui-component: rancher-cis-benchmark + apiVersion: v1 + appVersion: v5.6.0 + created: "2024-11-11T18:18:15.519400168-03:00" + description: The cis-operator enables running CIS benchmark security scans on + a kubernetes cluster + digest: 23b3df0f8babcb8de7a9488f3ed3f3027634abac4b410957694704a9d66b518f + icon: https://charts.rancher.io/assets/logos/cis-kube-bench.svg + keywords: + - security + name: rancher-cis-benchmark + urls: + - assets/rancher-cis-benchmark/rancher-cis-benchmark-5.6.0.tgz + version: 5.6.0 - annotations: catalog.cattle.io/auto-install: rancher-cis-benchmark-crd=match catalog.cattle.io/certified: rancher @@ -13798,6 +13925,20 @@ entries: urls: - assets/rancher-cis-benchmark-crd/rancher-cis-benchmark-crd-6.0.0.tgz version: 6.0.0 + - annotations: + catalog.cattle.io/certified: rancher + catalog.cattle.io/hidden: "true" + catalog.cattle.io/namespace: cis-operator-system + catalog.cattle.io/release-name: rancher-cis-benchmark-crd + apiVersion: v1 + created: "2024-11-11T18:18:19.167292006-03:00" + description: Installs the CRDs for rancher-cis-benchmark. + digest: 019b4a28a9f16c8a188a61530282bec109e8a6fb5ea5747b69a30614aff1be84 + name: rancher-cis-benchmark-crd + type: application + urls: + - assets/rancher-cis-benchmark-crd/rancher-cis-benchmark-crd-5.6.0.tgz + version: 5.6.0 - annotations: catalog.cattle.io/certified: rancher catalog.cattle.io/hidden: "true" @@ -26851,6 +26992,24 @@ entries: urls: - assets/rancher-webhook/rancher-webhook-104.0.0+up0.5.0.tgz version: 104.0.0+up0.5.0 + - annotations: + catalog.cattle.io/certified: rancher + catalog.cattle.io/hidden: "true" + catalog.cattle.io/kube-version: '>= 1.23.0-0 < 1.29.0-0' + catalog.cattle.io/namespace: cattle-system + catalog.cattle.io/os: linux + catalog.cattle.io/permits-os: linux,windows + catalog.cattle.io/rancher-version: '>= 2.8.0-0 < 2.9.0-0' + catalog.cattle.io/release-name: rancher-webhook + apiVersion: v2 + appVersion: 0.4.13 + created: "2024-11-11T18:18:12.357365288-03:00" + description: ValidatingAdmissionWebhook for Rancher types + digest: 11c56a367d8bbc9f95fc1fbeeaa52f343afd3320afc57109d0610f0ad87bae36 + name: rancher-webhook + urls: + - assets/rancher-webhook/rancher-webhook-103.0.12+up0.4.13.tgz + version: 103.0.12+up0.4.13 - annotations: catalog.cattle.io/certified: rancher catalog.cattle.io/hidden: "true" @@ -29090,6 +29249,29 @@ entries: - assets/system-upgrade-controller/system-upgrade-controller-100.0.0+up0.3.0.tgz version: 100.0.0+up0.3.0 ui-plugin-operator: + - annotations: + catalog.cattle.io/auto-install: ui-plugin-operator-crd=match + catalog.cattle.io/certified: rancher + catalog.cattle.io/display-name: UI Plugin Operator + catalog.cattle.io/kube-version: '>= 1.16.0-0 < 1.29.0-0' + catalog.cattle.io/namespace: cattle-ui-plugin-system + catalog.cattle.io/os: linux + catalog.cattle.io/permits-os: linux, windows + catalog.cattle.io/rancher-version: '>= 2.8.0-0 < 2.9.0-0' + catalog.cattle.io/release-name: ui-plugin-operator + apiVersion: v1 + appVersion: 0.1.3 + created: "2024-11-11T18:56:13.217478307-03:00" + description: A UI Plugin Operator Chart for plugin management in Rancher + digest: f18a89fc30f8df5a42fea717151343b6326edfe0aab7e09f251c9ea229b9747c + keywords: + - applications + - infrastructure + name: ui-plugin-operator + type: application + urls: + - assets/ui-plugin-operator/ui-plugin-operator-103.0.3+up0.2.2.tgz + version: 103.0.3+up0.2.2 - annotations: catalog.cattle.io/auto-install: ui-plugin-operator-crd=match catalog.cattle.io/certified: rancher @@ -29252,6 +29434,20 @@ entries: - assets/ui-plugin-operator/ui-plugin-operator-101.0.0+up0.1.0.tgz version: 101.0.0+up0.1.0 ui-plugin-operator-crd: + - annotations: + catalog.cattle.io/certified: rancher + catalog.cattle.io/hidden: "true" + catalog.cattle.io/namespace: cattle-ui-plugin-system + catalog.cattle.io/release-name: ui-plugin-operator-crd + apiVersion: v1 + created: "2024-11-11T18:56:17.440486344-03:00" + description: Installs the CRDs for ui-plugin-operator. + digest: fe6d83a7a42cbf62a9661babd7d112181badc2312b863ab3566097bf14a39e02 + name: ui-plugin-operator-crd + type: application + urls: + - assets/ui-plugin-operator-crd/ui-plugin-operator-crd-103.0.3+up0.2.2.tgz + version: 103.0.3+up0.2.2 - annotations: catalog.cattle.io/certified: rancher catalog.cattle.io/hidden: "true" diff --git a/release.yaml b/release.yaml index 573c31c120..0864bbceb5 100644 --- a/release.yaml +++ b/release.yaml @@ -1,62 +1,20 @@ elemental: - - 104.2.1+up1.6.5 + - 103.4.1+up1.6.5 elemental-crd: - - 104.2.1+up1.6.5 -rancher-istio: - - 104.4.1+up1.22.1 - - 104.5.0+up1.23.2 -rancher-backup: - - 103.0.4+up4.0.4 -rancher-backup-crd: - - 103.0.4+up4.0.4 -fleet: - - 102.2.6+up0.8.5 - - 102.2.7+up0.8.6 - - 103.1.9+up0.9.10 - - 104.1.1+up0.10.5 -fleet-agent: - - 102.2.6+up0.8.5 - - 102.2.7+up0.8.6 - - 103.1.9+up0.9.10 - - 104.1.1+up0.10.5 -fleet-crd: - - 102.2.6+up0.8.5 - - 102.2.7+up0.8.6 - - 103.1.9+up0.9.10 - - 104.1.1+up0.10.5 -harvester-csi-driver: - - 103.0.3+up0.1.20 -rancher-aks-operator: - - 104.4.0+up1.9.4 -rancher-aks-operator-crd: - - 104.4.0+up1.9.4 -rancher-eks-operator: - - 104.4.0+up1.9.4 -rancher-eks-operator-crd: - - 104.4.0+up1.9.4 -rancher-gke-operator: - - 104.4.0+up1.9.4 -rancher-gke-operator-crd: - - 104.4.0+up1.9.4 + - 103.4.1+up1.6.5 rancher-webhook: - - 104.0.4+up0.5.4 - - 104.0.3+up0.5.3 - - 2.0.13+up0.3.13 -rancher-gatekeeper: - - 104.0.1+up3.13.0 -rancher-gatekeeper-crd: - - 104.0.1+up3.13.0 -longhorn: - - 104.2.1+up1.7.2 - - 102.5.1+up1.7.2 - - 103.4.1+up1.7.2 -longhorn-crd: - - 104.2.1+up1.7.2 - - 102.5.1+up1.7.2 - - 103.4.1+up1.7.2 -prometheus-federator: - - 104.0.2+up0.4.2 + - 103.0.12+up0.4.13 rancher-cis-benchmark: - - 6.4.0 + - 5.6.0 rancher-cis-benchmark-crd: - - 6.4.0 + - 5.6.0 +fleet: + - 103.1.10+up0.9.11 +fleet-crd: + - 103.1.10+up0.9.11 +fleet-agent: + - 103.1.10+up0.9.11 +ui-plugin-operator: + - 103.0.3+up0.2.2 +ui-plugin-operator-crd: + - 103.0.3+up0.2.2