From 35f73493abba216dd9eb8bf645d687ffb7924878 Mon Sep 17 00:00:00 2001 From: shahargl Date: Sun, 20 Oct 2024 16:47:21 +0300 Subject: [PATCH 01/19] feat: wip --- charts/keep/Chart.lock | 6 + charts/keep/Chart.yaml | 7 +- charts/keep/charts/ingress-nginx-4.11.3.tgz | Bin 0 -> 58282 bytes charts/keep/charts/ingress-nginx/.helmignore | 23 + charts/keep/charts/ingress-nginx/Chart.yaml | 25 + charts/keep/charts/ingress-nginx/OWNERS | 10 + charts/keep/charts/ingress-nginx/README.md | 559 +++++++ .../charts/ingress-nginx/README.md.gotmpl | 229 +++ .../changelog/helm-chart-2.10.0.md | 9 + .../changelog/helm-chart-2.11.0.md | 10 + .../changelog/helm-chart-2.11.1.md | 9 + .../changelog/helm-chart-2.11.2.md | 9 + .../changelog/helm-chart-2.11.3.md | 9 + .../changelog/helm-chart-2.12.0.md | 10 + .../changelog/helm-chart-2.12.1.md | 9 + .../changelog/helm-chart-2.13.0.md | 10 + .../changelog/helm-chart-2.14.0.md | 9 + .../changelog/helm-chart-2.15.0.md | 9 + .../changelog/helm-chart-2.16.0.md | 9 + .../changelog/helm-chart-2.9.0.md | 9 + .../changelog/helm-chart-2.9.1.md | 9 + .../changelog/helm-chart-3.0.0.md | 9 + .../changelog/helm-chart-3.10.0.md | 9 + .../changelog/helm-chart-3.10.1.md | 9 + .../changelog/helm-chart-3.11.0.md | 9 + .../changelog/helm-chart-3.11.1.md | 9 + .../changelog/helm-chart-3.12.0.md | 9 + .../changelog/helm-chart-3.13.0.md | 9 + .../changelog/helm-chart-3.14.0.md | 9 + .../changelog/helm-chart-3.15.0.md | 9 + .../changelog/helm-chart-3.15.1.md | 9 + .../changelog/helm-chart-3.16.0.md | 9 + .../changelog/helm-chart-3.16.1.md | 9 + .../changelog/helm-chart-3.17.0.md | 9 + .../changelog/helm-chart-3.18.0.md | 10 + .../changelog/helm-chart-3.19.0.md | 9 + .../changelog/helm-chart-3.20.0.md | 9 + .../changelog/helm-chart-3.20.1.md | 10 + .../changelog/helm-chart-3.21.0.md | 12 + .../changelog/helm-chart-3.22.0.md | 10 + .../changelog/helm-chart-3.23.0.md | 9 + .../changelog/helm-chart-3.24.0.md | 9 + .../changelog/helm-chart-3.25.0.md | 9 + .../changelog/helm-chart-3.26.0.md | 9 + .../changelog/helm-chart-3.27.0.md | 9 + .../changelog/helm-chart-3.28.0.md | 9 + .../changelog/helm-chart-3.29.0.md | 9 + .../changelog/helm-chart-3.3.0.md | 12 + .../changelog/helm-chart-3.3.1.md | 12 + .../changelog/helm-chart-3.30.0.md | 9 + .../changelog/helm-chart-3.31.0.md | 9 + .../changelog/helm-chart-3.32.0.md | 9 + .../changelog/helm-chart-3.33.0.md | 9 + .../changelog/helm-chart-3.34.0.md | 9 + .../changelog/helm-chart-3.4.0.md | 9 + .../changelog/helm-chart-3.5.0.md | 9 + .../changelog/helm-chart-3.5.1.md | 9 + .../changelog/helm-chart-3.6.0.md | 9 + .../changelog/helm-chart-3.7.0.md | 9 + .../changelog/helm-chart-3.7.1.md | 9 + .../changelog/helm-chart-3.8.0.md | 13 + .../changelog/helm-chart-3.9.0.md | 9 + .../changelog/helm-chart-4.0.1.md | 9 + .../changelog/helm-chart-4.0.10.md | 9 + .../changelog/helm-chart-4.0.11.md | 9 + .../changelog/helm-chart-4.0.12.md | 9 + .../changelog/helm-chart-4.0.13.md | 9 + .../changelog/helm-chart-4.0.14.md | 9 + .../changelog/helm-chart-4.0.15.md | 43 + .../changelog/helm-chart-4.0.18.md | 40 + .../changelog/helm-chart-4.0.2.md | 9 + .../changelog/helm-chart-4.0.3.md | 9 + .../changelog/helm-chart-4.0.5.md | 9 + .../changelog/helm-chart-4.0.6.md | 12 + .../changelog/helm-chart-4.0.7.md | 10 + .../changelog/helm-chart-4.0.9.md | 9 + .../changelog/helm-chart-4.1.0.md | 21 + .../changelog/helm-chart-4.1.2.md | 11 + .../changelog/helm-chart-4.10.0.md | 9 + .../changelog/helm-chart-4.10.1.md | 11 + .../changelog/helm-chart-4.10.2.md | 18 + .../changelog/helm-chart-4.11.0.md | 18 + .../changelog/helm-chart-4.11.1.md | 9 + .../changelog/helm-chart-4.11.2.md | 9 + .../changelog/helm-chart-4.11.3.md | 9 + .../changelog/helm-chart-4.2.0.md | 47 + .../changelog/helm-chart-4.2.1.md | 10 + .../changelog/helm-chart-4.3.0.md | 14 + .../changelog/helm-chart-4.4.0.md | 12 + .../changelog/helm-chart-4.5.2.md | 13 + .../changelog/helm-chart-4.6.0.md | 24 + .../changelog/helm-chart-4.6.1.md | 11 + .../changelog/helm-chart-4.7.0.md | 14 + .../changelog/helm-chart-4.7.1.md | 12 + .../changelog/helm-chart-4.7.2.md | 9 + .../changelog/helm-chart-4.8.0-beta.0.md | 13 + .../changelog/helm-chart-4.8.0.md | 13 + .../changelog/helm-chart-4.8.1.md | 9 + .../changelog/helm-chart-4.8.2.md | 10 + .../changelog/helm-chart-4.8.3.md | 9 + .../changelog/helm-chart-4.9.0.md | 13 + .../changelog/helm-chart-4.9.1.md | 10 + .../changelog/helm-chart.md.gotmpl | 11 + ...dmission-webhooks-cert-manager-values.yaml | 12 + ...ontroller-configmap-addheaders-values.yaml | 11 + ...troller-configmap-proxyheaders-values.yaml | 11 + .../ci/controller-configmap-values.yaml | 11 + ...roller-daemonset-extra-modules-values.yaml | 30 + .../controller-daemonset-metrics-values.yaml | 13 + ...roller-daemonset-opentelemetry-values.yaml | 13 + ...oller-daemonset-podannotations-values.yaml | 16 + .../ci/controller-daemonset-values.yaml | 10 + ...oller-deployment-extra-modules-values.yaml | 30 + .../controller-deployment-metrics-values.yaml | 13 + ...oller-deployment-opentelemetry-values.yaml | 13 + ...ller-deployment-podannotations-values.yaml | 16 + .../ci/controller-deployment-values.yaml | 10 + .../ci/controller-hpa-values.yaml | 18 + .../ci/controller-ingressclass-values.yaml | 15 + .../controller-service-internal-values.yaml | 13 + .../ci/controller-service-values.yaml | 22 + .../ci/deamonset-psp-values.yaml | 13 + .../ci/deamonset-webhook-and-psp-values.yaml | 13 + .../ci/deployment-psp-values.yaml | 10 + .../ci/deployment-webhook-and-psp-values.yaml | 12 + .../charts/ingress-nginx/templates/NOTES.txt | 73 + .../ingress-nginx/templates/_helpers.tpl | 272 ++++ .../ingress-nginx/templates/_params.tpl | 77 + .../admission-webhooks/cert-manager.yaml | 63 + .../job-patch/clusterrole.yaml | 33 + .../job-patch/clusterrolebinding.yaml | 23 + .../job-patch/job-createSecret.yaml | 79 + .../job-patch/job-patchWebhook.yaml | 81 + .../job-patch/networkpolicy.yaml | 26 + .../admission-webhooks/job-patch/psp.yaml | 52 + .../admission-webhooks/job-patch/role.yaml | 24 + .../job-patch/rolebinding.yaml | 24 + .../job-patch/serviceaccount.yaml | 17 + .../validating-webhook.yaml | 54 + .../ingress-nginx/templates/clusterrole.yaml | 102 ++ .../templates/clusterrolebinding.yaml | 19 + .../controller-configmap-addheaders.yaml | 14 + .../controller-configmap-proxyheaders.yaml | 14 + .../templates/controller-configmap-tcp.yaml | 17 + .../templates/controller-configmap-udp.yaml | 17 + .../templates/controller-configmap.yaml | 28 + .../templates/controller-daemonset.yaml | 242 +++ .../templates/controller-deployment.yaml | 245 +++ .../templates/controller-hpa.yaml | 47 + .../controller-ingressclass-aliases.yaml | 23 + .../templates/controller-ingressclass.yaml | 26 + .../templates/controller-keda.yaml | 46 + .../templates/controller-networkpolicy.yaml | 45 + .../controller-poddisruptionbudget.yaml | 36 + .../templates/controller-prometheusrule.yaml | 23 + .../templates/controller-psp.yaml | 100 ++ .../templates/controller-role.yaml | 104 ++ .../templates/controller-rolebinding.yaml | 21 + .../templates/controller-secret.yaml | 15 + .../controller-service-internal.yaml | 105 ++ .../templates/controller-service-metrics.yaml | 45 + .../templates/controller-service-webhook.yaml | 40 + .../templates/controller-service.yaml | 105 ++ .../templates/controller-serviceaccount.yaml | 17 + .../templates/controller-servicemonitor.yaml | 53 + .../templates/default-backend-deployment.yaml | 119 ++ .../default-backend-extra-configmaps.yaml | 23 + .../templates/default-backend-hpa.yaml | 40 + .../default-backend-networkpolicy.yaml | 25 + .../default-backend-poddisruptionbudget.yaml | 25 + .../templates/default-backend-psp.yaml | 50 + .../templates/default-backend-role.yaml | 22 + .../default-backend-rolebinding.yaml | 21 + .../templates/default-backend-service.yaml | 41 + .../default-backend-serviceaccount.yaml | 14 + .../job-patch/clusterrole_test.yaml | 11 + .../job-patch/clusterrolebinding_test.yaml | 11 + .../job-patch/role_test.yaml | 11 + .../job-patch/rolebinding_test.yaml | 11 + .../job-patch/serviceaccount_test.yaml | 47 + .../validating-webhook_test.yaml | 32 + .../controller-configmap-addheaders_test.yaml | 27 + ...ontroller-configmap-proxyheaders_test.yaml | 27 + .../tests/controller-configmap_test.yaml | 31 + .../tests/controller-daemonset_test.yaml | 172 +++ .../tests/controller-deployment_test.yaml | 191 +++ .../tests/controller-hpa_test.yaml | 31 + .../controller-ingressclass-aliases_test.yaml | 110 ++ .../tests/controller-ingressclass_test.yaml | 93 ++ .../tests/controller-keda_test.yaml | 31 + .../tests/controller-networkpolicy_test.yaml | 23 + .../controller-poddisruptionbudget_test.yaml | 89 ++ .../tests/controller-prometheusrule_test.yaml | 17 + .../controller-service-internal_test.yaml | 25 + .../controller-service-metrics_test.yaml | 23 + .../controller-service-webhook_test.yaml | 32 + .../tests/controller-service_test.yaml | 32 + .../tests/controller-servicemonitor_test.yaml | 29 + .../default-backend-deployment_test.yaml | 169 +++ ...default-backend-extra-configmaps_test.yaml | 50 + ...ault-backend-poddisruptionbudget_test.yaml | 48 + .../tests/default-backend-service_test.yaml | 32 + charts/keep/charts/ingress-nginx/values.yaml | 1192 +++++++++++++++ charts/keep/t | 1308 +++++++++++++++++ charts/keep/templates/db-pvc.yaml | 15 +- charts/keep/templates/frontend-ingress.yaml | 64 - charts/keep/templates/nginx-ingress.yaml | 88 ++ charts/keep/values.yaml | 26 +- concat.sh | 31 + 209 files changed, 9137 insertions(+), 72 deletions(-) create mode 100644 charts/keep/Chart.lock create mode 100644 charts/keep/charts/ingress-nginx-4.11.3.tgz create mode 100644 charts/keep/charts/ingress-nginx/.helmignore create mode 100644 charts/keep/charts/ingress-nginx/Chart.yaml create mode 100644 charts/keep/charts/ingress-nginx/OWNERS create mode 100644 charts/keep/charts/ingress-nginx/README.md create mode 100644 charts/keep/charts/ingress-nginx/README.md.gotmpl create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.10.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.2.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.3.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.13.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.14.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.15.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.16.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.0.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.12.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.13.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.14.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.17.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.18.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.19.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.21.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.22.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.23.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.24.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.25.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.26.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.27.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.28.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.29.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.30.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.31.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.32.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.33.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.34.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.4.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.6.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.8.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.9.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.10.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.11.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.12.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.13.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.14.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.15.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.18.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.2.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.3.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.5.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.6.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.7.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.9.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.2.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.2.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.2.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.3.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.3.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.4.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.5.2.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.2.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0-beta.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.2.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.3.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart.md.gotmpl create mode 100644 charts/keep/charts/ingress-nginx/ci/admission-webhooks-cert-manager-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-configmap-addheaders-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-configmap-proxyheaders-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-configmap-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-extra-modules-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-metrics-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-opentelemetry-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-podannotations-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-extra-modules-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-metrics-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-opentelemetry-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-podannotations-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-hpa-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-ingressclass-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-service-internal-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-service-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/deamonset-psp-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/deamonset-webhook-and-psp-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/deployment-psp-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/deployment-webhook-and-psp-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/NOTES.txt create mode 100644 charts/keep/charts/ingress-nginx/templates/_helpers.tpl create mode 100644 charts/keep/charts/ingress-nginx/templates/_params.tpl create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/cert-manager.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/networkpolicy.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/psp.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/clusterrole.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/clusterrolebinding.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap-addheaders.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap-proxyheaders.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap-tcp.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap-udp.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-daemonset.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-deployment.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-hpa.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-ingressclass-aliases.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-ingressclass.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-keda.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-networkpolicy.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-prometheusrule.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-psp.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-role.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-rolebinding.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-secret.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-service-internal.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-service-metrics.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-service-webhook.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-service.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-servicemonitor.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-deployment.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-extra-configmaps.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-hpa.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-networkpolicy.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-poddisruptionbudget.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-psp.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-role.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-rolebinding.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-service.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-serviceaccount.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrole_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrolebinding_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/role_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/rolebinding_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/serviceaccount_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/validating-webhook_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-configmap-addheaders_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-configmap-proxyheaders_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-configmap_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-daemonset_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-deployment_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-hpa_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-ingressclass-aliases_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-ingressclass_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-keda_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-networkpolicy_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-poddisruptionbudget_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-prometheusrule_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-service-internal_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-service-metrics_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-service-webhook_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-service_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-servicemonitor_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/default-backend-deployment_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/default-backend-extra-configmaps_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/default-backend-poddisruptionbudget_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/default-backend-service_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/values.yaml create mode 100644 charts/keep/t delete mode 100644 charts/keep/templates/frontend-ingress.yaml create mode 100644 charts/keep/templates/nginx-ingress.yaml create mode 100755 concat.sh diff --git a/charts/keep/Chart.lock b/charts/keep/Chart.lock new file mode 100644 index 0000000..7189fb1 --- /dev/null +++ b/charts/keep/Chart.lock @@ -0,0 +1,6 @@ +dependencies: +- name: ingress-nginx + repository: https://kubernetes.github.io/ingress-nginx + version: 4.11.3 +digest: sha256:b8a1d7ce0c002bf7b1b31c5a55e5d9a05b4de11638998e871abb336954c3901b +generated: "2024-10-20T14:13:00.322813+03:00" diff --git a/charts/keep/Chart.yaml b/charts/keep/Chart.yaml index 4323014..48c6552 100644 --- a/charts/keep/Chart.yaml +++ b/charts/keep/Chart.yaml @@ -1,6 +1,6 @@ apiVersion: v2 name: keep -version: 0.1.24 +version: 0.1.25 description: Keep Helm Chart type: application icon: https://platform.keephq.dev/_next/image?url=%2Fkeep.png&w=48&q=75 @@ -12,6 +12,11 @@ keywords: - alerting - monitoring - monitoring-tool +dependencies: + - name: ingress-nginx + repository: https://kubernetes.github.io/ingress-nginx + version: 4.11.3 + condition: ingress-nginx.enabled home: https://platform.keephq.dev/ sources: - https://github.com/keephq/helm-charts diff --git a/charts/keep/charts/ingress-nginx-4.11.3.tgz b/charts/keep/charts/ingress-nginx-4.11.3.tgz new file mode 100644 index 0000000000000000000000000000000000000000..577573363137944b4216cb8243b93a8b40b2e856 GIT binary patch literal 58282 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.21.0-0' +maintainers: +- name: cpanato +- name: Gacko +- name: puerco +- name: rikatz +- name: strongjz +- name: tao12345666333 +name: ingress-nginx +sources: +- https://github.com/kubernetes/ingress-nginx +version: 4.11.3 diff --git a/charts/keep/charts/ingress-nginx/OWNERS b/charts/keep/charts/ingress-nginx/OWNERS new file mode 100644 index 0000000..d588ede --- /dev/null +++ b/charts/keep/charts/ingress-nginx/OWNERS @@ -0,0 +1,10 @@ +# See the OWNERS docs: https://www.kubernetes.dev/docs/guide/owners + +approvers: +- ingress-nginx-helm-maintainers + +reviewers: +- ingress-nginx-helm-reviewers + +labels: +- area/helm diff --git a/charts/keep/charts/ingress-nginx/README.md b/charts/keep/charts/ingress-nginx/README.md new file mode 100644 index 0000000..f70bd0a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/README.md @@ -0,0 +1,559 @@ +# ingress-nginx + +[ingress-nginx](https://github.com/kubernetes/ingress-nginx) Ingress controller for Kubernetes using NGINX as a reverse proxy and load balancer + +![Version: 4.11.3](https://img.shields.io/badge/Version-4.11.3-informational?style=flat-square) ![AppVersion: 1.11.3](https://img.shields.io/badge/AppVersion-1.11.3-informational?style=flat-square) + +To use, add `ingressClassName: nginx` spec field or the `kubernetes.io/ingress.class: nginx` annotation to your Ingress resources. + +This chart bootstraps an ingress-nginx deployment on a [Kubernetes](http://kubernetes.io) cluster using the [Helm](https://helm.sh) package manager. + +## Requirements + +Kubernetes: `>=1.21.0-0` + +## Get Repo Info + +```console +helm repo add ingress-nginx https://kubernetes.github.io/ingress-nginx +helm repo update +``` + +## Install Chart + +**Important:** only helm3 is supported + +```console +helm install [RELEASE_NAME] ingress-nginx/ingress-nginx +``` + +The command deploys ingress-nginx on the Kubernetes cluster in the default configuration. + +_See [configuration](#configuration) below._ + +_See [helm install](https://helm.sh/docs/helm/helm_install/) for command documentation._ + +## Uninstall Chart + +```console +helm uninstall [RELEASE_NAME] +``` + +This removes all the Kubernetes components associated with the chart and deletes the release. + +_See [helm uninstall](https://helm.sh/docs/helm/helm_uninstall/) for command documentation._ + +## Upgrading Chart + +```console +helm upgrade [RELEASE_NAME] [CHART] --install +``` + +_See [helm upgrade](https://helm.sh/docs/helm/helm_upgrade/) for command documentation._ + +### Migrating from stable/nginx-ingress + +There are two main ways to migrate a release from `stable/nginx-ingress` to `ingress-nginx/ingress-nginx` chart: + +1. For Nginx Ingress controllers used for non-critical services, the easiest method is to [uninstall](#uninstall-chart) the old release and [install](#install-chart) the new one +1. For critical services in production that require zero-downtime, you will want to: + 1. [Install](#install-chart) a second Ingress controller + 1. Redirect your DNS traffic from the old controller to the new controller + 1. Log traffic from both controllers during this changeover + 1. [Uninstall](#uninstall-chart) the old controller once traffic has fully drained from it + +Note that there are some different and upgraded configurations between the two charts, described by Rimas Mocevicius from JFrog in the "Upgrading to ingress-nginx Helm chart" section of [Migrating from Helm chart nginx-ingress to ingress-nginx](https://rimusz.net/migrating-to-ingress-nginx). As the `ingress-nginx/ingress-nginx` chart continues to update, you will want to check current differences by running [helm configuration](#configuration) commands on both charts. + +## Configuration + +See [Customizing the Chart Before Installing](https://helm.sh/docs/intro/using_helm/#customizing-the-chart-before-installing). To see all configurable options with detailed comments, visit the chart's [values.yaml](./values.yaml), or run these configuration commands: + +```console +helm show values ingress-nginx/ingress-nginx +``` + +### PodDisruptionBudget + +Note that the PodDisruptionBudget resource will only be defined if the replicaCount is greater than one, +else it would make it impossible to evacuate a node. See [gh issue #7127](https://github.com/helm/charts/issues/7127) for more info. + +### Prometheus Metrics + +The Ingress-Nginx Controller can export Prometheus metrics, by setting `controller.metrics.enabled` to `true`. + +You can add Prometheus annotations to the metrics service using `controller.metrics.service.annotations`. +Alternatively, if you use the Prometheus Operator, you can enable ServiceMonitor creation using `controller.metrics.serviceMonitor.enabled`. And set `controller.metrics.serviceMonitor.additionalLabels.release="prometheus"`. "release=prometheus" should match the label configured in the prometheus servicemonitor ( see `kubectl get servicemonitor prometheus-kube-prom-prometheus -oyaml -n prometheus`) + +### ingress-nginx nginx\_status page/stats server + +Previous versions of this chart had a `controller.stats.*` configuration block, which is now obsolete due to the following changes in Ingress-Nginx Controller: + +- In [0.16.1](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0161), the vts (virtual host traffic status) dashboard was removed +- In [0.23.0](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0230), the status page at port 18080 is now a unix socket webserver only available at localhost. + You can use `curl --unix-socket /tmp/nginx-status-server.sock http://localhost/nginx_status` inside the controller container to access it locally, or use the snippet from [nginx-ingress changelog](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0230) to re-enable the http server + +### ExternalDNS Service Configuration + +Add an [ExternalDNS](https://github.com/kubernetes-sigs/external-dns) annotation to the LoadBalancer service: + +```yaml +controller: + service: + annotations: + external-dns.alpha.kubernetes.io/hostname: kubernetes-example.com. +``` + +### AWS L7 ELB with SSL Termination + +Annotate the controller as shown in the [nginx-ingress l7 patch](https://github.com/kubernetes/ingress-nginx/blob/ab3a789caae65eec4ad6e3b46b19750b481b6bce/deploy/aws/l7/service-l7.yaml): + +```yaml +controller: + service: + targetPorts: + http: http + https: http + annotations: + service.beta.kubernetes.io/aws-load-balancer-ssl-cert: arn:aws:acm:XX-XXXX-X:XXXXXXXXX:certificate/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXX + service.beta.kubernetes.io/aws-load-balancer-backend-protocol: "http" + service.beta.kubernetes.io/aws-load-balancer-ssl-ports: "https" + service.beta.kubernetes.io/aws-load-balancer-connection-idle-timeout: '3600' +``` + +### Additional Internal Load Balancer + +This setup is useful when you need both external and internal load balancers but don't want to have multiple ingress controllers and multiple ingress objects per application. + +By default, the ingress object will point to the external load balancer address, but if correctly configured, you can make use of the internal one if the URL you are looking up resolves to the internal load balancer's URL. + +You'll need to set both the following values: + +`controller.service.internal.enabled` +`controller.service.internal.annotations` + +If one of them is missing the internal load balancer will not be deployed. Example you may have `controller.service.internal.enabled=true` but no annotations set, in this case no action will be taken. + +`controller.service.internal.annotations` varies with the cloud service you're using. + +Example for AWS: + +```yaml +controller: + service: + internal: + enabled: true + annotations: + # Create internal NLB + service.beta.kubernetes.io/aws-load-balancer-scheme: "internal" + # Create internal ELB(Deprecated) + # service.beta.kubernetes.io/aws-load-balancer-internal: "true" + # Any other annotation can be declared here. +``` + +Example for GCE: + +```yaml +controller: + service: + internal: + enabled: true + annotations: + # Create internal LB. More information: https://cloud.google.com/kubernetes-engine/docs/how-to/internal-load-balancing + # For GKE versions 1.17 and later + networking.gke.io/load-balancer-type: "Internal" + # For earlier versions + # cloud.google.com/load-balancer-type: "Internal" + + # Any other annotation can be declared here. +``` + +Example for Azure: + +```yaml +controller: + service: + annotations: + # Create internal LB + service.beta.kubernetes.io/azure-load-balancer-internal: "true" + # Any other annotation can be declared here. +``` + +Example for Oracle Cloud Infrastructure: + +```yaml +controller: + service: + annotations: + # Create internal LB + service.beta.kubernetes.io/oci-load-balancer-internal: "true" + # Any other annotation can be declared here. +``` + +The load balancer annotations of more cloud service providers can be found: [Internal load balancer](https://kubernetes.io/docs/concepts/services-networking/service/#internal-load-balancer). + +An use case for this scenario is having a split-view DNS setup where the public zone CNAME records point to the external balancer URL while the private zone CNAME records point to the internal balancer URL. This way, you only need one ingress kubernetes object. + +Optionally you can set `controller.service.loadBalancerIP` if you need a static IP for the resulting `LoadBalancer`. + +### Ingress Admission Webhooks + +With nginx-ingress-controller version 0.25+, the Ingress-Nginx Controller pod exposes an endpoint that will integrate with the `validatingwebhookconfiguration` Kubernetes feature to prevent bad ingress from being added to the cluster. +**This feature is enabled by default since 0.31.0.** + +With nginx-ingress-controller in 0.25.* work only with kubernetes 1.14+, 0.26 fix [this issue](https://github.com/kubernetes/ingress-nginx/pull/4521) + +#### How the Chart Configures the Hooks +A validating and configuration requires the endpoint to which the request is sent to use TLS. It is possible to set up custom certificates to do this, but in most cases, a self-signed certificate is enough. The setup of this component requires some more complex orchestration when using helm. The steps are created to be idempotent and to allow turning the feature on and off without running into helm quirks. + +1. A pre-install hook provisions a certificate into the same namespace using a format compatible with provisioning using end user certificates. If the certificate already exists, the hook exits. +2. The Ingress-Nginx Controller pod is configured to use a TLS proxy container, which will load that certificate. +3. Validating and Mutating webhook configurations are created in the cluster. +4. A post-install hook reads the CA from the secret created by step 1 and patches the Validating and Mutating webhook configurations. This process will allow a custom CA provisioned by some other process to also be patched into the webhook configurations. The chosen failure policy is also patched into the webhook configurations + +#### Alternatives +It should be possible to use [cert-manager/cert-manager](https://github.com/cert-manager/cert-manager) if a more complete solution is required. + +You can enable automatic self-signed TLS certificate provisioning via cert-manager by setting the `controller.admissionWebhooks.certManager.enabled` value to true. + +Please ensure that cert-manager is correctly installed and configured. + +### Helm Error When Upgrading: spec.clusterIP: Invalid value: "" + +If you are upgrading this chart from a version between 0.31.0 and 1.2.2 then you may get an error like this: + +```console +Error: UPGRADE FAILED: Service "?????-controller" is invalid: spec.clusterIP: Invalid value: "": field is immutable +``` + +Detail of how and why are in [this issue](https://github.com/helm/charts/pull/13646) but to resolve this you can set `xxxx.service.omitClusterIP` to `true` where `xxxx` is the service referenced in the error. + +As of version `1.26.0` of this chart, by simply not providing any clusterIP value, `invalid: spec.clusterIP: Invalid value: "": field is immutable` will no longer occur since `clusterIP: ""` will not be rendered. + +## Values + +| Key | Type | Default | Description | +|-----|------|---------|-------------| +| commonLabels | object | `{}` | | +| controller.addHeaders | object | `{}` | Will add custom headers before sending response traffic to the client according to: https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/#add-headers | +| controller.admissionWebhooks.annotations | object | `{}` | | +| controller.admissionWebhooks.certManager.admissionCert.duration | string | `""` | | +| controller.admissionWebhooks.certManager.enabled | bool | `false` | | +| controller.admissionWebhooks.certManager.rootCert.duration | string | `""` | | +| controller.admissionWebhooks.certificate | string | `"/usr/local/certificates/cert"` | | +| controller.admissionWebhooks.createSecretJob.name | string | `"create"` | | +| controller.admissionWebhooks.createSecretJob.resources | object | `{}` | | +| controller.admissionWebhooks.createSecretJob.securityContext | object | `{"allowPrivilegeEscalation":false,"capabilities":{"drop":["ALL"]},"readOnlyRootFilesystem":true,"runAsNonRoot":true,"runAsUser":65532,"seccompProfile":{"type":"RuntimeDefault"}}` | Security context for secret creation containers | +| controller.admissionWebhooks.enabled | bool | `true` | | +| controller.admissionWebhooks.existingPsp | string | `""` | Use an existing PSP instead of creating one | +| controller.admissionWebhooks.extraEnvs | list | `[]` | Additional environment variables to set | +| controller.admissionWebhooks.failurePolicy | string | `"Fail"` | Admission Webhook failure policy to use | +| controller.admissionWebhooks.key | string | `"/usr/local/certificates/key"` | | +| controller.admissionWebhooks.labels | object | `{}` | Labels to be added to admission webhooks | +| controller.admissionWebhooks.name | string | `"admission"` | | +| controller.admissionWebhooks.namespaceSelector | object | `{}` | | +| controller.admissionWebhooks.objectSelector | object | `{}` | | +| controller.admissionWebhooks.patch.enabled | bool | `true` | | +| controller.admissionWebhooks.patch.image.digest | string | `"sha256:a9f03b34a3cbfbb26d103a14046ab2c5130a80c3d69d526ff8063d2b37b9fd3f"` | | +| controller.admissionWebhooks.patch.image.image | string | `"ingress-nginx/kube-webhook-certgen"` | | +| controller.admissionWebhooks.patch.image.pullPolicy | string | `"IfNotPresent"` | | +| controller.admissionWebhooks.patch.image.registry | string | `"registry.k8s.io"` | | +| controller.admissionWebhooks.patch.image.tag | string | `"v1.4.4"` | | +| controller.admissionWebhooks.patch.labels | object | `{}` | Labels to be added to patch job resources | +| controller.admissionWebhooks.patch.networkPolicy.enabled | bool | `false` | Enable 'networkPolicy' or not | +| controller.admissionWebhooks.patch.nodeSelector."kubernetes.io/os" | string | `"linux"` | | +| controller.admissionWebhooks.patch.podAnnotations | object | `{}` | | +| controller.admissionWebhooks.patch.priorityClassName | string | `""` | Provide a priority class name to the webhook patching job # | +| controller.admissionWebhooks.patch.rbac | object | `{"create":true}` | Admission webhook patch job RBAC | +| controller.admissionWebhooks.patch.rbac.create | bool | `true` | Create RBAC or not | +| controller.admissionWebhooks.patch.securityContext | object | `{}` | Security context for secret creation & webhook patch pods | +| controller.admissionWebhooks.patch.serviceAccount | object | `{"automountServiceAccountToken":true,"create":true,"name":""}` | Admission webhook patch job service account | +| controller.admissionWebhooks.patch.serviceAccount.automountServiceAccountToken | bool | `true` | Auto-mount service account token or not | +| controller.admissionWebhooks.patch.serviceAccount.create | bool | `true` | Create a service account or not | +| controller.admissionWebhooks.patch.serviceAccount.name | string | `""` | Custom service account name | +| controller.admissionWebhooks.patch.tolerations | list | `[]` | | +| controller.admissionWebhooks.patchWebhookJob.name | string | `"patch"` | | +| controller.admissionWebhooks.patchWebhookJob.resources | object | `{}` | | +| controller.admissionWebhooks.patchWebhookJob.securityContext | object | `{"allowPrivilegeEscalation":false,"capabilities":{"drop":["ALL"]},"readOnlyRootFilesystem":true,"runAsNonRoot":true,"runAsUser":65532,"seccompProfile":{"type":"RuntimeDefault"}}` | Security context for webhook patch containers | +| controller.admissionWebhooks.port | int | `8443` | | +| controller.admissionWebhooks.service.annotations | object | `{}` | | +| controller.admissionWebhooks.service.externalIPs | list | `[]` | | +| controller.admissionWebhooks.service.loadBalancerSourceRanges | list | `[]` | | +| controller.admissionWebhooks.service.servicePort | int | `443` | | +| controller.admissionWebhooks.service.type | string | `"ClusterIP"` | | +| controller.affinity | object | `{}` | Affinity and anti-affinity rules for server scheduling to nodes # Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#affinity-and-anti-affinity # | +| controller.allowSnippetAnnotations | bool | `false` | This configuration defines if Ingress Controller should allow users to set their own *-snippet annotations, otherwise this is forbidden / dropped when users add those annotations. Global snippets in ConfigMap are still respected | +| controller.annotations | object | `{}` | Annotations to be added to the controller Deployment or DaemonSet # | +| controller.autoscaling.annotations | object | `{}` | | +| controller.autoscaling.behavior | object | `{}` | | +| controller.autoscaling.enabled | bool | `false` | | +| controller.autoscaling.maxReplicas | int | `11` | | +| controller.autoscaling.minReplicas | int | `1` | | +| controller.autoscaling.targetCPUUtilizationPercentage | int | `50` | | +| controller.autoscaling.targetMemoryUtilizationPercentage | int | `50` | | +| controller.autoscalingTemplate | list | `[]` | | +| controller.config | object | `{}` | Global configuration passed to the ConfigMap consumed by the controller. Values may contain Helm templates. Ref.: https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/ | +| controller.configAnnotations | object | `{}` | Annotations to be added to the controller config configuration configmap. | +| controller.configMapNamespace | string | `""` | Allows customization of the configmap / nginx-configmap namespace; defaults to $(POD_NAMESPACE) | +| controller.containerName | string | `"controller"` | Configures the controller container name | +| controller.containerPort | object | `{"http":80,"https":443}` | Configures the ports that the nginx-controller listens on | +| controller.containerSecurityContext | object | `{}` | Security context for controller containers | +| controller.customTemplate.configMapKey | string | `""` | | +| controller.customTemplate.configMapName | string | `""` | | +| controller.disableLeaderElection | bool | `false` | This configuration disable Nginx Controller Leader Election | +| controller.dnsConfig | object | `{}` | Optionally customize the pod dnsConfig. | +| controller.dnsPolicy | string | `"ClusterFirst"` | Optionally change this to ClusterFirstWithHostNet in case you have 'hostNetwork: true'. By default, while using host network, name resolution uses the host's DNS. If you wish nginx-controller to keep resolving names inside the k8s network, use ClusterFirstWithHostNet. | +| controller.electionID | string | `""` | Election ID to use for status update, by default it uses the controller name combined with a suffix of 'leader' | +| controller.electionTTL | string | `""` | Duration a leader election is valid before it's getting re-elected, e.g. `15s`, `10m` or `1h`. (Default: 30s) | +| controller.enableAnnotationValidations | bool | `false` | | +| controller.enableMimalloc | bool | `true` | Enable mimalloc as a drop-in replacement for malloc. # ref: https://github.com/microsoft/mimalloc # | +| controller.enableTopologyAwareRouting | bool | `false` | This configuration enables Topology Aware Routing feature, used together with service annotation service.kubernetes.io/topology-mode="auto" Defaults to false | +| controller.existingPsp | string | `""` | Use an existing PSP instead of creating one | +| controller.extraArgs | object | `{}` | Additional command line arguments to pass to Ingress-Nginx Controller E.g. to specify the default SSL certificate you can use | +| controller.extraContainers | list | `[]` | Additional containers to be added to the controller pod. See https://github.com/lemonldap-ng-controller/lemonldap-ng-controller as example. | +| controller.extraEnvs | list | `[]` | Additional environment variables to set | +| controller.extraInitContainers | list | `[]` | Containers, which are run before the app containers are started. | +| controller.extraModules | list | `[]` | Modules, which are mounted into the core nginx image. See values.yaml for a sample to add opentelemetry module | +| controller.extraVolumeMounts | list | `[]` | Additional volumeMounts to the controller main container. | +| controller.extraVolumes | list | `[]` | Additional volumes to the controller pod. | +| controller.healthCheckHost | string | `""` | Address to bind the health check endpoint. It is better to set this option to the internal node address if the Ingress-Nginx Controller is running in the `hostNetwork: true` mode. | +| controller.healthCheckPath | string | `"/healthz"` | Path of the health check endpoint. All requests received on the port defined by the healthz-port parameter are forwarded internally to this path. | +| controller.hostAliases | list | `[]` | Optionally customize the pod hostAliases. | +| controller.hostNetwork | bool | `false` | Required for use with CNI based kubernetes installations (such as ones set up by kubeadm), since CNI and hostport don't mix yet. Can be deprecated once https://github.com/kubernetes/kubernetes/issues/23920 is merged | +| controller.hostPort.enabled | bool | `false` | Enable 'hostPort' or not | +| controller.hostPort.ports.http | int | `80` | 'hostPort' http port | +| controller.hostPort.ports.https | int | `443` | 'hostPort' https port | +| controller.hostname | object | `{}` | Optionally customize the pod hostname. | +| controller.image.allowPrivilegeEscalation | bool | `false` | | +| controller.image.chroot | bool | `false` | | +| controller.image.digest | string | `"sha256:d56f135b6462cfc476447cfe564b83a45e8bb7da2774963b00d12161112270b7"` | | +| controller.image.digestChroot | string | `"sha256:22701f0fc0f2dd209ef782f4e281bfe2d8cccd50ededa00aec88e0cdbe7edd14"` | | +| controller.image.image | string | `"ingress-nginx/controller"` | | +| controller.image.pullPolicy | string | `"IfNotPresent"` | | +| controller.image.readOnlyRootFilesystem | bool | `false` | | +| controller.image.registry | string | `"registry.k8s.io"` | | +| controller.image.runAsNonRoot | bool | `true` | | +| controller.image.runAsUser | int | `101` | | +| controller.image.seccompProfile.type | string | `"RuntimeDefault"` | | +| controller.image.tag | string | `"v1.11.3"` | | +| controller.ingressClass | string | `"nginx"` | For backwards compatibility with ingress.class annotation, use ingressClass. Algorithm is as follows, first ingressClassName is considered, if not present, controller looks for ingress.class annotation | +| controller.ingressClassByName | bool | `false` | Process IngressClass per name (additionally as per spec.controller). | +| controller.ingressClassResource | object | `{"aliases":[],"annotations":{},"controllerValue":"k8s.io/ingress-nginx","default":false,"enabled":true,"name":"nginx","parameters":{}}` | This section refers to the creation of the IngressClass resource. IngressClasses are immutable and cannot be changed after creation. We do not support namespaced IngressClasses, yet, so a ClusterRole and a ClusterRoleBinding is required. | +| controller.ingressClassResource.aliases | list | `[]` | Aliases of this IngressClass. Creates copies with identical settings but the respective alias as name. Useful for development environments with only one Ingress Controller but production-like Ingress resources. `default` gets enabled on the original IngressClass only. | +| controller.ingressClassResource.annotations | object | `{}` | Annotations to be added to the IngressClass resource. | +| controller.ingressClassResource.controllerValue | string | `"k8s.io/ingress-nginx"` | Controller of the IngressClass. An Ingress Controller looks for IngressClasses it should reconcile by this value. This value is also being set as the `--controller-class` argument of this Ingress Controller. Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#ingress-class | +| controller.ingressClassResource.default | bool | `false` | If true, Ingresses without `ingressClassName` get assigned to this IngressClass on creation. Ingress creation gets rejected if there are multiple default IngressClasses. Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#default-ingress-class | +| controller.ingressClassResource.enabled | bool | `true` | Create the IngressClass or not | +| controller.ingressClassResource.name | string | `"nginx"` | Name of the IngressClass | +| controller.ingressClassResource.parameters | object | `{}` | A link to a custom resource containing additional configuration for the controller. This is optional if the controller consuming this IngressClass does not require additional parameters. Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#ingress-class | +| controller.keda.apiVersion | string | `"keda.sh/v1alpha1"` | | +| controller.keda.behavior | object | `{}` | | +| controller.keda.cooldownPeriod | int | `300` | | +| controller.keda.enabled | bool | `false` | | +| controller.keda.maxReplicas | int | `11` | | +| controller.keda.minReplicas | int | `1` | | +| controller.keda.pollingInterval | int | `30` | | +| controller.keda.restoreToOriginalReplicaCount | bool | `false` | | +| controller.keda.scaledObject.annotations | object | `{}` | | +| controller.keda.triggers | list | `[]` | | +| controller.kind | string | `"Deployment"` | Use a `DaemonSet` or `Deployment` | +| controller.labels | object | `{}` | Labels to be added to the controller Deployment or DaemonSet and other resources that do not have option to specify labels # | +| controller.lifecycle | object | `{"preStop":{"exec":{"command":["/wait-shutdown"]}}}` | Improve connection draining when ingress controller pod is deleted using a lifecycle hook: With this new hook, we increased the default terminationGracePeriodSeconds from 30 seconds to 300, allowing the draining of connections up to five minutes. If the active connections end before that, the pod will terminate gracefully at that time. To effectively take advantage of this feature, the Configmap feature worker-shutdown-timeout new value is 240s instead of 10s. # | +| controller.livenessProbe.failureThreshold | int | `5` | | +| controller.livenessProbe.httpGet.path | string | `"/healthz"` | | +| controller.livenessProbe.httpGet.port | int | `10254` | | +| controller.livenessProbe.httpGet.scheme | string | `"HTTP"` | | +| controller.livenessProbe.initialDelaySeconds | int | `10` | | +| controller.livenessProbe.periodSeconds | int | `10` | | +| controller.livenessProbe.successThreshold | int | `1` | | +| controller.livenessProbe.timeoutSeconds | int | `1` | | +| controller.maxmindLicenseKey | string | `""` | Maxmind license key to download GeoLite2 Databases. # https://blog.maxmind.com/2019/12/significant-changes-to-accessing-and-using-geolite2-databases/ | +| controller.metrics.enabled | bool | `false` | | +| controller.metrics.port | int | `10254` | | +| controller.metrics.portName | string | `"metrics"` | | +| controller.metrics.prometheusRule.additionalLabels | object | `{}` | | +| controller.metrics.prometheusRule.enabled | bool | `false` | | +| controller.metrics.prometheusRule.rules | list | `[]` | | +| controller.metrics.service.annotations | object | `{}` | | +| controller.metrics.service.externalIPs | list | `[]` | List of IP addresses at which the stats-exporter service is available # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips # | +| controller.metrics.service.labels | object | `{}` | Labels to be added to the metrics service resource | +| controller.metrics.service.loadBalancerSourceRanges | list | `[]` | | +| controller.metrics.service.servicePort | int | `10254` | | +| controller.metrics.service.type | string | `"ClusterIP"` | | +| controller.metrics.serviceMonitor.additionalLabels | object | `{}` | | +| controller.metrics.serviceMonitor.annotations | object | `{}` | Annotations to be added to the ServiceMonitor. | +| controller.metrics.serviceMonitor.enabled | bool | `false` | | +| controller.metrics.serviceMonitor.metricRelabelings | list | `[]` | | +| controller.metrics.serviceMonitor.namespace | string | `""` | | +| controller.metrics.serviceMonitor.namespaceSelector | object | `{}` | | +| controller.metrics.serviceMonitor.relabelings | list | `[]` | | +| controller.metrics.serviceMonitor.scrapeInterval | string | `"30s"` | | +| controller.metrics.serviceMonitor.targetLabels | list | `[]` | | +| controller.minAvailable | int | `1` | Minimum available pods set in PodDisruptionBudget. Define either 'minAvailable' or 'maxUnavailable', never both. | +| controller.minReadySeconds | int | `0` | `minReadySeconds` to avoid killing pods before we are ready # | +| controller.name | string | `"controller"` | | +| controller.networkPolicy.enabled | bool | `false` | Enable 'networkPolicy' or not | +| controller.nodeSelector | object | `{"kubernetes.io/os":"linux"}` | Node labels for controller pod assignment # Ref: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/ # | +| controller.opentelemetry.containerSecurityContext.allowPrivilegeEscalation | bool | `false` | | +| controller.opentelemetry.containerSecurityContext.capabilities.drop[0] | string | `"ALL"` | | +| controller.opentelemetry.containerSecurityContext.readOnlyRootFilesystem | bool | `true` | | +| controller.opentelemetry.containerSecurityContext.runAsNonRoot | bool | `true` | | +| controller.opentelemetry.containerSecurityContext.runAsUser | int | `65532` | The image's default user, inherited from its base image `cgr.dev/chainguard/static`. | +| controller.opentelemetry.containerSecurityContext.seccompProfile.type | string | `"RuntimeDefault"` | | +| controller.opentelemetry.enabled | bool | `false` | | +| controller.opentelemetry.image.digest | string | `"sha256:f7604ac0547ed64d79b98d92133234e66c2c8aade3c1f4809fed5eec1fb7f922"` | | +| controller.opentelemetry.image.distroless | bool | `true` | | +| controller.opentelemetry.image.image | string | `"ingress-nginx/opentelemetry-1.25.3"` | | +| controller.opentelemetry.image.registry | string | `"registry.k8s.io"` | | +| controller.opentelemetry.image.tag | string | `"v20240813-b933310d"` | | +| controller.opentelemetry.name | string | `"opentelemetry"` | | +| controller.opentelemetry.resources | object | `{}` | | +| controller.podAnnotations | object | `{}` | Annotations to be added to controller pods # | +| controller.podLabels | object | `{}` | Labels to add to the pod container metadata | +| controller.podSecurityContext | object | `{}` | Security context for controller pods | +| controller.priorityClassName | string | `""` | | +| controller.proxySetHeaders | object | `{}` | Will add custom headers before sending traffic to backends according to https://github.com/kubernetes/ingress-nginx/tree/main/docs/examples/customization/custom-headers | +| controller.publishService | object | `{"enabled":true,"pathOverride":""}` | Allows customization of the source of the IP address or FQDN to report in the ingress status field. By default, it reads the information provided by the service. If disable, the status field reports the IP address of the node or nodes where an ingress controller pod is running. | +| controller.publishService.enabled | bool | `true` | Enable 'publishService' or not | +| controller.publishService.pathOverride | string | `""` | Allows overriding of the publish service to bind to Must be / | +| controller.readinessProbe.failureThreshold | int | `3` | | +| controller.readinessProbe.httpGet.path | string | `"/healthz"` | | +| controller.readinessProbe.httpGet.port | int | `10254` | | +| controller.readinessProbe.httpGet.scheme | string | `"HTTP"` | | +| controller.readinessProbe.initialDelaySeconds | int | `10` | | +| controller.readinessProbe.periodSeconds | int | `10` | | +| controller.readinessProbe.successThreshold | int | `1` | | +| controller.readinessProbe.timeoutSeconds | int | `1` | | +| controller.replicaCount | int | `1` | | +| controller.reportNodeInternalIp | bool | `false` | Bare-metal considerations via the host network https://kubernetes.github.io/ingress-nginx/deploy/baremetal/#via-the-host-network Ingress status was blank because there is no Service exposing the Ingress-Nginx Controller in a configuration using the host network, the default --publish-service flag used in standard cloud setups does not apply | +| controller.resources.requests.cpu | string | `"100m"` | | +| controller.resources.requests.memory | string | `"90Mi"` | | +| controller.scope.enabled | bool | `false` | Enable 'scope' or not | +| controller.scope.namespace | string | `""` | Namespace to limit the controller to; defaults to $(POD_NAMESPACE) | +| controller.scope.namespaceSelector | string | `""` | When scope.enabled == false, instead of watching all namespaces, we watching namespaces whose labels only match with namespaceSelector. Format like foo=bar. Defaults to empty, means watching all namespaces. | +| controller.service.annotations | object | `{}` | Annotations to be added to the external controller service. See `controller.service.internal.annotations` for annotations to be added to the internal controller service. | +| controller.service.appProtocol | bool | `true` | Declare the app protocol of the external HTTP and HTTPS listeners or not. Supersedes provider-specific annotations for declaring the backend protocol. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#application-protocol | +| controller.service.clusterIP | string | `""` | Pre-defined cluster internal IP address of the external controller service. Take care of collisions with existing services. This value is immutable. Set once, it can not be changed without deleting and re-creating the service. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#choosing-your-own-ip-address | +| controller.service.enableHttp | bool | `true` | Enable the HTTP listener on both controller services or not. | +| controller.service.enableHttps | bool | `true` | Enable the HTTPS listener on both controller services or not. | +| controller.service.enabled | bool | `true` | Enable controller services or not. This does not influence the creation of either the admission webhook or the metrics service. | +| controller.service.external.enabled | bool | `true` | Enable the external controller service or not. Useful for internal-only deployments. | +| controller.service.externalIPs | list | `[]` | List of node IP addresses at which the external controller service is available. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips | +| controller.service.externalTrafficPolicy | string | `""` | External traffic policy of the external controller service. Set to "Local" to preserve source IP on providers supporting it. Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip | +| controller.service.internal.annotations | object | `{}` | Annotations to be added to the internal controller service. Mandatory for the internal controller service to be created. Varies with the cloud service. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#internal-load-balancer | +| controller.service.internal.appProtocol | bool | `true` | Declare the app protocol of the internal HTTP and HTTPS listeners or not. Supersedes provider-specific annotations for declaring the backend protocol. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#application-protocol | +| controller.service.internal.clusterIP | string | `""` | Pre-defined cluster internal IP address of the internal controller service. Take care of collisions with existing services. This value is immutable. Set once, it can not be changed without deleting and re-creating the service. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#choosing-your-own-ip-address | +| controller.service.internal.enabled | bool | `false` | Enable the internal controller service or not. Remember to configure `controller.service.internal.annotations` when enabling this. | +| controller.service.internal.externalIPs | list | `[]` | List of node IP addresses at which the internal controller service is available. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips | +| controller.service.internal.externalTrafficPolicy | string | `""` | External traffic policy of the internal controller service. Set to "Local" to preserve source IP on providers supporting it. Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip | +| controller.service.internal.ipFamilies | list | `["IPv4"]` | List of IP families (e.g. IPv4, IPv6) assigned to the internal controller service. This field is usually assigned automatically based on cluster configuration and the `ipFamilyPolicy` field. Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services | +| controller.service.internal.ipFamilyPolicy | string | `"SingleStack"` | Represents the dual-stack capabilities of the internal controller service. Possible values are SingleStack, PreferDualStack or RequireDualStack. Fields `ipFamilies` and `clusterIP` depend on the value of this field. Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services | +| controller.service.internal.loadBalancerClass | string | `""` | Load balancer class of the internal controller service. Used by cloud providers to select a load balancer implementation other than the cloud provider default. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-class | +| controller.service.internal.loadBalancerIP | string | `""` | Deprecated: Pre-defined IP address of the internal controller service. Used by cloud providers to connect the resulting load balancer service to a pre-existing static IP. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#loadbalancer | +| controller.service.internal.loadBalancerSourceRanges | list | `[]` | Restrict access to the internal controller service. Values must be CIDRs. Allows any source address by default. | +| controller.service.internal.nodePorts.http | string | `""` | Node port allocated for the internal HTTP listener. If left empty, the service controller allocates one from the configured node port range. | +| controller.service.internal.nodePorts.https | string | `""` | Node port allocated for the internal HTTPS listener. If left empty, the service controller allocates one from the configured node port range. | +| controller.service.internal.nodePorts.tcp | object | `{}` | Node port mapping for internal TCP listeners. If left empty, the service controller allocates them from the configured node port range. Example: tcp: 8080: 30080 | +| controller.service.internal.nodePorts.udp | object | `{}` | Node port mapping for internal UDP listeners. If left empty, the service controller allocates them from the configured node port range. Example: udp: 53: 30053 | +| controller.service.internal.ports | object | `{}` | | +| controller.service.internal.sessionAffinity | string | `""` | Session affinity of the internal controller service. Must be either "None" or "ClientIP" if set. Defaults to "None". Ref: https://kubernetes.io/docs/reference/networking/virtual-ips/#session-affinity | +| controller.service.internal.targetPorts | object | `{}` | | +| controller.service.internal.type | string | `""` | Type of the internal controller service. Defaults to the value of `controller.service.type`. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types | +| controller.service.ipFamilies | list | `["IPv4"]` | List of IP families (e.g. IPv4, IPv6) assigned to the external controller service. This field is usually assigned automatically based on cluster configuration and the `ipFamilyPolicy` field. Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services | +| controller.service.ipFamilyPolicy | string | `"SingleStack"` | Represents the dual-stack capabilities of the external controller service. Possible values are SingleStack, PreferDualStack or RequireDualStack. Fields `ipFamilies` and `clusterIP` depend on the value of this field. Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services | +| controller.service.labels | object | `{}` | Labels to be added to both controller services. | +| controller.service.loadBalancerClass | string | `""` | Load balancer class of the external controller service. Used by cloud providers to select a load balancer implementation other than the cloud provider default. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-class | +| controller.service.loadBalancerIP | string | `""` | Deprecated: Pre-defined IP address of the external controller service. Used by cloud providers to connect the resulting load balancer service to a pre-existing static IP. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#loadbalancer | +| controller.service.loadBalancerSourceRanges | list | `[]` | Restrict access to the external controller service. Values must be CIDRs. Allows any source address by default. | +| controller.service.nodePorts.http | string | `""` | Node port allocated for the external HTTP listener. If left empty, the service controller allocates one from the configured node port range. | +| controller.service.nodePorts.https | string | `""` | Node port allocated for the external HTTPS listener. If left empty, the service controller allocates one from the configured node port range. | +| controller.service.nodePorts.tcp | object | `{}` | Node port mapping for external TCP listeners. If left empty, the service controller allocates them from the configured node port range. Example: tcp: 8080: 30080 | +| controller.service.nodePorts.udp | object | `{}` | Node port mapping for external UDP listeners. If left empty, the service controller allocates them from the configured node port range. Example: udp: 53: 30053 | +| controller.service.ports.http | int | `80` | Port the external HTTP listener is published with. | +| controller.service.ports.https | int | `443` | Port the external HTTPS listener is published with. | +| controller.service.sessionAffinity | string | `""` | Session affinity of the external controller service. Must be either "None" or "ClientIP" if set. Defaults to "None". Ref: https://kubernetes.io/docs/reference/networking/virtual-ips/#session-affinity | +| controller.service.targetPorts.http | string | `"http"` | Port of the ingress controller the external HTTP listener is mapped to. | +| controller.service.targetPorts.https | string | `"https"` | Port of the ingress controller the external HTTPS listener is mapped to. | +| controller.service.type | string | `"LoadBalancer"` | Type of the external controller service. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types | +| controller.shareProcessNamespace | bool | `false` | | +| controller.sysctls | object | `{}` | sysctls for controller pods # Ref: https://kubernetes.io/docs/tasks/administer-cluster/sysctl-cluster/ | +| controller.tcp.annotations | object | `{}` | Annotations to be added to the tcp config configmap | +| controller.tcp.configMapNamespace | string | `""` | Allows customization of the tcp-services-configmap; defaults to $(POD_NAMESPACE) | +| controller.terminationGracePeriodSeconds | int | `300` | `terminationGracePeriodSeconds` to avoid killing pods before we are ready # wait up to five minutes for the drain of connections # | +| controller.tolerations | list | `[]` | Node tolerations for server scheduling to nodes with taints # Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/ # | +| controller.topologySpreadConstraints | list | `[]` | Topology spread constraints rely on node labels to identify the topology domain(s) that each Node is in. # Ref: https://kubernetes.io/docs/concepts/workloads/pods/pod-topology-spread-constraints/ # | +| controller.udp.annotations | object | `{}` | Annotations to be added to the udp config configmap | +| controller.udp.configMapNamespace | string | `""` | Allows customization of the udp-services-configmap; defaults to $(POD_NAMESPACE) | +| controller.updateStrategy | object | `{}` | The update strategy to apply to the Deployment or DaemonSet # | +| controller.watchIngressWithoutClass | bool | `false` | Process Ingress objects without ingressClass annotation/ingressClassName field Overrides value for --watch-ingress-without-class flag of the controller binary Defaults to false | +| defaultBackend.affinity | object | `{}` | Affinity and anti-affinity rules for server scheduling to nodes # Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#affinity-and-anti-affinity | +| defaultBackend.autoscaling.annotations | object | `{}` | | +| defaultBackend.autoscaling.enabled | bool | `false` | | +| defaultBackend.autoscaling.maxReplicas | int | `2` | | +| defaultBackend.autoscaling.minReplicas | int | `1` | | +| defaultBackend.autoscaling.targetCPUUtilizationPercentage | int | `50` | | +| defaultBackend.autoscaling.targetMemoryUtilizationPercentage | int | `50` | | +| defaultBackend.containerSecurityContext | object | `{}` | Security context for default backend containers | +| defaultBackend.enabled | bool | `false` | | +| defaultBackend.existingPsp | string | `""` | Use an existing PSP instead of creating one | +| defaultBackend.extraArgs | object | `{}` | | +| defaultBackend.extraConfigMaps | list | `[]` | | +| defaultBackend.extraEnvs | list | `[]` | Additional environment variables to set for defaultBackend pods | +| defaultBackend.extraVolumeMounts | list | `[]` | | +| defaultBackend.extraVolumes | list | `[]` | | +| defaultBackend.image.allowPrivilegeEscalation | bool | `false` | | +| defaultBackend.image.image | string | `"defaultbackend-amd64"` | | +| defaultBackend.image.pullPolicy | string | `"IfNotPresent"` | | +| defaultBackend.image.readOnlyRootFilesystem | bool | `true` | | +| defaultBackend.image.registry | string | `"registry.k8s.io"` | | +| defaultBackend.image.runAsNonRoot | bool | `true` | | +| defaultBackend.image.runAsUser | int | `65534` | | +| defaultBackend.image.seccompProfile.type | string | `"RuntimeDefault"` | | +| defaultBackend.image.tag | string | `"1.5"` | | +| defaultBackend.labels | object | `{}` | Labels to be added to the default backend resources | +| defaultBackend.livenessProbe.failureThreshold | int | `3` | | +| defaultBackend.livenessProbe.initialDelaySeconds | int | `30` | | +| defaultBackend.livenessProbe.periodSeconds | int | `10` | | +| defaultBackend.livenessProbe.successThreshold | int | `1` | | +| defaultBackend.livenessProbe.timeoutSeconds | int | `5` | | +| defaultBackend.minAvailable | int | `1` | Minimum available pods set in PodDisruptionBudget. | +| defaultBackend.minReadySeconds | int | `0` | `minReadySeconds` to avoid killing pods before we are ready # | +| defaultBackend.name | string | `"defaultbackend"` | | +| defaultBackend.networkPolicy.enabled | bool | `false` | Enable 'networkPolicy' or not | +| defaultBackend.nodeSelector | object | `{"kubernetes.io/os":"linux"}` | Node labels for default backend pod assignment # Ref: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/ # | +| defaultBackend.podAnnotations | object | `{}` | Annotations to be added to default backend pods # | +| defaultBackend.podLabels | object | `{}` | Labels to add to the pod container metadata | +| defaultBackend.podSecurityContext | object | `{}` | Security context for default backend pods | +| defaultBackend.port | int | `8080` | | +| defaultBackend.priorityClassName | string | `""` | | +| defaultBackend.readinessProbe.failureThreshold | int | `6` | | +| defaultBackend.readinessProbe.initialDelaySeconds | int | `0` | | +| defaultBackend.readinessProbe.periodSeconds | int | `5` | | +| defaultBackend.readinessProbe.successThreshold | int | `1` | | +| defaultBackend.readinessProbe.timeoutSeconds | int | `5` | | +| defaultBackend.replicaCount | int | `1` | | +| defaultBackend.resources | object | `{}` | | +| defaultBackend.service.annotations | object | `{}` | | +| defaultBackend.service.externalIPs | list | `[]` | List of IP addresses at which the default backend service is available # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips # | +| defaultBackend.service.loadBalancerSourceRanges | list | `[]` | | +| defaultBackend.service.servicePort | int | `80` | | +| defaultBackend.service.type | string | `"ClusterIP"` | | +| defaultBackend.serviceAccount.automountServiceAccountToken | bool | `true` | | +| defaultBackend.serviceAccount.create | bool | `true` | | +| defaultBackend.serviceAccount.name | string | `""` | | +| defaultBackend.tolerations | list | `[]` | Node tolerations for server scheduling to nodes with taints # Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/ # | +| defaultBackend.topologySpreadConstraints | list | `[]` | Topology spread constraints rely on node labels to identify the topology domain(s) that each Node is in. Ref.: https://kubernetes.io/docs/concepts/workloads/pods/pod-topology-spread-constraints/ | +| defaultBackend.updateStrategy | object | `{}` | The update strategy to apply to the Deployment or DaemonSet # | +| dhParam | string | `""` | A base64-encoded Diffie-Hellman parameter. This can be generated with: `openssl dhparam 4096 2> /dev/null | base64` # Ref: https://github.com/kubernetes/ingress-nginx/tree/main/docs/examples/customization/ssl-dh-param | +| imagePullSecrets | list | `[]` | Optional array of imagePullSecrets containing private registry credentials # Ref: https://kubernetes.io/docs/tasks/configure-pod-container/pull-image-private-registry/ | +| namespaceOverride | string | `""` | Override the deployment namespace; defaults to .Release.Namespace | +| podSecurityPolicy.enabled | bool | `false` | | +| portNamePrefix | string | `""` | Prefix for TCP and UDP ports names in ingress controller service # Some cloud providers, like Yandex Cloud may have a requirements for a port name regex to support cloud load balancer integration | +| rbac.create | bool | `true` | | +| rbac.scope | bool | `false` | | +| revisionHistoryLimit | int | `10` | Rollback limit # | +| serviceAccount.annotations | object | `{}` | Annotations for the controller service account | +| serviceAccount.automountServiceAccountToken | bool | `true` | | +| serviceAccount.create | bool | `true` | | +| serviceAccount.name | string | `""` | | +| tcp | object | `{}` | TCP service key-value pairs # Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/exposing-tcp-udp-services.md # | +| udp | object | `{}` | UDP service key-value pairs # Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/exposing-tcp-udp-services.md # | diff --git a/charts/keep/charts/ingress-nginx/README.md.gotmpl b/charts/keep/charts/ingress-nginx/README.md.gotmpl new file mode 100644 index 0000000..17b029b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/README.md.gotmpl @@ -0,0 +1,229 @@ +{{ template "chart.header" . }} +[ingress-nginx](https://github.com/kubernetes/ingress-nginx) Ingress controller for Kubernetes using NGINX as a reverse proxy and load balancer + +{{ template "chart.versionBadge" . }}{{ template "chart.typeBadge" . }}{{ template "chart.appVersionBadge" . }} + +To use, add `ingressClassName: nginx` spec field or the `kubernetes.io/ingress.class: nginx` annotation to your Ingress resources. + +This chart bootstraps an ingress-nginx deployment on a [Kubernetes](http://kubernetes.io) cluster using the [Helm](https://helm.sh) package manager. + +{{ template "chart.requirementsSection" . }} + +## Get Repo Info + +```console +helm repo add ingress-nginx https://kubernetes.github.io/ingress-nginx +helm repo update +``` + +## Install Chart + +**Important:** only helm3 is supported + +```console +helm install [RELEASE_NAME] ingress-nginx/ingress-nginx +``` + +The command deploys ingress-nginx on the Kubernetes cluster in the default configuration. + +_See [configuration](#configuration) below._ + +_See [helm install](https://helm.sh/docs/helm/helm_install/) for command documentation._ + +## Uninstall Chart + +```console +helm uninstall [RELEASE_NAME] +``` + +This removes all the Kubernetes components associated with the chart and deletes the release. + +_See [helm uninstall](https://helm.sh/docs/helm/helm_uninstall/) for command documentation._ + +## Upgrading Chart + +```console +helm upgrade [RELEASE_NAME] [CHART] --install +``` + +_See [helm upgrade](https://helm.sh/docs/helm/helm_upgrade/) for command documentation._ + +### Migrating from stable/nginx-ingress + +There are two main ways to migrate a release from `stable/nginx-ingress` to `ingress-nginx/ingress-nginx` chart: + +1. For Nginx Ingress controllers used for non-critical services, the easiest method is to [uninstall](#uninstall-chart) the old release and [install](#install-chart) the new one +1. For critical services in production that require zero-downtime, you will want to: + 1. [Install](#install-chart) a second Ingress controller + 1. Redirect your DNS traffic from the old controller to the new controller + 1. Log traffic from both controllers during this changeover + 1. [Uninstall](#uninstall-chart) the old controller once traffic has fully drained from it + +Note that there are some different and upgraded configurations between the two charts, described by Rimas Mocevicius from JFrog in the "Upgrading to ingress-nginx Helm chart" section of [Migrating from Helm chart nginx-ingress to ingress-nginx](https://rimusz.net/migrating-to-ingress-nginx). As the `ingress-nginx/ingress-nginx` chart continues to update, you will want to check current differences by running [helm configuration](#configuration) commands on both charts. + +## Configuration + +See [Customizing the Chart Before Installing](https://helm.sh/docs/intro/using_helm/#customizing-the-chart-before-installing). To see all configurable options with detailed comments, visit the chart's [values.yaml](./values.yaml), or run these configuration commands: + +```console +helm show values ingress-nginx/ingress-nginx +``` + +### PodDisruptionBudget + +Note that the PodDisruptionBudget resource will only be defined if the replicaCount is greater than one, +else it would make it impossible to evacuate a node. See [gh issue #7127](https://github.com/helm/charts/issues/7127) for more info. + +### Prometheus Metrics + +The Ingress-Nginx Controller can export Prometheus metrics, by setting `controller.metrics.enabled` to `true`. + +You can add Prometheus annotations to the metrics service using `controller.metrics.service.annotations`. +Alternatively, if you use the Prometheus Operator, you can enable ServiceMonitor creation using `controller.metrics.serviceMonitor.enabled`. And set `controller.metrics.serviceMonitor.additionalLabels.release="prometheus"`. "release=prometheus" should match the label configured in the prometheus servicemonitor ( see `kubectl get servicemonitor prometheus-kube-prom-prometheus -oyaml -n prometheus`) + +### ingress-nginx nginx\_status page/stats server + +Previous versions of this chart had a `controller.stats.*` configuration block, which is now obsolete due to the following changes in Ingress-Nginx Controller: + +- In [0.16.1](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0161), the vts (virtual host traffic status) dashboard was removed +- In [0.23.0](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0230), the status page at port 18080 is now a unix socket webserver only available at localhost. + You can use `curl --unix-socket /tmp/nginx-status-server.sock http://localhost/nginx_status` inside the controller container to access it locally, or use the snippet from [nginx-ingress changelog](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0230) to re-enable the http server + +### ExternalDNS Service Configuration + +Add an [ExternalDNS](https://github.com/kubernetes-sigs/external-dns) annotation to the LoadBalancer service: + +```yaml +controller: + service: + annotations: + external-dns.alpha.kubernetes.io/hostname: kubernetes-example.com. +``` + +### AWS L7 ELB with SSL Termination + +Annotate the controller as shown in the [nginx-ingress l7 patch](https://github.com/kubernetes/ingress-nginx/blob/ab3a789caae65eec4ad6e3b46b19750b481b6bce/deploy/aws/l7/service-l7.yaml): + +```yaml +controller: + service: + targetPorts: + http: http + https: http + annotations: + service.beta.kubernetes.io/aws-load-balancer-ssl-cert: arn:aws:acm:XX-XXXX-X:XXXXXXXXX:certificate/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXX + service.beta.kubernetes.io/aws-load-balancer-backend-protocol: "http" + service.beta.kubernetes.io/aws-load-balancer-ssl-ports: "https" + service.beta.kubernetes.io/aws-load-balancer-connection-idle-timeout: '3600' +``` + +### Additional Internal Load Balancer + +This setup is useful when you need both external and internal load balancers but don't want to have multiple ingress controllers and multiple ingress objects per application. + +By default, the ingress object will point to the external load balancer address, but if correctly configured, you can make use of the internal one if the URL you are looking up resolves to the internal load balancer's URL. + +You'll need to set both the following values: + +`controller.service.internal.enabled` +`controller.service.internal.annotations` + +If one of them is missing the internal load balancer will not be deployed. Example you may have `controller.service.internal.enabled=true` but no annotations set, in this case no action will be taken. + +`controller.service.internal.annotations` varies with the cloud service you're using. + +Example for AWS: + +```yaml +controller: + service: + internal: + enabled: true + annotations: + # Create internal NLB + service.beta.kubernetes.io/aws-load-balancer-scheme: "internal" + # Create internal ELB(Deprecated) + # service.beta.kubernetes.io/aws-load-balancer-internal: "true" + # Any other annotation can be declared here. +``` + +Example for GCE: + +```yaml +controller: + service: + internal: + enabled: true + annotations: + # Create internal LB. More information: https://cloud.google.com/kubernetes-engine/docs/how-to/internal-load-balancing + # For GKE versions 1.17 and later + networking.gke.io/load-balancer-type: "Internal" + # For earlier versions + # cloud.google.com/load-balancer-type: "Internal" + + # Any other annotation can be declared here. +``` + +Example for Azure: + +```yaml +controller: + service: + annotations: + # Create internal LB + service.beta.kubernetes.io/azure-load-balancer-internal: "true" + # Any other annotation can be declared here. +``` + +Example for Oracle Cloud Infrastructure: + +```yaml +controller: + service: + annotations: + # Create internal LB + service.beta.kubernetes.io/oci-load-balancer-internal: "true" + # Any other annotation can be declared here. +``` + +The load balancer annotations of more cloud service providers can be found: [Internal load balancer](https://kubernetes.io/docs/concepts/services-networking/service/#internal-load-balancer). + +An use case for this scenario is having a split-view DNS setup where the public zone CNAME records point to the external balancer URL while the private zone CNAME records point to the internal balancer URL. This way, you only need one ingress kubernetes object. + +Optionally you can set `controller.service.loadBalancerIP` if you need a static IP for the resulting `LoadBalancer`. + +### Ingress Admission Webhooks + +With nginx-ingress-controller version 0.25+, the Ingress-Nginx Controller pod exposes an endpoint that will integrate with the `validatingwebhookconfiguration` Kubernetes feature to prevent bad ingress from being added to the cluster. +**This feature is enabled by default since 0.31.0.** + +With nginx-ingress-controller in 0.25.* work only with kubernetes 1.14+, 0.26 fix [this issue](https://github.com/kubernetes/ingress-nginx/pull/4521) + +#### How the Chart Configures the Hooks +A validating and configuration requires the endpoint to which the request is sent to use TLS. It is possible to set up custom certificates to do this, but in most cases, a self-signed certificate is enough. The setup of this component requires some more complex orchestration when using helm. The steps are created to be idempotent and to allow turning the feature on and off without running into helm quirks. + +1. A pre-install hook provisions a certificate into the same namespace using a format compatible with provisioning using end user certificates. If the certificate already exists, the hook exits. +2. The Ingress-Nginx Controller pod is configured to use a TLS proxy container, which will load that certificate. +3. Validating and Mutating webhook configurations are created in the cluster. +4. A post-install hook reads the CA from the secret created by step 1 and patches the Validating and Mutating webhook configurations. This process will allow a custom CA provisioned by some other process to also be patched into the webhook configurations. The chosen failure policy is also patched into the webhook configurations + +#### Alternatives +It should be possible to use [cert-manager/cert-manager](https://github.com/cert-manager/cert-manager) if a more complete solution is required. + +You can enable automatic self-signed TLS certificate provisioning via cert-manager by setting the `controller.admissionWebhooks.certManager.enabled` value to true. + +Please ensure that cert-manager is correctly installed and configured. + +### Helm Error When Upgrading: spec.clusterIP: Invalid value: "" + +If you are upgrading this chart from a version between 0.31.0 and 1.2.2 then you may get an error like this: + +```console +Error: UPGRADE FAILED: Service "?????-controller" is invalid: spec.clusterIP: Invalid value: "": field is immutable +``` + +Detail of how and why are in [this issue](https://github.com/helm/charts/pull/13646) but to resolve this you can set `xxxx.service.omitClusterIP` to `true` where `xxxx` is the service referenced in the error. + +As of version `1.26.0` of this chart, by simply not providing any clusterIP value, `invalid: spec.clusterIP: Invalid value: "": field is immutable` will no longer occur since `clusterIP: ""` will not be rendered. + +{{ template "chart.valuesSection" . }} diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.10.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.10.0.md new file mode 100644 index 0000000..b42d6c2 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.10.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.10.0 + +* [#5843](https://github.com/kubernetes/ingress-nginx/pull/5843) Update jettech/kube-webhook-certgen image + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.9.1...ingress-nginx-2.10.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.0.md new file mode 100644 index 0000000..e549b38 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.0.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.11.0 + +* [#5879](https://github.com/kubernetes/ingress-nginx/pull/5879) Update helm chart for v0.34.0 +* [#5671](https://github.com/kubernetes/ingress-nginx/pull/5671) Make liveness probe more fault tolerant than readiness probe + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.10.0...ingress-nginx-2.11.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.1.md new file mode 100644 index 0000000..d910d3b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.11.1 + +* [#5900](https://github.com/kubernetes/ingress-nginx/pull/5900) Release helm chart for v0.34.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.11.0...ingress-nginx-2.11.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.2.md new file mode 100644 index 0000000..9f78210 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.2.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.11.2 + +* [#5951](https://github.com/kubernetes/ingress-nginx/pull/5951) Bump chart patch version + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.11.1...ingress-nginx-2.11.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.3.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.3.md new file mode 100644 index 0000000..3447691 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.3.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.11.3 + +* [#6038](https://github.com/kubernetes/ingress-nginx/pull/6038) Bump chart version PATCH + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.11.2...ingress-nginx-2.11.3 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.0.md new file mode 100644 index 0000000..5cb3888 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.0.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.12.0 + +* [#6039](https://github.com/kubernetes/ingress-nginx/pull/6039) Add configurable serviceMonitor metricRelabelling and targetLabels +* [#6044](https://github.com/kubernetes/ingress-nginx/pull/6044) Fix YAML linting + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.11.3...ingress-nginx-2.12.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.1.md new file mode 100644 index 0000000..94d121d --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.12.1 + +* [#6075](https://github.com/kubernetes/ingress-nginx/pull/6075) Sync helm chart affinity examples + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.12.0...ingress-nginx-2.12.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.13.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.13.0.md new file mode 100644 index 0000000..01fe0b1 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.13.0.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.13.0 + +* [#6093](https://github.com/kubernetes/ingress-nginx/pull/6093) Release v0.35.0 +* [#6080](https://github.com/kubernetes/ingress-nginx/pull/6080) Switch images to k8s.gcr.io after Vanity Domain Flip + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.12.1...ingress-nginx-2.13.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.14.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.14.0.md new file mode 100644 index 0000000..2fb7a5a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.14.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.14.0 + +* [#6104](https://github.com/kubernetes/ingress-nginx/pull/6104) Misc fixes for nginx-ingress chart for better keel and prometheus-operator integration + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.13.0...ingress-nginx-2.14.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.15.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.15.0.md new file mode 100644 index 0000000..543a559 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.15.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.15.0 + +* [#6087](https://github.com/kubernetes/ingress-nginx/pull/6087) Adding parameter for externalTrafficPolicy in internal controller service spec + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.14.0...ingress-nginx-2.15.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.16.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.16.0.md new file mode 100644 index 0000000..996f448 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.16.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.16.0 + +* [#6154](https://github.com/kubernetes/ingress-nginx/pull/6154) add `topologySpreadConstraint` to controller + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.15.0...ingress-nginx-2.16.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.0.md new file mode 100644 index 0000000..11c5f5f --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.9.0 + +* [#5795](https://github.com/kubernetes/ingress-nginx/pull/5795) Use fully qualified images to avoid cri-o issues + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-TODO...ingress-nginx-2.9.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.1.md new file mode 100644 index 0000000..7d4314d --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.9.1 + +* [#5823](https://github.com/kubernetes/ingress-nginx/pull/5823) Add quoting to sysctls because numeric values need to be presented as strings (#5823) + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.9.0...ingress-nginx-2.9.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.0.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.0.0.md new file mode 100644 index 0000000..a7d50ee --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.0.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.0.0 + +* [#6167](https://github.com/kubernetes/ingress-nginx/pull/6167) Update chart requirements + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.16.0...ingress-nginx-3.0.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.0.md new file mode 100644 index 0000000..3369bed --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.10.0 + +* Fix routing regression introduced in 0.41.0 with PathType Exact + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.9.0...ingress-nginx-3.10.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.1.md new file mode 100644 index 0000000..6ff682e --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.10.1 + +* Fix regression introduced in 0.41.0 with external authentication + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.10.0...ingress-nginx-3.10.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.0.md new file mode 100644 index 0000000..69ba550 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.11.0 + +* Support Keda Autoscaling + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.10.1...ingress-nginx-3.11.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.1.md new file mode 100644 index 0000000..4e81f4b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.11.1 + +* [#6505](https://github.com/kubernetes/ingress-nginx/pull/6505) Reorder HPA resource list to work with GitOps tooling + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.11.0...ingress-nginx-3.11.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.12.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.12.0.md new file mode 100644 index 0000000..41b9744 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.12.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.12.0 + +* [#6514](https://github.com/kubernetes/ingress-nginx/pull/6514) Remove helm2 support and update docs + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.11.1...ingress-nginx-3.12.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.13.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.13.0.md new file mode 100644 index 0000000..0855a79 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.13.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.13.0 + +* [#6544](https://github.com/kubernetes/ingress-nginx/pull/6544) Fix default backend HPA name variable + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.12.0...ingress-nginx-3.13.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.14.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.14.0.md new file mode 100644 index 0000000..e07880b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.14.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.14.0 + +* [#6469](https://github.com/kubernetes/ingress-nginx/pull/6469) Allow custom service names for controller and backend + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.13.0...ingress-nginx-3.14.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.0.md new file mode 100644 index 0000000..3053a35 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.15.0 + +* [#6586](https://github.com/kubernetes/ingress-nginx/pull/6586) Fix 'maxmindLicenseKey' location in values.yaml + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.14.0...ingress-nginx-3.15.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.1.md new file mode 100644 index 0000000..f11ee0a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.15.1 + +* Fix chart-releaser action + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.15.0...ingress-nginx-3.15.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.0.md new file mode 100644 index 0000000..fba30b1 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.16.0 + +* [#6646](https://github.com/kubernetes/ingress-nginx/pull/6646) Added LoadBalancerIP value for internal service + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.15.1...helm-chart-3.16.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.1.md new file mode 100644 index 0000000..650d1b8 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.16.1 + +* Fix chart-releaser action + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.16.0...helm-chart-3.16.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.17.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.17.0.md new file mode 100644 index 0000000..175c7a2 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.17.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.17.0 + +* Update ingress-nginx v0.42.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.16.1...helm-chart-3.17.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.18.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.18.0.md new file mode 100644 index 0000000..31b815e --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.18.0.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.18.0 + +* [#6688](https://github.com/kubernetes/ingress-nginx/pull/6688) Allow volume-type emptyDir in controller podsecuritypolicy +* [#6691](https://github.com/kubernetes/ingress-nginx/pull/6691) Improve parsing of helm parameters + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.17.0...helm-chart-3.18.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.19.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.19.0.md new file mode 100644 index 0000000..0970bf0 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.19.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.19.0 + +* Update ingress-nginx v0.43.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.18.0...helm-chart-3.19.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.0.md new file mode 100644 index 0000000..4b81ae4 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.20.0 + +* [#6730](https://github.com/kubernetes/ingress-nginx/pull/6730) Do not create HPA for defaultBackend if not enabled. + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.19.0...helm-chart-3.20.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.1.md new file mode 100644 index 0000000..952bf2b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.1.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.20.1 + +* Do not create KEDA in case of DaemonSets. +* Fix KEDA v2 definition + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.20.0...helm-chart-3.20.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.21.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.21.0.md new file mode 100644 index 0000000..25edbef --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.21.0.md @@ -0,0 +1,12 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.21.0 + +* [#6783](https://github.com/kubernetes/ingress-nginx/pull/6783) Add custom annotations to ScaledObject +* [#6761](https://github.com/kubernetes/ingress-nginx/pull/6761) Adding quotes in the serviceAccount name in Helm values +* [#6767](https://github.com/kubernetes/ingress-nginx/pull/6767) Remove ClusterRole when scope option is enabled +* [#6785](https://github.com/kubernetes/ingress-nginx/pull/6785) Update kube-webhook-certgen image to v1.5.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.20.1...helm-chart-3.21.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.22.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.22.0.md new file mode 100644 index 0000000..147d664 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.22.0.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.22.0 + +* [#6802](https://github.com/kubernetes/ingress-nginx/pull/6802) Add value for configuring a custom Diffie-Hellman parameters file +* [#6815](https://github.com/kubernetes/ingress-nginx/pull/6815) Allow use of numeric namespaces in helm chart + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.21.0...helm-chart-3.22.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.23.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.23.0.md new file mode 100644 index 0000000..5dcb50f --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.23.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.23.0 + +* Update ingress-nginx v0.44.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.22.0...helm-chart-3.23.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.24.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.24.0.md new file mode 100644 index 0000000..d7db808 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.24.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.24.0 + +* [#6908](https://github.com/kubernetes/ingress-nginx/pull/6908) Add volumes to default-backend deployment + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.23.0...helm-chart-3.24.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.25.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.25.0.md new file mode 100644 index 0000000..f9679a1 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.25.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.25.0 + +* [#6957](https://github.com/kubernetes/ingress-nginx/pull/6957) Add ability to specify automountServiceAccountToken + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.24.0...helm-chart-3.25.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.26.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.26.0.md new file mode 100644 index 0000000..0c3a1df --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.26.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.26.0 + +* [#6979](https://github.com/kubernetes/ingress-nginx/pull/6979) Changed servicePort value for metrics + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.25.0...helm-chart-3.26.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.27.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.27.0.md new file mode 100644 index 0000000..8113d7b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.27.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.27.0 + +* Update ingress-nginx v0.45.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.26.0...helm-chart-3.27.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.28.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.28.0.md new file mode 100644 index 0000000..eee0ccb --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.28.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.28.0 + +* [#6900](https://github.com/kubernetes/ingress-nginx/pull/6900) Support existing PSPs + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.27.0...helm-chart-3.28.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.29.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.29.0.md new file mode 100644 index 0000000..f0fabdc --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.29.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.29.0 + +* [#6945](https://github.com/kubernetes/ingress-nginx/pull/7020) Add option to specify job label for ServiceMonitor + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.28.0...helm-chart-3.29.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.0.md new file mode 100644 index 0000000..09fab37 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.0.md @@ -0,0 +1,12 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.3.0 + +* [#6203](https://github.com/kubernetes/ingress-nginx/pull/6203) Refactor parsing of key values +* [#6162](https://github.com/kubernetes/ingress-nginx/pull/6162) Add helm chart options to expose metrics service as NodePort +* [#6180](https://github.com/kubernetes/ingress-nginx/pull/6180) Fix helm chart admissionReviewVersions regression +* [#6169](https://github.com/kubernetes/ingress-nginx/pull/6169) Fix Typo in example prometheus rules + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.0.0...ingress-nginx-3.3.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.1.md new file mode 100644 index 0000000..81f44fd --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.1.md @@ -0,0 +1,12 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.3.1 + +* [#6259](https://github.com/kubernetes/ingress-nginx/pull/6259) Release helm chart +* [#6258](https://github.com/kubernetes/ingress-nginx/pull/6258) Fix chart markdown link +* [#6253](https://github.com/kubernetes/ingress-nginx/pull/6253) Release v0.40.0 +* [#6233](https://github.com/kubernetes/ingress-nginx/pull/6233) Add admission controller e2e test + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.3.0...ingress-nginx-3.3.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.30.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.30.0.md new file mode 100644 index 0000000..77ad6b4 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.30.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.30.0 + +* [#7092](https://github.com/kubernetes/ingress-nginx/pull/7092) Removes the possibility of using localhost in ExternalNames as endpoints + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.29.0...helm-chart-3.30.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.31.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.31.0.md new file mode 100644 index 0000000..bc07fed --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.31.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.31.0 + +* [7137] https://github.com/kubernetes/ingress-nginx/pull/7137 Add support for custom probes + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.30.0...helm-chart-3.31.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.32.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.32.0.md new file mode 100644 index 0000000..68f7ed6 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.32.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.32.0 + +* [7117] https://github.com/kubernetes/ingress-nginx/pull/7117 Add annotations for HPA + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.31.0...helm-chart-3.32.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.33.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.33.0.md new file mode 100644 index 0000000..b56c5fc --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.33.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.33.0 + +* [7164] https://github.com/kubernetes/ingress-nginx/pull/7164 Update nginx to v1.20.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.32.0...helm-chart-3.33.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.34.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.34.0.md new file mode 100644 index 0000000..a28cd02 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.34.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.34.0 + +* [7256] https://github.com/kubernetes/ingress-nginx/pull/7256 Add namespace field in the namespace scoped resource templates + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.33.0...helm-chart-3.34.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.4.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.4.0.md new file mode 100644 index 0000000..3b4ca93 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.4.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.4.0 + +* [#6268](https://github.com/kubernetes/ingress-nginx/pull/6268) Update to 0.40.2 in helm chart #6288 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.3.1...ingress-nginx-3.4.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.0.md new file mode 100644 index 0000000..44991b3 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.5.0 + +* [#6260](https://github.com/kubernetes/ingress-nginx/pull/6260) Allow Helm Chart to customize admission webhook's annotations, timeoutSeconds, namespaceSelector, objectSelector and cert files locations + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.4.0...ingress-nginx-3.5.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.1.md new file mode 100644 index 0000000..740f00c --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.5.1 + +* [#6299](https://github.com/kubernetes/ingress-nginx/pull/6299) Fix helm chart release + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.5.0...ingress-nginx-3.5.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.6.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.6.0.md new file mode 100644 index 0000000..4af7f11 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.6.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.6.0 + +* [#6305](https://github.com/kubernetes/ingress-nginx/pull/6305) Add default linux nodeSelector + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.5.1...ingress-nginx-3.6.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.0.md new file mode 100644 index 0000000..a6b1299 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.7.0 + +* [#6316](https://github.com/kubernetes/ingress-nginx/pull/6316) Numerals in podAnnotations in quotes [#6315](https://github.com/kubernetes/ingress-nginx/issues/6315) + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.6.0...ingress-nginx-3.7.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.1.md new file mode 100644 index 0000000..6ba12df --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.7.1 + +* [#6326](https://github.com/kubernetes/ingress-nginx/pull/6326) Fix liveness and readiness probe path in daemonset chart + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.7.0...ingress-nginx-3.7.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.8.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.8.0.md new file mode 100644 index 0000000..8df250a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.8.0.md @@ -0,0 +1,13 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.8.0 + +* [#6395](https://github.com/kubernetes/ingress-nginx/pull/6395) Update jettech/kube-webhook-certgen image +* [#6377](https://github.com/kubernetes/ingress-nginx/pull/6377) Added loadBalancerSourceRanges for internal lbs +* [#6356](https://github.com/kubernetes/ingress-nginx/pull/6356) Add securitycontext settings on defaultbackend +* [#6401](https://github.com/kubernetes/ingress-nginx/pull/6401) Fix controller service annotations +* [#6403](https://github.com/kubernetes/ingress-nginx/pull/6403) Initial helm chart changelog + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.7.1...ingress-nginx-3.8.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.9.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.9.0.md new file mode 100644 index 0000000..e8c9def --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.9.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.9.0 + +* [#6423](https://github.com/kubernetes/ingress-nginx/pull/6423) Add Default backend HPA autoscaling + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.8.0...ingress-nginx-3.9.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.1.md new file mode 100644 index 0000000..7a187b3 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.1 + +* [7535] https://github.com/kubernetes/ingress-nginx/pull/7535 Release v1.0.0 ingress-nginx + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.34.0...helm-chart-4.0.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.10.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.10.md new file mode 100644 index 0000000..c5d6516 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.10.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.10 + +* [7964] https://github.com/kubernetes/ingress-nginx/pull/7964 Update controller version to v1.1.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.9...helm-chart-4.0.10 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.11.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.11.md new file mode 100644 index 0000000..5541823 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.11.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.11 + +* [7873] https://github.com/kubernetes/ingress-nginx/pull/7873 Makes the [appProtocol](https://kubernetes.io/docs/concepts/services-networking/_print/#application-protocol) field optional. + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.10...helm-chart-4.0.11 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.12.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.12.md new file mode 100644 index 0000000..320f6f5 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.12.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.12 + +* [7978] https://github.com/kubernetes/ingress-nginx/pull/7979 Support custom annotations in admissions Jobs + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.11...helm-chart-4.0.12 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.13.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.13.md new file mode 100644 index 0000000..edd9228 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.13.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.13 + +* [8008] https://github.com/kubernetes/ingress-nginx/pull/8008 Add relabelings in controller-servicemonitor.yaml + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.12...helm-chart-4.0.13 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.14.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.14.md new file mode 100644 index 0000000..e927010 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.14.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.14 + +* [8061] https://github.com/kubernetes/ingress-nginx/pull/8061 Using helm-docs to populate values table in README.md + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.13...helm-chart-4.0.14 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.15.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.15.md new file mode 100644 index 0000000..d3d14a9 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.15.md @@ -0,0 +1,43 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.15 + +* [8120] https://github.com/kubernetes/ingress-nginx/pull/8120 Update go in runner and release v1.1.1 +* [8119] https://github.com/kubernetes/ingress-nginx/pull/8119 Update to go v1.17.6 +* [8118] https://github.com/kubernetes/ingress-nginx/pull/8118 Remove deprecated libraries, update other libs +* [8117] https://github.com/kubernetes/ingress-nginx/pull/8117 Fix codegen errors +* [8115] https://github.com/kubernetes/ingress-nginx/pull/8115 chart/ghaction: set the correct permission to have access to push a release +* [8098] https://github.com/kubernetes/ingress-nginx/pull/8098 generating SHA for CA only certs in backend_ssl.go + comparison of P… +* [8088] https://github.com/kubernetes/ingress-nginx/pull/8088 Fix Edit this page link to use main branch +* [8072] https://github.com/kubernetes/ingress-nginx/pull/8072 Expose GeoIP2 Continent code as variable +* [8061] https://github.com/kubernetes/ingress-nginx/pull/8061 docs(charts): using helm-docs for chart +* [8058] https://github.com/kubernetes/ingress-nginx/pull/8058 Bump github.com/spf13/cobra from 1.2.1 to 1.3.0 +* [8054] https://github.com/kubernetes/ingress-nginx/pull/8054 Bump google.golang.org/grpc from 1.41.0 to 1.43.0 +* [8051] https://github.com/kubernetes/ingress-nginx/pull/8051 align bug report with feature request regarding kind documentation +* [8046] https://github.com/kubernetes/ingress-nginx/pull/8046 Report expired certificates (#8045) +* [8044] https://github.com/kubernetes/ingress-nginx/pull/8044 remove G109 check till gosec resolves issues +* [8042] https://github.com/kubernetes/ingress-nginx/pull/8042 docs_multiple_instances_one_cluster_ticket_7543 +* [8041] https://github.com/kubernetes/ingress-nginx/pull/8041 docs: fix typo'd executable name +* [8035] https://github.com/kubernetes/ingress-nginx/pull/8035 Comment busy owners +* [8029] https://github.com/kubernetes/ingress-nginx/pull/8029 Add stream-snippet as a ConfigMap and Annotation option +* [8023] https://github.com/kubernetes/ingress-nginx/pull/8023 fix nginx compilation flags +* [8021] https://github.com/kubernetes/ingress-nginx/pull/8021 Disable default modsecurity_rules_file if modsecurity-snippet is specified +* [8019] https://github.com/kubernetes/ingress-nginx/pull/8019 Revise main documentation page +* [8018] https://github.com/kubernetes/ingress-nginx/pull/8018 Preserve order of plugin invocation +* [8015] https://github.com/kubernetes/ingress-nginx/pull/8015 Add newline indenting to admission webhook annotations +* [8014] https://github.com/kubernetes/ingress-nginx/pull/8014 Add link to example error page manifest in docs +* [8009] https://github.com/kubernetes/ingress-nginx/pull/8009 Fix spelling in documentation and top-level files +* [8008] https://github.com/kubernetes/ingress-nginx/pull/8008 Add relabelings in controller-servicemonitor.yaml +* [8003] https://github.com/kubernetes/ingress-nginx/pull/8003 Minor improvements (formatting, consistency) in install guide +* [8001] https://github.com/kubernetes/ingress-nginx/pull/8001 fix: go-grpc Dockerfile +* [7999] https://github.com/kubernetes/ingress-nginx/pull/7999 images: use k8s-staging-test-infra/gcb-docker-gcloud +* [7996] https://github.com/kubernetes/ingress-nginx/pull/7996 doc: improvement +* [7983] https://github.com/kubernetes/ingress-nginx/pull/7983 Fix a couple of misspellings in the annotations documentation. +* [7979] https://github.com/kubernetes/ingress-nginx/pull/7979 allow set annotations for admission Jobs +* [7977] https://github.com/kubernetes/ingress-nginx/pull/7977 Add ssl_reject_handshake to default server +* [7975] https://github.com/kubernetes/ingress-nginx/pull/7975 add legacy version update v0.50.0 to main changelog +* [7972] https://github.com/kubernetes/ingress-nginx/pull/7972 updated service upstream definition + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.14...helm-chart-4.0.15 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.18.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.18.md new file mode 100644 index 0000000..30a8f75 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.18.md @@ -0,0 +1,40 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.18 + +* [8291](https://github.com/kubernetes/ingress-nginx/pull/8291) remove git tag env from cloud build +* [8286](https://github.com/kubernetes/ingress-nginx/pull/8286) Fix OpenTelemetry sidecar image build +* [8277](https://github.com/kubernetes/ingress-nginx/pull/8277) Add OpenSSF Best practices badge +* [8273](https://github.com/kubernetes/ingress-nginx/pull/8273) Issue#8241 +* [8267](https://github.com/kubernetes/ingress-nginx/pull/8267) Add fsGroup value to admission-webhooks/job-patch charts +* [8262](https://github.com/kubernetes/ingress-nginx/pull/8262) Updated confusing error +* [8256](https://github.com/kubernetes/ingress-nginx/pull/8256) fix: deny locations with invalid auth-url annotation +* [8253](https://github.com/kubernetes/ingress-nginx/pull/8253) Add a certificate info metric +* [8236](https://github.com/kubernetes/ingress-nginx/pull/8236) webhook: remove useless code. +* [8227](https://github.com/kubernetes/ingress-nginx/pull/8227) Update libraries in webhook image +* [8225](https://github.com/kubernetes/ingress-nginx/pull/8225) fix inconsistent-label-cardinality for prometheus metrics: nginx_ingress_controller_requests +* [8221](https://github.com/kubernetes/ingress-nginx/pull/8221) Do not validate ingresses with unknown ingress class in admission webhook endpoint +* [8210](https://github.com/kubernetes/ingress-nginx/pull/8210) Bump github.com/prometheus/client_golang from 1.11.0 to 1.12.1 +* [8209](https://github.com/kubernetes/ingress-nginx/pull/8209) Bump google.golang.org/grpc from 1.43.0 to 1.44.0 +* [8204](https://github.com/kubernetes/ingress-nginx/pull/8204) Add Artifact Hub lint +* [8203](https://github.com/kubernetes/ingress-nginx/pull/8203) Fix Indentation of example and link to cert-manager tutorial +* [8201](https://github.com/kubernetes/ingress-nginx/pull/8201) feat(metrics): add path and method labels to requests countera +* [8199](https://github.com/kubernetes/ingress-nginx/pull/8199) use functional options to reduce number of methods creating an EchoDeployment +* [8196](https://github.com/kubernetes/ingress-nginx/pull/8196) docs: fix inconsistent controller annotation +* [8191](https://github.com/kubernetes/ingress-nginx/pull/8191) Using Go install for misspell +* [8186](https://github.com/kubernetes/ingress-nginx/pull/8186) prometheus+grafana using servicemonitor +* [8185](https://github.com/kubernetes/ingress-nginx/pull/8185) Append elements on match, instead of removing for cors-annotations +* [8179](https://github.com/kubernetes/ingress-nginx/pull/8179) Bump github.com/opencontainers/runc from 1.0.3 to 1.1.0 +* [8173](https://github.com/kubernetes/ingress-nginx/pull/8173) Adding annotations to the controller service account +* [8163](https://github.com/kubernetes/ingress-nginx/pull/8163) Update the $req_id placeholder description +* [8162](https://github.com/kubernetes/ingress-nginx/pull/8162) Versioned static manifests +* [8159](https://github.com/kubernetes/ingress-nginx/pull/8159) Adding some geoip variables and default values +* [8155](https://github.com/kubernetes/ingress-nginx/pull/8155) #7271 feat: avoid-pdb-creation-when-default-backend-disabled-and-replicas-gt-1 +* [8151](https://github.com/kubernetes/ingress-nginx/pull/8151) Automatically generate helm docs +* [8143](https://github.com/kubernetes/ingress-nginx/pull/8143) Allow to configure delay before controller exits +* [8136](https://github.com/kubernetes/ingress-nginx/pull/8136) add ingressClass option to helm chart - back compatibility with ingress.class annotations +* [8126](https://github.com/kubernetes/ingress-nginx/pull/8126) Example for JWT + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.15...helm-chart-4.0.18 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.2.md new file mode 100644 index 0000000..9dbd003 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.2.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.2 + +* [7681] https://github.com/kubernetes/ingress-nginx/pull/7681 Release v1.0.1 of ingress-nginx + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.1...helm-chart-4.0.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.3.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.3.md new file mode 100644 index 0000000..09b89f6 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.3.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.3 + +* [7707] https://github.com/kubernetes/ingress-nginx/pull/7707 Release v1.0.2 of ingress-nginx + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.2...helm-chart-4.0.3 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.5.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.5.md new file mode 100644 index 0000000..be67704 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.5.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.5 + +* [7740] https://github.com/kubernetes/ingress-nginx/pull/7740 Release v1.0.3 of ingress-nginx + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.3...helm-chart-4.0.5 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.6.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.6.md new file mode 100644 index 0000000..25276e2 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.6.md @@ -0,0 +1,12 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.6 + +* [7804] https://github.com/kubernetes/ingress-nginx/pull/7804 Release v1.0.4 of ingress-nginx +* [7651] https://github.com/kubernetes/ingress-nginx/pull/7651 Support ipFamilyPolicy and ipFamilies fields in Helm Chart +* [7798] https://github.com/kubernetes/ingress-nginx/pull/7798 Exoscale: use HTTP Healthcheck mode +* [7793] https://github.com/kubernetes/ingress-nginx/pull/7793 Update kube-webhook-certgen to v1.1.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.5...helm-chart-4.0.6 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.7.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.7.md new file mode 100644 index 0000000..50fd922 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.7.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.7 + +* [7923] https://github.com/kubernetes/ingress-nginx/pull/7923 Release v1.0.5 of ingress-nginx +* [7806] https://github.com/kubernetes/ingress-nginx/pull/7806 Choice option for internal/external loadbalancer type service + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.6...helm-chart-4.0.7 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.9.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.9.md new file mode 100644 index 0000000..f2f725c --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.9.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.9 + +* [6992] https://github.com/kubernetes/ingress-nginx/pull/6992 Add ability to specify labels for all resources + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.7...helm-chart-4.0.9 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.0.md new file mode 100644 index 0000000..24aaf49 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.0.md @@ -0,0 +1,21 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.1.0 + +* [8481](https://github.com/kubernetes/ingress-nginx/pull/8481) Fix log creation in chroot script +* [8479](https://github.com/kubernetes/ingress-nginx/pull/8479) changed nginx base img tag to img built with alpine3.14.6 +* [8478](https://github.com/kubernetes/ingress-nginx/pull/8478) update base images and protobuf gomod +* [8468](https://github.com/kubernetes/ingress-nginx/pull/8468) Fallback to ngx.var.scheme for redirectScheme with use-forward-headers when X-Forwarded-Proto is empty +* [8456](https://github.com/kubernetes/ingress-nginx/pull/8456) Implement object deep inspector +* [8455](https://github.com/kubernetes/ingress-nginx/pull/8455) Update dependencies +* [8454](https://github.com/kubernetes/ingress-nginx/pull/8454) Update index.md +* [8447](https://github.com/kubernetes/ingress-nginx/pull/8447) typo fixing +* [8446](https://github.com/kubernetes/ingress-nginx/pull/8446) Fix suggested annotation-value-word-blocklist +* [8444](https://github.com/kubernetes/ingress-nginx/pull/8444) replace deprecated topology key in example with current one +* [8443](https://github.com/kubernetes/ingress-nginx/pull/8443) Add dependency review enforcement +* [8434](https://github.com/kubernetes/ingress-nginx/pull/8434) added new auth-tls-match-cn annotation +* [8426](https://github.com/kubernetes/ingress-nginx/pull/8426) Bump github.com/prometheus/common from 0.32.1 to 0.33.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.18...helm-chart-4.1.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.2.md new file mode 100644 index 0000000..2061855 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.2.md @@ -0,0 +1,11 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.1.2 + +* [8587](https://github.com/kubernetes/ingress-nginx/pull/8587) Add CAP_SYS_CHROOT to DS/PSP when needed +* [8458](https://github.com/kubernetes/ingress-nginx/pull/8458) Add portNamePrefix Helm chart parameter +* [8522](https://github.com/kubernetes/ingress-nginx/pull/8522) Add documentation for controller.service.loadBalancerIP in Helm chart + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.1.0...helm-chart-4.1.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.0.md new file mode 100644 index 0000000..a1f1847 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.10.0 + +* - "Update Ingress-Nginx version controller-v1.10.0" + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.9.1...helm-chart-4.10.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.1.md new file mode 100644 index 0000000..3a28de0 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.1.md @@ -0,0 +1,11 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.10.1 + +* - "update post submit helm ci and clean up (#11221)" +* - "refactor helm ci tests part I (#11188)" +* - "Update Ingress-Nginx version controller-v1.10.1" + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.10.0...helm-chart-4.10.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.2.md new file mode 100644 index 0000000..399bd98 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.2.md @@ -0,0 +1,18 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.10.2 + +* Chores: Align security contacts & chart maintainers to actual owners. (#11480) +* Fix helm install on cloud provider admonition block (#11412) +* edited helm-install tips (#11411) +* added info for aws helm install (#11410) +* add workflow to helm release and update ct for branch (#11317) +* Merge pull request #11277 from strongjz/chart-1.10.1 (#11314) +* release helm chart from release branch (#11278) +* update post submit helm ci and clean up (#11221) +* refactor helm ci tests part I (#11188) +* Update Ingress-Nginx version controller-v1.10.2 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.10.1...helm-chart-4.10.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.0.md new file mode 100644 index 0000000..64108c0 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.0.md @@ -0,0 +1,18 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.11.0 + +* Chores: Align security contacts & chart maintainers to actual owners. (#11465) +* Merge pull request #11277 from strongjz/chart-1.10.1 (#11415) +* Fix helm install on cloud provider admonition block (#11394) +* edited helm-install tips (#11393) +* added info for aws helm install (#11390) +* add workflow to helm release and update ct for branch (#11378) +* release helm chart from release branch (#11276) +* update post submit helm ci and clean up (#11220) +* refactor helm ci tests part I (#11178) +* Update Ingress-Nginx version controller-v1.11.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.10.2...helm-chart-4.11.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.1.md new file mode 100644 index 0000000..281513e --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.11.1 + +* Update Ingress-Nginx version controller-v1.11.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.11.0...helm-chart-4.11.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.2.md new file mode 100644 index 0000000..c7645a5 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.2.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.11.2 + +* Update Ingress-Nginx version controller-v1.11.2 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.11.1...helm-chart-4.11.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.3.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.3.md new file mode 100644 index 0000000..18ec6ba --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.3.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.11.3 + +* Update Ingress-Nginx version controller-v1.11.3 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.11.2...helm-chart-4.11.3 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.0.md new file mode 100644 index 0000000..2074a09 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.0.md @@ -0,0 +1,47 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.2.0 + +* Support for Kubernetes v1.19.0 was removed +* [8810](https://github.com/kubernetes/ingress-nginx/pull/8810) Prepare for v1.3.0 +* [8808](https://github.com/kubernetes/ingress-nginx/pull/8808) revert arch var name +* [8805](https://github.com/kubernetes/ingress-nginx/pull/8805) Bump k8s.io/klog/v2 from 2.60.1 to 2.70.1 +* [8803](https://github.com/kubernetes/ingress-nginx/pull/8803) Update to nginx base with alpine v3.16 +* [8802](https://github.com/kubernetes/ingress-nginx/pull/8802) chore: start v1.3.0 release process +* [8798](https://github.com/kubernetes/ingress-nginx/pull/8798) Add v1.24.0 to test matrix +* [8796](https://github.com/kubernetes/ingress-nginx/pull/8796) fix: add MAC_OS variable for static-check +* [8793](https://github.com/kubernetes/ingress-nginx/pull/8793) changed to alpine-v3.16 +* [8781](https://github.com/kubernetes/ingress-nginx/pull/8781) Bump github.com/stretchr/testify from 1.7.5 to 1.8.0 +* [8778](https://github.com/kubernetes/ingress-nginx/pull/8778) chore: remove stable.txt from release process +* [8775](https://github.com/kubernetes/ingress-nginx/pull/8775) Remove stable +* [8773](https://github.com/kubernetes/ingress-nginx/pull/8773) Bump github/codeql-action from 2.1.14 to 2.1.15 +* [8772](https://github.com/kubernetes/ingress-nginx/pull/8772) Bump ossf/scorecard-action from 1.1.1 to 1.1.2 +* [8771](https://github.com/kubernetes/ingress-nginx/pull/8771) fix bullet md format +* [8770](https://github.com/kubernetes/ingress-nginx/pull/8770) Add condition for monitoring.coreos.com/v1 API +* [8769](https://github.com/kubernetes/ingress-nginx/pull/8769) Fix typos and add links to developer guide +* [8767](https://github.com/kubernetes/ingress-nginx/pull/8767) change v1.2.0 to v1.2.1 in deploy doc URLs +* [8765](https://github.com/kubernetes/ingress-nginx/pull/8765) Bump github/codeql-action from 1.0.26 to 2.1.14 +* [8752](https://github.com/kubernetes/ingress-nginx/pull/8752) Bump github.com/spf13/cobra from 1.4.0 to 1.5.0 +* [8751](https://github.com/kubernetes/ingress-nginx/pull/8751) Bump github.com/stretchr/testify from 1.7.2 to 1.7.5 +* [8750](https://github.com/kubernetes/ingress-nginx/pull/8750) added announcement +* [8740](https://github.com/kubernetes/ingress-nginx/pull/8740) change sha e2etestrunner and echoserver +* [8738](https://github.com/kubernetes/ingress-nginx/pull/8738) Update docs to make it easier for noobs to follow step by step +* [8737](https://github.com/kubernetes/ingress-nginx/pull/8737) updated baseimage sha +* [8736](https://github.com/kubernetes/ingress-nginx/pull/8736) set ld-musl-path +* [8733](https://github.com/kubernetes/ingress-nginx/pull/8733) feat: migrate leaderelection lock to leases +* [8726](https://github.com/kubernetes/ingress-nginx/pull/8726) prometheus metric: upstream_latency_seconds +* [8720](https://github.com/kubernetes/ingress-nginx/pull/8720) Ci pin deps +* [8719](https://github.com/kubernetes/ingress-nginx/pull/8719) Working OpenTelemetry sidecar (base nginx image) +* [8714](https://github.com/kubernetes/ingress-nginx/pull/8714) Create Openssf scorecard +* [8708](https://github.com/kubernetes/ingress-nginx/pull/8708) Bump github.com/prometheus/common from 0.34.0 to 0.35.0 +* [8703](https://github.com/kubernetes/ingress-nginx/pull/8703) Bump actions/dependency-review-action from 1 to 2 +* [8701](https://github.com/kubernetes/ingress-nginx/pull/8701) Fix several typos +* [8699](https://github.com/kubernetes/ingress-nginx/pull/8699) fix the gosec test and a make target for it +* [8698](https://github.com/kubernetes/ingress-nginx/pull/8698) Bump actions/upload-artifact from 2.3.1 to 3.1.0 +* [8697](https://github.com/kubernetes/ingress-nginx/pull/8697) Bump actions/setup-go from 2.2.0 to 3.2.0 +* [8695](https://github.com/kubernetes/ingress-nginx/pull/8695) Bump actions/download-artifact from 2 to 3 +* [8694](https://github.com/kubernetes/ingress-nginx/pull/8694) Bump crazy-max/ghaction-docker-buildx from 1.6.2 to 3.3.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.1.2...helm-chart-4.2.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.1.md new file mode 100644 index 0000000..7965bb1 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.1.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.2.1 + +* The sha of kube-webhook-certgen image & the opentelemetry image, in values file, was changed to new images built on alpine-v3.16.1 +* [8896](https://github.com/kubernetes/ingress-nginx/pull/8896) updated to new images built today + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.2.0...helm-chart-4.2.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.3.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.3.0.md new file mode 100644 index 0000000..f9dca22 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.3.0.md @@ -0,0 +1,14 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.3.0 + +* Support for Kubernetes v.1.25.0 was added and support for endpoint slices +* Support for Kubernetes v1.20.0 and v1.21.0 was removed +* [8890](https://github.com/kubernetes/ingress-nginx/pull/8890) migrate to endpointslices +* [9059](https://github.com/kubernetes/ingress-nginx/pull/9059) kubewebhookcertgen sha change after go1191 +* [9046](https://github.com/kubernetes/ingress-nginx/pull/9046) Parameterize metrics port name +* [9104](https://github.com/kubernetes/ingress-nginx/pull/9104) Fix yaml formatting error with multiple annotations + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.2.1...helm-chart-4.3.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.4.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.4.0.md new file mode 100644 index 0000000..20f9e23 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.4.0.md @@ -0,0 +1,12 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.4.0 + +* Adding support for disabling liveness and readiness probes to the Helm chart by @njegosrailic in https://github.com/kubernetes/ingress-nginx/pull/9238 +* add:(admission-webhooks) ability to set securityContext by @ybelMekk in https://github.com/kubernetes/ingress-nginx/pull/9186 +* #7652 - Updated Helm chart to use the fullname for the electionID if not specified. by @FutureMatt in https://github.com/kubernetes/ingress-nginx/pull/9133 +* Rename controller-wehbooks-networkpolicy.yaml. by @Gacko in https://github.com/kubernetes/ingress-nginx/pull/9123 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.3.0...helm-chart-4.4.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.5.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.5.2.md new file mode 100644 index 0000000..b6d8a3b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.5.2.md @@ -0,0 +1,13 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.5.2 + +* add lint on chart before release (#9570) +* ci: remove setup-helm step (#9404) +* feat(helm): Optionally use cert-manager instead admission patch (#9279) +* run helm release on main only and when the chart/value changes only (#9290) +* Update Ingress-Nginx version controller-v1.6.4 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.4.3...helm-chart-4.5.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.0.md new file mode 100644 index 0000000..469aaba --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.0.md @@ -0,0 +1,24 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.5.3 + +* docs(helm): fix value key in readme for enabling certManager (#9640) +* Upgrade alpine 3.17.2 +* Upgrade golang 1.20 +* Drop testing/support for Kubernetes 1.23 +* docs(helm): fix value key in readme for enabling certManager (#9640) +* Update Ingress-Nginx version controller-v1.7.0 +* feat: OpenTelemetry module integration (#9062) +* canary-weight-total annotation ignored in rule backends (#9729) +* fix controller psp's volume config (#9740) +* Fix several Helm YAML issues with extraModules and extraInitContainers (#9709) +* Chart: Drop `controller.headers`, rework DH param secret. (#9659) +* Deployment/DaemonSet: Label pods using `ingress-nginx.labels`. (#9732) +* HPA: autoscaling/v2beta1 deprecated, bump apiVersion to v2 for defaultBackend (#9731) +* Fix incorrect annotation name in upstream hashing configuration (#9617) + +* Update Ingress-Nginx version controller-v1.7.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.5.2...helm-chart-4.6.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.1.md new file mode 100644 index 0000000..57d99b8 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.1.md @@ -0,0 +1,11 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.6.1 + +* [helm] Support custom port configuration for internal service (#9846) +* Adding resource type to default HPA configuration to resolve issues with Terraform helm chart usage (#9803) +* Update Ingress-Nginx version controller-v1.7.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.6.0...helm-chart-4.6.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.0.md new file mode 100644 index 0000000..9d54070 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.0.md @@ -0,0 +1,14 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.7.0 + +* helm: Fix opentelemetry module installation for daemonset (#9792) +* Update charts/* to keep project name display aligned (#9931) +* HPA: Use capabilities & align manifests. (#9521) +* PodDisruptionBudget spec logic update (#9904) +* add option for annotations in PodDisruptionBudget (#9843) +* Update Ingress-Nginx version controller-v1.8.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.6.1...helm-chart-4.7.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.1.md new file mode 100644 index 0000000..4d69a71 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.1.md @@ -0,0 +1,12 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.7.1 + +* Added a doc line to the missing helm value service.internal.loadBalancerIP (#9406) +* feat(helm): Add loadBalancerClass (#9562) +* added helmshowvalues example (#10019) +* Update Ingress-Nginx version controller-v1.8.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.7.0...helm-chart-4.7.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.2.md new file mode 100644 index 0000000..57b17b9 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.2.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.7.2 + +* Update Ingress-Nginx version controller-v1.8.2 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.7.1...helm-chart-4.7.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0-beta.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0-beta.0.md new file mode 100644 index 0000000..9072a75 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0-beta.0.md @@ -0,0 +1,13 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.8.0-beta.0 + +* ci(helm): fix Helm Chart release action 422 error (#10237) +* helm: Use .Release.Namespace as default for ServiceMonitor namespace (#10249) +* [helm] configure allow to configure hostAliases (#10180) +* [helm] pass service annotations through helm tpl engine (#10084) +* Update Ingress-Nginx version controller-v1.9.0-beta.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.7.2...helm-chart-4.8.0-beta.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0.md new file mode 100644 index 0000000..af8f124 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0.md @@ -0,0 +1,13 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.8.0 + +* ci(helm): fix Helm Chart release action 422 error (#10237) +* helm: Use .Release.Namespace as default for ServiceMonitor namespace (#10249) +* [helm] configure allow to configure hostAliases (#10180) +* [helm] pass service annotations through helm tpl engine (#10084) +* Update Ingress-Nginx version controller-v1.9.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.7.2...helm-chart-4.8.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.1.md new file mode 100644 index 0000000..53a4493 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.8.1 + +* Update Ingress-Nginx version controller-v1.9.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.8.0...helm-chart-4.8.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.2.md new file mode 100644 index 0000000..9957c1a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.2.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.8.2 + +* update nginx base, httpbun, e2e, helm webhook cert gen (#10506) +* Update Ingress-Nginx version controller-v1.9.3 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.8.1...helm-chart-4.8.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.3.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.3.md new file mode 100644 index 0000000..b8d4d56 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.3.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.8.3 + +* Update Ingress-Nginx version controller-v1.9.4 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.8.2...helm-chart-4.8.3 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.0.md new file mode 100644 index 0000000..5c77298 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.0.md @@ -0,0 +1,13 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.9.0 + +* - "Add controller.metrics.serviceMonitor.annotations in Helm chart" +* - "fix(labels): use complete labels variable on default-backend deployment" +* - "chart: allow setting allocateLoadBalancerNodePorts (#10693)" +* - "[release-1.9] feat(helm): add documentation about metric args (#10695)" +* - "Update Ingress-Nginx version controller-v1.9.5" + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.8.3...helm-chart-4.9.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.1.md new file mode 100644 index 0000000..c6120e7 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.1.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.9.1 + +* - "update web hook cert gen to latest release v20231226-1a7112e06" +* - "Update Ingress-Nginx version controller-v1.9.6" + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.9.0...helm-chart-4.9.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart.md.gotmpl b/charts/keep/charts/ingress-nginx/changelog/helm-chart.md.gotmpl new file mode 100644 index 0000000..ef5add5 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart.md.gotmpl @@ -0,0 +1,11 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### {{ .NewHelmChartVersion }} +{{ with .HelmUpdates }} +{{- range . }} +* {{ . }} +{{- end }} +{{ end }} +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-{{ .PreviousHelmChartVersion }}...helm-chart-{{ .NewHelmChartVersion }} diff --git a/charts/keep/charts/ingress-nginx/ci/admission-webhooks-cert-manager-values.yaml b/charts/keep/charts/ingress-nginx/ci/admission-webhooks-cert-manager-values.yaml new file mode 100644 index 0000000..7eafd0c --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/admission-webhooks-cert-manager-values.yaml @@ -0,0 +1,12 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + admissionWebhooks: + certManager: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-configmap-addheaders-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-configmap-addheaders-values.yaml new file mode 100644 index 0000000..460a610 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-configmap-addheaders-values.yaml @@ -0,0 +1,11 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + addHeaders: + X-Frame-Options: deny diff --git a/charts/keep/charts/ingress-nginx/ci/controller-configmap-proxyheaders-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-configmap-proxyheaders-values.yaml new file mode 100644 index 0000000..e23a13c --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-configmap-proxyheaders-values.yaml @@ -0,0 +1,11 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + proxySetHeaders: + X-Forwarded-Proto: https diff --git a/charts/keep/charts/ingress-nginx/ci/controller-configmap-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-configmap-values.yaml new file mode 100644 index 0000000..a702989 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-configmap-values.yaml @@ -0,0 +1,11 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + config: + use-proxy-protocol: "true" diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-extra-modules-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-extra-modules-values.yaml new file mode 100644 index 0000000..edf12e7 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-extra-modules-values.yaml @@ -0,0 +1,30 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: DaemonSet + + extraModules: + - name: opentelemetry + image: + registry: registry.k8s.io + image: ingress-nginx/opentelemetry-1.25.3 + tag: v20240813-b933310d + digest: sha256:f7604ac0547ed64d79b98d92133234e66c2c8aade3c1f4809fed5eec1fb7f922 + distroless: true + containerSecurityContext: + runAsNonRoot: true + runAsUser: 65532 + runAsGroup: 65532 + allowPrivilegeEscalation: false + seccompProfile: + type: RuntimeDefault + capabilities: + drop: + - ALL + readOnlyRootFilesystem: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-metrics-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-metrics-values.yaml new file mode 100644 index 0000000..7a98580 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-metrics-values.yaml @@ -0,0 +1,13 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: DaemonSet + + metrics: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-opentelemetry-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-opentelemetry-values.yaml new file mode 100644 index 0000000..179ab2a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-opentelemetry-values.yaml @@ -0,0 +1,13 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: DaemonSet + + opentelemetry: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-podannotations-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-podannotations-values.yaml new file mode 100644 index 0000000..405992e --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-podannotations-values.yaml @@ -0,0 +1,16 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: DaemonSet + + podAnnotations: + prometheus.io/scrape: "true" + prometheus.io/port: "10254" + prometheus.io/scheme: http + prometheus.io/path: /metrics diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-values.yaml new file mode 100644 index 0000000..d34025c --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-values.yaml @@ -0,0 +1,10 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: DaemonSet diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-extra-modules-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-extra-modules-values.yaml new file mode 100644 index 0000000..d4083cc --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-deployment-extra-modules-values.yaml @@ -0,0 +1,30 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: Deployment + + extraModules: + - name: opentelemetry + image: + registry: registry.k8s.io + image: ingress-nginx/opentelemetry-1.25.3 + tag: v20240813-b933310d + digest: sha256:f7604ac0547ed64d79b98d92133234e66c2c8aade3c1f4809fed5eec1fb7f922 + distroless: true + containerSecurityContext: + runAsNonRoot: true + runAsUser: 65532 + runAsGroup: 65532 + allowPrivilegeEscalation: false + seccompProfile: + type: RuntimeDefault + capabilities: + drop: + - ALL + readOnlyRootFilesystem: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-metrics-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-metrics-values.yaml new file mode 100644 index 0000000..9c95d34 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-deployment-metrics-values.yaml @@ -0,0 +1,13 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: Deployment + + metrics: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-opentelemetry-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-opentelemetry-values.yaml new file mode 100644 index 0000000..9443dde --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-deployment-opentelemetry-values.yaml @@ -0,0 +1,13 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: Deployment + + opentelemetry: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-podannotations-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-podannotations-values.yaml new file mode 100644 index 0000000..cf1f261 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-deployment-podannotations-values.yaml @@ -0,0 +1,16 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: Deployment + + podAnnotations: + prometheus.io/scrape: "true" + prometheus.io/port: "10254" + prometheus.io/scheme: http + prometheus.io/path: /metrics diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-values.yaml new file mode 100644 index 0000000..1b092dc --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-deployment-values.yaml @@ -0,0 +1,10 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: Deployment diff --git a/charts/keep/charts/ingress-nginx/ci/controller-hpa-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-hpa-values.yaml new file mode 100644 index 0000000..54a0d2f --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-hpa-values.yaml @@ -0,0 +1,18 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + autoscaling: + enabled: true + behavior: + scaleDown: + stabilizationWindowSeconds: 300 + policies: + - type: Pods + value: 1 + periodSeconds: 180 diff --git a/charts/keep/charts/ingress-nginx/ci/controller-ingressclass-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-ingressclass-values.yaml new file mode 100644 index 0000000..c06429f --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-ingressclass-values.yaml @@ -0,0 +1,15 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + ingressClassResource: + name: custom-nginx + default: true + controllerValue: k8s.io/custom-nginx + + watchIngressWithoutClass: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-service-internal-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-service-internal-values.yaml new file mode 100644 index 0000000..11108fb --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-service-internal-values.yaml @@ -0,0 +1,13 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + internal: + enabled: true + annotations: + service.beta.kubernetes.io/aws-load-balancer-internal: "true" diff --git a/charts/keep/charts/ingress-nginx/ci/controller-service-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-service-values.yaml new file mode 100644 index 0000000..9039368 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-service-values.yaml @@ -0,0 +1,22 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: NodePort + + nodePorts: + tcp: + 9000: 30090 + udp: + 9001: 30091 + +portNamePrefix: port + +tcp: + 9000: default/test:8080 + +udp: + 9001: default/test:8080 diff --git a/charts/keep/charts/ingress-nginx/ci/deamonset-psp-values.yaml b/charts/keep/charts/ingress-nginx/ci/deamonset-psp-values.yaml new file mode 100644 index 0000000..8026a63 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/deamonset-psp-values.yaml @@ -0,0 +1,13 @@ +controller: + kind: DaemonSet + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + admissionWebhooks: + enabled: false + service: + type: ClusterIP + +podSecurityPolicy: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/deamonset-webhook-and-psp-values.yaml b/charts/keep/charts/ingress-nginx/ci/deamonset-webhook-and-psp-values.yaml new file mode 100644 index 0000000..fccdb13 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/deamonset-webhook-and-psp-values.yaml @@ -0,0 +1,13 @@ +controller: + kind: DaemonSet + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + admissionWebhooks: + enabled: true + service: + type: ClusterIP + +podSecurityPolicy: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/deployment-psp-values.yaml b/charts/keep/charts/ingress-nginx/ci/deployment-psp-values.yaml new file mode 100644 index 0000000..2f332a7 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/deployment-psp-values.yaml @@ -0,0 +1,10 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + service: + type: ClusterIP + +podSecurityPolicy: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/deployment-webhook-and-psp-values.yaml b/charts/keep/charts/ingress-nginx/ci/deployment-webhook-and-psp-values.yaml new file mode 100644 index 0000000..6195bb3 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/deployment-webhook-and-psp-values.yaml @@ -0,0 +1,12 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + admissionWebhooks: + enabled: true + service: + type: ClusterIP + +podSecurityPolicy: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/templates/NOTES.txt b/charts/keep/charts/ingress-nginx/templates/NOTES.txt new file mode 100644 index 0000000..f492300 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/NOTES.txt @@ -0,0 +1,73 @@ +The ingress-nginx controller has been installed. + +{{- if contains "NodePort" .Values.controller.service.type }} +Get the application URL by running these commands: + +{{- if (not (empty .Values.controller.service.nodePorts.http)) }} + export HTTP_NODE_PORT={{ .Values.controller.service.nodePorts.http }} +{{- else }} + export HTTP_NODE_PORT=$(kubectl get service --namespace {{ include "ingress-nginx.namespace" . }} {{ include "ingress-nginx.controller.fullname" . }} --output jsonpath="{.spec.ports[0].nodePort}") +{{- end }} +{{- if (not (empty .Values.controller.service.nodePorts.https)) }} + export HTTPS_NODE_PORT={{ .Values.controller.service.nodePorts.https }} +{{- else }} + export HTTPS_NODE_PORT=$(kubectl get service --namespace {{ include "ingress-nginx.namespace" . }} {{ include "ingress-nginx.controller.fullname" . }} --output jsonpath="{.spec.ports[1].nodePort}") +{{- end }} + export NODE_IP="$(kubectl get nodes --output jsonpath="{.items[0].status.addresses[1].address}")" + + echo "Visit http://${NODE_IP}:${HTTP_NODE_PORT} to access your application via HTTP." + echo "Visit https://${NODE_IP}:${HTTPS_NODE_PORT} to access your application via HTTPS." +{{- else if contains "LoadBalancer" .Values.controller.service.type }} +It may take a few minutes for the load balancer IP to be available. +You can watch the status by running 'kubectl get service --namespace {{ include "ingress-nginx.namespace" . }} {{ include "ingress-nginx.controller.fullname" . }} --output wide --watch' +{{- else if contains "ClusterIP" .Values.controller.service.type }} +Get the application URL by running these commands: + export POD_NAME="$(kubectl get pods --namespace {{ include "ingress-nginx.namespace" . }} --selector app.kubernetes.io/name={{ include "ingress-nginx.name" . }},app.kubernetes.io/instance={{ .Release.Name }},app.kubernetes.io/component=controller --output jsonpath="{.items[0].metadata.name}")" + kubectl port-forward --namespace {{ include "ingress-nginx.namespace" . }} "${POD_NAME}" 8080:80 + echo "Visit http://127.0.0.1:8080 to access your application." +{{- end }} + +An example Ingress that makes use of the controller: + +{{- $isV1 := semverCompare ">=1" .Chart.AppVersion}} + apiVersion: networking.k8s.io/v1 + kind: Ingress + metadata: + name: example + namespace: foo + {{- if eq $isV1 false }} + annotations: + kubernetes.io/ingress.class: {{ .Values.controller.ingressClass }} + {{- end }} + spec: + {{- if $isV1 }} + ingressClassName: {{ .Values.controller.ingressClassResource.name }} + {{- end }} + rules: + - host: www.example.com + http: + paths: + - pathType: Prefix + backend: + service: + name: exampleService + port: + number: 80 + path: / + # This section is only required if TLS is to be enabled for the Ingress + tls: + - hosts: + - www.example.com + secretName: example-tls + +If TLS is enabled for the Ingress, a Secret containing the certificate and key must also be provided: + + apiVersion: v1 + kind: Secret + metadata: + name: example-tls + namespace: foo + data: + tls.crt: + tls.key: + type: kubernetes.io/tls diff --git a/charts/keep/charts/ingress-nginx/templates/_helpers.tpl b/charts/keep/charts/ingress-nginx/templates/_helpers.tpl new file mode 100644 index 0000000..24cfd14 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/_helpers.tpl @@ -0,0 +1,272 @@ +{{/* vim: set filetype=mustache: */}} +{{/* +Expand the name of the chart. +*/}} +{{- define "ingress-nginx.name" -}} +{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" -}} +{{- end -}} + +{{/* +Create chart name and version as used by the chart label. +*/}} +{{- define "ingress-nginx.chart" -}} +{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | 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). +*/}} +{{- define "ingress-nginx.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 -}} + +{{/* +Expand the namespace of the release. +Allows overriding it for multi-namespace deployments in combined charts. +*/}} +{{- define "ingress-nginx.namespace" -}} +{{- default .Release.Namespace .Values.namespaceOverride | trunc 63 | trimSuffix "-" -}} +{{- end -}} + +{{/* +Controller container security context. +*/}} +{{- define "ingress-nginx.controller.containerSecurityContext" -}} +{{- if .Values.controller.containerSecurityContext -}} +{{- toYaml .Values.controller.containerSecurityContext -}} +{{- else -}} +runAsNonRoot: {{ .Values.controller.image.runAsNonRoot }} +runAsUser: {{ .Values.controller.image.runAsUser }} +allowPrivilegeEscalation: {{ or .Values.controller.image.allowPrivilegeEscalation .Values.controller.image.chroot }} +{{- if .Values.controller.image.seccompProfile }} +seccompProfile: {{ toYaml .Values.controller.image.seccompProfile | nindent 2 }} +{{- end }} +capabilities: + drop: + - ALL + add: + - NET_BIND_SERVICE + {{- if .Values.controller.image.chroot }} + {{- if .Values.controller.image.seccompProfile }} + - SYS_ADMIN + {{- end }} + - SYS_CHROOT + {{- end }} +readOnlyRootFilesystem: {{ .Values.controller.image.readOnlyRootFilesystem }} +{{- end -}} +{{- end -}} + +{{/* +Get specific image +*/}} +{{- define "ingress-nginx.image" -}} +{{- if .chroot -}} +{{- printf "%s-chroot" .image -}} +{{- else -}} +{{- printf "%s" .image -}} +{{- end }} +{{- end -}} + +{{/* +Get specific image digest +*/}} +{{- define "ingress-nginx.imageDigest" -}} +{{- if .chroot -}} +{{- if .digestChroot -}} +{{- printf "@%s" .digestChroot -}} +{{- end }} +{{- else -}} +{{ if .digest -}} +{{- printf "@%s" .digest -}} +{{- end -}} +{{- end -}} +{{- end -}} + +{{/* +Create a default fully qualified controller name. +We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). +*/}} +{{- define "ingress-nginx.controller.fullname" -}} +{{- printf "%s-%s" (include "ingress-nginx.fullname" .) .Values.controller.name | trunc 63 | trimSuffix "-" -}} +{{- end -}} + +{{/* +Construct a unique electionID. +Users can provide an override for an explicit electionID if they want via `.Values.controller.electionID` +*/}} +{{- define "ingress-nginx.controller.electionID" -}} +{{- $defElectionID := printf "%s-leader" (include "ingress-nginx.fullname" .) -}} +{{- $electionID := default $defElectionID .Values.controller.electionID -}} +{{- print $electionID -}} +{{- end -}} + +{{/* +Construct the path for the publish-service. + +By convention this will simply use the / to match the name of the +service generated. + +Users can provide an override for an explicit service they want bound via `.Values.controller.publishService.pathOverride` +*/}} +{{- define "ingress-nginx.controller.publishServicePath" -}} +{{- $defServiceName := printf "%s/%s" "$(POD_NAMESPACE)" (include "ingress-nginx.controller.fullname" .) -}} +{{- $servicePath := default $defServiceName .Values.controller.publishService.pathOverride }} +{{- print $servicePath | trimSuffix "-" -}} +{{- end -}} + +{{/* +Common labels +*/}} +{{- define "ingress-nginx.labels" -}} +helm.sh/chart: {{ include "ingress-nginx.chart" . }} +{{ include "ingress-nginx.selectorLabels" . }} +{{- if .Chart.AppVersion }} +app.kubernetes.io/version: {{ .Chart.AppVersion | quote }} +{{- end }} +app.kubernetes.io/part-of: {{ template "ingress-nginx.name" . }} +app.kubernetes.io/managed-by: {{ .Release.Service }} +{{- if .Values.commonLabels}} +{{ toYaml .Values.commonLabels }} +{{- end }} +{{- end -}} + +{{/* +Selector labels +*/}} +{{- define "ingress-nginx.selectorLabels" -}} +app.kubernetes.io/name: {{ include "ingress-nginx.name" . }} +app.kubernetes.io/instance: {{ .Release.Name }} +{{- end -}} + +{{/* +Create the name of the controller service account to use +*/}} +{{- define "ingress-nginx.serviceAccountName" -}} +{{- if .Values.serviceAccount.create -}} + {{ default (include "ingress-nginx.fullname" .) .Values.serviceAccount.name }} +{{- else -}} + {{ default "default" .Values.serviceAccount.name }} +{{- end -}} +{{- end -}} + +{{/* +Create a default fully qualified admission webhook name. +We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). +*/}} +{{- define "ingress-nginx.admissionWebhooks.fullname" -}} +{{- printf "%s-%s" (include "ingress-nginx.fullname" .) .Values.controller.admissionWebhooks.name | trunc 63 | trimSuffix "-" -}} +{{- end -}} + +{{/* +Create the name of the admission webhook patch job service account to use +*/}} +{{- define "ingress-nginx.admissionWebhooks.patch.serviceAccountName" -}} +{{- if .Values.controller.admissionWebhooks.patch.serviceAccount.create -}} + {{ default (include "ingress-nginx.admissionWebhooks.fullname" .) .Values.controller.admissionWebhooks.patch.serviceAccount.name }} +{{- else -}} + {{ default "default" .Values.controller.admissionWebhooks.patch.serviceAccount.name }} +{{- end -}} +{{- end -}} + +{{/* +Create a default fully qualified admission webhook secret creation job name. +We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). +*/}} +{{- define "ingress-nginx.admissionWebhooks.createSecretJob.fullname" -}} +{{- printf "%s-%s" (include "ingress-nginx.admissionWebhooks.fullname" .) .Values.controller.admissionWebhooks.createSecretJob.name | trunc 63 | trimSuffix "-" -}} +{{- end -}} + +{{/* +Create a default fully qualified admission webhook patch job name. +We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). +*/}} +{{- define "ingress-nginx.admissionWebhooks.patchWebhookJob.fullname" -}} +{{- printf "%s-%s" (include "ingress-nginx.admissionWebhooks.fullname" .) .Values.controller.admissionWebhooks.patchWebhookJob.name | trunc 63 | trimSuffix "-" -}} +{{- end -}} + +{{/* +Create a default fully qualified default backend name. +We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). +*/}} +{{- define "ingress-nginx.defaultBackend.fullname" -}} +{{- printf "%s-%s" (include "ingress-nginx.fullname" .) .Values.defaultBackend.name | trunc 63 | trimSuffix "-" -}} +{{- end -}} + +{{/* +Create the name of the default backend service account to use +*/}} +{{- define "ingress-nginx.defaultBackend.serviceAccountName" -}} +{{- if .Values.defaultBackend.serviceAccount.create -}} + {{ default (printf "%s-backend" (include "ingress-nginx.fullname" .)) .Values.defaultBackend.serviceAccount.name }} +{{- else -}} + {{ default "default-backend" .Values.defaultBackend.serviceAccount.name }} +{{- end -}} +{{- end -}} + +{{/* +Default backend container security context. +*/}} +{{- define "ingress-nginx.defaultBackend.containerSecurityContext" -}} +{{- if .Values.defaultBackend.containerSecurityContext -}} +{{- toYaml .Values.defaultBackend.containerSecurityContext -}} +{{- else -}} +runAsNonRoot: {{ .Values.defaultBackend.image.runAsNonRoot }} +runAsUser: {{ .Values.defaultBackend.image.runAsUser }} +allowPrivilegeEscalation: {{ .Values.defaultBackend.image.allowPrivilegeEscalation }} +{{- if .Values.defaultBackend.image.seccompProfile }} +seccompProfile: {{ toYaml .Values.defaultBackend.image.seccompProfile | nindent 2 }} +{{- end }} +capabilities: + drop: + - ALL +readOnlyRootFilesystem: {{ .Values.defaultBackend.image.readOnlyRootFilesystem }} +{{- end -}} +{{- end -}} + +{{/* +Return the appropriate apiGroup for PodSecurityPolicy. +*/}} +{{- define "podSecurityPolicy.apiGroup" -}} +{{- if semverCompare ">=1.14-0" .Capabilities.KubeVersion.GitVersion -}} +{{- print "policy" -}} +{{- else -}} +{{- print "extensions" -}} +{{- end -}} +{{- end -}} + +{{/* +Extra modules. +*/}} +{{- define "extraModules" -}} +- name: {{ .name }} + {{- with .image }} + image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ .image }}{{ end }}:{{ .tag }}{{ if .digest }}@{{ .digest }}{{ end }} + command: + {{- if .distroless }} + - /init_module + {{- else }} + - sh + - -c + - /usr/local/bin/init_module.sh + {{- end }} + {{- end }} + {{- if .containerSecurityContext }} + securityContext: {{ toYaml .containerSecurityContext | nindent 4 }} + {{- end }} + {{- if .resources }} + resources: {{ toYaml .resources | nindent 4 }} + {{- end }} + volumeMounts: + - name: modules + mountPath: /modules_mount +{{- end -}} diff --git a/charts/keep/charts/ingress-nginx/templates/_params.tpl b/charts/keep/charts/ingress-nginx/templates/_params.tpl new file mode 100644 index 0000000..48569a8 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/_params.tpl @@ -0,0 +1,77 @@ +{{- define "ingress-nginx.params" -}} +- /nginx-ingress-controller +{{- if .Values.controller.enableAnnotationValidations }} +- --enable-annotation-validation=true +{{- end }} +{{- if .Values.defaultBackend.enabled }} +- --default-backend-service=$(POD_NAMESPACE)/{{ include "ingress-nginx.defaultBackend.fullname" . }} +{{- end }} +{{- if and .Values.controller.publishService.enabled .Values.controller.service.enabled }} +{{- if .Values.controller.service.external.enabled }} +- --publish-service={{ template "ingress-nginx.controller.publishServicePath" . }} +{{- else if .Values.controller.service.internal.enabled }} +- --publish-service={{ template "ingress-nginx.controller.publishServicePath" . }}-internal +{{- end }} +{{- end }} +- --election-id={{ include "ingress-nginx.controller.electionID" . }} +- --controller-class={{ .Values.controller.ingressClassResource.controllerValue }} +{{- if .Values.controller.ingressClass }} +- --ingress-class={{ .Values.controller.ingressClass }} +{{- end }} +- --configmap={{ default "$(POD_NAMESPACE)" .Values.controller.configMapNamespace }}/{{ include "ingress-nginx.controller.fullname" . }} +{{- if .Values.tcp }} +- --tcp-services-configmap={{ default "$(POD_NAMESPACE)" .Values.controller.tcp.configMapNamespace }}/{{ include "ingress-nginx.fullname" . }}-tcp +{{- end }} +{{- if .Values.udp }} +- --udp-services-configmap={{ default "$(POD_NAMESPACE)" .Values.controller.udp.configMapNamespace }}/{{ include "ingress-nginx.fullname" . }}-udp +{{- end }} +{{- if .Values.controller.scope.enabled }} +- --watch-namespace={{ default "$(POD_NAMESPACE)" .Values.controller.scope.namespace }} +{{- end }} +{{- if and (not .Values.controller.scope.enabled) .Values.controller.scope.namespaceSelector }} +- --watch-namespace-selector={{ .Values.controller.scope.namespaceSelector }} +{{- end }} +{{- if and .Values.controller.reportNodeInternalIp .Values.controller.hostNetwork }} +- --report-node-internal-ip-address={{ .Values.controller.reportNodeInternalIp }} +{{- end }} +{{- if .Values.controller.admissionWebhooks.enabled }} +- --validating-webhook=:{{ .Values.controller.admissionWebhooks.port }} +- --validating-webhook-certificate={{ .Values.controller.admissionWebhooks.certificate }} +- --validating-webhook-key={{ .Values.controller.admissionWebhooks.key }} +{{- end }} +{{- if .Values.controller.maxmindLicenseKey }} +- --maxmind-license-key={{ .Values.controller.maxmindLicenseKey }} +{{- end }} +{{- if .Values.controller.healthCheckHost }} +- --healthz-host={{ .Values.controller.healthCheckHost }} +{{- end }} +{{- if not (eq .Values.controller.healthCheckPath "/healthz") }} +- --health-check-path={{ .Values.controller.healthCheckPath }} +{{- end }} +{{- if .Values.controller.ingressClassByName }} +- --ingress-class-by-name=true +{{- end }} +{{- if .Values.controller.watchIngressWithoutClass }} +- --watch-ingress-without-class=true +{{- end }} +{{- if not .Values.controller.metrics.enabled }} +- --enable-metrics={{ .Values.controller.metrics.enabled }} +{{- end }} +{{- if .Values.controller.enableTopologyAwareRouting }} +- --enable-topology-aware-routing=true +{{- end }} +{{- if .Values.controller.disableLeaderElection }} +- --disable-leader-election=true +{{- end }} +{{- if .Values.controller.electionTTL }} +- --election-ttl={{ .Values.controller.electionTTL }} +{{- end }} +{{- range $key, $value := .Values.controller.extraArgs }} +{{- /* Accept keys without values or with false as value */}} +{{- if eq ($value | quote | len) 2 }} +- --{{ $key }} +{{- else }} +- --{{ $key }}={{ $value }} +{{- end }} +{{- end }} +{{- end -}} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/cert-manager.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/cert-manager.yaml new file mode 100644 index 0000000..db2946c --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/cert-manager.yaml @@ -0,0 +1,63 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.certManager.enabled -}} +{{- if not .Values.controller.admissionWebhooks.certManager.issuerRef -}} +# Create a selfsigned Issuer, in order to create a root CA certificate for +# signing webhook serving certificates +apiVersion: cert-manager.io/v1 +kind: Issuer +metadata: + name: {{ include "ingress-nginx.fullname" . }}-self-signed-issuer + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + selfSigned: {} +--- +# Generate a CA Certificate used to sign certificates for the webhook +apiVersion: cert-manager.io/v1 +kind: Certificate +metadata: + name: {{ include "ingress-nginx.fullname" . }}-root-cert + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + secretName: {{ include "ingress-nginx.fullname" . }}-root-cert + duration: {{ .Values.controller.admissionWebhooks.certManager.rootCert.duration | default "43800h0m0s" | quote }} + issuerRef: + name: {{ include "ingress-nginx.fullname" . }}-self-signed-issuer + commonName: "ca.webhook.ingress-nginx" + isCA: true + subject: + organizations: + - ingress-nginx +--- +# Create an Issuer that uses the above generated CA certificate to issue certs +apiVersion: cert-manager.io/v1 +kind: Issuer +metadata: + name: {{ include "ingress-nginx.fullname" . }}-root-issuer + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + ca: + secretName: {{ include "ingress-nginx.fullname" . }}-root-cert +{{- end }} +--- +# generate a server certificate for the apiservices to use +apiVersion: cert-manager.io/v1 +kind: Certificate +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + secretName: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + duration: {{ .Values.controller.admissionWebhooks.certManager.admissionCert.duration | default "8760h0m0s" | quote }} + issuerRef: + {{- if .Values.controller.admissionWebhooks.certManager.issuerRef }} + {{- toYaml .Values.controller.admissionWebhooks.certManager.issuerRef | nindent 4 }} + {{- else }} + name: {{ include "ingress-nginx.fullname" . }}-root-issuer + {{- end }} + dnsNames: + - {{ include "ingress-nginx.controller.fullname" . }}-admission + - {{ include "ingress-nginx.controller.fullname" . }}-admission.{{ include "ingress-nginx.namespace" . }} + - {{ include "ingress-nginx.controller.fullname" . }}-admission.{{ include "ingress-nginx.namespace" . }}.svc + subject: + organizations: + - ingress-nginx-admission +{{- end -}} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml new file mode 100644 index 0000000..a218482 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml @@ -0,0 +1,33 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.rbac.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +rules: + - apiGroups: + - admissionregistration.k8s.io + resources: + - validatingwebhookconfigurations + verbs: + - get + - update +{{- if .Values.podSecurityPolicy.enabled }} + - apiGroups: [{{ template "podSecurityPolicy.apiGroup" . }}] + resources: ['podsecuritypolicies'] + verbs: ['use'] + {{- with .Values.controller.admissionWebhooks.existingPsp }} + resourceNames: [{{ . }}] + {{- else }} + resourceNames: [{{ include "ingress-nginx.admissionWebhooks.fullname" . }}] + {{- end }} +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml new file mode 100644 index 0000000..b893884 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml @@ -0,0 +1,23 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.rbac.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} +subjects: + - kind: ServiceAccount + name: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml new file mode 100644 index 0000000..1766164 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml @@ -0,0 +1,79 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled (not .Values.controller.admissionWebhooks.certManager.enabled) -}} +apiVersion: batch/v1 +kind: Job +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.createSecretJob.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + annotations: + "helm.sh/hook": pre-install,pre-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + {{- with .Values.controller.admissionWebhooks.annotations }} + {{- toYaml . | nindent 4 }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +spec: +{{- if .Capabilities.APIVersions.Has "batch/v1alpha1" }} + # Alpha feature since k8s 1.12 + ttlSecondsAfterFinished: 0 +{{- end }} + template: + metadata: + name: {{ include "ingress-nginx.admissionWebhooks.createSecretJob.fullname" . }} + {{- if .Values.controller.admissionWebhooks.patch.podAnnotations }} + annotations: {{ toYaml .Values.controller.admissionWebhooks.patch.podAnnotations | nindent 8 }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 8 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 8 }} + {{- end }} + spec: + {{- if .Values.controller.admissionWebhooks.patch.priorityClassName }} + priorityClassName: {{ .Values.controller.admissionWebhooks.patch.priorityClassName }} + {{- end }} + {{- if .Values.imagePullSecrets }} + imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} + {{- end }} + containers: + - name: create + {{- with .Values.controller.admissionWebhooks.patch.image }} + image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ .image }}{{ end }}:{{ .tag }}{{ if .digest }}@{{ .digest }}{{ end }} + {{- end }} + imagePullPolicy: {{ .Values.controller.admissionWebhooks.patch.image.pullPolicy }} + args: + - create + - --host={{ include "ingress-nginx.controller.fullname" . }}-admission,{{ include "ingress-nginx.controller.fullname" . }}-admission.$(POD_NAMESPACE).svc + - --namespace=$(POD_NAMESPACE) + - --secret-name={{ include "ingress-nginx.admissionWebhooks.fullname" . }} + env: + - name: POD_NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + {{- if .Values.controller.admissionWebhooks.extraEnvs }} + {{- toYaml .Values.controller.admissionWebhooks.extraEnvs | nindent 12 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.createSecretJob.securityContext }} + securityContext: {{ toYaml .Values.controller.admissionWebhooks.createSecretJob.securityContext | nindent 12 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.createSecretJob.resources }} + resources: {{ toYaml .Values.controller.admissionWebhooks.createSecretJob.resources | nindent 12 }} + {{- end }} + restartPolicy: OnFailure + serviceAccountName: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} + {{- if .Values.controller.admissionWebhooks.patch.nodeSelector }} + nodeSelector: {{ toYaml .Values.controller.admissionWebhooks.patch.nodeSelector | nindent 8 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.patch.tolerations }} + tolerations: {{ toYaml .Values.controller.admissionWebhooks.patch.tolerations | nindent 8 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.patch.securityContext }} + securityContext: {{ toYaml .Values.controller.admissionWebhooks.patch.securityContext | nindent 8 }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml new file mode 100644 index 0000000..f7d44a2 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml @@ -0,0 +1,81 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled (not .Values.controller.admissionWebhooks.certManager.enabled) -}} +apiVersion: batch/v1 +kind: Job +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.patchWebhookJob.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + annotations: + "helm.sh/hook": post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + {{- with .Values.controller.admissionWebhooks.annotations }} + {{- toYaml . | nindent 4 }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +spec: +{{- if .Capabilities.APIVersions.Has "batch/v1alpha1" }} + # Alpha feature since k8s 1.12 + ttlSecondsAfterFinished: 0 +{{- end }} + template: + metadata: + name: {{ include "ingress-nginx.admissionWebhooks.patchWebhookJob.fullname" . }} + {{- if .Values.controller.admissionWebhooks.patch.podAnnotations }} + annotations: {{ toYaml .Values.controller.admissionWebhooks.patch.podAnnotations | nindent 8 }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 8 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 8 }} + {{- end }} + spec: + {{- if .Values.controller.admissionWebhooks.patch.priorityClassName }} + priorityClassName: {{ .Values.controller.admissionWebhooks.patch.priorityClassName }} + {{- end }} + {{- if .Values.imagePullSecrets }} + imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} + {{- end }} + containers: + - name: patch + {{- with .Values.controller.admissionWebhooks.patch.image }} + image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ .image }}{{ end }}:{{ .tag }}{{ if .digest }}@{{ .digest }}{{ end }} + {{- end }} + imagePullPolicy: {{ .Values.controller.admissionWebhooks.patch.image.pullPolicy }} + args: + - patch + - --webhook-name={{ include "ingress-nginx.admissionWebhooks.fullname" . }} + - --namespace=$(POD_NAMESPACE) + - --patch-mutating=false + - --secret-name={{ include "ingress-nginx.admissionWebhooks.fullname" . }} + - --patch-failure-policy={{ .Values.controller.admissionWebhooks.failurePolicy }} + env: + - name: POD_NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + {{- if .Values.controller.admissionWebhooks.extraEnvs }} + {{- toYaml .Values.controller.admissionWebhooks.extraEnvs | nindent 12 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.patchWebhookJob.securityContext }} + securityContext: {{ toYaml .Values.controller.admissionWebhooks.patchWebhookJob.securityContext | nindent 12 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.patchWebhookJob.resources }} + resources: {{ toYaml .Values.controller.admissionWebhooks.patchWebhookJob.resources | nindent 12 }} + {{- end }} + restartPolicy: OnFailure + serviceAccountName: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} + {{- if .Values.controller.admissionWebhooks.patch.nodeSelector }} + nodeSelector: {{ toYaml .Values.controller.admissionWebhooks.patch.nodeSelector | nindent 8 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.patch.tolerations }} + tolerations: {{ toYaml .Values.controller.admissionWebhooks.patch.tolerations | nindent 8 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.patch.securityContext }} + securityContext: {{ toYaml .Values.controller.admissionWebhooks.patch.securityContext | nindent 8 }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/networkpolicy.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/networkpolicy.yaml new file mode 100644 index 0000000..a8f38df --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/networkpolicy.yaml @@ -0,0 +1,26 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.networkPolicy.enabled (not .Values.controller.admissionWebhooks.certManager.enabled) -}} +apiVersion: networking.k8s.io/v1 +kind: NetworkPolicy +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +spec: + podSelector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: admission-webhook + policyTypes: + - Ingress + - Egress + egress: + - {} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/psp.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/psp.yaml new file mode 100644 index 0000000..8e5dc72 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/psp.yaml @@ -0,0 +1,52 @@ +{{- if (semverCompare "<1.25.0-0" .Capabilities.KubeVersion.Version) }} +{{- if and .Values.podSecurityPolicy.enabled .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled (empty .Values.controller.admissionWebhooks.existingPsp) -}} +apiVersion: policy/v1beta1 +kind: PodSecurityPolicy +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + seccomp.security.alpha.kubernetes.io/allowedProfileNames: "*" + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +spec: + privileged: false + hostPID: false + hostIPC: false + hostNetwork: false + volumes: + - configMap + - downwardAPI + - emptyDir + - secret + - projected + fsGroup: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + readOnlyRootFilesystem: true + runAsUser: + rule: MustRunAsNonRoot + runAsGroup: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + supplementalGroups: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + allowPrivilegeEscalation: false + requiredDropCapabilities: + - ALL + seLinux: + rule: RunAsAny +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml new file mode 100644 index 0000000..c4b23aa --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml @@ -0,0 +1,24 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.rbac.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +rules: + - apiGroups: + - "" + resources: + - secrets + verbs: + - get + - create +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml new file mode 100644 index 0000000..425e8d8 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml @@ -0,0 +1,24 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.rbac.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} +subjects: + - kind: ServiceAccount + name: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml new file mode 100644 index 0000000..52f94dc --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml @@ -0,0 +1,17 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.serviceAccount.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} +apiVersion: v1 +kind: ServiceAccount +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +automountServiceAccountToken: {{ .Values.controller.admissionWebhooks.patch.serviceAccount.automountServiceAccountToken }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml new file mode 100644 index 0000000..0949cea --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml @@ -0,0 +1,54 @@ +{{- if .Values.controller.admissionWebhooks.enabled -}} +# before changing this value, check the required kubernetes version +# https://kubernetes.io/docs/reference/access-authn-authz/extensible-admission-controllers/#prerequisites +apiVersion: admissionregistration.k8s.io/v1 +kind: ValidatingWebhookConfiguration +metadata: + annotations: + {{- if .Values.controller.admissionWebhooks.certManager.enabled }} + certmanager.k8s.io/inject-ca-from: {{ printf "%s/%s" (include "ingress-nginx.namespace" .) (include "ingress-nginx.admissionWebhooks.fullname" .) | quote }} + cert-manager.io/inject-ca-from: {{ printf "%s/%s" (include "ingress-nginx.namespace" .) (include "ingress-nginx.admissionWebhooks.fullname" .) | quote }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.annotations }} + {{- toYaml .Values.controller.admissionWebhooks.annotations | nindent 4 }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} +webhooks: + - name: validate.nginx.ingress.kubernetes.io + matchPolicy: Equivalent + rules: + - apiGroups: + - networking.k8s.io + apiVersions: + - v1 + operations: + - CREATE + - UPDATE + resources: + - ingresses + failurePolicy: {{ .Values.controller.admissionWebhooks.failurePolicy | default "Fail" }} + sideEffects: None + admissionReviewVersions: + - v1 + clientConfig: + service: + name: {{ include "ingress-nginx.controller.fullname" . }}-admission + namespace: {{ include "ingress-nginx.namespace" . }} + port: {{ .Values.controller.admissionWebhooks.service.servicePort }} + path: /networking/v1/ingresses + {{- if .Values.controller.admissionWebhooks.timeoutSeconds }} + timeoutSeconds: {{ .Values.controller.admissionWebhooks.timeoutSeconds }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.namespaceSelector }} + namespaceSelector: {{ toYaml .Values.controller.admissionWebhooks.namespaceSelector | nindent 6 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.objectSelector }} + objectSelector: {{ toYaml .Values.controller.admissionWebhooks.objectSelector | nindent 6 }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/clusterrole.yaml b/charts/keep/charts/ingress-nginx/templates/clusterrole.yaml new file mode 100644 index 0000000..51bc500 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/clusterrole.yaml @@ -0,0 +1,102 @@ +{{- if .Values.rbac.create }} + +{{- if and .Values.rbac.scope (not .Values.controller.scope.enabled) -}} + {{ required "Invalid configuration: 'rbac.scope' should be equal to 'controller.scope.enabled' (true/false)." (index (dict) ".") }} +{{- end }} + +{{- if not .Values.rbac.scope -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.fullname" . }} +rules: + - apiGroups: + - "" + resources: + - configmaps + - endpoints + - nodes + - pods + - secrets +{{- if not .Values.controller.scope.enabled }} + - namespaces +{{- end}} + verbs: + - list + - watch + - apiGroups: + - coordination.k8s.io + resources: + - leases + verbs: + - list + - watch +{{- if and .Values.controller.scope.enabled .Values.controller.scope.namespace }} + - apiGroups: + - "" + resources: + - namespaces + resourceNames: + - "{{ .Values.controller.scope.namespace }}" + verbs: + - get +{{- end }} + - apiGroups: + - "" + resources: + - nodes + verbs: + - get + - apiGroups: + - "" + resources: + - services + verbs: + - get + - list + - watch + - apiGroups: + - networking.k8s.io + resources: + - ingresses + verbs: + - get + - list + - watch + - apiGroups: + - "" + resources: + - events + verbs: + - create + - patch + - apiGroups: + - networking.k8s.io + resources: + - ingresses/status + verbs: + - update + - apiGroups: + - networking.k8s.io + resources: + - ingressclasses + verbs: + - get + - list + - watch + - apiGroups: + - discovery.k8s.io + resources: + - endpointslices + verbs: + - list + - watch + - get +{{- end }} + +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/clusterrolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/clusterrolebinding.yaml new file mode 100644 index 0000000..8f91aac --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/clusterrolebinding.yaml @@ -0,0 +1,19 @@ +{{- if and .Values.rbac.create (not .Values.rbac.scope) -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.fullname" . }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: {{ include "ingress-nginx.fullname" . }} +subjects: + - kind: ServiceAccount + name: {{ template "ingress-nginx.serviceAccountName" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap-addheaders.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap-addheaders.yaml new file mode 100644 index 0000000..4e4bd13 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-configmap-addheaders.yaml @@ -0,0 +1,14 @@ +{{- if .Values.controller.addHeaders -}} +apiVersion: v1 +kind: ConfigMap +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.fullname" . }}-custom-add-headers + namespace: {{ include "ingress-nginx.namespace" . }} +data: {{ toYaml .Values.controller.addHeaders | nindent 2 }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap-proxyheaders.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap-proxyheaders.yaml new file mode 100644 index 0000000..0a22600 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-configmap-proxyheaders.yaml @@ -0,0 +1,14 @@ +{{- if .Values.controller.proxySetHeaders -}} +apiVersion: v1 +kind: ConfigMap +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.fullname" . }}-custom-proxy-headers + namespace: {{ include "ingress-nginx.namespace" . }} +data: {{ toYaml .Values.controller.proxySetHeaders | nindent 2 }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap-tcp.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap-tcp.yaml new file mode 100644 index 0000000..131a9ad --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-configmap-tcp.yaml @@ -0,0 +1,17 @@ +{{- if .Values.tcp -}} +apiVersion: v1 +kind: ConfigMap +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +{{- if .Values.controller.tcp.annotations }} + annotations: {{ toYaml .Values.controller.tcp.annotations | nindent 4 }} +{{- end }} + name: {{ include "ingress-nginx.fullname" . }}-tcp + namespace: {{ include "ingress-nginx.namespace" . }} +data: {{ tpl (toYaml .Values.tcp) . | nindent 2 }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap-udp.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap-udp.yaml new file mode 100644 index 0000000..7137da9 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-configmap-udp.yaml @@ -0,0 +1,17 @@ +{{- if .Values.udp -}} +apiVersion: v1 +kind: ConfigMap +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +{{- if .Values.controller.udp.annotations }} + annotations: {{ toYaml .Values.controller.udp.annotations | nindent 4 }} +{{- end }} + name: {{ include "ingress-nginx.fullname" . }}-udp + namespace: {{ include "ingress-nginx.namespace" . }} +data: {{ tpl (toYaml .Values.udp) . | nindent 2 }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap.yaml new file mode 100644 index 0000000..22080d1 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-configmap.yaml @@ -0,0 +1,28 @@ +apiVersion: v1 +kind: ConfigMap +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +{{- if .Values.controller.configAnnotations }} + annotations: {{ toYaml .Values.controller.configAnnotations | nindent 4 }} +{{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +data: + allow-snippet-annotations: "{{ .Values.controller.allowSnippetAnnotations }}" +{{- if .Values.controller.addHeaders }} + add-headers: {{ include "ingress-nginx.namespace" . }}/{{ include "ingress-nginx.fullname" . }}-custom-add-headers +{{- end }} +{{- if .Values.controller.proxySetHeaders }} + proxy-set-headers: {{ include "ingress-nginx.namespace" . }}/{{ include "ingress-nginx.fullname" . }}-custom-proxy-headers +{{- end }} +{{- if .Values.dhParam }} + ssl-dh-param: {{ include "ingress-nginx.namespace" . }}/{{ include "ingress-nginx.controller.fullname" . }} +{{- end }} +{{- range $key, $value := .Values.controller.config }} + {{- $key | nindent 2 }}: {{ tpl (toString $value) $ | quote }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-daemonset.yaml b/charts/keep/charts/ingress-nginx/templates/controller-daemonset.yaml new file mode 100644 index 0000000..fcc633d --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-daemonset.yaml @@ -0,0 +1,242 @@ +{{- if eq .Values.controller.kind "DaemonSet" -}} +apiVersion: apps/v1 +kind: DaemonSet +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + {{- if .Values.controller.annotations }} + annotations: {{ toYaml .Values.controller.annotations | nindent 4 }} + {{- end }} +spec: + selector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: controller + revisionHistoryLimit: {{ .Values.revisionHistoryLimit }} + {{- if .Values.controller.updateStrategy }} + updateStrategy: {{ toYaml .Values.controller.updateStrategy | nindent 4 }} + {{- end }} + minReadySeconds: {{ .Values.controller.minReadySeconds }} + template: + metadata: + {{- if .Values.controller.podAnnotations }} + annotations: + {{- range $key, $value := .Values.controller.podAnnotations }} + {{ $key }}: {{ $value | quote }} + {{- end }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 8 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 8 }} + {{- end }} + {{- if .Values.controller.podLabels }} + {{- toYaml .Values.controller.podLabels | nindent 8 }} + {{- end }} + spec: + {{- if .Values.controller.dnsConfig }} + dnsConfig: {{ toYaml .Values.controller.dnsConfig | nindent 8 }} + {{- end }} + {{- if .Values.controller.hostAliases }} + hostAliases: {{ tpl (toYaml .Values.controller.hostAliases) $ | nindent 8 }} + {{- end }} + {{- if .Values.controller.hostname }} + hostname: {{ toYaml .Values.controller.hostname | nindent 8 }} + {{- end }} + dnsPolicy: {{ .Values.controller.dnsPolicy }} + {{- if .Values.imagePullSecrets }} + imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} + {{- end }} + {{- if .Values.controller.priorityClassName }} + priorityClassName: {{ .Values.controller.priorityClassName | quote }} + {{- end }} + {{- if or .Values.controller.podSecurityContext .Values.controller.sysctls }} + securityContext: + {{- if .Values.controller.podSecurityContext }} + {{- toYaml .Values.controller.podSecurityContext | nindent 8 }} + {{- end }} + {{- if .Values.controller.sysctls }} + sysctls: + {{- range $sysctl, $value := .Values.controller.sysctls }} + - name: {{ $sysctl | quote }} + value: {{ $value | quote }} + {{- end }} + {{- end }} + {{- end }} + {{- if .Values.controller.shareProcessNamespace }} + shareProcessNamespace: {{ .Values.controller.shareProcessNamespace }} + {{- end }} + containers: + - name: {{ .Values.controller.containerName }} + {{- with .Values.controller.image }} + image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ include "ingress-nginx.image" . }}{{ end }}:{{ .tag }}{{ include "ingress-nginx.imageDigest" . }} + {{- end }} + imagePullPolicy: {{ .Values.controller.image.pullPolicy }} + {{- if .Values.controller.lifecycle }} + lifecycle: {{ toYaml .Values.controller.lifecycle | nindent 12 }} + {{- end }} + args: {{ include "ingress-nginx.params" . | nindent 12 }} + securityContext: {{ include "ingress-nginx.controller.containerSecurityContext" . | nindent 12 }} + env: + - name: POD_NAME + valueFrom: + fieldRef: + fieldPath: metadata.name + - name: POD_NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + {{- if .Values.controller.enableMimalloc }} + - name: LD_PRELOAD + value: /usr/local/lib/libmimalloc.so + {{- end }} + {{- if .Values.controller.extraEnvs }} + {{- toYaml .Values.controller.extraEnvs | nindent 12 }} + {{- end }} + {{- if .Values.controller.startupProbe }} + startupProbe: {{ toYaml .Values.controller.startupProbe | nindent 12 }} + {{- end }} + {{- if .Values.controller.livenessProbe }} + livenessProbe: {{ toYaml .Values.controller.livenessProbe | nindent 12 }} + {{- end }} + {{- if .Values.controller.readinessProbe }} + readinessProbe: {{ toYaml .Values.controller.readinessProbe | nindent 12 }} + {{- end }} + ports: + {{- range $key, $value := .Values.controller.containerPort }} + - name: {{ $key }} + containerPort: {{ $value }} + protocol: TCP + {{- if $.Values.controller.hostPort.enabled }} + hostPort: {{ index $.Values.controller.hostPort.ports $key | default $value }} + {{- end }} + {{- end }} + {{- if .Values.controller.metrics.enabled }} + - name: {{ .Values.controller.metrics.portName }} + containerPort: {{ .Values.controller.metrics.port }} + protocol: TCP + {{- end }} + {{- if .Values.controller.admissionWebhooks.enabled }} + - name: webhook + containerPort: {{ .Values.controller.admissionWebhooks.port }} + protocol: TCP + {{- end }} + {{- range $key, $value := .Values.tcp }} + - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp + containerPort: {{ $key }} + protocol: TCP + {{- if $.Values.controller.hostPort.enabled }} + hostPort: {{ $key }} + {{- end }} + {{- end }} + {{- range $key, $value := .Values.udp }} + - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp + containerPort: {{ $key }} + protocol: UDP + {{- if $.Values.controller.hostPort.enabled }} + hostPort: {{ $key }} + {{- end }} + {{- end }} + {{- if (or .Values.controller.customTemplate.configMapName .Values.controller.extraVolumeMounts .Values.controller.admissionWebhooks.enabled .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} + volumeMounts: + {{- if (or .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} + - name: modules + {{- if .Values.controller.image.chroot }} + mountPath: /chroot/modules_mount + {{- else }} + mountPath: /modules_mount + {{- end }} + {{- end }} + {{- if .Values.controller.customTemplate.configMapName }} + - mountPath: /etc/nginx/template + name: nginx-template-volume + readOnly: true + {{- end }} + {{- if .Values.controller.admissionWebhooks.enabled }} + - name: webhook-cert + mountPath: /usr/local/certificates/ + readOnly: true + {{- end }} + {{- if .Values.controller.extraVolumeMounts }} + {{- toYaml .Values.controller.extraVolumeMounts | nindent 12 }} + {{- end }} + {{- end }} + {{- if .Values.controller.resources }} + resources: {{ toYaml .Values.controller.resources | nindent 12 }} + {{- end }} + {{- if .Values.controller.extraContainers }} + {{- toYaml .Values.controller.extraContainers | nindent 8 }} + {{- end }} + {{- if (or .Values.controller.extraInitContainers .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} + initContainers: + {{- if .Values.controller.extraInitContainers }} + {{- toYaml .Values.controller.extraInitContainers | nindent 8 }} + {{- end }} + {{- if .Values.controller.extraModules }} + {{- range .Values.controller.extraModules }} + {{- $containerSecurityContext := .containerSecurityContext | default $.Values.controller.containerSecurityContext }} + {{- include "extraModules" (dict "name" .name "image" .image "containerSecurityContext" $containerSecurityContext "resources" .resources) | nindent 8 }} + {{- end }} + {{- end }} + {{- if .Values.controller.opentelemetry.enabled }} + {{- with .Values.controller.opentelemetry }} + {{- $containerSecurityContext := .containerSecurityContext | default $.Values.controller.containerSecurityContext }} + {{- include "extraModules" (dict "name" .name "image" .image "containerSecurityContext" $containerSecurityContext "resources" .resources) | nindent 8 }} + {{- end }} + {{- end }} + {{- end }} + {{- if .Values.controller.hostNetwork }} + hostNetwork: {{ .Values.controller.hostNetwork }} + {{- end }} + {{- if .Values.controller.nodeSelector }} + nodeSelector: {{ toYaml .Values.controller.nodeSelector | nindent 8 }} + {{- end }} + {{- if .Values.controller.tolerations }} + tolerations: {{ toYaml .Values.controller.tolerations | nindent 8 }} + {{- end }} + {{- if .Values.controller.affinity }} + affinity: {{ tpl (toYaml .Values.controller.affinity) $ | nindent 8 }} + {{- end }} + {{- if .Values.controller.topologySpreadConstraints }} + topologySpreadConstraints: {{ tpl (toYaml .Values.controller.topologySpreadConstraints) $ | nindent 8 }} + {{- end }} + serviceAccountName: {{ template "ingress-nginx.serviceAccountName" . }} + terminationGracePeriodSeconds: {{ .Values.controller.terminationGracePeriodSeconds }} + {{- if (or .Values.controller.customTemplate.configMapName .Values.controller.extraVolumeMounts .Values.controller.admissionWebhooks.enabled .Values.controller.extraVolumes .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} + volumes: + {{- if (or .Values.controller.extraModules .Values.controller.opentelemetry.enabled)}} + - name: modules + emptyDir: {} + {{- end }} + {{- if .Values.controller.customTemplate.configMapName }} + - name: nginx-template-volume + configMap: + name: {{ .Values.controller.customTemplate.configMapName }} + items: + - key: {{ .Values.controller.customTemplate.configMapKey }} + path: nginx.tmpl + {{- end }} + {{- if .Values.controller.admissionWebhooks.enabled }} + - name: webhook-cert + secret: + secretName: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + {{- if .Values.controller.admissionWebhooks.certManager.enabled }} + items: + - key: tls.crt + path: cert + - key: tls.key + path: key + {{- end }} + {{- end }} + {{- if .Values.controller.extraVolumes }} + {{ toYaml .Values.controller.extraVolumes | nindent 8 }} + {{- end }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-deployment.yaml b/charts/keep/charts/ingress-nginx/templates/controller-deployment.yaml new file mode 100644 index 0000000..5211acd --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-deployment.yaml @@ -0,0 +1,245 @@ +{{- if eq .Values.controller.kind "Deployment" -}} +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + {{- if .Values.controller.annotations }} + annotations: {{ toYaml .Values.controller.annotations | nindent 4 }} + {{- end }} +spec: + selector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: controller + {{- if eq .Values.controller.autoscaling.enabled .Values.controller.keda.enabled }} + replicas: {{ .Values.controller.replicaCount }} + {{- end }} + revisionHistoryLimit: {{ .Values.revisionHistoryLimit }} + {{- if .Values.controller.updateStrategy }} + strategy: {{ toYaml .Values.controller.updateStrategy | nindent 4 }} + {{- end }} + minReadySeconds: {{ .Values.controller.minReadySeconds }} + template: + metadata: + {{- if .Values.controller.podAnnotations }} + annotations: + {{- range $key, $value := .Values.controller.podAnnotations }} + {{ $key }}: {{ $value | quote }} + {{- end }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 8 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 8 }} + {{- end }} + {{- if .Values.controller.podLabels }} + {{- toYaml .Values.controller.podLabels | nindent 8 }} + {{- end }} + spec: + {{- if .Values.controller.dnsConfig }} + dnsConfig: {{ toYaml .Values.controller.dnsConfig | nindent 8 }} + {{- end }} + {{- if .Values.controller.hostAliases }} + hostAliases: {{ tpl (toYaml .Values.controller.hostAliases) $ | nindent 8 }} + {{- end }} + {{- if .Values.controller.hostname }} + hostname: {{ toYaml .Values.controller.hostname | nindent 8 }} + {{- end }} + dnsPolicy: {{ .Values.controller.dnsPolicy }} + {{- if .Values.imagePullSecrets }} + imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} + {{- end }} + {{- if .Values.controller.priorityClassName }} + priorityClassName: {{ .Values.controller.priorityClassName | quote }} + {{- end }} + {{- if or .Values.controller.podSecurityContext .Values.controller.sysctls }} + securityContext: + {{- if .Values.controller.podSecurityContext }} + {{- toYaml .Values.controller.podSecurityContext | nindent 8 }} + {{- end }} + {{- if .Values.controller.sysctls }} + sysctls: + {{- range $sysctl, $value := .Values.controller.sysctls }} + - name: {{ $sysctl | quote }} + value: {{ $value | quote }} + {{- end }} + {{- end }} + {{- end }} + {{- if .Values.controller.shareProcessNamespace }} + shareProcessNamespace: {{ .Values.controller.shareProcessNamespace }} + {{- end }} + containers: + - name: {{ .Values.controller.containerName }} + {{- with .Values.controller.image }} + image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ include "ingress-nginx.image" . }}{{ end }}:{{ .tag }}{{ include "ingress-nginx.imageDigest" . }} + {{- end }} + imagePullPolicy: {{ .Values.controller.image.pullPolicy }} + {{- if .Values.controller.lifecycle }} + lifecycle: {{ toYaml .Values.controller.lifecycle | nindent 12 }} + {{- end }} + args: {{ include "ingress-nginx.params" . | nindent 12 }} + securityContext: {{ include "ingress-nginx.controller.containerSecurityContext" . | nindent 12 }} + env: + - name: POD_NAME + valueFrom: + fieldRef: + fieldPath: metadata.name + - name: POD_NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + {{- if .Values.controller.enableMimalloc }} + - name: LD_PRELOAD + value: /usr/local/lib/libmimalloc.so + {{- end }} + {{- if .Values.controller.extraEnvs }} + {{- toYaml .Values.controller.extraEnvs | nindent 12 }} + {{- end }} + {{- if .Values.controller.startupProbe }} + startupProbe: {{ toYaml .Values.controller.startupProbe | nindent 12 }} + {{- end }} + {{- if .Values.controller.livenessProbe }} + livenessProbe: {{ toYaml .Values.controller.livenessProbe | nindent 12 }} + {{- end }} + {{- if .Values.controller.readinessProbe }} + readinessProbe: {{ toYaml .Values.controller.readinessProbe | nindent 12 }} + {{- end }} + ports: + {{- range $key, $value := .Values.controller.containerPort }} + - name: {{ $key }} + containerPort: {{ $value }} + protocol: TCP + {{- if $.Values.controller.hostPort.enabled }} + hostPort: {{ index $.Values.controller.hostPort.ports $key | default $value }} + {{- end }} + {{- end }} + {{- if .Values.controller.metrics.enabled }} + - name: {{ .Values.controller.metrics.portName }} + containerPort: {{ .Values.controller.metrics.port }} + protocol: TCP + {{- end }} + {{- if .Values.controller.admissionWebhooks.enabled }} + - name: webhook + containerPort: {{ .Values.controller.admissionWebhooks.port }} + protocol: TCP + {{- end }} + {{- range $key, $value := .Values.tcp }} + - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp + containerPort: {{ $key }} + protocol: TCP + {{- if $.Values.controller.hostPort.enabled }} + hostPort: {{ $key }} + {{- end }} + {{- end }} + {{- range $key, $value := .Values.udp }} + - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp + containerPort: {{ $key }} + protocol: UDP + {{- if $.Values.controller.hostPort.enabled }} + hostPort: {{ $key }} + {{- end }} + {{- end }} + {{- if (or .Values.controller.customTemplate.configMapName .Values.controller.extraVolumeMounts .Values.controller.admissionWebhooks.enabled .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} + volumeMounts: + {{- if (or .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} + - name: modules + {{- if .Values.controller.image.chroot }} + mountPath: /chroot/modules_mount + {{- else }} + mountPath: /modules_mount + {{- end }} + {{- end }} + {{- if .Values.controller.customTemplate.configMapName }} + - mountPath: /etc/nginx/template + name: nginx-template-volume + readOnly: true + {{- end }} + {{- if .Values.controller.admissionWebhooks.enabled }} + - name: webhook-cert + mountPath: /usr/local/certificates/ + readOnly: true + {{- end }} + {{- if .Values.controller.extraVolumeMounts }} + {{- toYaml .Values.controller.extraVolumeMounts | nindent 12 }} + {{- end }} + {{- end }} + {{- if .Values.controller.resources }} + resources: {{ toYaml .Values.controller.resources | nindent 12 }} + {{- end }} + {{- if .Values.controller.extraContainers }} + {{- toYaml .Values.controller.extraContainers | nindent 8 }} + {{- end }} + {{- if (or .Values.controller.extraInitContainers .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} + initContainers: + {{- if .Values.controller.extraInitContainers }} + {{- toYaml .Values.controller.extraInitContainers | nindent 8 }} + {{- end }} + {{- if .Values.controller.extraModules }} + {{- range .Values.controller.extraModules }} + {{- $containerSecurityContext := .containerSecurityContext | default $.Values.controller.containerSecurityContext }} + {{- include "extraModules" (dict "name" .name "image" .image "containerSecurityContext" $containerSecurityContext "resources" .resources) | nindent 8 }} + {{- end }} + {{- end }} + {{- if .Values.controller.opentelemetry.enabled }} + {{- with .Values.controller.opentelemetry }} + {{- $containerSecurityContext := .containerSecurityContext | default $.Values.controller.containerSecurityContext }} + {{- include "extraModules" (dict "name" .name "image" .image "containerSecurityContext" $containerSecurityContext "resources" .resources) | nindent 8 }} + {{- end }} + {{- end }} + {{- end }} + {{- if .Values.controller.hostNetwork }} + hostNetwork: {{ .Values.controller.hostNetwork }} + {{- end }} + {{- if .Values.controller.nodeSelector }} + nodeSelector: {{ toYaml .Values.controller.nodeSelector | nindent 8 }} + {{- end }} + {{- if .Values.controller.tolerations }} + tolerations: {{ toYaml .Values.controller.tolerations | nindent 8 }} + {{- end }} + {{- if .Values.controller.affinity }} + affinity: {{ tpl (toYaml .Values.controller.affinity) $ | nindent 8 }} + {{- end }} + {{- if .Values.controller.topologySpreadConstraints }} + topologySpreadConstraints: {{ tpl (toYaml .Values.controller.topologySpreadConstraints) $ | nindent 8 }} + {{- end }} + serviceAccountName: {{ template "ingress-nginx.serviceAccountName" . }} + terminationGracePeriodSeconds: {{ .Values.controller.terminationGracePeriodSeconds }} + {{- if (or .Values.controller.customTemplate.configMapName .Values.controller.extraVolumeMounts .Values.controller.admissionWebhooks.enabled .Values.controller.extraVolumes .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} + volumes: + {{- if (or .Values.controller.extraModules .Values.controller.opentelemetry.enabled)}} + - name: modules + emptyDir: {} + {{- end }} + {{- if .Values.controller.customTemplate.configMapName }} + - name: nginx-template-volume + configMap: + name: {{ .Values.controller.customTemplate.configMapName }} + items: + - key: {{ .Values.controller.customTemplate.configMapKey }} + path: nginx.tmpl + {{- end }} + {{- if .Values.controller.admissionWebhooks.enabled }} + - name: webhook-cert + secret: + secretName: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + {{- if .Values.controller.admissionWebhooks.certManager.enabled }} + items: + - key: tls.crt + path: cert + - key: tls.key + path: key + {{- end }} + {{- end }} + {{- if .Values.controller.extraVolumes }} + {{ toYaml .Values.controller.extraVolumes | nindent 8 }} + {{- end }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-hpa.yaml b/charts/keep/charts/ingress-nginx/templates/controller-hpa.yaml new file mode 100644 index 0000000..ec9ad73 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-hpa.yaml @@ -0,0 +1,47 @@ +{{- if and (eq .Values.controller.kind "Deployment") .Values.controller.autoscaling.enabled (not .Values.controller.keda.enabled) -}} +apiVersion: {{ ternary "autoscaling/v2" "autoscaling/v2beta2" (.Capabilities.APIVersions.Has "autoscaling/v2") }} +kind: HorizontalPodAutoscaler +metadata: + {{- with .Values.controller.autoscaling.annotations }} + annotations: {{ toYaml . | nindent 4 }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + scaleTargetRef: + apiVersion: apps/v1 + kind: Deployment + name: {{ include "ingress-nginx.controller.fullname" . }} + minReplicas: {{ .Values.controller.autoscaling.minReplicas }} + maxReplicas: {{ .Values.controller.autoscaling.maxReplicas }} + metrics: + {{- with .Values.controller.autoscaling.targetMemoryUtilizationPercentage }} + - type: Resource + resource: + name: memory + target: + type: Utilization + averageUtilization: {{ . }} + {{- end }} + {{- with .Values.controller.autoscaling.targetCPUUtilizationPercentage }} + - type: Resource + resource: + name: cpu + target: + type: Utilization + averageUtilization: {{ . }} + {{- end }} + {{- with .Values.controller.autoscalingTemplate }} + {{- toYaml . | nindent 2 }} + {{- end }} + {{- with .Values.controller.autoscaling.behavior }} + behavior: + {{- toYaml . | nindent 4 }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-ingressclass-aliases.yaml b/charts/keep/charts/ingress-nginx/templates/controller-ingressclass-aliases.yaml new file mode 100644 index 0000000..ffe2231 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-ingressclass-aliases.yaml @@ -0,0 +1,23 @@ +{{- if .Values.controller.ingressClassResource.enabled -}} +{{- range .Values.controller.ingressClassResource.aliases }} +--- +apiVersion: networking.k8s.io/v1 +kind: IngressClass +metadata: + labels: + {{- include "ingress-nginx.labels" $ | nindent 4 }} + app.kubernetes.io/component: controller + {{- with $.Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ . }} + {{- if $.Values.controller.ingressClassResource.annotations }} + annotations: {{ toYaml $.Values.controller.ingressClassResource.annotations | nindent 4 }} + {{- end }} +spec: + controller: {{ $.Values.controller.ingressClassResource.controllerValue }} + {{- with $.Values.controller.ingressClassResource.parameters }} + parameters: {{ toYaml . | nindent 4 }} + {{- end }} +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-ingressclass.yaml b/charts/keep/charts/ingress-nginx/templates/controller-ingressclass.yaml new file mode 100644 index 0000000..98479a5 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-ingressclass.yaml @@ -0,0 +1,26 @@ +{{- if .Values.controller.ingressClassResource.enabled -}} +apiVersion: networking.k8s.io/v1 +kind: IngressClass +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ .Values.controller.ingressClassResource.name }} + {{- if or .Values.controller.ingressClassResource.default .Values.controller.ingressClassResource.annotations }} + annotations: + {{- if .Values.controller.ingressClassResource.default }} + ingressclass.kubernetes.io/is-default-class: "true" + {{- end }} + {{- if .Values.controller.ingressClassResource.annotations }} + {{- toYaml .Values.controller.ingressClassResource.annotations | nindent 4 }} + {{- end }} + {{- end }} +spec: + controller: {{ .Values.controller.ingressClassResource.controllerValue }} + {{- with .Values.controller.ingressClassResource.parameters }} + parameters: {{ toYaml . | nindent 4 }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-keda.yaml b/charts/keep/charts/ingress-nginx/templates/controller-keda.yaml new file mode 100644 index 0000000..24d30fa --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-keda.yaml @@ -0,0 +1,46 @@ +{{- if and (eq .Values.controller.kind "Deployment") .Values.controller.keda.enabled (not .Values.controller.autoscaling.enabled) -}} +apiVersion: {{ .Values.controller.keda.apiVersion }} +kind: ScaledObject +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + {{- if .Values.controller.keda.scaledObject.annotations }} + annotations: {{ toYaml .Values.controller.keda.scaledObject.annotations | nindent 4 }} + {{- end }} +spec: + scaleTargetRef: +{{- if eq .Values.controller.keda.apiVersion "keda.k8s.io/v1alpha1" }} + deploymentName: {{ include "ingress-nginx.controller.fullname" . }} +{{- else if eq .Values.controller.keda.apiVersion "keda.sh/v1alpha1" }} + name: {{ include "ingress-nginx.controller.fullname" . }} +{{- end }} + pollingInterval: {{ .Values.controller.keda.pollingInterval }} + cooldownPeriod: {{ .Values.controller.keda.cooldownPeriod }} + minReplicaCount: {{ .Values.controller.keda.minReplicas }} + maxReplicaCount: {{ .Values.controller.keda.maxReplicas }} +{{- with .Values.controller.keda.fallback }} + fallback: + failureThreshold: {{ .failureThreshold | default 3 }} + replicas: {{ .replicas | default $.Values.controller.keda.maxReplicas }} +{{- end }} + triggers: +{{- with .Values.controller.keda.triggers }} +{{ toYaml . | indent 2 }} +{{ end }} + advanced: + restoreToOriginalReplicaCount: {{ .Values.controller.keda.restoreToOriginalReplicaCount }} +{{- if .Values.controller.keda.behavior }} + horizontalPodAutoscalerConfig: + behavior: +{{ with .Values.controller.keda.behavior -}} +{{ toYaml . | indent 8 }} +{{ end }} + +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-networkpolicy.yaml b/charts/keep/charts/ingress-nginx/templates/controller-networkpolicy.yaml new file mode 100644 index 0000000..e68f991 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-networkpolicy.yaml @@ -0,0 +1,45 @@ +{{- if .Values.controller.networkPolicy.enabled }} +apiVersion: networking.k8s.io/v1 +kind: NetworkPolicy +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + podSelector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: controller + policyTypes: + - Ingress + - Egress + ingress: + - ports: + {{- range $key, $value := .Values.controller.containerPort }} + - protocol: TCP + port: {{ $value }} + {{- end }} + {{- if .Values.controller.metrics.enabled }} + - protocol: TCP + port: {{ .Values.controller.metrics.port }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.enabled }} + - protocol: TCP + port: {{ .Values.controller.admissionWebhooks.port }} + {{- end }} + {{- range $key, $value := .Values.tcp }} + - protocol: TCP + port: {{ $key }} + {{- end }} + {{- range $key, $value := .Values.udp }} + - protocol: UDP + port: {{ $key }} + {{- end }} + egress: + - {} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml b/charts/keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml new file mode 100644 index 0000000..8e0181f --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml @@ -0,0 +1,36 @@ +# PDB is not supported for DaemonSets. +# https://github.com/kubernetes/kubernetes/issues/108124 +{{- if eq .Values.controller.kind "Deployment" }} +{{- $replicas := .Values.controller.replicaCount }} +{{- if and .Values.controller.autoscaling.enabled (not .Values.controller.keda.enabled) }} +{{- $replicas = .Values.controller.autoscaling.minReplicas }} +{{- else if and .Values.controller.keda.enabled (not .Values.controller.autoscaling.enabled) }} +{{- $replicas = .Values.controller.keda.minReplicas }} +{{- end }} +{{- if gt ($replicas | int) 1 }} +apiVersion: {{ ternary "policy/v1" "policy/v1beta1" (semverCompare ">=1.21.0-0" .Capabilities.KubeVersion.Version) }} +kind: PodDisruptionBudget +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + {{- if .Values.controller.annotations }} + annotations: {{ toYaml .Values.controller.annotations | nindent 4 }} + {{- end }} +spec: + selector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: controller + {{- if and .Values.controller.minAvailable (not (hasKey .Values.controller "maxUnavailable")) }} + minAvailable: {{ .Values.controller.minAvailable }} + {{- else if .Values.controller.maxUnavailable }} + maxUnavailable: {{ .Values.controller.maxUnavailable }} + {{- end }} +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-prometheusrule.yaml b/charts/keep/charts/ingress-nginx/templates/controller-prometheusrule.yaml new file mode 100644 index 0000000..41684c3 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-prometheusrule.yaml @@ -0,0 +1,23 @@ +{{- if and .Values.controller.metrics.enabled .Values.controller.metrics.prometheusRule.enabled -}} +apiVersion: monitoring.coreos.com/v1 +kind: PrometheusRule +metadata: + name: {{ include "ingress-nginx.controller.fullname" . }} +{{- if .Values.controller.metrics.prometheusRule.namespace }} + namespace: {{ .Values.controller.metrics.prometheusRule.namespace }} +{{- else }} + namespace: {{ include "ingress-nginx.namespace" . }} +{{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- if .Values.controller.metrics.prometheusRule.additionalLabels }} + {{- toYaml .Values.controller.metrics.prometheusRule.additionalLabels | nindent 4 }} + {{- end }} +spec: +{{- if .Values.controller.metrics.prometheusRule.rules }} + groups: + - name: {{ template "ingress-nginx.name" . }} + rules: {{- toYaml .Values.controller.metrics.prometheusRule.rules | nindent 4 }} +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-psp.yaml b/charts/keep/charts/ingress-nginx/templates/controller-psp.yaml new file mode 100644 index 0000000..aad1d27 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-psp.yaml @@ -0,0 +1,100 @@ +{{- if (semverCompare "<1.25.0-0" .Capabilities.KubeVersion.Version) }} +{{- if and .Values.podSecurityPolicy.enabled (empty .Values.controller.existingPsp) -}} +apiVersion: policy/v1beta1 +kind: PodSecurityPolicy +metadata: + name: {{ include "ingress-nginx.fullname" . }} + annotations: + seccomp.security.alpha.kubernetes.io/allowedProfileNames: "*" + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +spec: + privileged: false + hostPID: false + hostIPC: false + hostNetwork: {{ .Values.controller.hostNetwork }} +{{- if or .Values.controller.hostNetwork .Values.controller.hostPort.enabled }} + hostPorts: + {{- if .Values.controller.hostNetwork }} + {{- range $key, $value := .Values.controller.containerPort }} + # controller.containerPort.{{ $key }} + - min: {{ $value }} + max: {{ $value }} + {{- end }} + {{- else if .Values.controller.hostPort.enabled }} + {{- range $key, $value := .Values.controller.hostPort.ports }} + # controller.hostPort.ports.{{ $key }} + - min: {{ $value }} + max: {{ $value }} + {{- end }} + {{- end }} + {{- if .Values.controller.metrics.enabled }} + # controller.metrics.port + - min: {{ .Values.controller.metrics.port }} + max: {{ .Values.controller.metrics.port }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.enabled }} + # controller.admissionWebhooks.port + - min: {{ .Values.controller.admissionWebhooks.port }} + max: {{ .Values.controller.admissionWebhooks.port }} + {{- end }} + {{- range $key, $value := .Values.tcp }} + # tcp.{{ $key }} + - min: {{ $key }} + max: {{ $key }} + {{- end }} + {{- range $key, $value := .Values.udp }} + # udp.{{ $key }} + - min: {{ $key }} + max: {{ $key }} + {{- end }} +{{- end }} + volumes: + - configMap + - downwardAPI + - emptyDir + - secret + - projected + fsGroup: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + readOnlyRootFilesystem: false + runAsUser: + rule: MustRunAsNonRoot + runAsGroup: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + supplementalGroups: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + allowPrivilegeEscalation: {{ or .Values.controller.image.allowPrivilegeEscalation .Values.controller.image.chroot }} + requiredDropCapabilities: + - ALL + allowedCapabilities: + - NET_BIND_SERVICE + {{- if .Values.controller.image.chroot }} + {{- if .Values.controller.image.seccompProfile }} + - SYS_ADMIN + {{- end }} + - SYS_CHROOT + {{- end }} + seLinux: + rule: RunAsAny +{{- if .Values.controller.sysctls }} + allowedUnsafeSysctls: + {{- range $sysctl, $value := .Values.controller.sysctls }} + - {{ $sysctl }} + {{- end }} +{{- end }} +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-role.yaml b/charts/keep/charts/ingress-nginx/templates/controller-role.yaml new file mode 100644 index 0000000..a94b399 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-role.yaml @@ -0,0 +1,104 @@ +{{- if .Values.rbac.create -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +rules: + - apiGroups: + - "" + resources: + - namespaces + verbs: + - get + - apiGroups: + - "" + resources: + - configmaps + - pods + - secrets + - endpoints + verbs: + - get + - list + - watch + - apiGroups: + - "" + resources: + - services + verbs: + - get + - list + - watch + - apiGroups: + - networking.k8s.io + resources: + - ingresses + verbs: + - get + - list + - watch + # Omit Ingress status permissions if `--update-status` is disabled. + {{- if ne (index .Values.controller.extraArgs "update-status") "false" }} + - apiGroups: + - networking.k8s.io + resources: + - ingresses/status + verbs: + - update + {{- end }} + - apiGroups: + - networking.k8s.io + resources: + - ingressclasses + verbs: + - get + - list + - watch + - apiGroups: + - coordination.k8s.io + resources: + - leases + resourceNames: + - {{ include "ingress-nginx.controller.electionID" . }} + verbs: + - get + - update + - apiGroups: + - coordination.k8s.io + resources: + - leases + verbs: + - create + - apiGroups: + - "" + resources: + - events + verbs: + - create + - patch + - apiGroups: + - discovery.k8s.io + resources: + - endpointslices + verbs: + - list + - watch + - get +{{- if .Values.podSecurityPolicy.enabled }} + - apiGroups: [{{ template "podSecurityPolicy.apiGroup" . }}] + resources: ['podsecuritypolicies'] + verbs: ['use'] + {{- with .Values.controller.existingPsp }} + resourceNames: [{{ . }}] + {{- else }} + resourceNames: [{{ include "ingress-nginx.fullname" . }}] + {{- end }} +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-rolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/controller-rolebinding.yaml new file mode 100644 index 0000000..153430a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-rolebinding.yaml @@ -0,0 +1,21 @@ +{{- if .Values.rbac.create -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: {{ include "ingress-nginx.fullname" . }} +subjects: + - kind: ServiceAccount + name: {{ template "ingress-nginx.serviceAccountName" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-secret.yaml b/charts/keep/charts/ingress-nginx/templates/controller-secret.yaml new file mode 100644 index 0000000..f20f534 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-secret.yaml @@ -0,0 +1,15 @@ +{{- if .Values.dhParam -}} +apiVersion: v1 +kind: Secret +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +data: + dhparam.pem: {{ .Values.dhParam }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-service-internal.yaml b/charts/keep/charts/ingress-nginx/templates/controller-service-internal.yaml new file mode 100644 index 0000000..6d0b47c --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-service-internal.yaml @@ -0,0 +1,105 @@ +{{- if and .Values.controller.service.enabled .Values.controller.service.internal.enabled .Values.controller.service.internal.annotations -}} +apiVersion: v1 +kind: Service +metadata: + annotations: + {{- range $key, $value := .Values.controller.service.internal.annotations }} + {{ $key }}: {{ tpl ($value | toString) $ | quote }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- if .Values.controller.service.labels }} + {{- toYaml .Values.controller.service.labels | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }}-internal + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + type: {{ .Values.controller.service.internal.type | default .Values.controller.service.type }} +{{- if .Values.controller.service.internal.clusterIP }} + clusterIP: {{ .Values.controller.service.internal.clusterIP }} +{{- end }} +{{- if .Values.controller.service.internal.externalIPs }} + externalIPs: {{ toYaml .Values.controller.service.internal.externalIPs | nindent 4 }} +{{- end }} +{{- if .Values.controller.service.internal.loadBalancerIP }} + loadBalancerIP: {{ .Values.controller.service.internal.loadBalancerIP }} +{{- end }} +{{- if .Values.controller.service.internal.loadBalancerSourceRanges }} + loadBalancerSourceRanges: {{ toYaml .Values.controller.service.internal.loadBalancerSourceRanges | nindent 4 }} +{{- end }} +{{- if .Values.controller.service.internal.loadBalancerClass }} + loadBalancerClass: {{ .Values.controller.service.internal.loadBalancerClass }} +{{- end }} +{{- if hasKey .Values.controller.service.internal "allocateLoadBalancerNodePorts" }} + allocateLoadBalancerNodePorts: {{ .Values.controller.service.internal.allocateLoadBalancerNodePorts }} +{{- end }} +{{- if .Values.controller.service.internal.externalTrafficPolicy }} + externalTrafficPolicy: {{ .Values.controller.service.internal.externalTrafficPolicy }} +{{- end }} +{{- if .Values.controller.service.internal.sessionAffinity }} + sessionAffinity: {{ .Values.controller.service.internal.sessionAffinity }} +{{- end }} +{{- if .Values.controller.service.internal.healthCheckNodePort }} + healthCheckNodePort: {{ .Values.controller.service.internal.healthCheckNodePort }} +{{- end }} +{{- if semverCompare ">=1.21.0-0" .Capabilities.KubeVersion.Version -}} +{{- if .Values.controller.service.internal.ipFamilyPolicy }} + ipFamilyPolicy: {{ .Values.controller.service.internal.ipFamilyPolicy }} +{{- end }} +{{- if .Values.controller.service.internal.ipFamilies }} + ipFamilies: {{ toYaml .Values.controller.service.internal.ipFamilies | nindent 4 }} +{{- end }} +{{- end }} + ports: + {{- $setNodePorts := (or (eq .Values.controller.service.type "NodePort") (eq .Values.controller.service.type "LoadBalancer")) }} + {{- if .Values.controller.service.enableHttp }} + - name: http + port: {{ .Values.controller.service.internal.ports.http | default .Values.controller.service.ports.http }} + protocol: TCP + targetPort: {{ .Values.controller.service.internal.targetPorts.http | default .Values.controller.service.targetPorts.http }} + {{- if and (semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version) (.Values.controller.service.internal.appProtocol) }} + appProtocol: http + {{- end }} + {{- if (and $setNodePorts (not (empty .Values.controller.service.internal.nodePorts.http))) }} + nodePort: {{ .Values.controller.service.internal.nodePorts.http }} + {{- end }} + {{- end }} + {{- if .Values.controller.service.enableHttps }} + - name: https + port: {{ .Values.controller.service.internal.ports.https | default .Values.controller.service.ports.https }} + protocol: TCP + targetPort: {{ .Values.controller.service.internal.targetPorts.https | default .Values.controller.service.targetPorts.https }} + {{- if and (semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version) (.Values.controller.service.internal.appProtocol) }} + appProtocol: https + {{- end }} + {{- if (and $setNodePorts (not (empty .Values.controller.service.internal.nodePorts.https))) }} + nodePort: {{ .Values.controller.service.internal.nodePorts.https }} + {{- end }} + {{- end }} + {{- range $key, $value := .Values.tcp }} + - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp + port: {{ $key }} + protocol: TCP + targetPort: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp + {{- if $.Values.controller.service.internal.nodePorts.tcp }} + {{- if index $.Values.controller.service.internal.nodePorts.tcp $key }} + nodePort: {{ index $.Values.controller.service.internal.nodePorts.tcp $key }} + {{- end }} + {{- end }} + {{- end }} + {{- range $key, $value := .Values.udp }} + - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp + port: {{ $key }} + protocol: UDP + targetPort: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp + {{- if $.Values.controller.service.internal.nodePorts.udp }} + {{- if index $.Values.controller.service.internal.nodePorts.udp $key }} + nodePort: {{ index $.Values.controller.service.internal.nodePorts.udp $key }} + {{- end }} + {{- end }} + {{- end }} + selector: + {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} + app.kubernetes.io/component: controller +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-service-metrics.yaml b/charts/keep/charts/ingress-nginx/templates/controller-service-metrics.yaml new file mode 100644 index 0000000..7c15329 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-service-metrics.yaml @@ -0,0 +1,45 @@ +{{- if .Values.controller.metrics.enabled -}} +apiVersion: v1 +kind: Service +metadata: +{{- if .Values.controller.metrics.service.annotations }} + annotations: {{ toYaml .Values.controller.metrics.service.annotations | nindent 4 }} +{{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- if .Values.controller.metrics.service.labels }} + {{- toYaml .Values.controller.metrics.service.labels | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }}-metrics + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + type: {{ .Values.controller.metrics.service.type }} +{{- if .Values.controller.metrics.service.clusterIP }} + clusterIP: {{ .Values.controller.metrics.service.clusterIP }} +{{- end }} +{{- if .Values.controller.metrics.service.externalIPs }} + externalIPs: {{ toYaml .Values.controller.metrics.service.externalIPs | nindent 4 }} +{{- end }} +{{- if .Values.controller.metrics.service.loadBalancerIP }} + loadBalancerIP: {{ .Values.controller.metrics.service.loadBalancerIP }} +{{- end }} +{{- if .Values.controller.metrics.service.loadBalancerSourceRanges }} + loadBalancerSourceRanges: {{ toYaml .Values.controller.metrics.service.loadBalancerSourceRanges | nindent 4 }} +{{- end }} +{{- if .Values.controller.metrics.service.externalTrafficPolicy }} + externalTrafficPolicy: {{ .Values.controller.metrics.service.externalTrafficPolicy }} +{{- end }} + ports: + - name: {{ .Values.controller.metrics.portName }} + port: {{ .Values.controller.metrics.service.servicePort }} + protocol: TCP + targetPort: {{ .Values.controller.metrics.portName }} + {{- $setNodePorts := (or (eq .Values.controller.metrics.service.type "NodePort") (eq .Values.controller.metrics.service.type "LoadBalancer")) }} + {{- if (and $setNodePorts (not (empty .Values.controller.metrics.service.nodePort))) }} + nodePort: {{ .Values.controller.metrics.service.nodePort }} + {{- end }} + selector: + {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} + app.kubernetes.io/component: controller +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-service-webhook.yaml b/charts/keep/charts/ingress-nginx/templates/controller-service-webhook.yaml new file mode 100644 index 0000000..67aac0d --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-service-webhook.yaml @@ -0,0 +1,40 @@ +{{- if .Values.controller.admissionWebhooks.enabled -}} +apiVersion: v1 +kind: Service +metadata: +{{- if .Values.controller.admissionWebhooks.service.annotations }} + annotations: {{ toYaml .Values.controller.admissionWebhooks.service.annotations | nindent 4 }} +{{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }}-admission + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + type: {{ .Values.controller.admissionWebhooks.service.type }} +{{- if .Values.controller.admissionWebhooks.service.clusterIP }} + clusterIP: {{ .Values.controller.admissionWebhooks.service.clusterIP }} +{{- end }} +{{- if .Values.controller.admissionWebhooks.service.externalIPs }} + externalIPs: {{ toYaml .Values.controller.admissionWebhooks.service.externalIPs | nindent 4 }} +{{- end }} +{{- if .Values.controller.admissionWebhooks.service.loadBalancerIP }} + loadBalancerIP: {{ .Values.controller.admissionWebhooks.service.loadBalancerIP }} +{{- end }} +{{- if .Values.controller.admissionWebhooks.service.loadBalancerSourceRanges }} + loadBalancerSourceRanges: {{ toYaml .Values.controller.admissionWebhooks.service.loadBalancerSourceRanges | nindent 4 }} +{{- end }} + ports: + - name: https-webhook + port: {{ .Values.controller.admissionWebhooks.service.servicePort }} + targetPort: webhook + {{- if semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version }} + appProtocol: https + {{- end }} + selector: + {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} + app.kubernetes.io/component: controller +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-service.yaml b/charts/keep/charts/ingress-nginx/templates/controller-service.yaml new file mode 100644 index 0000000..cb78a70 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-service.yaml @@ -0,0 +1,105 @@ +{{- if and .Values.controller.service.enabled .Values.controller.service.external.enabled -}} +apiVersion: v1 +kind: Service +metadata: + annotations: + {{- range $key, $value := .Values.controller.service.annotations }} + {{ $key }}: {{ tpl ($value | toString) $ | quote }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- if .Values.controller.service.labels }} + {{- toYaml .Values.controller.service.labels | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + type: {{ .Values.controller.service.type }} +{{- if .Values.controller.service.clusterIP }} + clusterIP: {{ .Values.controller.service.clusterIP }} +{{- end }} +{{- if .Values.controller.service.externalIPs }} + externalIPs: {{ toYaml .Values.controller.service.externalIPs | nindent 4 }} +{{- end }} +{{- if .Values.controller.service.loadBalancerIP }} + loadBalancerIP: {{ .Values.controller.service.loadBalancerIP }} +{{- end }} +{{- if .Values.controller.service.loadBalancerSourceRanges }} + loadBalancerSourceRanges: {{ toYaml .Values.controller.service.loadBalancerSourceRanges | nindent 4 }} +{{- end }} +{{- if .Values.controller.service.loadBalancerClass }} + loadBalancerClass: {{ .Values.controller.service.loadBalancerClass }} +{{- end }} +{{- if hasKey .Values.controller.service "allocateLoadBalancerNodePorts" }} + allocateLoadBalancerNodePorts: {{ .Values.controller.service.allocateLoadBalancerNodePorts }} +{{- end }} +{{- if .Values.controller.service.externalTrafficPolicy }} + externalTrafficPolicy: {{ .Values.controller.service.externalTrafficPolicy }} +{{- end }} +{{- if .Values.controller.service.sessionAffinity }} + sessionAffinity: {{ .Values.controller.service.sessionAffinity }} +{{- end }} +{{- if .Values.controller.service.healthCheckNodePort }} + healthCheckNodePort: {{ .Values.controller.service.healthCheckNodePort }} +{{- end }} +{{- if semverCompare ">=1.21.0-0" .Capabilities.KubeVersion.Version -}} +{{- if .Values.controller.service.ipFamilyPolicy }} + ipFamilyPolicy: {{ .Values.controller.service.ipFamilyPolicy }} +{{- end }} +{{- if .Values.controller.service.ipFamilies }} + ipFamilies: {{ toYaml .Values.controller.service.ipFamilies | nindent 4 }} +{{- end }} +{{- end }} + ports: + {{- $setNodePorts := (or (eq .Values.controller.service.type "NodePort") (eq .Values.controller.service.type "LoadBalancer")) }} + {{- if .Values.controller.service.enableHttp }} + - name: http + port: {{ .Values.controller.service.ports.http }} + protocol: TCP + targetPort: {{ .Values.controller.service.targetPorts.http }} + {{- if and (semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version) (.Values.controller.service.appProtocol) }} + appProtocol: http + {{- end }} + {{- if (and $setNodePorts (not (empty .Values.controller.service.nodePorts.http))) }} + nodePort: {{ .Values.controller.service.nodePorts.http }} + {{- end }} + {{- end }} + {{- if .Values.controller.service.enableHttps }} + - name: https + port: {{ .Values.controller.service.ports.https }} + protocol: TCP + targetPort: {{ .Values.controller.service.targetPorts.https }} + {{- if and (semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version) (.Values.controller.service.appProtocol) }} + appProtocol: https + {{- end }} + {{- if (and $setNodePorts (not (empty .Values.controller.service.nodePorts.https))) }} + nodePort: {{ .Values.controller.service.nodePorts.https }} + {{- end }} + {{- end }} + {{- range $key, $value := .Values.tcp }} + - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp + port: {{ $key }} + protocol: TCP + targetPort: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp + {{- if $.Values.controller.service.nodePorts.tcp }} + {{- if index $.Values.controller.service.nodePorts.tcp $key }} + nodePort: {{ index $.Values.controller.service.nodePorts.tcp $key }} + {{- end }} + {{- end }} + {{- end }} + {{- range $key, $value := .Values.udp }} + - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp + port: {{ $key }} + protocol: UDP + targetPort: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp + {{- if $.Values.controller.service.nodePorts.udp }} + {{- if index $.Values.controller.service.nodePorts.udp $key }} + nodePort: {{ index $.Values.controller.service.nodePorts.udp $key }} + {{- end }} + {{- end }} + {{- end }} + selector: + {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} + app.kubernetes.io/component: controller +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml b/charts/keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml new file mode 100644 index 0000000..df83de3 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml @@ -0,0 +1,17 @@ +{{- if or .Values.serviceAccount.create -}} +apiVersion: v1 +kind: ServiceAccount +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ template "ingress-nginx.serviceAccountName" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + {{- if .Values.serviceAccount.annotations }} + annotations: {{ toYaml .Values.serviceAccount.annotations | nindent 4 }} + {{- end }} +automountServiceAccountToken: {{ .Values.serviceAccount.automountServiceAccountToken }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-servicemonitor.yaml b/charts/keep/charts/ingress-nginx/templates/controller-servicemonitor.yaml new file mode 100644 index 0000000..62301da --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-servicemonitor.yaml @@ -0,0 +1,53 @@ +{{- if and .Values.controller.metrics.enabled .Values.controller.metrics.serviceMonitor.enabled -}} +apiVersion: monitoring.coreos.com/v1 +kind: ServiceMonitor +metadata: + name: {{ include "ingress-nginx.controller.fullname" . }} +{{- if .Values.controller.metrics.serviceMonitor.namespace }} + namespace: {{ .Values.controller.metrics.serviceMonitor.namespace }} +{{- else }} + namespace: {{ include "ingress-nginx.namespace" . }} +{{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- if .Values.controller.metrics.serviceMonitor.additionalLabels }} + {{- toYaml .Values.controller.metrics.serviceMonitor.additionalLabels | nindent 4 }} + {{- end }} + {{- if .Values.controller.metrics.serviceMonitor.annotations }} + annotations: {{ toYaml .Values.controller.metrics.serviceMonitor.annotations | nindent 4 }} + {{- end }} +spec: + endpoints: + - port: {{ .Values.controller.metrics.portName }} + interval: {{ .Values.controller.metrics.serviceMonitor.scrapeInterval }} + {{- if .Values.controller.metrics.serviceMonitor.honorLabels }} + honorLabels: true + {{- end }} + {{- if .Values.controller.metrics.serviceMonitor.relabelings }} + relabelings: {{ toYaml .Values.controller.metrics.serviceMonitor.relabelings | nindent 8 }} + {{- end }} + {{- if .Values.controller.metrics.serviceMonitor.metricRelabelings }} + metricRelabelings: {{ toYaml .Values.controller.metrics.serviceMonitor.metricRelabelings | nindent 8 }} + {{- end }} +{{- if .Values.controller.metrics.serviceMonitor.jobLabel }} + jobLabel: {{ .Values.controller.metrics.serviceMonitor.jobLabel | quote }} +{{- end }} +{{- if .Values.controller.metrics.serviceMonitor.namespaceSelector }} + namespaceSelector: {{ toYaml .Values.controller.metrics.serviceMonitor.namespaceSelector | nindent 4 }} +{{- else }} + namespaceSelector: + matchNames: + - {{ include "ingress-nginx.namespace" . }} +{{- end }} +{{- if .Values.controller.metrics.serviceMonitor.targetLabels }} + targetLabels: + {{- range .Values.controller.metrics.serviceMonitor.targetLabels }} + - {{ . }} + {{- end }} +{{- end }} + selector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: controller +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-deployment.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-deployment.yaml new file mode 100644 index 0000000..6755e23 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-deployment.yaml @@ -0,0 +1,119 @@ +{{- if .Values.defaultBackend.enabled -}} +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.defaultBackend.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + selector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: default-backend +{{- if not .Values.defaultBackend.autoscaling.enabled }} + replicas: {{ .Values.defaultBackend.replicaCount }} +{{- end }} + revisionHistoryLimit: {{ .Values.revisionHistoryLimit }} + {{- if .Values.defaultBackend.updateStrategy }} + strategy: + {{ toYaml .Values.defaultBackend.updateStrategy | nindent 4 }} + {{- end }} + minReadySeconds: {{ .Values.defaultBackend.minReadySeconds }} + template: + metadata: + {{- if .Values.defaultBackend.podAnnotations }} + annotations: {{ toYaml .Values.defaultBackend.podAnnotations | nindent 8 }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 8 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 8 }} + {{- end }} + {{- if .Values.defaultBackend.podLabels }} + {{- toYaml .Values.defaultBackend.podLabels | nindent 8 }} + {{- end }} + spec: + {{- if .Values.imagePullSecrets }} + imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} + {{- end }} + {{- if .Values.defaultBackend.priorityClassName }} + priorityClassName: {{ .Values.defaultBackend.priorityClassName }} + {{- end }} + {{- if .Values.defaultBackend.podSecurityContext }} + securityContext: {{ toYaml .Values.defaultBackend.podSecurityContext | nindent 8 }} + {{- end }} + containers: + - name: {{ template "ingress-nginx.name" . }}-default-backend + {{- with .Values.defaultBackend.image }} + image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ .image }}{{ end }}:{{ .tag }}{{ if .digest }}@{{ .digest }}{{ end }} + {{- end }} + imagePullPolicy: {{ .Values.defaultBackend.image.pullPolicy }} + {{- if .Values.defaultBackend.extraArgs }} + args: + {{- range $key, $value := .Values.defaultBackend.extraArgs }} + {{- /* Accept keys without values or with false as value */}} + {{- if eq ($value | quote | len) 2 }} + - --{{ $key }} + {{- else }} + - --{{ $key }}={{ $value }} + {{- end }} + {{- end }} + {{- end }} + securityContext: {{ include "ingress-nginx.defaultBackend.containerSecurityContext" . | nindent 12 }} + {{- if .Values.defaultBackend.extraEnvs }} + env: {{ toYaml .Values.defaultBackend.extraEnvs | nindent 12 }} + {{- end }} + livenessProbe: + httpGet: + path: /healthz + port: {{ .Values.defaultBackend.port }} + scheme: HTTP + initialDelaySeconds: {{ .Values.defaultBackend.livenessProbe.initialDelaySeconds }} + periodSeconds: {{ .Values.defaultBackend.livenessProbe.periodSeconds }} + timeoutSeconds: {{ .Values.defaultBackend.livenessProbe.timeoutSeconds }} + successThreshold: {{ .Values.defaultBackend.livenessProbe.successThreshold }} + failureThreshold: {{ .Values.defaultBackend.livenessProbe.failureThreshold }} + readinessProbe: + httpGet: + path: /healthz + port: {{ .Values.defaultBackend.port }} + scheme: HTTP + initialDelaySeconds: {{ .Values.defaultBackend.readinessProbe.initialDelaySeconds }} + periodSeconds: {{ .Values.defaultBackend.readinessProbe.periodSeconds }} + timeoutSeconds: {{ .Values.defaultBackend.readinessProbe.timeoutSeconds }} + successThreshold: {{ .Values.defaultBackend.readinessProbe.successThreshold }} + failureThreshold: {{ .Values.defaultBackend.readinessProbe.failureThreshold }} + ports: + - name: http + containerPort: {{ .Values.defaultBackend.port }} + protocol: TCP + {{- if .Values.defaultBackend.extraVolumeMounts }} + volumeMounts: {{- toYaml .Values.defaultBackend.extraVolumeMounts | nindent 12 }} + {{- end }} + {{- if .Values.defaultBackend.resources }} + resources: {{ toYaml .Values.defaultBackend.resources | nindent 12 }} + {{- end }} + {{- if .Values.defaultBackend.nodeSelector }} + nodeSelector: {{ toYaml .Values.defaultBackend.nodeSelector | nindent 8 }} + {{- end }} + serviceAccountName: {{ include "ingress-nginx.defaultBackend.serviceAccountName" . }} + {{- if .Values.defaultBackend.tolerations }} + tolerations: {{ toYaml .Values.defaultBackend.tolerations | nindent 8 }} + {{- end }} + {{- if .Values.defaultBackend.affinity }} + affinity: {{ tpl (toYaml .Values.defaultBackend.affinity) $ | nindent 8 }} + {{- end }} + {{- if .Values.defaultBackend.topologySpreadConstraints }} + topologySpreadConstraints: {{ tpl (toYaml .Values.defaultBackend.topologySpreadConstraints) $ | nindent 8 }} + {{- end }} + terminationGracePeriodSeconds: 60 + {{- if .Values.defaultBackend.extraVolumes }} + volumes: {{ toYaml .Values.defaultBackend.extraVolumes | nindent 8 }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-extra-configmaps.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-extra-configmaps.yaml new file mode 100644 index 0000000..9af56cf --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-extra-configmaps.yaml @@ -0,0 +1,23 @@ +{{- if .Values.defaultBackend.enabled }} +{{- range .Values.defaultBackend.extraConfigMaps }} +--- +apiVersion: v1 +kind: ConfigMap +metadata: + labels: + {{- include "ingress-nginx.labels" $ | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with $.Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + {{- with .labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ .name }} + namespace: {{ include "ingress-nginx.namespace" $ }} +data: + {{- with .data }} + {{- toYaml . | nindent 2 }} + {{- end }} +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-hpa.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-hpa.yaml new file mode 100644 index 0000000..49bcdcf --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-hpa.yaml @@ -0,0 +1,40 @@ +{{- if and .Values.defaultBackend.enabled .Values.defaultBackend.autoscaling.enabled }} +apiVersion: {{ ternary "autoscaling/v2" "autoscaling/v2beta2" (.Capabilities.APIVersions.Has "autoscaling/v2") }} +kind: HorizontalPodAutoscaler +metadata: + {{- with .Values.defaultBackend.autoscaling.annotations }} + annotations: {{ toYaml . | nindent 4 }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.defaultBackend.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + scaleTargetRef: + apiVersion: apps/v1 + kind: Deployment + name: {{ include "ingress-nginx.defaultBackend.fullname" . }} + minReplicas: {{ .Values.defaultBackend.autoscaling.minReplicas }} + maxReplicas: {{ .Values.defaultBackend.autoscaling.maxReplicas }} + metrics: + {{- with .Values.defaultBackend.autoscaling.targetMemoryUtilizationPercentage }} + - type: Resource + resource: + name: memory + target: + type: Utilization + averageUtilization: {{ . }} + {{- end }} + {{- with .Values.defaultBackend.autoscaling.targetCPUUtilizationPercentage }} + - type: Resource + resource: + name: cpu + target: + type: Utilization + averageUtilization: {{ . }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-networkpolicy.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-networkpolicy.yaml new file mode 100644 index 0000000..90b3c2b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-networkpolicy.yaml @@ -0,0 +1,25 @@ +{{- if and .Values.defaultBackend.enabled .Values.defaultBackend.networkPolicy.enabled }} +apiVersion: networking.k8s.io/v1 +kind: NetworkPolicy +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.defaultBackend.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + podSelector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: default-backend + policyTypes: + - Ingress + - Egress + ingress: + - ports: + - protocol: TCP + port: {{ .Values.defaultBackend.port }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-poddisruptionbudget.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-poddisruptionbudget.yaml new file mode 100644 index 0000000..c8363fd --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-poddisruptionbudget.yaml @@ -0,0 +1,25 @@ +{{- if .Values.defaultBackend.enabled -}} +{{- $replicas := .Values.defaultBackend.replicaCount }} +{{- if .Values.defaultBackend.autoscaling.enabled }} +{{- $replicas = .Values.defaultBackend.autoscaling.minReplicas }} +{{- end }} +{{- if gt ($replicas | int) 1 }} +apiVersion: {{ ternary "policy/v1" "policy/v1beta1" (semverCompare ">=1.21.0-0" .Capabilities.KubeVersion.Version) }} +kind: PodDisruptionBudget +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.defaultBackend.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + selector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: default-backend + minAvailable: {{ .Values.defaultBackend.minAvailable }} +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-psp.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-psp.yaml new file mode 100644 index 0000000..4241091 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-psp.yaml @@ -0,0 +1,50 @@ +{{- if (semverCompare "<1.25.0-0" .Capabilities.KubeVersion.Version) }} +{{- if and .Values.podSecurityPolicy.enabled .Values.defaultBackend.enabled (empty .Values.defaultBackend.existingPsp) -}} +apiVersion: policy/v1beta1 +kind: PodSecurityPolicy +metadata: + name: {{ include "ingress-nginx.fullname" . }}-backend + annotations: + seccomp.security.alpha.kubernetes.io/allowedProfileNames: "*" + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +spec: + privileged: false + hostPID: false + hostIPC: false + hostNetwork: false + volumes: + - configMap + - downwardAPI + - emptyDir + - secret + - projected + fsGroup: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + readOnlyRootFilesystem: true + runAsUser: + rule: MustRunAsNonRoot + runAsGroup: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + supplementalGroups: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + allowPrivilegeEscalation: false + requiredDropCapabilities: + - ALL + seLinux: + rule: RunAsAny +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-role.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-role.yaml new file mode 100644 index 0000000..dd7868a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-role.yaml @@ -0,0 +1,22 @@ +{{- if and .Values.rbac.create .Values.podSecurityPolicy.enabled .Values.defaultBackend.enabled -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.fullname" . }}-backend + namespace: {{ include "ingress-nginx.namespace" . }} +rules: + - apiGroups: [{{ template "podSecurityPolicy.apiGroup" . }}] + resources: ['podsecuritypolicies'] + verbs: ['use'] + {{- with .Values.defaultBackend.existingPsp }} + resourceNames: [{{ . }}] + {{- else }} + resourceNames: [{{ include "ingress-nginx.fullname" . }}-backend] + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-rolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-rolebinding.yaml new file mode 100644 index 0000000..3203b6f --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-rolebinding.yaml @@ -0,0 +1,21 @@ +{{- if and .Values.rbac.create .Values.podSecurityPolicy.enabled .Values.defaultBackend.enabled -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.fullname" . }}-backend + namespace: {{ include "ingress-nginx.namespace" . }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: {{ include "ingress-nginx.fullname" . }}-backend +subjects: + - kind: ServiceAccount + name: {{ template "ingress-nginx.defaultBackend.serviceAccountName" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-service.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-service.yaml new file mode 100644 index 0000000..65b6b83 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-service.yaml @@ -0,0 +1,41 @@ +{{- if .Values.defaultBackend.enabled -}} +apiVersion: v1 +kind: Service +metadata: +{{- if .Values.defaultBackend.service.annotations }} + annotations: {{ toYaml .Values.defaultBackend.service.annotations | nindent 4 }} +{{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.defaultBackend.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + type: {{ .Values.defaultBackend.service.type }} +{{- if .Values.defaultBackend.service.clusterIP }} + clusterIP: {{ .Values.defaultBackend.service.clusterIP }} +{{- end }} +{{- if .Values.defaultBackend.service.externalIPs }} + externalIPs: {{ toYaml .Values.defaultBackend.service.externalIPs | nindent 4 }} +{{- end }} +{{- if .Values.defaultBackend.service.loadBalancerIP }} + loadBalancerIP: {{ .Values.defaultBackend.service.loadBalancerIP }} +{{- end }} +{{- if .Values.defaultBackend.service.loadBalancerSourceRanges }} + loadBalancerSourceRanges: {{ toYaml .Values.defaultBackend.service.loadBalancerSourceRanges | nindent 4 }} +{{- end }} + ports: + - name: http + port: {{ .Values.defaultBackend.service.servicePort }} + protocol: TCP + targetPort: http + {{- if semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version }} + appProtocol: http + {{- end }} + selector: + {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} + app.kubernetes.io/component: default-backend +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-serviceaccount.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-serviceaccount.yaml new file mode 100644 index 0000000..6fd2d62 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-serviceaccount.yaml @@ -0,0 +1,14 @@ +{{- if and .Values.defaultBackend.enabled .Values.defaultBackend.serviceAccount.create -}} +apiVersion: v1 +kind: ServiceAccount +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.defaultBackend.serviceAccountName" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +automountServiceAccountToken: {{ .Values.defaultBackend.serviceAccount.automountServiceAccountToken }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrole_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrole_test.yaml new file mode 100644 index 0000000..d7a8b88 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrole_test.yaml @@ -0,0 +1,11 @@ +suite: Admission Webhooks > Patch Job > ClusterRole +templates: + - admission-webhooks/job-patch/clusterrole.yaml + +tests: + - it: should not create a ClusterRole if `controller.admissionWebhooks.patch.rbac.create` is false + set: + controller.admissionWebhooks.patch.rbac.create: false + asserts: + - hasDocuments: + count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrolebinding_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrolebinding_test.yaml new file mode 100644 index 0000000..d7c3266 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrolebinding_test.yaml @@ -0,0 +1,11 @@ +suite: Admission Webhooks > Patch Job > ClusterRoleBinding +templates: + - admission-webhooks/job-patch/clusterrolebinding.yaml + +tests: + - it: should not create a ClusterRoleBinding if `controller.admissionWebhooks.patch.rbac.create` is false + set: + controller.admissionWebhooks.patch.rbac.create: false + asserts: + - hasDocuments: + count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/role_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/role_test.yaml new file mode 100644 index 0000000..a236f3d --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/role_test.yaml @@ -0,0 +1,11 @@ +suite: Admission Webhooks > Patch Job > Role +templates: + - admission-webhooks/job-patch/role.yaml + +tests: + - it: should not create a Role if `controller.admissionWebhooks.patch.rbac.create` is false + set: + controller.admissionWebhooks.patch.rbac.create: false + asserts: + - hasDocuments: + count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/rolebinding_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/rolebinding_test.yaml new file mode 100644 index 0000000..74abaa1 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/rolebinding_test.yaml @@ -0,0 +1,11 @@ +suite: Admission Webhooks > Patch Job > RoleBinding +templates: + - admission-webhooks/job-patch/rolebinding.yaml + +tests: + - it: should not create a RoleBinding if `controller.admissionWebhooks.patch.rbac.create` is false + set: + controller.admissionWebhooks.patch.rbac.create: false + asserts: + - hasDocuments: + count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/serviceaccount_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/serviceaccount_test.yaml new file mode 100644 index 0000000..7c30d1e --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/serviceaccount_test.yaml @@ -0,0 +1,47 @@ +suite: Admission Webhooks > Patch Job > ServiceAccount +templates: + - admission-webhooks/job-patch/serviceaccount.yaml + +tests: + - it: should not create a ServiceAccount if `controller.admissionWebhooks.patch.serviceAccount.create` is false + set: + controller.admissionWebhooks.patch.serviceAccount.create: false + asserts: + - hasDocuments: + count: 0 + + - it: should create a ServiceAccount if `controller.admissionWebhooks.patch.serviceAccount.create` is true + set: + controller.admissionWebhooks.patch.serviceAccount.create: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ServiceAccount + - equal: + path: metadata.name + value: ingress-nginx-admission + + - it: should create a ServiceAccount with specified name if `controller.admissionWebhooks.patch.serviceAccount.name` is set + set: + controller.admissionWebhooks.patch.serviceAccount.name: ingress-nginx-admission-test-sa + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ServiceAccount + - equal: + path: metadata.name + value: ingress-nginx-admission-test-sa + + - it: should create a ServiceAccount with token auto-mounting disabled if `controller.admissionWebhooks.patch.serviceAccount.automountServiceAccountToken` is false + set: + controller.admissionWebhooks.patch.serviceAccount.automountServiceAccountToken: false + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ServiceAccount + - equal: + path: automountServiceAccountToken + value: false diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/validating-webhook_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/validating-webhook_test.yaml new file mode 100644 index 0000000..b9d6d78 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/validating-webhook_test.yaml @@ -0,0 +1,32 @@ +suite: Admission Webhooks > ValidatingWebhookConfiguration +templates: + - admission-webhooks/validating-webhook.yaml + +tests: + - it: should not create a ValidatingWebhookConfiguration if `controller.admissionWebhooks.enabled` is false + set: + controller.admissionWebhooks.enabled: false + asserts: + - hasDocuments: + count: 0 + + - it: should create a ValidatingWebhookConfiguration if `controller.admissionWebhooks.enabled` is true + set: + controller.admissionWebhooks.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ValidatingWebhookConfiguration + - equal: + path: metadata.name + value: RELEASE-NAME-admission + + - it: should create a ValidatingWebhookConfiguration with a custom port if `controller.admissionWebhooks.service.servicePort` is set + set: + controller.admissionWebhooks.enabled: true + controller.admissionWebhooks.service.servicePort: 9443 + asserts: + - equal: + path: webhooks[0].clientConfig.service.port + value: 9443 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-configmap-addheaders_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-configmap-addheaders_test.yaml new file mode 100644 index 0000000..e831d50 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-configmap-addheaders_test.yaml @@ -0,0 +1,27 @@ +suite: Controller > ConfigMap > Add Headers +templates: + - controller-configmap-addheaders.yaml + +tests: + - it: should not create a ConfigMap if `controller.addHeaders` is not set + set: + controller.addHeaders: null + asserts: + - hasDocuments: + count: 0 + + - it: should create a ConfigMap if `controller.addHeaders` is set + set: + controller.addHeaders: + X-Another-Custom-Header: Value + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ConfigMap + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-custom-add-headers + - equal: + path: data.X-Another-Custom-Header + value: Value diff --git a/charts/keep/charts/ingress-nginx/tests/controller-configmap-proxyheaders_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-configmap-proxyheaders_test.yaml new file mode 100644 index 0000000..0634a37 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-configmap-proxyheaders_test.yaml @@ -0,0 +1,27 @@ +suite: Controller > ConfigMap > Proxy Headers +templates: + - controller-configmap-proxyheaders.yaml + +tests: + - it: should not create a ConfigMap if `controller.proxySetHeaders` is not set + set: + controller.proxySetHeaders: null + asserts: + - hasDocuments: + count: 0 + + - it: should create a ConfigMap if `controller.proxySetHeaders` is set + set: + controller.proxySetHeaders: + X-Custom-Header: Value + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ConfigMap + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-custom-proxy-headers + - equal: + path: data.X-Custom-Header + value: Value diff --git a/charts/keep/charts/ingress-nginx/tests/controller-configmap_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-configmap_test.yaml new file mode 100644 index 0000000..168b657 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-configmap_test.yaml @@ -0,0 +1,31 @@ +suite: Controller > ConfigMap +templates: + - controller-configmap.yaml + +tests: + - it: should create a ConfigMap + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ConfigMap + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should create a ConfigMap with templated values if `controller.config` contains templates + set: + controller.config: + template: "test.{{ .Release.Namespace }}.svc.kubernetes.local" + integer: 12345 + boolean: true + asserts: + - equal: + path: data.template + value: test.NAMESPACE.svc.kubernetes.local + - equal: + path: data.integer + value: "12345" + - equal: + path: data.boolean + value: "true" diff --git a/charts/keep/charts/ingress-nginx/tests/controller-daemonset_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-daemonset_test.yaml new file mode 100644 index 0000000..81d067b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-daemonset_test.yaml @@ -0,0 +1,172 @@ +suite: Controller > DaemonSet +templates: + - controller-daemonset.yaml + +tests: + - it: should create a DaemonSet if `controller.kind` is "DaemonSet" + set: + controller.kind: DaemonSet + asserts: + - hasDocuments: + count: 1 + - isKind: + of: DaemonSet + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should create a DaemonSet with argument `--enable-metrics=false` if `controller.metrics.enabled` is false + set: + controller.kind: DaemonSet + controller.metrics.enabled: false + asserts: + - contains: + path: spec.template.spec.containers[0].args + content: --enable-metrics=false + + - it: should create a DaemonSet without argument `--enable-metrics=false` if `controller.metrics.enabled` is true + set: + controller.kind: DaemonSet + controller.metrics.enabled: true + asserts: + - notContains: + path: spec.template.spec.containers[0].args + content: --enable-metrics=false + + - it: should create a DaemonSet with argument `--controller-class=k8s.io/ingress-nginx-internal` if `controller.ingressClassResource.controllerValue` is "k8s.io/ingress-nginx-internal" + set: + controller.kind: DaemonSet + controller.ingressClassResource.controllerValue: k8s.io/ingress-nginx-internal + asserts: + - contains: + path: spec.template.spec.containers[0].args + content: --controller-class=k8s.io/ingress-nginx-internal + + - it: should create a DaemonSet with resource limits if `controller.resources.limits` is set + set: + controller.kind: DaemonSet + controller.resources.limits.cpu: 500m + controller.resources.limits.memory: 512Mi + asserts: + - equal: + path: spec.template.spec.containers[0].resources.limits.cpu + value: 500m + - equal: + path: spec.template.spec.containers[0].resources.limits.memory + value: 512Mi + + - it: should create a DaemonSet with topology spread constraints if `controller.topologySpreadConstraints` is set + set: + controller.kind: DaemonSet + controller.topologySpreadConstraints: + - labelSelector: + matchLabels: + app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + app.kubernetes.io/instance: '{{ .Release.Name }}' + app.kubernetes.io/component: controller + topologyKey: topology.kubernetes.io/zone + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + - labelSelector: + matchLabels: + app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + app.kubernetes.io/instance: '{{ .Release.Name }}' + app.kubernetes.io/component: controller + topologyKey: kubernetes.io/hostname + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + asserts: + - equal: + path: spec.template.spec.topologySpreadConstraints + value: + - labelSelector: + matchLabels: + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: RELEASE-NAME + app.kubernetes.io/component: controller + topologyKey: topology.kubernetes.io/zone + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + - labelSelector: + matchLabels: + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: RELEASE-NAME + app.kubernetes.io/component: controller + topologyKey: kubernetes.io/hostname + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + + - it: should create a DaemonSet with affinity if `controller.affinity` is set + set: + controller.kind: DaemonSet + controller.affinity: + podAntiAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + - labelSelector: + matchExpressions: + - key: app.kubernetes.io/name + operator: In + values: + - '{{ include "ingress-nginx.name" . }}' + - key: app.kubernetes.io/instance + operator: In + values: + - '{{ .Release.Name }}' + - key: app.kubernetes.io/component + operator: In + values: + - controller + topologyKey: kubernetes.io/hostname + asserts: + - equal: + path: spec.template.spec.affinity + value: + podAntiAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + - labelSelector: + matchExpressions: + - key: app.kubernetes.io/name + operator: In + values: + - ingress-nginx + - key: app.kubernetes.io/instance + operator: In + values: + - RELEASE-NAME + - key: app.kubernetes.io/component + operator: In + values: + - controller + topologyKey: kubernetes.io/hostname + + - it: should create a DaemonSet with a custom registry if `controller.image.registry` is set + set: + controller.kind: DaemonSet + controller.image.registry: custom.registry.io + controller.image.tag: v1.0.0-dev + controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: custom.registry.io/ingress-nginx/controller:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + + - it: should create a DaemonSet with a custom image if `controller.image.image` is set + set: + controller.kind: DaemonSet + controller.image.image: custom-repo/custom-image + controller.image.tag: v1.0.0-dev + controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: registry.k8s.io/custom-repo/custom-image:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + + - it: should create a DaemonSet with a custom tag if `controller.image.tag` is set + set: + controller.kind: DaemonSet + controller.image.tag: custom-tag + controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: registry.k8s.io/ingress-nginx/controller:custom-tag@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd diff --git a/charts/keep/charts/ingress-nginx/tests/controller-deployment_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-deployment_test.yaml new file mode 100644 index 0000000..382aecd --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-deployment_test.yaml @@ -0,0 +1,191 @@ +suite: Controller > Deployment +templates: + - controller-deployment.yaml + +tests: + - it: should create a Deployment + asserts: + - hasDocuments: + count: 1 + - isKind: + of: Deployment + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should create a Deployment with 3 replicas if `controller.replicaCount` is 3 + set: + controller.replicaCount: 3 + asserts: + - equal: + path: spec.replicas + value: 3 + + - it: should create a Deployment without replicas if `controller.autoscaling.enabled` is true + set: + controller.autoscaling.enabled: true + asserts: + - notExists: + path: spec.replicas + + - it: should create a Deployment without replicas if `controller.keda.enabled` is true + set: + controller.keda.enabled: true + asserts: + - notExists: + path: spec.replicas + + - it: should create a Deployment with replicas if `controller.autoscaling.enabled` is true and `controller.keda.enabled` is true + set: + controller.autoscaling.enabled: true + controller.keda.enabled: true + asserts: + - exists: + path: spec.replicas + + - it: should create a Deployment with argument `--enable-metrics=false` if `controller.metrics.enabled` is false + set: + controller.metrics.enabled: false + asserts: + - contains: + path: spec.template.spec.containers[0].args + content: --enable-metrics=false + + - it: should create a Deployment without argument `--enable-metrics=false` if `controller.metrics.enabled` is true + set: + controller.metrics.enabled: true + asserts: + - notContains: + path: spec.template.spec.containers[0].args + content: --enable-metrics=false + + - it: should create a Deployment with argument `--controller-class=k8s.io/ingress-nginx-internal` if `controller.ingressClassResource.controllerValue` is "k8s.io/ingress-nginx-internal" + set: + controller.ingressClassResource.controllerValue: k8s.io/ingress-nginx-internal + asserts: + - contains: + path: spec.template.spec.containers[0].args + content: --controller-class=k8s.io/ingress-nginx-internal + + - it: should create a Deployment with resource limits if `controller.resources.limits` is set + set: + controller.resources.limits.cpu: 500m + controller.resources.limits.memory: 512Mi + asserts: + - equal: + path: spec.template.spec.containers[0].resources.limits.cpu + value: 500m + - equal: + path: spec.template.spec.containers[0].resources.limits.memory + value: 512Mi + + - it: should create a Deployment with topology spread constraints if `controller.topologySpreadConstraints` is set + set: + controller.topologySpreadConstraints: + - labelSelector: + matchLabels: + app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + app.kubernetes.io/instance: '{{ .Release.Name }}' + app.kubernetes.io/component: controller + topologyKey: topology.kubernetes.io/zone + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + - labelSelector: + matchLabels: + app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + app.kubernetes.io/instance: '{{ .Release.Name }}' + app.kubernetes.io/component: controller + topologyKey: kubernetes.io/hostname + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + asserts: + - equal: + path: spec.template.spec.topologySpreadConstraints + value: + - labelSelector: + matchLabels: + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: RELEASE-NAME + app.kubernetes.io/component: controller + topologyKey: topology.kubernetes.io/zone + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + - labelSelector: + matchLabels: + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: RELEASE-NAME + app.kubernetes.io/component: controller + topologyKey: kubernetes.io/hostname + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + + - it: should create a Deployment with affinity if `controller.affinity` is set + set: + controller.affinity: + podAntiAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + - labelSelector: + matchExpressions: + - key: app.kubernetes.io/name + operator: In + values: + - '{{ include "ingress-nginx.name" . }}' + - key: app.kubernetes.io/instance + operator: In + values: + - '{{ .Release.Name }}' + - key: app.kubernetes.io/component + operator: In + values: + - controller + topologyKey: kubernetes.io/hostname + asserts: + - equal: + path: spec.template.spec.affinity + value: + podAntiAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + - labelSelector: + matchExpressions: + - key: app.kubernetes.io/name + operator: In + values: + - ingress-nginx + - key: app.kubernetes.io/instance + operator: In + values: + - RELEASE-NAME + - key: app.kubernetes.io/component + operator: In + values: + - controller + topologyKey: kubernetes.io/hostname + + - it: should create a Deployment with a custom registry if `controller.image.registry` is set + set: + controller.image.registry: custom.registry.io + controller.image.tag: v1.0.0-dev + controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: custom.registry.io/ingress-nginx/controller:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + + - it: should create a Deployment with a custom image if `controller.image.image` is set + set: + controller.image.image: custom-repo/custom-image + controller.image.tag: v1.0.0-dev + controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: registry.k8s.io/custom-repo/custom-image:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + + - it: should create a Deployment with a custom tag if `controller.image.tag` is set + set: + controller.image.tag: custom-tag + controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: registry.k8s.io/ingress-nginx/controller:custom-tag@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd diff --git a/charts/keep/charts/ingress-nginx/tests/controller-hpa_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-hpa_test.yaml new file mode 100644 index 0000000..869d3a6 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-hpa_test.yaml @@ -0,0 +1,31 @@ +suite: Controller > HPA +templates: + - controller-hpa.yaml + +tests: + - it: should create an HPA if `controller.autoscaling.enabled` is true + set: + controller.autoscaling.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: HorizontalPodAutoscaler + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should not create an HPA if `controller.autoscaling.enabled` is true and `controller.keda.enabled` is true + set: + controller.autoscaling.enabled: true + controller.keda.enabled: true + asserts: + - hasDocuments: + count: 0 + + - it: should not create an HPA if `controller.kind` is "DaemonSet" + set: + controller.kind: DaemonSet + asserts: + - hasDocuments: + count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-ingressclass-aliases_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-ingressclass-aliases_test.yaml new file mode 100644 index 0000000..9a4a576 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-ingressclass-aliases_test.yaml @@ -0,0 +1,110 @@ +suite: Controller > IngressClass > Aliases +templates: + - controller-ingressclass-aliases.yaml + +tests: + - it: should not create IngressClass aliases + asserts: + - hasDocuments: + count: 0 + + - it: should create an IngressClass alias with name "nginx-alias" if `controller.ingressClassResource.aliases` is set + set: + controller.ingressClassResource.aliases: + - nginx-alias + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx-alias + + - it: should create an IngressClass alias without annotation `ingressclass.kubernetes.io/is-default-class` if `controller.ingressClassResource.default` is true + set: + controller.ingressClassResource.aliases: + - nginx-alias + controller.ingressClassResource.default: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx-alias + - notExists: + path: metadata.annotations["ingressclass.kubernetes.io/is-default-class"] + + - it: should create an IngressClass alias with annotations if `controller.ingressClassResource.annotations` is set + set: + controller.ingressClassResource.aliases: + - nginx-alias + controller.ingressClassResource.annotations: + my-fancy-annotation: has-a-value + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx-alias + - equal: + path: metadata.annotations.my-fancy-annotation + value: has-a-value + + - it: should create an IngressClass alias with controller "k8s.io/ingress-nginx-internal" if `controller.ingressClassResource.controllerValue` is "k8s.io/ingress-nginx-internal" + set: + controller.ingressClassResource.aliases: + - nginx-alias + controller.ingressClassResource.controllerValue: k8s.io/ingress-nginx-internal + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx-alias + - equal: + path: spec.controller + value: k8s.io/ingress-nginx-internal + + - it: should create an IngressClass alias with parameters if `controller.ingressClassResource.parameters` is set + set: + controller.ingressClassResource.aliases: + - nginx-alias + controller.ingressClassResource.parameters: + apiGroup: k8s.example.com + kind: IngressParameters + name: external-lb + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx-alias + - equal: + path: spec.parameters + value: + apiGroup: k8s.example.com + kind: IngressParameters + name: external-lb + + - it: should create two IngressClass aliases if `controller.ingressClassResource.aliases` has two elements + set: + controller.ingressClassResource.aliases: + - nginx-alias-1 + - nginx-alias-2 + asserts: + - hasDocuments: + count: 2 + - isKind: + of: IngressClass + - matchRegex: + path: metadata.name + pattern: nginx-alias-(1|2) diff --git a/charts/keep/charts/ingress-nginx/tests/controller-ingressclass_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-ingressclass_test.yaml new file mode 100644 index 0000000..b3384af --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-ingressclass_test.yaml @@ -0,0 +1,93 @@ +suite: Controller > IngressClass +templates: + - controller-ingressclass.yaml + +tests: + - it: should create an IngressClass + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx + + - it: should create an IngressClass with name "nginx-internal" if `controller.ingressClassResource.name` is "nginx-internal" + set: + controller.ingressClassResource.name: nginx-internal + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx-internal + + - it: "should create an IngressClass with annotation `ingressclass.kubernetes.io/is-default-class: \"true\"` if `controller.ingressClassResource.default` is true" + set: + controller.ingressClassResource.default: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx + - equal: + path: metadata.annotations["ingressclass.kubernetes.io/is-default-class"] + value: "true" + + - it: should create an IngressClass with annotations if `controller.ingressClassResource.annotations` is set + set: + controller.ingressClassResource.annotations: + my-fancy-annotation: has-a-value + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx + - equal: + path: metadata.annotations.my-fancy-annotation + value: has-a-value + + - it: should create an IngressClass with controller "k8s.io/ingress-nginx-internal" if `controller.ingressClassResource.controllerValue` is "k8s.io/ingress-nginx-internal" + set: + controller.ingressClassResource.controllerValue: k8s.io/ingress-nginx-internal + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx + - equal: + path: spec.controller + value: k8s.io/ingress-nginx-internal + + - it: should create an IngressClass with parameters if `controller.ingressClassResource.parameters` is set + set: + controller.ingressClassResource.parameters: + apiGroup: k8s.example.com + kind: IngressParameters + name: external-lb + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx + - equal: + path: spec.parameters + value: + apiGroup: k8s.example.com + kind: IngressParameters + name: external-lb diff --git a/charts/keep/charts/ingress-nginx/tests/controller-keda_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-keda_test.yaml new file mode 100644 index 0000000..8002834 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-keda_test.yaml @@ -0,0 +1,31 @@ +suite: Controller > KEDA +templates: + - controller-keda.yaml + +tests: + - it: should create a ScaledObject if `controller.keda.enabled` is true + set: + controller.keda.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ScaledObject + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should not create a ScaledObject if `controller.keda.enabled` is true and `controller.autoscaling.enabled` is true + set: + controller.keda.enabled: true + controller.autoscaling.enabled: true + asserts: + - hasDocuments: + count: 0 + + - it: should not create a ScaledObject if `controller.kind` is "DaemonSet" + set: + controller.kind: DaemonSet + asserts: + - hasDocuments: + count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-networkpolicy_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-networkpolicy_test.yaml new file mode 100644 index 0000000..5de12e9 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-networkpolicy_test.yaml @@ -0,0 +1,23 @@ +suite: Controller > NetworkPolicy +templates: + - controller-networkpolicy.yaml + +tests: + - it: should not create a NetworkPolicy if `controller.networkPolicy.enabled` is false + set: + controller.networkPolicy.enabled: false + asserts: + - hasDocuments: + count: 0 + + - it: should create a NetworkPolicy if `controller.networkPolicy.enabled` is true + set: + controller.networkPolicy.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: NetworkPolicy + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller diff --git a/charts/keep/charts/ingress-nginx/tests/controller-poddisruptionbudget_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-poddisruptionbudget_test.yaml new file mode 100644 index 0000000..f215f35 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-poddisruptionbudget_test.yaml @@ -0,0 +1,89 @@ +suite: Controller > PodDisruptionBudget +templates: + - controller-poddisruptionbudget.yaml + +tests: + - it: should create a PodDisruptionBudget if `controller.replicaCount` is greater than 1 + set: + controller.replicaCount: 2 + asserts: + - hasDocuments: + count: 1 + - isKind: + of: PodDisruptionBudget + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should not create a PodDisruptionBudget if `controller.replicaCount` is less than or equal 1 + set: + controller.replicaCount: 1 + asserts: + - hasDocuments: + count: 0 + + - it: should create a PodDisruptionBudget if `controller.autoscaling.enabled` is true and `controller.autoscaling.minReplicas` is greater than 1 + set: + controller.autoscaling.enabled: true + controller.autoscaling.minReplicas: 2 + asserts: + - hasDocuments: + count: 1 + - isKind: + of: PodDisruptionBudget + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should not create a PodDisruptionBudget if `controller.autoscaling.enabled` is true and `controller.autoscaling.minReplicas` is less than or equal 1 + set: + controller.autoscaling.enabled: true + controller.autoscaling.minReplicas: 1 + asserts: + - hasDocuments: + count: 0 + + - it: should create a PodDisruptionBudget if `controller.keda.enabled` is true and `controller.keda.minReplicas` is greater than 1 + set: + controller.keda.enabled: true + controller.keda.minReplicas: 2 + asserts: + - hasDocuments: + count: 1 + - isKind: + of: PodDisruptionBudget + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should not create a PodDisruptionBudget if `controller.keda.enabled` is true and `controller.keda.minReplicas` is less than or equal 1 + set: + controller.keda.enabled: true + controller.keda.minReplicas: 1 + asserts: + - hasDocuments: + count: 0 + + - it: should not create a PodDisruptionBudget if `controller.autoscaling.enabled` is true and `controller.keda.enabled` is true + set: + controller.autoscaling.enabled: true + controller.keda.enabled: true + asserts: + - hasDocuments: + count: 0 + + - it: should create a PodDisruptionBudget without `minAvailable` and with `maxUnavailable` if `controller.minAvailable` and `controller.maxUnavailable` are set + set: + controller.replicaCount: 2 + controller.minAvailable: 1 + controller.maxUnavailable: 1 + asserts: + - hasDocuments: + count: 1 + - isKind: + of: PodDisruptionBudget + - notExists: + path: spec.minAvailable + - equal: + path: spec.maxUnavailable + value: 1 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-prometheusrule_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-prometheusrule_test.yaml new file mode 100644 index 0000000..d60a983 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-prometheusrule_test.yaml @@ -0,0 +1,17 @@ +suite: Controller > PrometheusRule +templates: + - controller-prometheusrule.yaml + +tests: + - it: should create a PrometheusRule if `controller.metrics.prometheusRule.enabled` is true + set: + controller.metrics.enabled: true + controller.metrics.prometheusRule.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: PrometheusRule + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller diff --git a/charts/keep/charts/ingress-nginx/tests/controller-service-internal_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-service-internal_test.yaml new file mode 100644 index 0000000..5465e1a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-service-internal_test.yaml @@ -0,0 +1,25 @@ +suite: Controller > Service > Internal +templates: + - controller-service-internal.yaml + +tests: + - it: should not create an internal Service if `controller.service.internal.enabled` is false + set: + controller.service.internal.enabled: false + asserts: + - hasDocuments: + count: 0 + + - it: should create an internal Service if `controller.service.internal.enabled` is true and `controller.service.internal.annotations` are set + set: + controller.service.internal.enabled: true + controller.service.internal.annotations: + test.annotation: "true" + asserts: + - hasDocuments: + count: 1 + - isKind: + of: Service + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller-internal diff --git a/charts/keep/charts/ingress-nginx/tests/controller-service-metrics_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-service-metrics_test.yaml new file mode 100644 index 0000000..afdb940 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-service-metrics_test.yaml @@ -0,0 +1,23 @@ +suite: Controller > Service > Metrics +templates: + - controller-service-metrics.yaml + +tests: + - it: should not create a metrics Service if `controller.metrics.enabled` is false + set: + controller.metrics.enabled: false + asserts: + - hasDocuments: + count: 0 + + - it: should create a metrics Service if `controller.metrics.enabled` is true + set: + controller.metrics.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: Service + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller-metrics diff --git a/charts/keep/charts/ingress-nginx/tests/controller-service-webhook_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-service-webhook_test.yaml new file mode 100644 index 0000000..1c759ed --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-service-webhook_test.yaml @@ -0,0 +1,32 @@ +suite: Controller > Service > Webhook +templates: + - controller-service-webhook.yaml + +tests: + - it: should not create a webhook Service if `controller.admissionWebhooks.enabled` is false + set: + controller.admissionWebhooks.enabled: false + asserts: + - hasDocuments: + count: 0 + + - it: should create a webhook Service if `controller.admissionWebhooks.enabled` is true + set: + controller.admissionWebhooks.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: Service + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller-admission + + - it: should create a webhook Service with a custom port if `controller.admissionWebhooks.service.servicePort` is set + set: + controller.admissionWebhooks.enabled: true + controller.admissionWebhooks.service.servicePort: 9443 + asserts: + - equal: + path: spec.ports[0].port + value: 9443 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-service_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-service_test.yaml new file mode 100644 index 0000000..10574f2 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-service_test.yaml @@ -0,0 +1,32 @@ +suite: Controller > Service +templates: + - controller-service.yaml + +tests: + - it: should not create a Service if `controller.service.external.enabled` is false + set: + controller.service.external.enabled: false + asserts: + - hasDocuments: + count: 0 + + - it: should create a Service if `controller.service.external.enabled` is true + set: + controller.service.external.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: Service + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should create a Service of type "NodePort" if `controller.service.external.enabled` is true and `controller.service.type` is "NodePort" + set: + controller.service.external.enabled: true + controller.service.type: NodePort + asserts: + - equal: + path: spec.type + value: NodePort diff --git a/charts/keep/charts/ingress-nginx/tests/controller-servicemonitor_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-servicemonitor_test.yaml new file mode 100644 index 0000000..310097c --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-servicemonitor_test.yaml @@ -0,0 +1,29 @@ +suite: Controller > ServiceMonitor +templates: + - controller-servicemonitor.yaml + +tests: + - it: should create a ServiceMonitor if `controller.metrics.serviceMonitor.enabled` is true + set: + controller.metrics.enabled: true + controller.metrics.serviceMonitor.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ServiceMonitor + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should create a ServiceMonitor with annotations if `controller.metrics.serviceMonitor.annotations` is set + set: + controller.metrics.enabled: true + controller.metrics.serviceMonitor.enabled: true + controller.metrics.serviceMonitor.annotations: + my-little-annotation: test-value + asserts: + - equal: + path: metadata.annotations + value: + my-little-annotation: test-value diff --git a/charts/keep/charts/ingress-nginx/tests/default-backend-deployment_test.yaml b/charts/keep/charts/ingress-nginx/tests/default-backend-deployment_test.yaml new file mode 100644 index 0000000..4ba4b03 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/default-backend-deployment_test.yaml @@ -0,0 +1,169 @@ +suite: Default Backend > Deployment +templates: + - default-backend-deployment.yaml + +tests: + - it: should not create a Deployment if `defaultBackend.enabled` is false + set: + defaultBackend.enabled: false + asserts: + - hasDocuments: + count: 0 + + - it: should create a Deployment if `defaultBackend.enabled` is true + set: + defaultBackend.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: Deployment + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-defaultbackend + + - it: should create a Deployment with 3 replicas if `defaultBackend.replicaCount` is 3 + set: + defaultBackend.enabled: true + defaultBackend.replicaCount: 3 + asserts: + - equal: + path: spec.replicas + value: 3 + + - it: should create a Deployment without replicas if `defaultBackend.autoscaling.enabled` is true + set: + defaultBackend.enabled: true + defaultBackend.autoscaling.enabled: true + asserts: + - notExists: + path: spec.replicas + + - it: should create a Deployment with resource limits if `defaultBackend.resources.limits` is set + set: + defaultBackend.enabled: true + defaultBackend.resources.limits.cpu: 500m + defaultBackend.resources.limits.memory: 512Mi + asserts: + - equal: + path: spec.template.spec.containers[0].resources.limits.cpu + value: 500m + - equal: + path: spec.template.spec.containers[0].resources.limits.memory + value: 512Mi + + - it: should create a Deployment with topology spread constraints if `defaultBackend.topologySpreadConstraints` is set + set: + defaultBackend.enabled: true + defaultBackend.topologySpreadConstraints: + - labelSelector: + matchLabels: + app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + app.kubernetes.io/instance: '{{ .Release.Name }}' + app.kubernetes.io/component: default-backend + topologyKey: topology.kubernetes.io/zone + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + - labelSelector: + matchLabels: + app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + app.kubernetes.io/instance: '{{ .Release.Name }}' + app.kubernetes.io/component: default-backend + topologyKey: kubernetes.io/hostname + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + asserts: + - equal: + path: spec.template.spec.topologySpreadConstraints + value: + - labelSelector: + matchLabels: + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: RELEASE-NAME + app.kubernetes.io/component: default-backend + topologyKey: topology.kubernetes.io/zone + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + - labelSelector: + matchLabels: + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: RELEASE-NAME + app.kubernetes.io/component: default-backend + topologyKey: kubernetes.io/hostname + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + + - it: should create a Deployment with affinity if `defaultBackend.affinity` is set + set: + defaultBackend.enabled: true + defaultBackend.affinity: + podAntiAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + - labelSelector: + matchExpressions: + - key: app.kubernetes.io/name + operator: In + values: + - '{{ include "ingress-nginx.name" . }}' + - key: app.kubernetes.io/instance + operator: In + values: + - '{{ .Release.Name }}' + - key: app.kubernetes.io/component + operator: In + values: + - default-backend + topologyKey: kubernetes.io/hostname + asserts: + - equal: + path: spec.template.spec.affinity + value: + podAntiAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + - labelSelector: + matchExpressions: + - key: app.kubernetes.io/name + operator: In + values: + - ingress-nginx + - key: app.kubernetes.io/instance + operator: In + values: + - RELEASE-NAME + - key: app.kubernetes.io/component + operator: In + values: + - default-backend + topologyKey: kubernetes.io/hostname + + - it: should create a Deployment with a custom registry if `defaultBackend.image.registry` is set + set: + defaultBackend.enabled: true + defaultBackend.image.registry: custom.registry.io + defaultBackend.image.tag: v1.0.0-dev + defaultBackend.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: custom.registry.io/defaultbackend-amd64:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + + - it: should create a Deployment with a custom image if `defaultBackend.image.image` is set + set: + defaultBackend.enabled: true + defaultBackend.image.image: custom-repo/custom-image + defaultBackend.image.tag: v1.0.0-dev + defaultBackend.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: registry.k8s.io/custom-repo/custom-image:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + + - it: should create a Deployment with a custom tag if `defaultBackend.image.tag` is set + set: + defaultBackend.enabled: true + defaultBackend.image.tag: custom-tag + defaultBackend.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: registry.k8s.io/defaultbackend-amd64:custom-tag@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd diff --git a/charts/keep/charts/ingress-nginx/tests/default-backend-extra-configmaps_test.yaml b/charts/keep/charts/ingress-nginx/tests/default-backend-extra-configmaps_test.yaml new file mode 100644 index 0000000..aa600e7 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/default-backend-extra-configmaps_test.yaml @@ -0,0 +1,50 @@ +suite: Default Backend > Extra ConfigMaps +templates: + - default-backend-extra-configmaps.yaml + +tests: + - it: should not create a ConfigMap if `defaultBackend.extraConfigMaps` is empty + set: + defaultBackend.enabled: true + defaultBackend.extraConfigMaps: [] + asserts: + - hasDocuments: + count: 0 + + - it: should create one ConfigMap if `defaultBackend.extraConfigMaps` has one element + set: + defaultBackend.enabled: true + defaultBackend.extraConfigMaps: + - name: my-configmap-1 + data: + key1: value1 + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ConfigMap + - equal: + path: metadata.name + value: my-configmap-1 + - equal: + path: data.key1 + value: value1 + + - it: should create two ConfigMaps if `defaultBackend.extraConfigMaps` has two elements + set: + defaultBackend.enabled: true + defaultBackend.extraConfigMaps: + - name: my-configmap-1 + data: + key1: value1 + - name: my-configmap-2 + data: + key2: value2 + asserts: + - hasDocuments: + count: 2 + - isKind: + of: ConfigMap + - matchRegex: + path: metadata.name + pattern: my-configmap-(1|2) diff --git a/charts/keep/charts/ingress-nginx/tests/default-backend-poddisruptionbudget_test.yaml b/charts/keep/charts/ingress-nginx/tests/default-backend-poddisruptionbudget_test.yaml new file mode 100644 index 0000000..0958018 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/default-backend-poddisruptionbudget_test.yaml @@ -0,0 +1,48 @@ +suite: Default Backend > PodDisruptionBudget +templates: + - default-backend-poddisruptionbudget.yaml + +tests: + - it: should create a PodDisruptionBudget if `defaultBackend.replicaCount` is greater than 1 + set: + defaultBackend.enabled: true + defaultBackend.replicaCount: 2 + asserts: + - hasDocuments: + count: 1 + - isKind: + of: PodDisruptionBudget + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-defaultbackend + + - it: should not create a PodDisruptionBudget if `defaultBackend.replicaCount` is less than or equal 1 + set: + defaultBackend.enabled: true + defaultBackend.replicaCount: 1 + asserts: + - hasDocuments: + count: 0 + + - it: should create a PodDisruptionBudget if `defaultBackend.autoscaling.enabled` is true and `defaultBackend.autoscaling.minReplicas` is greater than 1 + set: + defaultBackend.enabled: true + defaultBackend.autoscaling.enabled: true + defaultBackend.autoscaling.minReplicas: 2 + asserts: + - hasDocuments: + count: 1 + - isKind: + of: PodDisruptionBudget + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-defaultbackend + + - it: should not create a PodDisruptionBudget if `defaultBackend.autoscaling.enabled` is true and `defaultBackend.autoscaling.minReplicas` is less than or equal 1 + set: + defaultBackend.enabled: true + defaultBackend.autoscaling.enabled: true + defaultBackend.autoscaling.minReplicas: 1 + asserts: + - hasDocuments: + count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/default-backend-service_test.yaml b/charts/keep/charts/ingress-nginx/tests/default-backend-service_test.yaml new file mode 100644 index 0000000..f16904f --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/default-backend-service_test.yaml @@ -0,0 +1,32 @@ +suite: Default Backend > Service +templates: + - default-backend-service.yaml + +tests: + - it: should not create a Service if `defaultBackend.enabled` is false + set: + defaultBackend.enabled: false + asserts: + - hasDocuments: + count: 0 + + - it: should create a Service if `defaultBackend.enabled` is true + set: + defaultBackend.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: Service + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-defaultbackend + + - it: should create a Service with port 80 if `defaultBackend.service.port` is 80 + set: + defaultBackend.enabled: true + defaultBackend.service.port: 80 + asserts: + - equal: + path: spec.ports[0].port + value: 80 diff --git a/charts/keep/charts/ingress-nginx/values.yaml b/charts/keep/charts/ingress-nginx/values.yaml new file mode 100644 index 0000000..f42a682 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/values.yaml @@ -0,0 +1,1192 @@ +## nginx configuration +## Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/nginx-configuration/index.md +## + +## Overrides for generated resource names +# See templates/_helpers.tpl +# nameOverride: +# fullnameOverride: + +# -- Override the deployment namespace; defaults to .Release.Namespace +namespaceOverride: "" +## Labels to apply to all resources +## +commonLabels: {} +# scmhash: abc123 +# myLabel: aakkmd + +controller: + name: controller + enableAnnotationValidations: false + image: + ## Keep false as default for now! + chroot: false + registry: registry.k8s.io + image: ingress-nginx/controller + ## for backwards compatibility consider setting the full image url via the repository value below + ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail + ## repository: + tag: "v1.11.3" + digest: sha256:d56f135b6462cfc476447cfe564b83a45e8bb7da2774963b00d12161112270b7 + digestChroot: sha256:22701f0fc0f2dd209ef782f4e281bfe2d8cccd50ededa00aec88e0cdbe7edd14 + pullPolicy: IfNotPresent + runAsNonRoot: true + # www-data -> uid 101 + runAsUser: 101 + allowPrivilegeEscalation: false + seccompProfile: + type: RuntimeDefault + readOnlyRootFilesystem: false + # -- Use an existing PSP instead of creating one + existingPsp: "" + # -- Configures the controller container name + containerName: controller + # -- Configures the ports that the nginx-controller listens on + containerPort: + http: 80 + https: 443 + # -- Global configuration passed to the ConfigMap consumed by the controller. Values may contain Helm templates. + # Ref.: https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/ + config: {} + # -- Annotations to be added to the controller config configuration configmap. + configAnnotations: {} + # -- Will add custom headers before sending traffic to backends according to https://github.com/kubernetes/ingress-nginx/tree/main/docs/examples/customization/custom-headers + proxySetHeaders: {} + # -- Will add custom headers before sending response traffic to the client according to: https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/#add-headers + addHeaders: {} + # -- Optionally customize the pod dnsConfig. + dnsConfig: {} + # -- Optionally customize the pod hostAliases. + hostAliases: [] + # - ip: 127.0.0.1 + # hostnames: + # - foo.local + # - bar.local + # - ip: 10.1.2.3 + # hostnames: + # - foo.remote + # - bar.remote + # -- Optionally customize the pod hostname. + hostname: {} + # -- Optionally change this to ClusterFirstWithHostNet in case you have 'hostNetwork: true'. + # By default, while using host network, name resolution uses the host's DNS. If you wish nginx-controller + # to keep resolving names inside the k8s network, use ClusterFirstWithHostNet. + dnsPolicy: ClusterFirst + # -- Bare-metal considerations via the host network https://kubernetes.github.io/ingress-nginx/deploy/baremetal/#via-the-host-network + # Ingress status was blank because there is no Service exposing the Ingress-Nginx Controller in a configuration using the host network, the default --publish-service flag used in standard cloud setups does not apply + reportNodeInternalIp: false + # -- Process Ingress objects without ingressClass annotation/ingressClassName field + # Overrides value for --watch-ingress-without-class flag of the controller binary + # Defaults to false + watchIngressWithoutClass: false + # -- Process IngressClass per name (additionally as per spec.controller). + ingressClassByName: false + # -- This configuration enables Topology Aware Routing feature, used together with service annotation service.kubernetes.io/topology-mode="auto" + # Defaults to false + enableTopologyAwareRouting: false + # -- This configuration disable Nginx Controller Leader Election + disableLeaderElection: false + # -- Duration a leader election is valid before it's getting re-elected, e.g. `15s`, `10m` or `1h`. (Default: 30s) + electionTTL: "" + # -- This configuration defines if Ingress Controller should allow users to set + # their own *-snippet annotations, otherwise this is forbidden / dropped + # when users add those annotations. + # Global snippets in ConfigMap are still respected + allowSnippetAnnotations: false + # -- Required for use with CNI based kubernetes installations (such as ones set up by kubeadm), + # since CNI and hostport don't mix yet. Can be deprecated once https://github.com/kubernetes/kubernetes/issues/23920 + # is merged + hostNetwork: false + ## Use host ports 80 and 443 + ## Disabled by default + hostPort: + # -- Enable 'hostPort' or not + enabled: false + ports: + # -- 'hostPort' http port + http: 80 + # -- 'hostPort' https port + https: 443 + # NetworkPolicy for controller component. + networkPolicy: + # -- Enable 'networkPolicy' or not + enabled: false + # -- Election ID to use for status update, by default it uses the controller name combined with a suffix of 'leader' + electionID: "" + # -- This section refers to the creation of the IngressClass resource. + # IngressClasses are immutable and cannot be changed after creation. + # We do not support namespaced IngressClasses, yet, so a ClusterRole and a ClusterRoleBinding is required. + ingressClassResource: + # -- Name of the IngressClass + name: nginx + # -- Create the IngressClass or not + enabled: true + # -- If true, Ingresses without `ingressClassName` get assigned to this IngressClass on creation. + # Ingress creation gets rejected if there are multiple default IngressClasses. + # Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#default-ingress-class + default: false + # -- Annotations to be added to the IngressClass resource. + annotations: {} + # -- Controller of the IngressClass. An Ingress Controller looks for IngressClasses it should reconcile by this value. + # This value is also being set as the `--controller-class` argument of this Ingress Controller. + # Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#ingress-class + controllerValue: k8s.io/ingress-nginx + # -- Aliases of this IngressClass. Creates copies with identical settings but the respective alias as name. + # Useful for development environments with only one Ingress Controller but production-like Ingress resources. + # `default` gets enabled on the original IngressClass only. + aliases: [] + # aliases: + # - nginx-alias-1 + # - nginx-alias-2 + # -- A link to a custom resource containing additional configuration for the controller. + # This is optional if the controller consuming this IngressClass does not require additional parameters. + # Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#ingress-class + parameters: {} + # parameters: + # apiGroup: k8s.example.com + # kind: IngressParameters + # name: external-lb + # -- For backwards compatibility with ingress.class annotation, use ingressClass. + # Algorithm is as follows, first ingressClassName is considered, if not present, controller looks for ingress.class annotation + ingressClass: nginx + # -- Labels to add to the pod container metadata + podLabels: {} + # key: value + + # -- Security context for controller pods + podSecurityContext: {} + # -- sysctls for controller pods + ## Ref: https://kubernetes.io/docs/tasks/administer-cluster/sysctl-cluster/ + sysctls: {} + # sysctls: + # "net.core.somaxconn": "8192" + # -- Security context for controller containers + containerSecurityContext: {} + # -- Allows customization of the source of the IP address or FQDN to report + # in the ingress status field. By default, it reads the information provided + # by the service. If disable, the status field reports the IP address of the + # node or nodes where an ingress controller pod is running. + publishService: + # -- Enable 'publishService' or not + enabled: true + # -- Allows overriding of the publish service to bind to + # Must be / + pathOverride: "" + # Limit the scope of the controller to a specific namespace + scope: + # -- Enable 'scope' or not + enabled: false + # -- Namespace to limit the controller to; defaults to $(POD_NAMESPACE) + namespace: "" + # -- When scope.enabled == false, instead of watching all namespaces, we watching namespaces whose labels + # only match with namespaceSelector. Format like foo=bar. Defaults to empty, means watching all namespaces. + namespaceSelector: "" + # -- Allows customization of the configmap / nginx-configmap namespace; defaults to $(POD_NAMESPACE) + configMapNamespace: "" + tcp: + # -- Allows customization of the tcp-services-configmap; defaults to $(POD_NAMESPACE) + configMapNamespace: "" + # -- Annotations to be added to the tcp config configmap + annotations: {} + udp: + # -- Allows customization of the udp-services-configmap; defaults to $(POD_NAMESPACE) + configMapNamespace: "" + # -- Annotations to be added to the udp config configmap + annotations: {} + # -- Maxmind license key to download GeoLite2 Databases. + ## https://blog.maxmind.com/2019/12/significant-changes-to-accessing-and-using-geolite2-databases/ + maxmindLicenseKey: "" + # -- Additional command line arguments to pass to Ingress-Nginx Controller + # E.g. to specify the default SSL certificate you can use + extraArgs: {} + ## extraArgs: + ## default-ssl-certificate: "/" + ## time-buckets: "0.005,0.01,0.025,0.05,0.1,0.25,0.5,1,2.5,5,10" + ## length-buckets: "10,20,30,40,50,60,70,80,90,100" + ## size-buckets: "10,100,1000,10000,100000,1e+06,1e+07" + + # -- Additional environment variables to set + extraEnvs: [] + # extraEnvs: + # - name: FOO + # valueFrom: + # secretKeyRef: + # key: FOO + # name: secret-resource + + # -- Use a `DaemonSet` or `Deployment` + kind: Deployment + # -- Annotations to be added to the controller Deployment or DaemonSet + ## + annotations: {} + # keel.sh/pollSchedule: "@every 60m" + + # -- Labels to be added to the controller Deployment or DaemonSet and other resources that do not have option to specify labels + ## + labels: {} + # keel.sh/policy: patch + # keel.sh/trigger: poll + + # -- The update strategy to apply to the Deployment or DaemonSet + ## + updateStrategy: {} + # rollingUpdate: + # maxUnavailable: 1 + # type: RollingUpdate + + # -- `minReadySeconds` to avoid killing pods before we are ready + ## + minReadySeconds: 0 + # -- Node tolerations for server scheduling to nodes with taints + ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/ + ## + tolerations: [] + # - key: "key" + # operator: "Equal|Exists" + # value: "value" + # effect: "NoSchedule|PreferNoSchedule|NoExecute(1.6 only)" + + # -- Affinity and anti-affinity rules for server scheduling to nodes + ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#affinity-and-anti-affinity + ## + affinity: {} + # # An example of preferred pod anti-affinity, weight is in the range 1-100 + # podAntiAffinity: + # preferredDuringSchedulingIgnoredDuringExecution: + # - weight: 100 + # podAffinityTerm: + # labelSelector: + # matchExpressions: + # - key: app.kubernetes.io/name + # operator: In + # values: + # - '{{ include "ingress-nginx.name" . }}' + # - key: app.kubernetes.io/instance + # operator: In + # values: + # - '{{ .Release.Name }}' + # - key: app.kubernetes.io/component + # operator: In + # values: + # - controller + # topologyKey: kubernetes.io/hostname + + # # An example of required pod anti-affinity + # podAntiAffinity: + # requiredDuringSchedulingIgnoredDuringExecution: + # - labelSelector: + # matchExpressions: + # - key: app.kubernetes.io/name + # operator: In + # values: + # - '{{ include "ingress-nginx.name" . }}' + # - key: app.kubernetes.io/instance + # operator: In + # values: + # - '{{ .Release.Name }}' + # - key: app.kubernetes.io/component + # operator: In + # values: + # - controller + # topologyKey: kubernetes.io/hostname + + # -- Topology spread constraints rely on node labels to identify the topology domain(s) that each Node is in. + ## Ref: https://kubernetes.io/docs/concepts/workloads/pods/pod-topology-spread-constraints/ + ## + topologySpreadConstraints: [] + # - labelSelector: + # matchLabels: + # app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + # app.kubernetes.io/instance: '{{ .Release.Name }}' + # app.kubernetes.io/component: controller + # topologyKey: topology.kubernetes.io/zone + # maxSkew: 1 + # whenUnsatisfiable: ScheduleAnyway + # - labelSelector: + # matchLabels: + # app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + # app.kubernetes.io/instance: '{{ .Release.Name }}' + # app.kubernetes.io/component: controller + # topologyKey: kubernetes.io/hostname + # maxSkew: 1 + # whenUnsatisfiable: ScheduleAnyway + + # -- `terminationGracePeriodSeconds` to avoid killing pods before we are ready + ## wait up to five minutes for the drain of connections + ## + terminationGracePeriodSeconds: 300 + # -- Node labels for controller pod assignment + ## Ref: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/ + ## + nodeSelector: + kubernetes.io/os: linux + ## Liveness and readiness probe values + ## Ref: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle/#container-probes + ## + ## startupProbe: + ## httpGet: + ## # should match container.healthCheckPath + ## path: "/healthz" + ## port: 10254 + ## scheme: HTTP + ## initialDelaySeconds: 5 + ## periodSeconds: 5 + ## timeoutSeconds: 2 + ## successThreshold: 1 + ## failureThreshold: 5 + livenessProbe: + httpGet: + # should match container.healthCheckPath + path: "/healthz" + port: 10254 + scheme: HTTP + initialDelaySeconds: 10 + periodSeconds: 10 + timeoutSeconds: 1 + successThreshold: 1 + failureThreshold: 5 + readinessProbe: + httpGet: + # should match container.healthCheckPath + path: "/healthz" + port: 10254 + scheme: HTTP + initialDelaySeconds: 10 + periodSeconds: 10 + timeoutSeconds: 1 + successThreshold: 1 + failureThreshold: 3 + # -- Path of the health check endpoint. All requests received on the port defined by + # the healthz-port parameter are forwarded internally to this path. + healthCheckPath: "/healthz" + # -- Address to bind the health check endpoint. + # It is better to set this option to the internal node address + # if the Ingress-Nginx Controller is running in the `hostNetwork: true` mode. + healthCheckHost: "" + # -- Annotations to be added to controller pods + ## + podAnnotations: {} + replicaCount: 1 + # -- Minimum available pods set in PodDisruptionBudget. + # Define either 'minAvailable' or 'maxUnavailable', never both. + minAvailable: 1 + # -- Maximum unavailable pods set in PodDisruptionBudget. If set, 'minAvailable' is ignored. + # maxUnavailable: 1 + + ## Define requests resources to avoid probe issues due to CPU utilization in busy nodes + ## ref: https://github.com/kubernetes/ingress-nginx/issues/4735#issuecomment-551204903 + ## Ideally, there should be no limits. + ## https://engineering.indeedblog.com/blog/2019/12/cpu-throttling-regression-fix/ + resources: + ## limits: + ## cpu: 100m + ## memory: 90Mi + requests: + cpu: 100m + memory: 90Mi + # Mutually exclusive with keda autoscaling + autoscaling: + enabled: false + annotations: {} + minReplicas: 1 + maxReplicas: 11 + targetCPUUtilizationPercentage: 50 + targetMemoryUtilizationPercentage: 50 + behavior: {} + # scaleDown: + # stabilizationWindowSeconds: 300 + # policies: + # - type: Pods + # value: 1 + # periodSeconds: 180 + # scaleUp: + # stabilizationWindowSeconds: 300 + # policies: + # - type: Pods + # value: 2 + # periodSeconds: 60 + autoscalingTemplate: [] + # Custom or additional autoscaling metrics + # ref: https://kubernetes.io/docs/tasks/run-application/horizontal-pod-autoscale/#support-for-custom-metrics + # - type: Pods + # pods: + # metric: + # name: nginx_ingress_controller_nginx_process_requests_total + # target: + # type: AverageValue + # averageValue: 10000m + + # Mutually exclusive with hpa autoscaling + keda: + apiVersion: "keda.sh/v1alpha1" + ## apiVersion changes with keda 1.x vs 2.x + ## 2.x = keda.sh/v1alpha1 + ## 1.x = keda.k8s.io/v1alpha1 + enabled: false + minReplicas: 1 + maxReplicas: 11 + pollingInterval: 30 + cooldownPeriod: 300 + # fallback: + # failureThreshold: 3 + # replicas: 11 + restoreToOriginalReplicaCount: false + scaledObject: + annotations: {} + # Custom annotations for ScaledObject resource + # annotations: + # key: value + triggers: [] + # - type: prometheus + # metadata: + # serverAddress: http://:9090 + # metricName: http_requests_total + # threshold: '100' + # query: sum(rate(http_requests_total{deployment="my-deployment"}[2m])) + + behavior: {} + # scaleDown: + # stabilizationWindowSeconds: 300 + # policies: + # - type: Pods + # value: 1 + # periodSeconds: 180 + # scaleUp: + # stabilizationWindowSeconds: 300 + # policies: + # - type: Pods + # value: 2 + # periodSeconds: 60 + # -- Enable mimalloc as a drop-in replacement for malloc. + ## ref: https://github.com/microsoft/mimalloc + ## + enableMimalloc: true + ## Override NGINX template + customTemplate: + configMapName: "" + configMapKey: "" + service: + # -- Enable controller services or not. This does not influence the creation of either the admission webhook or the metrics service. + enabled: true + external: + # -- Enable the external controller service or not. Useful for internal-only deployments. + enabled: true + # -- Annotations to be added to the external controller service. See `controller.service.internal.annotations` for annotations to be added to the internal controller service. + annotations: {} + # -- Labels to be added to both controller services. + labels: {} + # -- Type of the external controller service. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types + type: LoadBalancer + # -- Pre-defined cluster internal IP address of the external controller service. Take care of collisions with existing services. + # This value is immutable. Set once, it can not be changed without deleting and re-creating the service. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#choosing-your-own-ip-address + clusterIP: "" + # -- List of node IP addresses at which the external controller service is available. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips + externalIPs: [] + # -- Deprecated: Pre-defined IP address of the external controller service. Used by cloud providers to connect the resulting load balancer service to a pre-existing static IP. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#loadbalancer + loadBalancerIP: "" + # -- Restrict access to the external controller service. Values must be CIDRs. Allows any source address by default. + loadBalancerSourceRanges: [] + # -- Load balancer class of the external controller service. Used by cloud providers to select a load balancer implementation other than the cloud provider default. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-class + loadBalancerClass: "" + # -- Enable node port allocation for the external controller service or not. Applies to type `LoadBalancer` only. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-nodeport-allocation + # allocateLoadBalancerNodePorts: true + + # -- External traffic policy of the external controller service. Set to "Local" to preserve source IP on providers supporting it. + # Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip + externalTrafficPolicy: "" + # -- Session affinity of the external controller service. Must be either "None" or "ClientIP" if set. Defaults to "None". + # Ref: https://kubernetes.io/docs/reference/networking/virtual-ips/#session-affinity + sessionAffinity: "" + # -- Specifies the health check node port (numeric port number) for the external controller service. + # If not specified, the service controller allocates a port from your cluster's node port range. + # Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip + # healthCheckNodePort: 0 + + # -- Represents the dual-stack capabilities of the external controller service. Possible values are SingleStack, PreferDualStack or RequireDualStack. + # Fields `ipFamilies` and `clusterIP` depend on the value of this field. + # Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services + ipFamilyPolicy: SingleStack + # -- List of IP families (e.g. IPv4, IPv6) assigned to the external controller service. This field is usually assigned automatically based on cluster configuration and the `ipFamilyPolicy` field. + # Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services + ipFamilies: + - IPv4 + # -- Enable the HTTP listener on both controller services or not. + enableHttp: true + # -- Enable the HTTPS listener on both controller services or not. + enableHttps: true + ports: + # -- Port the external HTTP listener is published with. + http: 80 + # -- Port the external HTTPS listener is published with. + https: 443 + targetPorts: + # -- Port of the ingress controller the external HTTP listener is mapped to. + http: http + # -- Port of the ingress controller the external HTTPS listener is mapped to. + https: https + # -- Declare the app protocol of the external HTTP and HTTPS listeners or not. Supersedes provider-specific annotations for declaring the backend protocol. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#application-protocol + appProtocol: true + nodePorts: + # -- Node port allocated for the external HTTP listener. If left empty, the service controller allocates one from the configured node port range. + http: "" + # -- Node port allocated for the external HTTPS listener. If left empty, the service controller allocates one from the configured node port range. + https: "" + # -- Node port mapping for external TCP listeners. If left empty, the service controller allocates them from the configured node port range. + # Example: + # tcp: + # 8080: 30080 + tcp: {} + # -- Node port mapping for external UDP listeners. If left empty, the service controller allocates them from the configured node port range. + # Example: + # udp: + # 53: 30053 + udp: {} + internal: + # -- Enable the internal controller service or not. Remember to configure `controller.service.internal.annotations` when enabling this. + enabled: false + # -- Annotations to be added to the internal controller service. Mandatory for the internal controller service to be created. Varies with the cloud service. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#internal-load-balancer + annotations: {} + # -- Type of the internal controller service. + # Defaults to the value of `controller.service.type`. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types + type: "" + # -- Pre-defined cluster internal IP address of the internal controller service. Take care of collisions with existing services. + # This value is immutable. Set once, it can not be changed without deleting and re-creating the service. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#choosing-your-own-ip-address + clusterIP: "" + # -- List of node IP addresses at which the internal controller service is available. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips + externalIPs: [] + # -- Deprecated: Pre-defined IP address of the internal controller service. Used by cloud providers to connect the resulting load balancer service to a pre-existing static IP. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#loadbalancer + loadBalancerIP: "" + # -- Restrict access to the internal controller service. Values must be CIDRs. Allows any source address by default. + loadBalancerSourceRanges: [] + # -- Load balancer class of the internal controller service. Used by cloud providers to select a load balancer implementation other than the cloud provider default. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-class + loadBalancerClass: "" + # -- Enable node port allocation for the internal controller service or not. Applies to type `LoadBalancer` only. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-nodeport-allocation + # allocateLoadBalancerNodePorts: true + + # -- External traffic policy of the internal controller service. Set to "Local" to preserve source IP on providers supporting it. + # Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip + externalTrafficPolicy: "" + # -- Session affinity of the internal controller service. Must be either "None" or "ClientIP" if set. Defaults to "None". + # Ref: https://kubernetes.io/docs/reference/networking/virtual-ips/#session-affinity + sessionAffinity: "" + # -- Specifies the health check node port (numeric port number) for the internal controller service. + # If not specified, the service controller allocates a port from your cluster's node port range. + # Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip + # healthCheckNodePort: 0 + + # -- Represents the dual-stack capabilities of the internal controller service. Possible values are SingleStack, PreferDualStack or RequireDualStack. + # Fields `ipFamilies` and `clusterIP` depend on the value of this field. + # Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services + ipFamilyPolicy: SingleStack + # -- List of IP families (e.g. IPv4, IPv6) assigned to the internal controller service. This field is usually assigned automatically based on cluster configuration and the `ipFamilyPolicy` field. + # Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services + ipFamilies: + - IPv4 + ports: {} + # -- Port the internal HTTP listener is published with. + # Defaults to the value of `controller.service.ports.http`. + # http: 80 + # -- Port the internal HTTPS listener is published with. + # Defaults to the value of `controller.service.ports.https`. + # https: 443 + + targetPorts: {} + # -- Port of the ingress controller the internal HTTP listener is mapped to. + # Defaults to the value of `controller.service.targetPorts.http`. + # http: http + # -- Port of the ingress controller the internal HTTPS listener is mapped to. + # Defaults to the value of `controller.service.targetPorts.https`. + # https: https + + # -- Declare the app protocol of the internal HTTP and HTTPS listeners or not. Supersedes provider-specific annotations for declaring the backend protocol. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#application-protocol + appProtocol: true + nodePorts: + # -- Node port allocated for the internal HTTP listener. If left empty, the service controller allocates one from the configured node port range. + http: "" + # -- Node port allocated for the internal HTTPS listener. If left empty, the service controller allocates one from the configured node port range. + https: "" + # -- Node port mapping for internal TCP listeners. If left empty, the service controller allocates them from the configured node port range. + # Example: + # tcp: + # 8080: 30080 + tcp: {} + # -- Node port mapping for internal UDP listeners. If left empty, the service controller allocates them from the configured node port range. + # Example: + # udp: + # 53: 30053 + udp: {} + # shareProcessNamespace enables process namespace sharing within the pod. + # This can be used for example to signal log rotation using `kill -USR1` from a sidecar. + shareProcessNamespace: false + # -- Additional containers to be added to the controller pod. + # See https://github.com/lemonldap-ng-controller/lemonldap-ng-controller as example. + extraContainers: [] + # - name: my-sidecar + # image: nginx:latest + # - name: lemonldap-ng-controller + # image: lemonldapng/lemonldap-ng-controller:0.2.0 + # args: + # - /lemonldap-ng-controller + # - --alsologtostderr + # - --configmap=$(POD_NAMESPACE)/lemonldap-ng-configuration + # env: + # - name: POD_NAME + # valueFrom: + # fieldRef: + # fieldPath: metadata.name + # - name: POD_NAMESPACE + # valueFrom: + # fieldRef: + # fieldPath: metadata.namespace + # volumeMounts: + # - name: copy-portal-skins + # mountPath: /srv/var/lib/lemonldap-ng/portal/skins + + # -- Additional volumeMounts to the controller main container. + extraVolumeMounts: [] + # - name: copy-portal-skins + # mountPath: /var/lib/lemonldap-ng/portal/skins + + # -- Additional volumes to the controller pod. + extraVolumes: [] + # - name: copy-portal-skins + # emptyDir: {} + + # -- Containers, which are run before the app containers are started. + extraInitContainers: [] + # - name: init-myservice + # image: busybox + # command: ['sh', '-c', 'until nslookup myservice; do echo waiting for myservice; sleep 2; done;'] + + # -- Modules, which are mounted into the core nginx image. See values.yaml for a sample to add opentelemetry module + extraModules: [] + # - name: mytestmodule + # image: + # registry: registry.k8s.io + # image: ingress-nginx/mytestmodule + # ## for backwards compatibility consider setting the full image url via the repository value below + # ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail + # ## repository: + # tag: "v1.0.0" + # digest: "" + # distroless: false + # containerSecurityContext: + # runAsNonRoot: true + # runAsUser: + # allowPrivilegeEscalation: false + # seccompProfile: + # type: RuntimeDefault + # capabilities: + # drop: + # - ALL + # readOnlyRootFilesystem: true + # resources: {} + # + # The image must contain a `/usr/local/bin/init_module.sh` executable, which + # will be executed as initContainers, to move its config files within the + # mounted volume. + + opentelemetry: + enabled: false + name: opentelemetry + image: + registry: registry.k8s.io + image: ingress-nginx/opentelemetry-1.25.3 + ## for backwards compatibility consider setting the full image url via the repository value below + ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail + ## repository: + tag: v20240813-b933310d + digest: sha256:f7604ac0547ed64d79b98d92133234e66c2c8aade3c1f4809fed5eec1fb7f922 + distroless: true + containerSecurityContext: + runAsNonRoot: true + # -- The image's default user, inherited from its base image `cgr.dev/chainguard/static`. + runAsUser: 65532 + allowPrivilegeEscalation: false + seccompProfile: + type: RuntimeDefault + capabilities: + drop: + - ALL + readOnlyRootFilesystem: true + resources: {} + admissionWebhooks: + name: admission + annotations: {} + # ignore-check.kube-linter.io/no-read-only-rootfs: "This deployment needs write access to root filesystem". + + ## Additional annotations to the admission webhooks. + ## These annotations will be added to the ValidatingWebhookConfiguration and + ## the Jobs Spec of the admission webhooks. + enabled: true + # -- Additional environment variables to set + extraEnvs: [] + # extraEnvs: + # - name: FOO + # valueFrom: + # secretKeyRef: + # key: FOO + # name: secret-resource + # -- Admission Webhook failure policy to use + failurePolicy: Fail + # timeoutSeconds: 10 + port: 8443 + certificate: "/usr/local/certificates/cert" + key: "/usr/local/certificates/key" + namespaceSelector: {} + objectSelector: {} + # -- Labels to be added to admission webhooks + labels: {} + # -- Use an existing PSP instead of creating one + existingPsp: "" + service: + annotations: {} + # clusterIP: "" + externalIPs: [] + # loadBalancerIP: "" + loadBalancerSourceRanges: [] + servicePort: 443 + type: ClusterIP + createSecretJob: + name: create + # -- Security context for secret creation containers + securityContext: + runAsNonRoot: true + runAsUser: 65532 + allowPrivilegeEscalation: false + seccompProfile: + type: RuntimeDefault + capabilities: + drop: + - ALL + readOnlyRootFilesystem: true + resources: {} + # limits: + # cpu: 10m + # memory: 20Mi + # requests: + # cpu: 10m + # memory: 20Mi + patchWebhookJob: + name: patch + # -- Security context for webhook patch containers + securityContext: + runAsNonRoot: true + runAsUser: 65532 + allowPrivilegeEscalation: false + seccompProfile: + type: RuntimeDefault + capabilities: + drop: + - ALL + readOnlyRootFilesystem: true + resources: {} + patch: + enabled: true + image: + registry: registry.k8s.io + image: ingress-nginx/kube-webhook-certgen + ## for backwards compatibility consider setting the full image url via the repository value below + ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail + ## repository: + tag: v1.4.4 + digest: sha256:a9f03b34a3cbfbb26d103a14046ab2c5130a80c3d69d526ff8063d2b37b9fd3f + pullPolicy: IfNotPresent + # -- Provide a priority class name to the webhook patching job + ## + priorityClassName: "" + podAnnotations: {} + # NetworkPolicy for webhook patch + networkPolicy: + # -- Enable 'networkPolicy' or not + enabled: false + nodeSelector: + kubernetes.io/os: linux + tolerations: [] + # -- Labels to be added to patch job resources + labels: {} + # -- Security context for secret creation & webhook patch pods + securityContext: {} + # -- Admission webhook patch job RBAC + rbac: + # -- Create RBAC or not + create: true + # -- Admission webhook patch job service account + serviceAccount: + # -- Create a service account or not + create: true + # -- Custom service account name + name: "" + # -- Auto-mount service account token or not + automountServiceAccountToken: true + # Use certmanager to generate webhook certs + certManager: + enabled: false + # self-signed root certificate + rootCert: + # default to be 5y + duration: "" + admissionCert: + # default to be 1y + duration: "" + # issuerRef: + # name: "issuer" + # kind: "ClusterIssuer" + metrics: + port: 10254 + portName: metrics + # if this port is changed, change healthz-port: in extraArgs: accordingly + enabled: false + service: + annotations: {} + # prometheus.io/scrape: "true" + # prometheus.io/port: "10254" + # -- Labels to be added to the metrics service resource + labels: {} + # clusterIP: "" + + # -- List of IP addresses at which the stats-exporter service is available + ## Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips + ## + externalIPs: [] + # loadBalancerIP: "" + loadBalancerSourceRanges: [] + servicePort: 10254 + type: ClusterIP + # externalTrafficPolicy: "" + # nodePort: "" + serviceMonitor: + enabled: false + additionalLabels: {} + # -- Annotations to be added to the ServiceMonitor. + annotations: {} + ## The label to use to retrieve the job name from. + ## jobLabel: "app.kubernetes.io/name" + namespace: "" + namespaceSelector: {} + ## Default: scrape .Release.Namespace or namespaceOverride only + ## To scrape all, use the following: + ## namespaceSelector: + ## any: true + scrapeInterval: 30s + # honorLabels: true + targetLabels: [] + relabelings: [] + metricRelabelings: [] + prometheusRule: + enabled: false + additionalLabels: {} + # namespace: "" + rules: [] + # # These are just examples rules, please adapt them to your needs + # - alert: NGINXConfigFailed + # expr: count(nginx_ingress_controller_config_last_reload_successful == 0) > 0 + # for: 1s + # labels: + # severity: critical + # annotations: + # description: bad ingress config - nginx config test failed + # summary: uninstall the latest ingress changes to allow config reloads to resume + # # By default a fake self-signed certificate is generated as default and + # # it is fine if it expires. If `--default-ssl-certificate` flag is used + # # and a valid certificate passed please do not filter for `host` label! + # # (i.e. delete `{host!="_"}` so also the default SSL certificate is + # # checked for expiration) + # - alert: NGINXCertificateExpiry + # expr: (avg(nginx_ingress_controller_ssl_expire_time_seconds{host!="_"}) by (host) - time()) < 604800 + # for: 1s + # labels: + # severity: critical + # annotations: + # description: ssl certificate(s) will expire in less then a week + # summary: renew expiring certificates to avoid downtime + # - alert: NGINXTooMany500s + # expr: 100 * ( sum( nginx_ingress_controller_requests{status=~"5.+"} ) / sum(nginx_ingress_controller_requests) ) > 5 + # for: 1m + # labels: + # severity: warning + # annotations: + # description: Too many 5XXs + # summary: More than 5% of all requests returned 5XX, this requires your attention + # - alert: NGINXTooMany400s + # expr: 100 * ( sum( nginx_ingress_controller_requests{status=~"4.+"} ) / sum(nginx_ingress_controller_requests) ) > 5 + # for: 1m + # labels: + # severity: warning + # annotations: + # description: Too many 4XXs + # summary: More than 5% of all requests returned 4XX, this requires your attention + # -- Improve connection draining when ingress controller pod is deleted using a lifecycle hook: + # With this new hook, we increased the default terminationGracePeriodSeconds from 30 seconds + # to 300, allowing the draining of connections up to five minutes. + # If the active connections end before that, the pod will terminate gracefully at that time. + # To effectively take advantage of this feature, the Configmap feature + # worker-shutdown-timeout new value is 240s instead of 10s. + ## + lifecycle: + preStop: + exec: + command: + - /wait-shutdown + priorityClassName: "" +# -- Rollback limit +## +revisionHistoryLimit: 10 +## Default 404 backend +## +defaultBackend: + ## + enabled: false + name: defaultbackend + image: + registry: registry.k8s.io + image: defaultbackend-amd64 + ## for backwards compatibility consider setting the full image url via the repository value below + ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail + ## repository: + tag: "1.5" + pullPolicy: IfNotPresent + runAsNonRoot: true + # nobody user -> uid 65534 + runAsUser: 65534 + allowPrivilegeEscalation: false + seccompProfile: + type: RuntimeDefault + readOnlyRootFilesystem: true + # -- Use an existing PSP instead of creating one + existingPsp: "" + extraArgs: {} + serviceAccount: + create: true + name: "" + automountServiceAccountToken: true + # -- Additional environment variables to set for defaultBackend pods + extraEnvs: [] + port: 8080 + ## Readiness and liveness probes for default backend + ## Ref: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-probes/ + ## + livenessProbe: + failureThreshold: 3 + initialDelaySeconds: 30 + periodSeconds: 10 + successThreshold: 1 + timeoutSeconds: 5 + readinessProbe: + failureThreshold: 6 + initialDelaySeconds: 0 + periodSeconds: 5 + successThreshold: 1 + timeoutSeconds: 5 + # -- The update strategy to apply to the Deployment or DaemonSet + ## + updateStrategy: {} + # rollingUpdate: + # maxUnavailable: 1 + # type: RollingUpdate + + # -- `minReadySeconds` to avoid killing pods before we are ready + ## + minReadySeconds: 0 + # -- Node tolerations for server scheduling to nodes with taints + ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/ + ## + tolerations: [] + # - key: "key" + # operator: "Equal|Exists" + # value: "value" + # effect: "NoSchedule|PreferNoSchedule|NoExecute(1.6 only)" + + # -- Affinity and anti-affinity rules for server scheduling to nodes + ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#affinity-and-anti-affinity + affinity: {} + # # An example of preferred pod anti-affinity, weight is in the range 1-100 + # podAntiAffinity: + # preferredDuringSchedulingIgnoredDuringExecution: + # - weight: 100 + # podAffinityTerm: + # labelSelector: + # matchExpressions: + # - key: app.kubernetes.io/name + # operator: In + # values: + # - '{{ include "ingress-nginx.name" . }}' + # - key: app.kubernetes.io/instance + # operator: In + # values: + # - '{{ .Release.Name }}' + # - key: app.kubernetes.io/component + # operator: In + # values: + # - default-backend + # topologyKey: kubernetes.io/hostname + + # # An example of required pod anti-affinity + # podAntiAffinity: + # requiredDuringSchedulingIgnoredDuringExecution: + # - labelSelector: + # matchExpressions: + # - key: app.kubernetes.io/name + # operator: In + # values: + # - '{{ include "ingress-nginx.name" . }}' + # - key: app.kubernetes.io/instance + # operator: In + # values: + # - '{{ .Release.Name }}' + # - key: app.kubernetes.io/component + # operator: In + # values: + # - default-backend + # topologyKey: kubernetes.io/hostname + + # -- Topology spread constraints rely on node labels to identify the topology domain(s) that each Node is in. + # Ref.: https://kubernetes.io/docs/concepts/workloads/pods/pod-topology-spread-constraints/ + topologySpreadConstraints: [] + # - labelSelector: + # matchLabels: + # app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + # app.kubernetes.io/instance: '{{ .Release.Name }}' + # app.kubernetes.io/component: default-backend + # topologyKey: topology.kubernetes.io/zone + # maxSkew: 1 + # whenUnsatisfiable: ScheduleAnyway + # - labelSelector: + # matchLabels: + # app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + # app.kubernetes.io/instance: '{{ .Release.Name }}' + # app.kubernetes.io/component: default-backend + # topologyKey: kubernetes.io/hostname + # maxSkew: 1 + # whenUnsatisfiable: ScheduleAnyway + # -- Security context for default backend pods + podSecurityContext: {} + # -- Security context for default backend containers + containerSecurityContext: {} + # -- Labels to add to the pod container metadata + podLabels: {} + # key: value + + # -- Node labels for default backend pod assignment + ## Ref: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/ + ## + nodeSelector: + kubernetes.io/os: linux + # -- Annotations to be added to default backend pods + ## + podAnnotations: {} + replicaCount: 1 + # -- Minimum available pods set in PodDisruptionBudget. + minAvailable: 1 + resources: {} + # limits: + # cpu: 10m + # memory: 20Mi + # requests: + # cpu: 10m + # memory: 20Mi + + extraVolumeMounts: [] + ## Additional volumeMounts to the default backend container. + # - name: copy-portal-skins + # mountPath: /var/lib/lemonldap-ng/portal/skins + + extraVolumes: [] + ## Additional volumes to the default backend pod. + # - name: copy-portal-skins + # emptyDir: {} + + extraConfigMaps: [] + ## Additional configmaps to the default backend pod. + # - name: my-extra-configmap-1 + # labels: + # type: config-1 + # data: + # extra_file_1.html: | + # + # - name: my-extra-configmap-2 + # labels: + # type: config-2 + # data: + # extra_file_2.html: | + # + + autoscaling: + annotations: {} + enabled: false + minReplicas: 1 + maxReplicas: 2 + targetCPUUtilizationPercentage: 50 + targetMemoryUtilizationPercentage: 50 + # NetworkPolicy for default backend component. + networkPolicy: + # -- Enable 'networkPolicy' or not + enabled: false + service: + annotations: {} + # clusterIP: "" + + # -- List of IP addresses at which the default backend service is available + ## Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips + ## + externalIPs: [] + # loadBalancerIP: "" + loadBalancerSourceRanges: [] + servicePort: 80 + type: ClusterIP + priorityClassName: "" + # -- Labels to be added to the default backend resources + labels: {} +## Enable RBAC as per https://github.com/kubernetes/ingress-nginx/blob/main/docs/deploy/rbac.md and https://github.com/kubernetes/ingress-nginx/issues/266 +rbac: + create: true + scope: false +## If true, create & use Pod Security Policy resources +## https://kubernetes.io/docs/concepts/policy/pod-security-policy/ +podSecurityPolicy: + enabled: false +serviceAccount: + create: true + name: "" + automountServiceAccountToken: true + # -- Annotations for the controller service account + annotations: {} +# -- Optional array of imagePullSecrets containing private registry credentials +## Ref: https://kubernetes.io/docs/tasks/configure-pod-container/pull-image-private-registry/ +imagePullSecrets: [] +# - name: secretName + +# -- TCP service key-value pairs +## Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/exposing-tcp-udp-services.md +## +tcp: {} +# "8080": "default/example-tcp-svc:9000" + +# -- UDP service key-value pairs +## Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/exposing-tcp-udp-services.md +## +udp: {} +# "53": "kube-system/kube-dns:53" + +# -- Prefix for TCP and UDP ports names in ingress controller service +## Some cloud providers, like Yandex Cloud may have a requirements for a port name regex to support cloud load balancer integration +portNamePrefix: "" +# -- (string) A base64-encoded Diffie-Hellman parameter. +# This can be generated with: `openssl dhparam 4096 2> /dev/null | base64` +## Ref: https://github.com/kubernetes/ingress-nginx/tree/main/docs/examples/customization/ssl-dh-param +dhParam: "" diff --git a/charts/keep/t b/charts/keep/t new file mode 100644 index 0000000..3ad03f5 --- /dev/null +++ b/charts/keep/t @@ -0,0 +1,1308 @@ +--- +# Source: keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml +apiVersion: v1 +kind: ServiceAccount +metadata: + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: controller + name: keep-ingress-nginx + namespace: keep +automountServiceAccountToken: true +--- +# Source: keep/templates/serviceaccount.yaml +apiVersion: v1 +kind: ServiceAccount +metadata: + name: keep + labels: + helm.sh/chart: keep-0.1.25 + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "0.26.1" + app.kubernetes.io/managed-by: Helm +--- +# Source: keep/charts/ingress-nginx/templates/controller-configmap.yaml +apiVersion: v1 +kind: ConfigMap +metadata: + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: controller + name: keep-ingress-nginx-controller + namespace: keep +data: + allow-snippet-annotations: "false" +--- +# Source: keep/templates/db-pv.yaml +apiVersion: v1 +kind: PersistentVolume +metadata: + name: keep-pv +spec: + capacity: + storage: 5Gi + accessModes: + - ReadWriteOnce + persistentVolumeReclaimPolicy: Retain + storageClassName: + hostPath: + path: "/var/lib/mysql" +--- +# Source: keep/templates/db-pvc.yaml +apiVersion: v1 +kind: PersistentVolumeClaim +metadata: + name: keep-pvc +spec: + accessModes: + - ReadWriteOnce + # Define new PVC spec + resources: + requests: + storage: 5Gi +--- +# Source: keep/charts/ingress-nginx/templates/clusterrole.yaml +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + name: keep-ingress-nginx +rules: + - apiGroups: + - "" + resources: + - configmaps + - endpoints + - nodes + - pods + - secrets + - namespaces + verbs: + - list + - watch + - apiGroups: + - coordination.k8s.io + resources: + - leases + verbs: + - list + - watch + - apiGroups: + - "" + resources: + - nodes + verbs: + - get + - apiGroups: + - "" + resources: + - services + verbs: + - get + - list + - watch + - apiGroups: + - networking.k8s.io + resources: + - ingresses + verbs: + - get + - list + - watch + - apiGroups: + - "" + resources: + - events + verbs: + - create + - patch + - apiGroups: + - networking.k8s.io + resources: + - ingresses/status + verbs: + - update + - apiGroups: + - networking.k8s.io + resources: + - ingressclasses + verbs: + - get + - list + - watch + - apiGroups: + - discovery.k8s.io + resources: + - endpointslices + verbs: + - list + - watch + - get +--- +# Source: keep/charts/ingress-nginx/templates/clusterrolebinding.yaml +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + name: keep-ingress-nginx +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: keep-ingress-nginx +subjects: + - kind: ServiceAccount + name: keep-ingress-nginx + namespace: keep +--- +# Source: keep/charts/ingress-nginx/templates/controller-role.yaml +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: controller + name: keep-ingress-nginx + namespace: keep +rules: + - apiGroups: + - "" + resources: + - namespaces + verbs: + - get + - apiGroups: + - "" + resources: + - configmaps + - pods + - secrets + - endpoints + verbs: + - get + - list + - watch + - apiGroups: + - "" + resources: + - services + verbs: + - get + - list + - watch + - apiGroups: + - networking.k8s.io + resources: + - ingresses + verbs: + - get + - list + - watch + # Omit Ingress status permissions if `--update-status` is disabled. + - apiGroups: + - networking.k8s.io + resources: + - ingresses/status + verbs: + - update + - apiGroups: + - networking.k8s.io + resources: + - ingressclasses + verbs: + - get + - list + - watch + - apiGroups: + - coordination.k8s.io + resources: + - leases + resourceNames: + - keep-ingress-nginx-leader + verbs: + - get + - update + - apiGroups: + - coordination.k8s.io + resources: + - leases + verbs: + - create + - apiGroups: + - "" + resources: + - events + verbs: + - create + - patch + - apiGroups: + - discovery.k8s.io + resources: + - endpointslices + verbs: + - list + - watch + - get +--- +# Source: keep/templates/role-secret-manager.yaml +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: secret-manager-role + namespace: default +rules: + - apiGroups: [""] + resources: ["secrets"] + verbs: ["create", "delete", "get", "list", "patch"] +--- +# Source: keep/charts/ingress-nginx/templates/controller-rolebinding.yaml +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: controller + name: keep-ingress-nginx + namespace: keep +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: keep-ingress-nginx +subjects: + - kind: ServiceAccount + name: keep-ingress-nginx + namespace: keep +--- +# Source: keep/templates/role-binding-secret-manager.yaml +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: secret-manager-rolebinding + namespace: default +subjects: + - kind: ServiceAccount + name: keep + namespace: default +roleRef: + kind: Role + name: secret-manager-role + apiGroup: rbac.authorization.k8s.io +--- +# Source: keep/charts/ingress-nginx/templates/controller-service-webhook.yaml +apiVersion: v1 +kind: Service +metadata: + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: controller + name: keep-ingress-nginx-controller-admission + namespace: keep +spec: + type: ClusterIP + ports: + - name: https-webhook + port: 443 + targetPort: webhook + appProtocol: https + selector: + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/component: controller +--- +# Source: keep/charts/ingress-nginx/templates/controller-service.yaml +apiVersion: v1 +kind: Service +metadata: + annotations: + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: controller + name: keep-ingress-nginx-controller + namespace: keep +spec: + type: LoadBalancer + ipFamilyPolicy: SingleStack + ipFamilies: + - IPv4 + ports: + - name: http + port: 80 + protocol: TCP + targetPort: http + appProtocol: http + - name: https + port: 443 + protocol: TCP + targetPort: https + appProtocol: https + selector: + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/component: controller +--- +# Source: keep/templates/backend-service.yaml +apiVersion: v1 +kind: Service +metadata: + name: keep-backend + labels: + helm.sh/chart: keep-0.1.25 + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "0.26.1" + app.kubernetes.io/managed-by: Helm + keep-component: backend-service + annotations: + cloud.google.com/backend-config: '{"default": "keep-backend-backendconfig"}' +spec: + type: ClusterIP + ports: + - port: 8080 + targetPort: http + protocol: TCP + name: http + selector: + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + keep-component: backend +--- +# Source: keep/templates/db-service.yaml +apiVersion: v1 +kind: Service +metadata: + name: keep-database + labels: + helm.sh/chart: keep-0.1.25 + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "0.26.1" + app.kubernetes.io/managed-by: Helm + keep-component: database-service +spec: + type: ClusterIP + ports: + - port: 3306 + targetPort: 3306 + protocol: TCP + name: mysql + selector: + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + keep-component: database +--- +# Source: keep/templates/frontend-service.yaml +apiVersion: v1 +kind: Service +metadata: + name: keep-frontend + labels: + helm.sh/chart: keep-0.1.25 + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "0.26.1" + app.kubernetes.io/managed-by: Helm + keep-component: frontend-service + annotations: + cloud.google.com/backend-config: '{"default": "keep-frontend-backendconfig"}' +spec: + type: ClusterIP + ports: + - port: 3000 + targetPort: http + protocol: TCP + name: http + + selector: + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + keep-component: frontend +--- +# Source: keep/templates/websocket-server-service.yaml +apiVersion: v1 +kind: Service +metadata: + name: keep-websocket + labels: + helm.sh/chart: keep-0.1.25 + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "0.26.1" + app.kubernetes.io/managed-by: Helm + keep-component: websocket-service +spec: + type: ClusterIP + ports: + - port: 6001 + targetPort: http + protocol: TCP + name: http + selector: + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + keep-component: websocket +--- +# Source: keep/charts/ingress-nginx/templates/controller-deployment.yaml +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: controller + name: keep-ingress-nginx-controller + namespace: keep +spec: + selector: + matchLabels: + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/component: controller + replicas: 1 + revisionHistoryLimit: 10 + minReadySeconds: 0 + template: + metadata: + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: controller + spec: + dnsPolicy: ClusterFirst + containers: + - name: controller + image: registry.k8s.io/ingress-nginx/controller:v1.11.3@sha256:d56f135b6462cfc476447cfe564b83a45e8bb7da2774963b00d12161112270b7 + imagePullPolicy: IfNotPresent + lifecycle: + preStop: + exec: + command: + - /wait-shutdown + args: + - /nginx-ingress-controller + - --publish-service=$(POD_NAMESPACE)/keep-ingress-nginx-controller + - --election-id=keep-ingress-nginx-leader + - --controller-class=k8s.io/ingress-nginx + - --ingress-class=nginx + - --configmap=$(POD_NAMESPACE)/keep-ingress-nginx-controller + - --validating-webhook=:8443 + - --validating-webhook-certificate=/usr/local/certificates/cert + - --validating-webhook-key=/usr/local/certificates/key + - --enable-metrics=false + securityContext: + runAsNonRoot: true + runAsUser: 101 + allowPrivilegeEscalation: false + seccompProfile: + type: RuntimeDefault + capabilities: + drop: + - ALL + add: + - NET_BIND_SERVICE + readOnlyRootFilesystem: false + env: + - name: POD_NAME + valueFrom: + fieldRef: + fieldPath: metadata.name + - name: POD_NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + - name: LD_PRELOAD + value: /usr/local/lib/libmimalloc.so + livenessProbe: + failureThreshold: 5 + httpGet: + path: /healthz + port: 10254 + scheme: HTTP + initialDelaySeconds: 10 + periodSeconds: 10 + successThreshold: 1 + timeoutSeconds: 1 + readinessProbe: + failureThreshold: 3 + httpGet: + path: /healthz + port: 10254 + scheme: HTTP + initialDelaySeconds: 10 + periodSeconds: 10 + successThreshold: 1 + timeoutSeconds: 1 + ports: + - name: http + containerPort: 80 + protocol: TCP + - name: https + containerPort: 443 + protocol: TCP + - name: webhook + containerPort: 8443 + protocol: TCP + volumeMounts: + - name: webhook-cert + mountPath: /usr/local/certificates/ + readOnly: true + resources: + requests: + cpu: 100m + memory: 90Mi + nodeSelector: + kubernetes.io/os: linux + serviceAccountName: keep-ingress-nginx + terminationGracePeriodSeconds: 300 + volumes: + - name: webhook-cert + secret: + secretName: keep-ingress-nginx-admission +--- +# Source: keep/templates/backend.yaml +apiVersion: apps/v1 +kind: Deployment +metadata: + name: keep-backend + labels: + helm.sh/chart: keep-0.1.25 + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "0.26.1" + app.kubernetes.io/managed-by: Helm + keep-component: backend +spec: + replicas: 1 + selector: + matchLabels: + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + keep-component: backend + template: + metadata: + labels: + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + keep-component: backend + spec: + serviceAccountName: keep + securityContext: + {} + containers: + - name: keep + securityContext: + {} + image: "us-central1-docker.pkg.dev/keephq/keep/keep-api:0.26.1" + imagePullPolicy: Always + ports: + - name: http + containerPort: 8080 + protocol: TCP + env: + - name: DATABASE_CONNECTION_STRING + value: "mysql+pymysql://root@keep-database:3306/keep" + - name: SECRET_MANAGER_TYPE + value: "k8s" + - name: PORT + value: "8080" + - name: PUSHER_APP_ID + value: "1" + - name: PUSHER_APP_KEY + value: "keepappkey" + - name: PUSHER_APP_SECRET + value: "keepappsecret" + - name: PUSHER_HOST + value: "keep-websocket" + - name: PUSHER_PORT + value: "6001" + - name: K8S_NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + volumeMounts: + - name: state-volume + mountPath: /state + readOnly: false + resources: + {} + initContainers: + - name: wait-for-database + image: busybox + command: ['sh', '-c', 'until nc -z keep-database 3306; do sleep 1; done;'] + volumes: + - name: state-volume + emptyDir: {} +--- +# Source: keep/templates/db.yaml +apiVersion: apps/v1 +kind: Deployment +metadata: + name: keep-database + labels: + helm.sh/chart: keep-0.1.25 + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "0.26.1" + app.kubernetes.io/managed-by: Helm + keep-component: database +spec: + replicas: 1 + selector: + matchLabels: + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + keep-component: database + template: + metadata: + labels: + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + keep-component: database + spec: + serviceAccountName: keep + securityContext: + {} + containers: + - name: keep + securityContext: + {} + image: "mysql:latest" + imagePullPolicy: IfNotPresent + ports: + - name: mysql + containerPort: 3306 + protocol: TCP + env: + - name: MYSQL_ALLOW_EMPTY_PASSWORD + value: "true" + - name: MYSQL_DATABASE + value: "keep" + - name: MYSQL_PASSWORD + value: + volumeMounts: + - mountPath: /var/lib/mysql + name: keep-pv + readOnly: false + resources: + {} + volumes: + - name: keep-pv + persistentVolumeClaim: + claimName: keep-pvc +--- +# Source: keep/templates/frontend.yaml +apiVersion: apps/v1 +kind: Deployment +metadata: + name: keep-frontend + labels: + helm.sh/chart: keep-0.1.25 + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "0.26.1" + app.kubernetes.io/managed-by: Helm + keep-component: frontend +spec: + replicas: 1 + selector: + matchLabels: + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + keep-component: frontend + template: + metadata: + labels: + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + keep-component: frontend + spec: + serviceAccountName: keep + securityContext: + {} + containers: + - name: keep + securityContext: + {} + image: "us-central1-docker.pkg.dev/keephq/keep/keep-ui:feature_websocket-improve" + imagePullPolicy: Always + ports: + - name: http + containerPort: 3000 + protocol: TCP + env: + - name: NEXTAUTH_SECRET + value: "secret" + - name: NEXTAUTH_URL + value: "http://localhost:3000" + - name: VERCEL + value: "1" + - name: API_URL + value: "http://keep-backend:8080" + - name: NEXT_PUBLIC_POSTHOG_KEY + value: "phc_muk9qE3TfZsX3SZ9XxX52kCGJBclrjhkP9JxAQcm1PZ" + - name: NEXT_PUBLIC_POSTHOG_HOST + value: "https://app.posthog.com" + - name: ENV + value: "development" + - name: NODE_ENV + value: "development" + - name: HOSTNAME + value: "0.0.0.0" + - name: PUSHER_INGRESS + value: "true" + - name: PUSHER_APP_KEY + value: "keepappkey" + volumeMounts: + - name: state-volume + mountPath: /state + readOnly: false + resources: + {} + volumes: + - name: state-volume + emptyDir: {} +--- +# Source: keep/templates/websocket-server.yaml +apiVersion: apps/v1 +kind: Deployment +metadata: + name: keep-websocket + labels: + helm.sh/chart: keep-0.1.25 + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "0.26.1" + app.kubernetes.io/managed-by: Helm + keep-component: websocket +spec: + replicas: 1 + selector: + matchLabels: + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + keep-component: websocket + template: + metadata: + labels: + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + keep-component: websocket + spec: + serviceAccountName: keep + securityContext: + {} + containers: + - name: keep + securityContext: + {} + image: "quay.io/soketi/soketi:1.4-16-debian" + imagePullPolicy: Always + ports: + - name: http + containerPort: 6001 + protocol: TCP + env: + - name: SOKETI_HOST + value: "0.0.0.0" + - name: SOKETI_DEBUG + value: "1" + - name: SOKETI_USER_AUTHENTICATION_TIMEOUT + value: "3000" + - name: SOKETI_DEFAULT_APP_ID + value: "1" + - name: SOKETI_DEFAULT_APP_KEY + value: "keepappkey" + - name: SOKETI_DEFAULT_APP_SECRET + value: "keepappsecret" + volumeMounts: + - name: state-volume + mountPath: /state + readOnly: false + resources: + {} + volumes: + - name: state-volume + emptyDir: {} +--- +# Source: keep/charts/ingress-nginx/templates/controller-ingressclass.yaml +apiVersion: networking.k8s.io/v1 +kind: IngressClass +metadata: + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: controller + name: nginx +spec: + controller: k8s.io/ingress-nginx +--- +# Source: keep/templates/backend-ingress.yaml +apiVersion: networking.k8s.io/v1 +kind: Ingress +metadata: + name: keep-backend + labels: + helm.sh/chart: keep-0.1.25 + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "0.26.1" + app.kubernetes.io/managed-by: Helm +spec: + rules: + - host: + http: + paths: + - path: / + pathType: Prefix + backend: + service: + name: keep-backend + port: + number: 8080 +--- +# Source: keep/templates/nginx-ingress.yaml +apiVersion: networking.k8s.io/v1 +kind: Ingress +metadata: + name: keep-ingress + labels: + helm.sh/chart: keep-0.1.25 + app.kubernetes.io/name: keep + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "0.26.1" + app.kubernetes.io/managed-by: Helm + annotations: + kubernetes.io/ingress.class: "nginx" + nginx.ingress.kubernetes.io/proxy-read-timeout: "3600" + nginx.ingress.kubernetes.io/proxy-send-timeout: "3600" + nginx.ingress.kubernetes.io/proxy-connect-timeout: "3600" + nginx.ingress.kubernetes.io/proxy-buffering: "off" + nginx.ingress.kubernetes.io/proxy-http-version: "1.1" + nginx.ingress.kubernetes.io/use-http2: "false" + nginx.ingress.kubernetes.io/backend-protocol: "HTTP" + nginx.ingress.kubernetes.io/server-snippets: | + location /app/ { + proxy_pass http://keep-websocket:6001; + proxy_set_header Upgrade $http_upgrade; + proxy_set_header Connection "Upgrade"; + proxy_set_header X-Forwarded-For $remote_addr; + proxy_set_header Host $host; + proxy_cache_bypass $http_upgrade; + } +spec: + ingressClassName: nginx + rules: + - host: + http: + paths: + - path: /app + pathType: Prefix + backend: + service: + name: keep-websocket + port: + number: 6001 + - path: / + pathType: Prefix + backend: + service: + name: keep-frontend + port: + number: 3000 +--- +# Source: keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml +# PDB is not supported for DaemonSets. +# https://github.com/kubernetes/kubernetes/issues/108124 +--- +# Source: keep/templates/gke/backend-gke-healthcheck-config.yaml +apiVersion: cloud.google.com/v1 +kind: BackendConfig +metadata: + name: keep-backend-backendconfig + namespace: keep +spec: + healthCheck: + checkIntervalSec: 30 + timeoutSec: 10 + healthyThreshold: 1 + unhealthyThreshold: 3 + requestPath: /docs + port: 8080 + type: HTTP +--- +# Source: keep/templates/gke/frontend-gke-healthcheck-config.yaml +apiVersion: cloud.google.com/v1 +kind: BackendConfig +metadata: + name: keep-frontend-backendconfig + namespace: keep +spec: + healthCheck: + checkIntervalSec: 30 + timeoutSec: 10 + healthyThreshold: 1 + unhealthyThreshold: 3 + requestPath: /signin + port: 3000 + type: HTTP +--- +# Source: keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml +# before changing this value, check the required kubernetes version +# https://kubernetes.io/docs/reference/access-authn-authz/extensible-admission-controllers/#prerequisites +apiVersion: admissionregistration.k8s.io/v1 +kind: ValidatingWebhookConfiguration +metadata: + annotations: + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: admission-webhook + name: keep-ingress-nginx-admission +webhooks: + - name: validate.nginx.ingress.kubernetes.io + matchPolicy: Equivalent + rules: + - apiGroups: + - networking.k8s.io + apiVersions: + - v1 + operations: + - CREATE + - UPDATE + resources: + - ingresses + failurePolicy: Fail + sideEffects: None + admissionReviewVersions: + - v1 + clientConfig: + service: + name: keep-ingress-nginx-controller-admission + namespace: keep + port: 443 + path: /networking/v1/ingresses +--- +# Source: keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml +apiVersion: v1 +kind: ServiceAccount +metadata: + name: keep-ingress-nginx-admission + namespace: keep + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: admission-webhook +automountServiceAccountToken: true +--- +# Source: keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + name: keep-ingress-nginx-admission + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: admission-webhook +rules: + - apiGroups: + - admissionregistration.k8s.io + resources: + - validatingwebhookconfigurations + verbs: + - get + - update +--- +# Source: keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: keep-ingress-nginx-admission + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: admission-webhook +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: keep-ingress-nginx-admission +subjects: + - kind: ServiceAccount + name: keep-ingress-nginx-admission + namespace: keep +--- +# Source: keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: keep-ingress-nginx-admission + namespace: keep + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: admission-webhook +rules: + - apiGroups: + - "" + resources: + - secrets + verbs: + - get + - create +--- +# Source: keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: keep-ingress-nginx-admission + namespace: keep + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: admission-webhook +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: keep-ingress-nginx-admission +subjects: + - kind: ServiceAccount + name: keep-ingress-nginx-admission + namespace: keep +--- +# Source: keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml +apiVersion: batch/v1 +kind: Job +metadata: + name: keep-ingress-nginx-admission-create + namespace: keep + annotations: + "helm.sh/hook": pre-install,pre-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: admission-webhook +spec: + template: + metadata: + name: keep-ingress-nginx-admission-create + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: admission-webhook + spec: + containers: + - name: create + image: registry.k8s.io/ingress-nginx/kube-webhook-certgen:v1.4.4@sha256:a9f03b34a3cbfbb26d103a14046ab2c5130a80c3d69d526ff8063d2b37b9fd3f + imagePullPolicy: IfNotPresent + args: + - create + - --host=keep-ingress-nginx-controller-admission,keep-ingress-nginx-controller-admission.$(POD_NAMESPACE).svc + - --namespace=$(POD_NAMESPACE) + - --secret-name=keep-ingress-nginx-admission + env: + - name: POD_NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + securityContext: + allowPrivilegeEscalation: false + capabilities: + drop: + - ALL + readOnlyRootFilesystem: true + runAsNonRoot: true + runAsUser: 65532 + seccompProfile: + type: RuntimeDefault + restartPolicy: OnFailure + serviceAccountName: keep-ingress-nginx-admission + nodeSelector: + kubernetes.io/os: linux +--- +# Source: keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml +apiVersion: batch/v1 +kind: Job +metadata: + name: keep-ingress-nginx-admission-patch + namespace: keep + annotations: + "helm.sh/hook": post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: admission-webhook +spec: + template: + metadata: + name: keep-ingress-nginx-admission-patch + labels: + helm.sh/chart: ingress-nginx-4.11.3 + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: keep + app.kubernetes.io/version: "1.11.3" + app.kubernetes.io/part-of: ingress-nginx + app.kubernetes.io/managed-by: Helm + app.kubernetes.io/component: admission-webhook + spec: + containers: + - name: patch + image: registry.k8s.io/ingress-nginx/kube-webhook-certgen:v1.4.4@sha256:a9f03b34a3cbfbb26d103a14046ab2c5130a80c3d69d526ff8063d2b37b9fd3f + imagePullPolicy: IfNotPresent + args: + - patch + - --webhook-name=keep-ingress-nginx-admission + - --namespace=$(POD_NAMESPACE) + - --patch-mutating=false + - --secret-name=keep-ingress-nginx-admission + - --patch-failure-policy=Fail + env: + - name: POD_NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + securityContext: + allowPrivilegeEscalation: false + capabilities: + drop: + - ALL + readOnlyRootFilesystem: true + runAsNonRoot: true + runAsUser: 65532 + seccompProfile: + type: RuntimeDefault + restartPolicy: OnFailure + serviceAccountName: keep-ingress-nginx-admission + nodeSelector: + kubernetes.io/os: linux +--- +# Source: keep/templates/delete-secret-job.yaml +apiVersion: batch/v1 +kind: Job +metadata: + name: delete-keep-secrets + annotations: + "helm.sh/hook": pre-delete + "helm.sh/hook-delete-policy": hook-succeeded,hook-failed +spec: + template: + spec: + serviceAccountName: keep + containers: + - name: delete-secrets-container + image: bitnami/kubectl + command: + - /bin/sh + - -c + - > + secrets=$(kubectl get secrets -n -o name | grep '^secret/keep-'); + if [ -n "$secrets" ]; then + echo "$secrets" | xargs kubectl delete -n ; + else + echo "No matching secrets found to delete."; + fi + restartPolicy: Never diff --git a/charts/keep/templates/db-pvc.yaml b/charts/keep/templates/db-pvc.yaml index 6ab6274..0c5b2dd 100644 --- a/charts/keep/templates/db-pvc.yaml +++ b/charts/keep/templates/db-pvc.yaml @@ -1,13 +1,24 @@ -{{- if and .Values.database.enabled .Values.database.pvc.enabled -}} +{{- if and .Values.database.enabled .Values.database.pvc.enabled -}} +{{- $fullName := include "keep.fullname" . -}} +{{- $pvcName := printf "%s-pvc" $fullName -}} +{{- $existingPvc := lookup "v1" "PersistentVolumeClaim" .Release.Namespace $pvcName -}} apiVersion: v1 kind: PersistentVolumeClaim metadata: - name: {{ include "keep.fullname" . }}-pvc + name: {{ $pvcName }} spec: accessModes: - ReadWriteOnce + {{- if $existingPvc }} + # Use existing PVC spec + {{- toYaml $existingPvc.spec | nindent 2 }} + {{- else }} + # Define new PVC spec + {{- if .Values.database.pvc.storageClass }} storageClassName: {{ .Values.database.pvc.storageClass }} + {{- end }} resources: requests: storage: {{ .Values.database.pvc.size }} + {{- end }} {{- end }} \ No newline at end of file diff --git a/charts/keep/templates/frontend-ingress.yaml b/charts/keep/templates/frontend-ingress.yaml deleted file mode 100644 index c113f3f..0000000 --- a/charts/keep/templates/frontend-ingress.yaml +++ /dev/null @@ -1,64 +0,0 @@ -{{- if and .Values.frontend.enabled .Values.frontend.ingress.enabled -}} -{{- $fullName := include "keep.fullname" . -}} -{{- $svcPort := .Values.frontend.service.port -}} -{{- if and .Values.frontend.ingress.className (not (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion)) }} - {{- if not (hasKey .Values.frontend.ingress.annotations "kubernetes.io/ingress.class") }} - {{- $_ := set .Values.frontend.ingress.annotations "kubernetes.io/ingress.class" .Values.frontend.ingress.className}} - {{- end }} -{{- end }} -{{- if semverCompare ">=1.19-0" .Capabilities.KubeVersion.GitVersion -}} -apiVersion: networking.k8s.io/v1 -{{- else if semverCompare ">=1.14-0" .Capabilities.KubeVersion.GitVersion -}} -apiVersion: networking.k8s.io/v1beta1 -{{- else -}} -apiVersion: extensions/v1beta1 -{{- end }} -kind: Ingress -metadata: - name: {{ $fullName }}-frontend - labels: - {{- include "keep.labels" . | nindent 4 }} - {{- with .Values.frontend.ingress.annotations }} - annotations: - {{- toYaml . | nindent 4 }} - {{- end }} -spec: - {{- if and .Values.frontend.ingress.className (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion) }} - ingressClassName: {{ .Values.frontend.ingress.className }} - {{- end }} - {{- if .Values.frontend.ingress.tls }} - tls: - {{- range .Values.frontend.ingress.tls }} - - hosts: - {{- range .hosts }} - - {{ . | quote }} - {{- end }} - secretName: {{ .secretName }} - {{- end }} - {{- end }} - rules: - {{- range .Values.frontend.ingress.hosts }} - - host: {{ .host | quote }} - http: - paths: - {{- range .paths }} - - path: {{ .path }} - {{- if and .pathType (semverCompare ">=1.18-0" $.Capabilities.KubeVersion.GitVersion) }} - pathType: {{ .pathType }} - {{- end }} - backend: - {{- if semverCompare ">=1.19-0" $.Capabilities.KubeVersion.GitVersion }} - service: - name: {{ $fullName }}-frontend - port: - number: {{ $svcPort }} - {{- else }} - serviceName: {{ $fullName }}-frontend - servicePort: {{ $svcPort }} - {{- end }} - {{- end }} - {{- end }} - {{- if .Values.frontend.extraIngress -}} - {{ toYaml .Values.frontend.extraIngress | nindent 2 }} - {{- end }} -{{- end }} \ No newline at end of file diff --git a/charts/keep/templates/nginx-ingress.yaml b/charts/keep/templates/nginx-ingress.yaml new file mode 100644 index 0000000..693a706 --- /dev/null +++ b/charts/keep/templates/nginx-ingress.yaml @@ -0,0 +1,88 @@ +{{- if and .Values.frontend.enabled .Values.frontend.ingress.enabled }} +{{- $fullName := include "keep.fullname" . }} +{{- $frontendPort := .Values.frontend.service.port }} +{{- $websocketPort := .Values.websocket.service.port }} + +apiVersion: networking.k8s.io/v1 +kind: Ingress +metadata: + name: {{ $fullName }}-ingress + labels: + {{- include "keep.labels" . | nindent 4 }} + annotations: + kubernetes.io/ingress.class: "nginx" + nginx.ingress.kubernetes.io/proxy-read-timeout: "3600" + nginx.ingress.kubernetes.io/proxy-send-timeout: "3600" + nginx.ingress.kubernetes.io/proxy-connect-timeout: "3600" + nginx.ingress.kubernetes.io/proxy-buffering: "off" + nginx.ingress.kubernetes.io/proxy-http-version: "1.1" + nginx.ingress.kubernetes.io/use-http2: "false" + nginx.ingress.kubernetes.io/backend-protocol: "HTTP" + nginx.ingress.kubernetes.io/server-snippets: | + location /app/ { + proxy_pass http://{{ $fullName }}-websocket:6001; + proxy_set_header Upgrade $http_upgrade; + proxy_set_header Connection "Upgrade"; + proxy_set_header X-Forwarded-For $remote_addr; + proxy_set_header Host $host; + proxy_cache_bypass $http_upgrade; + } + {{- with .Values.frontend.ingress.annotations }} + {{- toYaml . | nindent 4 }} + {{- end }} +spec: + ingressClassName: nginx + {{- if .Values.frontend.ingress.tls }} + tls: + {{- range .Values.frontend.ingress.tls }} + - hosts: + {{- range .hosts }} + - {{ . | quote }} + {{- end }} + secretName: {{ .secretName }} + {{- end }} + {{- end }} + rules: + {{- if .Values.frontend.ingress.hosts }} + {{- range .Values.frontend.ingress.hosts }} + - host: {{ .host | quote }} + http: + paths: + {{- if and $.Values.websocket.enabled $websocketPort }} + - path: /app + pathType: Prefix + backend: + service: + name: {{ $fullName }}-websocket + port: + number: {{ $websocketPort }} + {{- end }} + - path: / + pathType: Prefix + backend: + service: + name: {{ $fullName }}-frontend + port: + number: {{ $frontendPort }} + {{- end }} + {{- else }} + - http: + paths: + {{- if and $.Values.websocket.enabled $websocketPort }} + - path: /app + pathType: Prefix + backend: + service: + name: {{ $fullName }}-websocket + port: + number: {{ $websocketPort }} + {{- end }} + - path: / + pathType: Prefix + backend: + service: + name: {{ $fullName }}-frontend + port: + number: {{ $frontendPort }} + {{- end }} +{{- end }} \ No newline at end of file diff --git a/charts/keep/values.yaml b/charts/keep/values.yaml index 280b1ce..22c838b 100644 --- a/charts/keep/values.yaml +++ b/charts/keep/values.yaml @@ -6,6 +6,19 @@ serviceAccount: nameOverride: "" fullnameOverride: "" isGKE: false +ingress-nginx: + enabled: true + controller: + nameOverride: keep-ingress-nginx + fullnameOverride: keep-ingress-nginx + service: + enabled: true + type: LoadBalancer + annotations: {} + ports: + http: 80 + https: 443 + backend: # if true, the backend will be enabled @@ -123,16 +136,15 @@ frontend: value: development - name: HOSTNAME value: 0.0.0.0 - - name: PUSHER_HOST - value: keep-websocket.default.svc.cluster.local - - name: PUSHER_PORT - value: 6001 + - name: PUSHER_INGRESS + value: true - name: PUSHER_APP_KEY value: "keepappkey" replicaCount: 1 image: repository: us-central1-docker.pkg.dev/keephq/keep/keep-ui pullPolicy: Always + tag: "feature_websocket-improve" imagePullSecrets: [] serviceAccount: create: true @@ -146,7 +158,7 @@ frontend: port: 3000 ingress: enabled: true - className: "" + className: "nginx" annotations: {} hosts: - paths: @@ -194,6 +206,10 @@ frontend: websocket: enabled: true env: + - name: SOKETI_HOST + value: "0.0.0.0" + - name: SOKETI_DEBUG + value: "1" - name: SOKETI_USER_AUTHENTICATION_TIMEOUT value: 3000 - name: SOKETI_DEFAULT_APP_ID diff --git a/concat.sh b/concat.sh new file mode 100755 index 0000000..5ad3b85 --- /dev/null +++ b/concat.sh @@ -0,0 +1,31 @@ +#!/bin/bash + +# Usage: ./concat_files_recursive.sh +# Example: ./concat_files_recursive.sh ./my_directory combined_output.txt + +# Check if the correct number of arguments is provided +if [ $# -ne 2 ]; then + echo "Usage: $0 " + exit 1 +fi + +# Assign arguments to variables for readability +DIRECTORY=$1 +OUTPUT_FILE=$2 + +# Check if the directory exists +if [ ! -d "$DIRECTORY" ]; then + echo "Error: Directory $DIRECTORY does not exist." + exit 1 +fi + +# Create or clear the output file +> "$OUTPUT_FILE" + +# Find and concatenate all files recursively +find "$DIRECTORY" -type f | while read -r file; do + echo "Adding $file to $OUTPUT_FILE" + cat "$file" >> "$OUTPUT_FILE" +done + +echo "All files have been recursively concatenated into $OUTPUT_FILE." From e334b96ad16ea2fd33218faccf711c50d2a6bb38 Mon Sep 17 00:00:00 2001 From: shahargl Date: Sun, 20 Oct 2024 21:23:25 +0300 Subject: [PATCH 02/19] feat: wip --- charts/keep/t | 1308 ---------------------- charts/keep/templates/_helpers.tpl | 60 + charts/keep/templates/frontend.yaml | 12 +- charts/keep/templates/nginx-ingress.yaml | 39 +- charts/keep/values.yaml | 23 +- 5 files changed, 115 insertions(+), 1327 deletions(-) delete mode 100644 charts/keep/t diff --git a/charts/keep/t b/charts/keep/t deleted file mode 100644 index 3ad03f5..0000000 --- a/charts/keep/t +++ /dev/null @@ -1,1308 +0,0 @@ ---- -# Source: keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml -apiVersion: v1 -kind: ServiceAccount -metadata: - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: controller - name: keep-ingress-nginx - namespace: keep -automountServiceAccountToken: true ---- -# Source: keep/templates/serviceaccount.yaml -apiVersion: v1 -kind: ServiceAccount -metadata: - name: keep - labels: - helm.sh/chart: keep-0.1.25 - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "0.26.1" - app.kubernetes.io/managed-by: Helm ---- -# Source: keep/charts/ingress-nginx/templates/controller-configmap.yaml -apiVersion: v1 -kind: ConfigMap -metadata: - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: controller - name: keep-ingress-nginx-controller - namespace: keep -data: - allow-snippet-annotations: "false" ---- -# Source: keep/templates/db-pv.yaml -apiVersion: v1 -kind: PersistentVolume -metadata: - name: keep-pv -spec: - capacity: - storage: 5Gi - accessModes: - - ReadWriteOnce - persistentVolumeReclaimPolicy: Retain - storageClassName: - hostPath: - path: "/var/lib/mysql" ---- -# Source: keep/templates/db-pvc.yaml -apiVersion: v1 -kind: PersistentVolumeClaim -metadata: - name: keep-pvc -spec: - accessModes: - - ReadWriteOnce - # Define new PVC spec - resources: - requests: - storage: 5Gi ---- -# Source: keep/charts/ingress-nginx/templates/clusterrole.yaml -apiVersion: rbac.authorization.k8s.io/v1 -kind: ClusterRole -metadata: - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - name: keep-ingress-nginx -rules: - - apiGroups: - - "" - resources: - - configmaps - - endpoints - - nodes - - pods - - secrets - - namespaces - verbs: - - list - - watch - - apiGroups: - - coordination.k8s.io - resources: - - leases - verbs: - - list - - watch - - apiGroups: - - "" - resources: - - nodes - verbs: - - get - - apiGroups: - - "" - resources: - - services - verbs: - - get - - list - - watch - - apiGroups: - - networking.k8s.io - resources: - - ingresses - verbs: - - get - - list - - watch - - apiGroups: - - "" - resources: - - events - verbs: - - create - - patch - - apiGroups: - - networking.k8s.io - resources: - - ingresses/status - verbs: - - update - - apiGroups: - - networking.k8s.io - resources: - - ingressclasses - verbs: - - get - - list - - watch - - apiGroups: - - discovery.k8s.io - resources: - - endpointslices - verbs: - - list - - watch - - get ---- -# Source: keep/charts/ingress-nginx/templates/clusterrolebinding.yaml -apiVersion: rbac.authorization.k8s.io/v1 -kind: ClusterRoleBinding -metadata: - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - name: keep-ingress-nginx -roleRef: - apiGroup: rbac.authorization.k8s.io - kind: ClusterRole - name: keep-ingress-nginx -subjects: - - kind: ServiceAccount - name: keep-ingress-nginx - namespace: keep ---- -# Source: keep/charts/ingress-nginx/templates/controller-role.yaml -apiVersion: rbac.authorization.k8s.io/v1 -kind: Role -metadata: - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: controller - name: keep-ingress-nginx - namespace: keep -rules: - - apiGroups: - - "" - resources: - - namespaces - verbs: - - get - - apiGroups: - - "" - resources: - - configmaps - - pods - - secrets - - endpoints - verbs: - - get - - list - - watch - - apiGroups: - - "" - resources: - - services - verbs: - - get - - list - - watch - - apiGroups: - - networking.k8s.io - resources: - - ingresses - verbs: - - get - - list - - watch - # Omit Ingress status permissions if `--update-status` is disabled. - - apiGroups: - - networking.k8s.io - resources: - - ingresses/status - verbs: - - update - - apiGroups: - - networking.k8s.io - resources: - - ingressclasses - verbs: - - get - - list - - watch - - apiGroups: - - coordination.k8s.io - resources: - - leases - resourceNames: - - keep-ingress-nginx-leader - verbs: - - get - - update - - apiGroups: - - coordination.k8s.io - resources: - - leases - verbs: - - create - - apiGroups: - - "" - resources: - - events - verbs: - - create - - patch - - apiGroups: - - discovery.k8s.io - resources: - - endpointslices - verbs: - - list - - watch - - get ---- -# Source: keep/templates/role-secret-manager.yaml -apiVersion: rbac.authorization.k8s.io/v1 -kind: Role -metadata: - name: secret-manager-role - namespace: default -rules: - - apiGroups: [""] - resources: ["secrets"] - verbs: ["create", "delete", "get", "list", "patch"] ---- -# Source: keep/charts/ingress-nginx/templates/controller-rolebinding.yaml -apiVersion: rbac.authorization.k8s.io/v1 -kind: RoleBinding -metadata: - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: controller - name: keep-ingress-nginx - namespace: keep -roleRef: - apiGroup: rbac.authorization.k8s.io - kind: Role - name: keep-ingress-nginx -subjects: - - kind: ServiceAccount - name: keep-ingress-nginx - namespace: keep ---- -# Source: keep/templates/role-binding-secret-manager.yaml -apiVersion: rbac.authorization.k8s.io/v1 -kind: RoleBinding -metadata: - name: secret-manager-rolebinding - namespace: default -subjects: - - kind: ServiceAccount - name: keep - namespace: default -roleRef: - kind: Role - name: secret-manager-role - apiGroup: rbac.authorization.k8s.io ---- -# Source: keep/charts/ingress-nginx/templates/controller-service-webhook.yaml -apiVersion: v1 -kind: Service -metadata: - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: controller - name: keep-ingress-nginx-controller-admission - namespace: keep -spec: - type: ClusterIP - ports: - - name: https-webhook - port: 443 - targetPort: webhook - appProtocol: https - selector: - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/component: controller ---- -# Source: keep/charts/ingress-nginx/templates/controller-service.yaml -apiVersion: v1 -kind: Service -metadata: - annotations: - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: controller - name: keep-ingress-nginx-controller - namespace: keep -spec: - type: LoadBalancer - ipFamilyPolicy: SingleStack - ipFamilies: - - IPv4 - ports: - - name: http - port: 80 - protocol: TCP - targetPort: http - appProtocol: http - - name: https - port: 443 - protocol: TCP - targetPort: https - appProtocol: https - selector: - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/component: controller ---- -# Source: keep/templates/backend-service.yaml -apiVersion: v1 -kind: Service -metadata: - name: keep-backend - labels: - helm.sh/chart: keep-0.1.25 - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "0.26.1" - app.kubernetes.io/managed-by: Helm - keep-component: backend-service - annotations: - cloud.google.com/backend-config: '{"default": "keep-backend-backendconfig"}' -spec: - type: ClusterIP - ports: - - port: 8080 - targetPort: http - protocol: TCP - name: http - selector: - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - keep-component: backend ---- -# Source: keep/templates/db-service.yaml -apiVersion: v1 -kind: Service -metadata: - name: keep-database - labels: - helm.sh/chart: keep-0.1.25 - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "0.26.1" - app.kubernetes.io/managed-by: Helm - keep-component: database-service -spec: - type: ClusterIP - ports: - - port: 3306 - targetPort: 3306 - protocol: TCP - name: mysql - selector: - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - keep-component: database ---- -# Source: keep/templates/frontend-service.yaml -apiVersion: v1 -kind: Service -metadata: - name: keep-frontend - labels: - helm.sh/chart: keep-0.1.25 - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "0.26.1" - app.kubernetes.io/managed-by: Helm - keep-component: frontend-service - annotations: - cloud.google.com/backend-config: '{"default": "keep-frontend-backendconfig"}' -spec: - type: ClusterIP - ports: - - port: 3000 - targetPort: http - protocol: TCP - name: http - - selector: - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - keep-component: frontend ---- -# Source: keep/templates/websocket-server-service.yaml -apiVersion: v1 -kind: Service -metadata: - name: keep-websocket - labels: - helm.sh/chart: keep-0.1.25 - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "0.26.1" - app.kubernetes.io/managed-by: Helm - keep-component: websocket-service -spec: - type: ClusterIP - ports: - - port: 6001 - targetPort: http - protocol: TCP - name: http - selector: - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - keep-component: websocket ---- -# Source: keep/charts/ingress-nginx/templates/controller-deployment.yaml -apiVersion: apps/v1 -kind: Deployment -metadata: - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: controller - name: keep-ingress-nginx-controller - namespace: keep -spec: - selector: - matchLabels: - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/component: controller - replicas: 1 - revisionHistoryLimit: 10 - minReadySeconds: 0 - template: - metadata: - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: controller - spec: - dnsPolicy: ClusterFirst - containers: - - name: controller - image: registry.k8s.io/ingress-nginx/controller:v1.11.3@sha256:d56f135b6462cfc476447cfe564b83a45e8bb7da2774963b00d12161112270b7 - imagePullPolicy: IfNotPresent - lifecycle: - preStop: - exec: - command: - - /wait-shutdown - args: - - /nginx-ingress-controller - - --publish-service=$(POD_NAMESPACE)/keep-ingress-nginx-controller - - --election-id=keep-ingress-nginx-leader - - --controller-class=k8s.io/ingress-nginx - - --ingress-class=nginx - - --configmap=$(POD_NAMESPACE)/keep-ingress-nginx-controller - - --validating-webhook=:8443 - - --validating-webhook-certificate=/usr/local/certificates/cert - - --validating-webhook-key=/usr/local/certificates/key - - --enable-metrics=false - securityContext: - runAsNonRoot: true - runAsUser: 101 - allowPrivilegeEscalation: false - seccompProfile: - type: RuntimeDefault - capabilities: - drop: - - ALL - add: - - NET_BIND_SERVICE - readOnlyRootFilesystem: false - env: - - name: POD_NAME - valueFrom: - fieldRef: - fieldPath: metadata.name - - name: POD_NAMESPACE - valueFrom: - fieldRef: - fieldPath: metadata.namespace - - name: LD_PRELOAD - value: /usr/local/lib/libmimalloc.so - livenessProbe: - failureThreshold: 5 - httpGet: - path: /healthz - port: 10254 - scheme: HTTP - initialDelaySeconds: 10 - periodSeconds: 10 - successThreshold: 1 - timeoutSeconds: 1 - readinessProbe: - failureThreshold: 3 - httpGet: - path: /healthz - port: 10254 - scheme: HTTP - initialDelaySeconds: 10 - periodSeconds: 10 - successThreshold: 1 - timeoutSeconds: 1 - ports: - - name: http - containerPort: 80 - protocol: TCP - - name: https - containerPort: 443 - protocol: TCP - - name: webhook - containerPort: 8443 - protocol: TCP - volumeMounts: - - name: webhook-cert - mountPath: /usr/local/certificates/ - readOnly: true - resources: - requests: - cpu: 100m - memory: 90Mi - nodeSelector: - kubernetes.io/os: linux - serviceAccountName: keep-ingress-nginx - terminationGracePeriodSeconds: 300 - volumes: - - name: webhook-cert - secret: - secretName: keep-ingress-nginx-admission ---- -# Source: keep/templates/backend.yaml -apiVersion: apps/v1 -kind: Deployment -metadata: - name: keep-backend - labels: - helm.sh/chart: keep-0.1.25 - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "0.26.1" - app.kubernetes.io/managed-by: Helm - keep-component: backend -spec: - replicas: 1 - selector: - matchLabels: - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - keep-component: backend - template: - metadata: - labels: - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - keep-component: backend - spec: - serviceAccountName: keep - securityContext: - {} - containers: - - name: keep - securityContext: - {} - image: "us-central1-docker.pkg.dev/keephq/keep/keep-api:0.26.1" - imagePullPolicy: Always - ports: - - name: http - containerPort: 8080 - protocol: TCP - env: - - name: DATABASE_CONNECTION_STRING - value: "mysql+pymysql://root@keep-database:3306/keep" - - name: SECRET_MANAGER_TYPE - value: "k8s" - - name: PORT - value: "8080" - - name: PUSHER_APP_ID - value: "1" - - name: PUSHER_APP_KEY - value: "keepappkey" - - name: PUSHER_APP_SECRET - value: "keepappsecret" - - name: PUSHER_HOST - value: "keep-websocket" - - name: PUSHER_PORT - value: "6001" - - name: K8S_NAMESPACE - valueFrom: - fieldRef: - fieldPath: metadata.namespace - volumeMounts: - - name: state-volume - mountPath: /state - readOnly: false - resources: - {} - initContainers: - - name: wait-for-database - image: busybox - command: ['sh', '-c', 'until nc -z keep-database 3306; do sleep 1; done;'] - volumes: - - name: state-volume - emptyDir: {} ---- -# Source: keep/templates/db.yaml -apiVersion: apps/v1 -kind: Deployment -metadata: - name: keep-database - labels: - helm.sh/chart: keep-0.1.25 - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "0.26.1" - app.kubernetes.io/managed-by: Helm - keep-component: database -spec: - replicas: 1 - selector: - matchLabels: - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - keep-component: database - template: - metadata: - labels: - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - keep-component: database - spec: - serviceAccountName: keep - securityContext: - {} - containers: - - name: keep - securityContext: - {} - image: "mysql:latest" - imagePullPolicy: IfNotPresent - ports: - - name: mysql - containerPort: 3306 - protocol: TCP - env: - - name: MYSQL_ALLOW_EMPTY_PASSWORD - value: "true" - - name: MYSQL_DATABASE - value: "keep" - - name: MYSQL_PASSWORD - value: - volumeMounts: - - mountPath: /var/lib/mysql - name: keep-pv - readOnly: false - resources: - {} - volumes: - - name: keep-pv - persistentVolumeClaim: - claimName: keep-pvc ---- -# Source: keep/templates/frontend.yaml -apiVersion: apps/v1 -kind: Deployment -metadata: - name: keep-frontend - labels: - helm.sh/chart: keep-0.1.25 - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "0.26.1" - app.kubernetes.io/managed-by: Helm - keep-component: frontend -spec: - replicas: 1 - selector: - matchLabels: - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - keep-component: frontend - template: - metadata: - labels: - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - keep-component: frontend - spec: - serviceAccountName: keep - securityContext: - {} - containers: - - name: keep - securityContext: - {} - image: "us-central1-docker.pkg.dev/keephq/keep/keep-ui:feature_websocket-improve" - imagePullPolicy: Always - ports: - - name: http - containerPort: 3000 - protocol: TCP - env: - - name: NEXTAUTH_SECRET - value: "secret" - - name: NEXTAUTH_URL - value: "http://localhost:3000" - - name: VERCEL - value: "1" - - name: API_URL - value: "http://keep-backend:8080" - - name: NEXT_PUBLIC_POSTHOG_KEY - value: "phc_muk9qE3TfZsX3SZ9XxX52kCGJBclrjhkP9JxAQcm1PZ" - - name: NEXT_PUBLIC_POSTHOG_HOST - value: "https://app.posthog.com" - - name: ENV - value: "development" - - name: NODE_ENV - value: "development" - - name: HOSTNAME - value: "0.0.0.0" - - name: PUSHER_INGRESS - value: "true" - - name: PUSHER_APP_KEY - value: "keepappkey" - volumeMounts: - - name: state-volume - mountPath: /state - readOnly: false - resources: - {} - volumes: - - name: state-volume - emptyDir: {} ---- -# Source: keep/templates/websocket-server.yaml -apiVersion: apps/v1 -kind: Deployment -metadata: - name: keep-websocket - labels: - helm.sh/chart: keep-0.1.25 - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "0.26.1" - app.kubernetes.io/managed-by: Helm - keep-component: websocket -spec: - replicas: 1 - selector: - matchLabels: - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - keep-component: websocket - template: - metadata: - labels: - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - keep-component: websocket - spec: - serviceAccountName: keep - securityContext: - {} - containers: - - name: keep - securityContext: - {} - image: "quay.io/soketi/soketi:1.4-16-debian" - imagePullPolicy: Always - ports: - - name: http - containerPort: 6001 - protocol: TCP - env: - - name: SOKETI_HOST - value: "0.0.0.0" - - name: SOKETI_DEBUG - value: "1" - - name: SOKETI_USER_AUTHENTICATION_TIMEOUT - value: "3000" - - name: SOKETI_DEFAULT_APP_ID - value: "1" - - name: SOKETI_DEFAULT_APP_KEY - value: "keepappkey" - - name: SOKETI_DEFAULT_APP_SECRET - value: "keepappsecret" - volumeMounts: - - name: state-volume - mountPath: /state - readOnly: false - resources: - {} - volumes: - - name: state-volume - emptyDir: {} ---- -# Source: keep/charts/ingress-nginx/templates/controller-ingressclass.yaml -apiVersion: networking.k8s.io/v1 -kind: IngressClass -metadata: - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: controller - name: nginx -spec: - controller: k8s.io/ingress-nginx ---- -# Source: keep/templates/backend-ingress.yaml -apiVersion: networking.k8s.io/v1 -kind: Ingress -metadata: - name: keep-backend - labels: - helm.sh/chart: keep-0.1.25 - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "0.26.1" - app.kubernetes.io/managed-by: Helm -spec: - rules: - - host: - http: - paths: - - path: / - pathType: Prefix - backend: - service: - name: keep-backend - port: - number: 8080 ---- -# Source: keep/templates/nginx-ingress.yaml -apiVersion: networking.k8s.io/v1 -kind: Ingress -metadata: - name: keep-ingress - labels: - helm.sh/chart: keep-0.1.25 - app.kubernetes.io/name: keep - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "0.26.1" - app.kubernetes.io/managed-by: Helm - annotations: - kubernetes.io/ingress.class: "nginx" - nginx.ingress.kubernetes.io/proxy-read-timeout: "3600" - nginx.ingress.kubernetes.io/proxy-send-timeout: "3600" - nginx.ingress.kubernetes.io/proxy-connect-timeout: "3600" - nginx.ingress.kubernetes.io/proxy-buffering: "off" - nginx.ingress.kubernetes.io/proxy-http-version: "1.1" - nginx.ingress.kubernetes.io/use-http2: "false" - nginx.ingress.kubernetes.io/backend-protocol: "HTTP" - nginx.ingress.kubernetes.io/server-snippets: | - location /app/ { - proxy_pass http://keep-websocket:6001; - proxy_set_header Upgrade $http_upgrade; - proxy_set_header Connection "Upgrade"; - proxy_set_header X-Forwarded-For $remote_addr; - proxy_set_header Host $host; - proxy_cache_bypass $http_upgrade; - } -spec: - ingressClassName: nginx - rules: - - host: - http: - paths: - - path: /app - pathType: Prefix - backend: - service: - name: keep-websocket - port: - number: 6001 - - path: / - pathType: Prefix - backend: - service: - name: keep-frontend - port: - number: 3000 ---- -# Source: keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml -# PDB is not supported for DaemonSets. -# https://github.com/kubernetes/kubernetes/issues/108124 ---- -# Source: keep/templates/gke/backend-gke-healthcheck-config.yaml -apiVersion: cloud.google.com/v1 -kind: BackendConfig -metadata: - name: keep-backend-backendconfig - namespace: keep -spec: - healthCheck: - checkIntervalSec: 30 - timeoutSec: 10 - healthyThreshold: 1 - unhealthyThreshold: 3 - requestPath: /docs - port: 8080 - type: HTTP ---- -# Source: keep/templates/gke/frontend-gke-healthcheck-config.yaml -apiVersion: cloud.google.com/v1 -kind: BackendConfig -metadata: - name: keep-frontend-backendconfig - namespace: keep -spec: - healthCheck: - checkIntervalSec: 30 - timeoutSec: 10 - healthyThreshold: 1 - unhealthyThreshold: 3 - requestPath: /signin - port: 3000 - type: HTTP ---- -# Source: keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml -# before changing this value, check the required kubernetes version -# https://kubernetes.io/docs/reference/access-authn-authz/extensible-admission-controllers/#prerequisites -apiVersion: admissionregistration.k8s.io/v1 -kind: ValidatingWebhookConfiguration -metadata: - annotations: - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: admission-webhook - name: keep-ingress-nginx-admission -webhooks: - - name: validate.nginx.ingress.kubernetes.io - matchPolicy: Equivalent - rules: - - apiGroups: - - networking.k8s.io - apiVersions: - - v1 - operations: - - CREATE - - UPDATE - resources: - - ingresses - failurePolicy: Fail - sideEffects: None - admissionReviewVersions: - - v1 - clientConfig: - service: - name: keep-ingress-nginx-controller-admission - namespace: keep - port: 443 - path: /networking/v1/ingresses ---- -# Source: keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml -apiVersion: v1 -kind: ServiceAccount -metadata: - name: keep-ingress-nginx-admission - namespace: keep - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: admission-webhook -automountServiceAccountToken: true ---- -# Source: keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml -apiVersion: rbac.authorization.k8s.io/v1 -kind: ClusterRole -metadata: - name: keep-ingress-nginx-admission - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: admission-webhook -rules: - - apiGroups: - - admissionregistration.k8s.io - resources: - - validatingwebhookconfigurations - verbs: - - get - - update ---- -# Source: keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml -apiVersion: rbac.authorization.k8s.io/v1 -kind: ClusterRoleBinding -metadata: - name: keep-ingress-nginx-admission - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: admission-webhook -roleRef: - apiGroup: rbac.authorization.k8s.io - kind: ClusterRole - name: keep-ingress-nginx-admission -subjects: - - kind: ServiceAccount - name: keep-ingress-nginx-admission - namespace: keep ---- -# Source: keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml -apiVersion: rbac.authorization.k8s.io/v1 -kind: Role -metadata: - name: keep-ingress-nginx-admission - namespace: keep - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: admission-webhook -rules: - - apiGroups: - - "" - resources: - - secrets - verbs: - - get - - create ---- -# Source: keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml -apiVersion: rbac.authorization.k8s.io/v1 -kind: RoleBinding -metadata: - name: keep-ingress-nginx-admission - namespace: keep - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: admission-webhook -roleRef: - apiGroup: rbac.authorization.k8s.io - kind: Role - name: keep-ingress-nginx-admission -subjects: - - kind: ServiceAccount - name: keep-ingress-nginx-admission - namespace: keep ---- -# Source: keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml -apiVersion: batch/v1 -kind: Job -metadata: - name: keep-ingress-nginx-admission-create - namespace: keep - annotations: - "helm.sh/hook": pre-install,pre-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: admission-webhook -spec: - template: - metadata: - name: keep-ingress-nginx-admission-create - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: admission-webhook - spec: - containers: - - name: create - image: registry.k8s.io/ingress-nginx/kube-webhook-certgen:v1.4.4@sha256:a9f03b34a3cbfbb26d103a14046ab2c5130a80c3d69d526ff8063d2b37b9fd3f - imagePullPolicy: IfNotPresent - args: - - create - - --host=keep-ingress-nginx-controller-admission,keep-ingress-nginx-controller-admission.$(POD_NAMESPACE).svc - - --namespace=$(POD_NAMESPACE) - - --secret-name=keep-ingress-nginx-admission - env: - - name: POD_NAMESPACE - valueFrom: - fieldRef: - fieldPath: metadata.namespace - securityContext: - allowPrivilegeEscalation: false - capabilities: - drop: - - ALL - readOnlyRootFilesystem: true - runAsNonRoot: true - runAsUser: 65532 - seccompProfile: - type: RuntimeDefault - restartPolicy: OnFailure - serviceAccountName: keep-ingress-nginx-admission - nodeSelector: - kubernetes.io/os: linux ---- -# Source: keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml -apiVersion: batch/v1 -kind: Job -metadata: - name: keep-ingress-nginx-admission-patch - namespace: keep - annotations: - "helm.sh/hook": post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: admission-webhook -spec: - template: - metadata: - name: keep-ingress-nginx-admission-patch - labels: - helm.sh/chart: ingress-nginx-4.11.3 - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: keep - app.kubernetes.io/version: "1.11.3" - app.kubernetes.io/part-of: ingress-nginx - app.kubernetes.io/managed-by: Helm - app.kubernetes.io/component: admission-webhook - spec: - containers: - - name: patch - image: registry.k8s.io/ingress-nginx/kube-webhook-certgen:v1.4.4@sha256:a9f03b34a3cbfbb26d103a14046ab2c5130a80c3d69d526ff8063d2b37b9fd3f - imagePullPolicy: IfNotPresent - args: - - patch - - --webhook-name=keep-ingress-nginx-admission - - --namespace=$(POD_NAMESPACE) - - --patch-mutating=false - - --secret-name=keep-ingress-nginx-admission - - --patch-failure-policy=Fail - env: - - name: POD_NAMESPACE - valueFrom: - fieldRef: - fieldPath: metadata.namespace - securityContext: - allowPrivilegeEscalation: false - capabilities: - drop: - - ALL - readOnlyRootFilesystem: true - runAsNonRoot: true - runAsUser: 65532 - seccompProfile: - type: RuntimeDefault - restartPolicy: OnFailure - serviceAccountName: keep-ingress-nginx-admission - nodeSelector: - kubernetes.io/os: linux ---- -# Source: keep/templates/delete-secret-job.yaml -apiVersion: batch/v1 -kind: Job -metadata: - name: delete-keep-secrets - annotations: - "helm.sh/hook": pre-delete - "helm.sh/hook-delete-policy": hook-succeeded,hook-failed -spec: - template: - spec: - serviceAccountName: keep - containers: - - name: delete-secrets-container - image: bitnami/kubectl - command: - - /bin/sh - - -c - - > - secrets=$(kubectl get secrets -n -o name | grep '^secret/keep-'); - if [ -n "$secrets" ]; then - echo "$secrets" | xargs kubectl delete -n ; - else - echo "No matching secrets found to delete."; - fi - restartPolicy: Never diff --git a/charts/keep/templates/_helpers.tpl b/charts/keep/templates/_helpers.tpl index a454d76..8e9af09 100644 --- a/charts/keep/templates/_helpers.tpl +++ b/charts/keep/templates/_helpers.tpl @@ -60,3 +60,63 @@ Create the name of the service account to use {{- default "default" .Values.serviceAccount.name }} {{- end }} {{- end }} + +{{/* +Helper function to find an environment variable in the list +*/}} +{{- define "keep.findEnvVar" -}} +{{- $name := index . 0 -}} +{{- $values := index . 1 -}} +{{- if and $values.frontend $values.frontend.env -}} + {{- range $values.frontend.env -}} + {{- if eq .name $name -}} + {{- .value -}} + {{- end -}} + {{- end -}} +{{- end -}} +{{- end -}} + +{{/* +Helper function for websocket host (relative) +*/}} +{{- define "keep.websocketPrefix" -}} +{{- coalesce .Values.websocket.ingress.prefix .Values.global.ingress.websocketPrefix "/websocket" -}} +{{- end -}} + +{{/* +Helper function for backend host (relative) +*/}} +{{- define "keep.backendPrefix" -}} +{{- coalesce .Values.backend.ingress.prefix .Values.global.ingress.backendPrefix "/api" -}} +{{- end -}} + +{{/* +Helper function for frontend host (relative) +*/}} +{{- define "keep.frontendPrefix" -}} +{{- coalesce .Values.frontend.ingress.prefix .Values.global.ingress.frontendPrefix "/" -}} +{{- end -}} + +{{/* +Helper function for PUSHER_HOST +*/}} +{{- define "keep.pusherHost" -}} +{{- $pusherHost := include "keep.findEnvVar" (list "PUSHER_HOST" .) -}} +{{- if $pusherHost -}} + {{- $pusherHost -}} +{{- else -}} + {{- include "keep.websocketPrefix" . -}} +{{- end -}} +{{- end -}} + +{{/* +Helper function for API_URL for the frontend +*/}} +{{- define "keep.apiUrl" -}} +{{- $apiUrl := include "keep.findEnvVar" (list "API_URL" .) -}} +{{- if $apiUrl -}} + {{- $apiUrl -}} +{{- else -}} + {{- include "keep.backendPrefix" . -}} +{{- end -}} +{{- end -}} \ No newline at end of file diff --git a/charts/keep/templates/frontend.yaml b/charts/keep/templates/frontend.yaml index cc2f509..3f599ce 100644 --- a/charts/keep/templates/frontend.yaml +++ b/charts/keep/templates/frontend.yaml @@ -42,10 +42,20 @@ spec: containerPort: {{ .Values.frontend.service.port }} protocol: TCP env: + {{- $pusherHost := include "keep.pusherHost" . -}} + {{- $apiUrl := include "keep.apiUrl" . -}} {{- range .Values.frontend.env }} - name: {{ .name }} value: {{ .value | quote }} {{- end }} + {{- if and $pusherHost (not (include "keep.findEnvVar" (list "PUSHER_HOST" .))) }} + - name: PUSHER_HOST + value: {{ $pusherHost | quote }} + {{- end }} + {{- if and $apiUrl (not (include "keep.findEnvVar" (list "API_URL" .))) }} + - name: API_URL + value: {{ $apiUrl | quote }} + {{- end }} volumeMounts: - name: state-volume mountPath: /state @@ -73,4 +83,4 @@ spec: volumes: - name: state-volume emptyDir: {} -{{- end }} +{{- end }} \ No newline at end of file diff --git a/charts/keep/templates/nginx-ingress.yaml b/charts/keep/templates/nginx-ingress.yaml index 693a706..cbf7262 100644 --- a/charts/keep/templates/nginx-ingress.yaml +++ b/charts/keep/templates/nginx-ingress.yaml @@ -1,6 +1,7 @@ -{{- if and .Values.frontend.enabled .Values.frontend.ingress.enabled }} +{{- if and (or .Values.frontend.enabled .Values.backend.enabled) .Values.frontend.ingress.enabled }} {{- $fullName := include "keep.fullname" . }} {{- $frontendPort := .Values.frontend.service.port }} +{{- $backendPort := .Values.backend.service.port }} {{- $websocketPort := .Values.websocket.service.port }} apiVersion: networking.k8s.io/v1 @@ -19,8 +20,8 @@ metadata: nginx.ingress.kubernetes.io/use-http2: "false" nginx.ingress.kubernetes.io/backend-protocol: "HTTP" nginx.ingress.kubernetes.io/server-snippets: | - location /app/ { - proxy_pass http://{{ $fullName }}-websocket:6001; + location {{ include "keep.websocketPrefix" . }}/ { + proxy_pass http://{{ $fullName }}-websocket:{{ .Values.websocket.service.port }}; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "Upgrade"; proxy_set_header X-Forwarded-For $remote_addr; @@ -43,13 +44,13 @@ spec: {{- end }} {{- end }} rules: - {{- if .Values.frontend.ingress.hosts }} - {{- range .Values.frontend.ingress.hosts }} - - host: {{ .host | quote }} + {{- if or .Values.frontend.ingress.hosts .Values.backend.ingress.hosts }} + {{- range $host := (concat .Values.frontend.ingress.hosts .Values.backend.ingress.hosts) }} + - host: {{ $host | quote }} http: paths: {{- if and $.Values.websocket.enabled $websocketPort }} - - path: /app + - path: {{ include "keep.websocketPrefix" $ }} pathType: Prefix backend: service: @@ -57,19 +58,28 @@ spec: port: number: {{ $websocketPort }} {{- end }} - - path: / + - path: {{ include "keep.frontendPrefix" $ }} pathType: Prefix backend: service: name: {{ $fullName }}-frontend port: number: {{ $frontendPort }} + {{- if and $.Values.backend $.Values.backend.enabled }} + - path: {{ include "keep.backendPrefix" $ }} + pathType: Prefix + backend: + service: + name: {{ $fullName }}-backend + port: + number: {{ $backendPort }} + {{- end }} {{- end }} {{- else }} - http: paths: {{- if and $.Values.websocket.enabled $websocketPort }} - - path: /app + - path: {{ include "keep.websocketPrefix" . }} pathType: Prefix backend: service: @@ -77,12 +87,21 @@ spec: port: number: {{ $websocketPort }} {{- end }} - - path: / + - path: {{ include "keep.frontendPrefix" . }} pathType: Prefix backend: service: name: {{ $fullName }}-frontend port: number: {{ $frontendPort }} + {{- if and $.Values.backend $.Values.backend.enabled }} + - path: {{ include "keep.backendPrefix" . }} + pathType: Prefix + backend: + service: + name: {{ $fullName }}-backend + port: + number: {{ $backendPort }} + {{- end }} {{- end }} {{- end }} \ No newline at end of file diff --git a/charts/keep/values.yaml b/charts/keep/values.yaml index 22c838b..925a706 100644 --- a/charts/keep/values.yaml +++ b/charts/keep/values.yaml @@ -6,6 +6,13 @@ serviceAccount: nameOverride: "" fullnameOverride: "" isGKE: false + +global: + ingress: + websocketPrefix: "/websocket" + backendPrefix: "/api" + frontendPrefix: "/" + ingress-nginx: enabled: true controller: @@ -18,6 +25,14 @@ ingress-nginx: ports: http: 80 https: 443 + admissionWebhooks: + failurePolicy: Ignore + patch: + enabled: true + image: + pullPolicy: IfNotPresent + certManager: + enabled: false backend: @@ -124,20 +139,12 @@ frontend: # https://github.com/nextauthjs/next-auth/issues/600 - name: VERCEL value: 1 - - name: API_URL - value: http://keep-backend:8080 - - name: NEXT_PUBLIC_POSTHOG_KEY - value: "phc_muk9qE3TfZsX3SZ9XxX52kCGJBclrjhkP9JxAQcm1PZ" - - name: NEXT_PUBLIC_POSTHOG_HOST - value: https://app.posthog.com - name: ENV value: development - name: NODE_ENV value: development - name: HOSTNAME value: 0.0.0.0 - - name: PUSHER_INGRESS - value: true - name: PUSHER_APP_KEY value: "keepappkey" replicaCount: 1 From 6dfdaecab67671c84e0b4595719d9979d7401ff9 Mon Sep 17 00:00:00 2001 From: shahargl Date: Sun, 20 Oct 2024 21:24:19 +0300 Subject: [PATCH 03/19] feat: wip --- charts/keep/charts/ingress-nginx/.helmignore | 23 - charts/keep/charts/ingress-nginx/Chart.yaml | 25 - charts/keep/charts/ingress-nginx/OWNERS | 10 - charts/keep/charts/ingress-nginx/README.md | 559 -------- .../charts/ingress-nginx/README.md.gotmpl | 229 ---- .../changelog/helm-chart-2.10.0.md | 9 - .../changelog/helm-chart-2.11.0.md | 10 - .../changelog/helm-chart-2.11.1.md | 9 - .../changelog/helm-chart-2.11.2.md | 9 - .../changelog/helm-chart-2.11.3.md | 9 - .../changelog/helm-chart-2.12.0.md | 10 - .../changelog/helm-chart-2.12.1.md | 9 - .../changelog/helm-chart-2.13.0.md | 10 - .../changelog/helm-chart-2.14.0.md | 9 - .../changelog/helm-chart-2.15.0.md | 9 - .../changelog/helm-chart-2.16.0.md | 9 - .../changelog/helm-chart-2.9.0.md | 9 - .../changelog/helm-chart-2.9.1.md | 9 - .../changelog/helm-chart-3.0.0.md | 9 - .../changelog/helm-chart-3.10.0.md | 9 - .../changelog/helm-chart-3.10.1.md | 9 - .../changelog/helm-chart-3.11.0.md | 9 - .../changelog/helm-chart-3.11.1.md | 9 - .../changelog/helm-chart-3.12.0.md | 9 - .../changelog/helm-chart-3.13.0.md | 9 - .../changelog/helm-chart-3.14.0.md | 9 - .../changelog/helm-chart-3.15.0.md | 9 - .../changelog/helm-chart-3.15.1.md | 9 - .../changelog/helm-chart-3.16.0.md | 9 - .../changelog/helm-chart-3.16.1.md | 9 - .../changelog/helm-chart-3.17.0.md | 9 - .../changelog/helm-chart-3.18.0.md | 10 - .../changelog/helm-chart-3.19.0.md | 9 - .../changelog/helm-chart-3.20.0.md | 9 - .../changelog/helm-chart-3.20.1.md | 10 - .../changelog/helm-chart-3.21.0.md | 12 - .../changelog/helm-chart-3.22.0.md | 10 - .../changelog/helm-chart-3.23.0.md | 9 - .../changelog/helm-chart-3.24.0.md | 9 - .../changelog/helm-chart-3.25.0.md | 9 - .../changelog/helm-chart-3.26.0.md | 9 - .../changelog/helm-chart-3.27.0.md | 9 - .../changelog/helm-chart-3.28.0.md | 9 - .../changelog/helm-chart-3.29.0.md | 9 - .../changelog/helm-chart-3.3.0.md | 12 - .../changelog/helm-chart-3.3.1.md | 12 - .../changelog/helm-chart-3.30.0.md | 9 - .../changelog/helm-chart-3.31.0.md | 9 - .../changelog/helm-chart-3.32.0.md | 9 - .../changelog/helm-chart-3.33.0.md | 9 - .../changelog/helm-chart-3.34.0.md | 9 - .../changelog/helm-chart-3.4.0.md | 9 - .../changelog/helm-chart-3.5.0.md | 9 - .../changelog/helm-chart-3.5.1.md | 9 - .../changelog/helm-chart-3.6.0.md | 9 - .../changelog/helm-chart-3.7.0.md | 9 - .../changelog/helm-chart-3.7.1.md | 9 - .../changelog/helm-chart-3.8.0.md | 13 - .../changelog/helm-chart-3.9.0.md | 9 - .../changelog/helm-chart-4.0.1.md | 9 - .../changelog/helm-chart-4.0.10.md | 9 - .../changelog/helm-chart-4.0.11.md | 9 - .../changelog/helm-chart-4.0.12.md | 9 - .../changelog/helm-chart-4.0.13.md | 9 - .../changelog/helm-chart-4.0.14.md | 9 - .../changelog/helm-chart-4.0.15.md | 43 - .../changelog/helm-chart-4.0.18.md | 40 - .../changelog/helm-chart-4.0.2.md | 9 - .../changelog/helm-chart-4.0.3.md | 9 - .../changelog/helm-chart-4.0.5.md | 9 - .../changelog/helm-chart-4.0.6.md | 12 - .../changelog/helm-chart-4.0.7.md | 10 - .../changelog/helm-chart-4.0.9.md | 9 - .../changelog/helm-chart-4.1.0.md | 21 - .../changelog/helm-chart-4.1.2.md | 11 - .../changelog/helm-chart-4.10.0.md | 9 - .../changelog/helm-chart-4.10.1.md | 11 - .../changelog/helm-chart-4.10.2.md | 18 - .../changelog/helm-chart-4.11.0.md | 18 - .../changelog/helm-chart-4.11.1.md | 9 - .../changelog/helm-chart-4.11.2.md | 9 - .../changelog/helm-chart-4.11.3.md | 9 - .../changelog/helm-chart-4.2.0.md | 47 - .../changelog/helm-chart-4.2.1.md | 10 - .../changelog/helm-chart-4.3.0.md | 14 - .../changelog/helm-chart-4.4.0.md | 12 - .../changelog/helm-chart-4.5.2.md | 13 - .../changelog/helm-chart-4.6.0.md | 24 - .../changelog/helm-chart-4.6.1.md | 11 - .../changelog/helm-chart-4.7.0.md | 14 - .../changelog/helm-chart-4.7.1.md | 12 - .../changelog/helm-chart-4.7.2.md | 9 - .../changelog/helm-chart-4.8.0-beta.0.md | 13 - .../changelog/helm-chart-4.8.0.md | 13 - .../changelog/helm-chart-4.8.1.md | 9 - .../changelog/helm-chart-4.8.2.md | 10 - .../changelog/helm-chart-4.8.3.md | 9 - .../changelog/helm-chart-4.9.0.md | 13 - .../changelog/helm-chart-4.9.1.md | 10 - .../changelog/helm-chart.md.gotmpl | 11 - ...dmission-webhooks-cert-manager-values.yaml | 12 - ...ontroller-configmap-addheaders-values.yaml | 11 - ...troller-configmap-proxyheaders-values.yaml | 11 - .../ci/controller-configmap-values.yaml | 11 - ...roller-daemonset-extra-modules-values.yaml | 30 - .../controller-daemonset-metrics-values.yaml | 13 - ...roller-daemonset-opentelemetry-values.yaml | 13 - ...oller-daemonset-podannotations-values.yaml | 16 - .../ci/controller-daemonset-values.yaml | 10 - ...oller-deployment-extra-modules-values.yaml | 30 - .../controller-deployment-metrics-values.yaml | 13 - ...oller-deployment-opentelemetry-values.yaml | 13 - ...ller-deployment-podannotations-values.yaml | 16 - .../ci/controller-deployment-values.yaml | 10 - .../ci/controller-hpa-values.yaml | 18 - .../ci/controller-ingressclass-values.yaml | 15 - .../controller-service-internal-values.yaml | 13 - .../ci/controller-service-values.yaml | 22 - .../ci/deamonset-psp-values.yaml | 13 - .../ci/deamonset-webhook-and-psp-values.yaml | 13 - .../ci/deployment-psp-values.yaml | 10 - .../ci/deployment-webhook-and-psp-values.yaml | 12 - .../charts/ingress-nginx/templates/NOTES.txt | 73 - .../ingress-nginx/templates/_helpers.tpl | 272 ---- .../ingress-nginx/templates/_params.tpl | 77 -- .../admission-webhooks/cert-manager.yaml | 63 - .../job-patch/clusterrole.yaml | 33 - .../job-patch/clusterrolebinding.yaml | 23 - .../job-patch/job-createSecret.yaml | 79 -- .../job-patch/job-patchWebhook.yaml | 81 -- .../job-patch/networkpolicy.yaml | 26 - .../admission-webhooks/job-patch/psp.yaml | 52 - .../admission-webhooks/job-patch/role.yaml | 24 - .../job-patch/rolebinding.yaml | 24 - .../job-patch/serviceaccount.yaml | 17 - .../validating-webhook.yaml | 54 - .../ingress-nginx/templates/clusterrole.yaml | 102 -- .../templates/clusterrolebinding.yaml | 19 - .../controller-configmap-addheaders.yaml | 14 - .../controller-configmap-proxyheaders.yaml | 14 - .../templates/controller-configmap-tcp.yaml | 17 - .../templates/controller-configmap-udp.yaml | 17 - .../templates/controller-configmap.yaml | 28 - .../templates/controller-daemonset.yaml | 242 ---- .../templates/controller-deployment.yaml | 245 ---- .../templates/controller-hpa.yaml | 47 - .../controller-ingressclass-aliases.yaml | 23 - .../templates/controller-ingressclass.yaml | 26 - .../templates/controller-keda.yaml | 46 - .../templates/controller-networkpolicy.yaml | 45 - .../controller-poddisruptionbudget.yaml | 36 - .../templates/controller-prometheusrule.yaml | 23 - .../templates/controller-psp.yaml | 100 -- .../templates/controller-role.yaml | 104 -- .../templates/controller-rolebinding.yaml | 21 - .../templates/controller-secret.yaml | 15 - .../controller-service-internal.yaml | 105 -- .../templates/controller-service-metrics.yaml | 45 - .../templates/controller-service-webhook.yaml | 40 - .../templates/controller-service.yaml | 105 -- .../templates/controller-serviceaccount.yaml | 17 - .../templates/controller-servicemonitor.yaml | 53 - .../templates/default-backend-deployment.yaml | 119 -- .../default-backend-extra-configmaps.yaml | 23 - .../templates/default-backend-hpa.yaml | 40 - .../default-backend-networkpolicy.yaml | 25 - .../default-backend-poddisruptionbudget.yaml | 25 - .../templates/default-backend-psp.yaml | 50 - .../templates/default-backend-role.yaml | 22 - .../default-backend-rolebinding.yaml | 21 - .../templates/default-backend-service.yaml | 41 - .../default-backend-serviceaccount.yaml | 14 - .../job-patch/clusterrole_test.yaml | 11 - .../job-patch/clusterrolebinding_test.yaml | 11 - .../job-patch/role_test.yaml | 11 - .../job-patch/rolebinding_test.yaml | 11 - .../job-patch/serviceaccount_test.yaml | 47 - .../validating-webhook_test.yaml | 32 - .../controller-configmap-addheaders_test.yaml | 27 - ...ontroller-configmap-proxyheaders_test.yaml | 27 - .../tests/controller-configmap_test.yaml | 31 - .../tests/controller-daemonset_test.yaml | 172 --- .../tests/controller-deployment_test.yaml | 191 --- .../tests/controller-hpa_test.yaml | 31 - .../controller-ingressclass-aliases_test.yaml | 110 -- .../tests/controller-ingressclass_test.yaml | 93 -- .../tests/controller-keda_test.yaml | 31 - .../tests/controller-networkpolicy_test.yaml | 23 - .../controller-poddisruptionbudget_test.yaml | 89 -- .../tests/controller-prometheusrule_test.yaml | 17 - .../controller-service-internal_test.yaml | 25 - .../controller-service-metrics_test.yaml | 23 - .../controller-service-webhook_test.yaml | 32 - .../tests/controller-service_test.yaml | 32 - .../tests/controller-servicemonitor_test.yaml | 29 - .../default-backend-deployment_test.yaml | 169 --- ...default-backend-extra-configmaps_test.yaml | 50 - ...ault-backend-poddisruptionbudget_test.yaml | 48 - .../tests/default-backend-service_test.yaml | 32 - charts/keep/charts/ingress-nginx/values.yaml | 1192 ----------------- 200 files changed, 7664 deletions(-) delete mode 100644 charts/keep/charts/ingress-nginx/.helmignore delete mode 100644 charts/keep/charts/ingress-nginx/Chart.yaml delete mode 100644 charts/keep/charts/ingress-nginx/OWNERS delete mode 100644 charts/keep/charts/ingress-nginx/README.md delete mode 100644 charts/keep/charts/ingress-nginx/README.md.gotmpl delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.10.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.2.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.3.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.13.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.14.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.15.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.16.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.0.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.12.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.13.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.14.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.17.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.18.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.19.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.21.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.22.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.23.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.24.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.25.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.26.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.27.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.28.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.29.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.30.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.31.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.32.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.33.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.34.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.4.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.6.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.8.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.9.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.10.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.11.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.12.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.13.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.14.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.15.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.18.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.2.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.3.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.5.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.6.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.7.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.9.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.2.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.2.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.2.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.3.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.3.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.4.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.5.2.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.2.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0-beta.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.2.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.3.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart.md.gotmpl delete mode 100644 charts/keep/charts/ingress-nginx/ci/admission-webhooks-cert-manager-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-configmap-addheaders-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-configmap-proxyheaders-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-configmap-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-extra-modules-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-metrics-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-opentelemetry-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-podannotations-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-extra-modules-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-metrics-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-opentelemetry-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-podannotations-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-hpa-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-ingressclass-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-service-internal-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-service-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/deamonset-psp-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/deamonset-webhook-and-psp-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/deployment-psp-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/deployment-webhook-and-psp-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/NOTES.txt delete mode 100644 charts/keep/charts/ingress-nginx/templates/_helpers.tpl delete mode 100644 charts/keep/charts/ingress-nginx/templates/_params.tpl delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/cert-manager.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/networkpolicy.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/psp.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/clusterrole.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/clusterrolebinding.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap-addheaders.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap-proxyheaders.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap-tcp.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap-udp.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-daemonset.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-deployment.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-hpa.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-ingressclass-aliases.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-ingressclass.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-keda.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-networkpolicy.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-prometheusrule.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-psp.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-role.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-rolebinding.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-secret.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-service-internal.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-service-metrics.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-service-webhook.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-service.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-servicemonitor.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-deployment.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-extra-configmaps.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-hpa.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-networkpolicy.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-poddisruptionbudget.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-psp.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-role.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-rolebinding.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-service.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-serviceaccount.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrole_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrolebinding_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/role_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/rolebinding_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/serviceaccount_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/validating-webhook_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-configmap-addheaders_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-configmap-proxyheaders_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-configmap_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-daemonset_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-deployment_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-hpa_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-ingressclass-aliases_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-ingressclass_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-keda_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-networkpolicy_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-poddisruptionbudget_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-prometheusrule_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-service-internal_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-service-metrics_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-service-webhook_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-service_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-servicemonitor_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/default-backend-deployment_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/default-backend-extra-configmaps_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/default-backend-poddisruptionbudget_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/default-backend-service_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/values.yaml diff --git a/charts/keep/charts/ingress-nginx/.helmignore b/charts/keep/charts/ingress-nginx/.helmignore deleted file mode 100644 index 109b408..0000000 --- a/charts/keep/charts/ingress-nginx/.helmignore +++ /dev/null @@ -1,23 +0,0 @@ -# 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 -*~ -# Various IDEs -.project -.idea/ -*.tmproj -.vscode/ -__snapshot__ diff --git a/charts/keep/charts/ingress-nginx/Chart.yaml b/charts/keep/charts/ingress-nginx/Chart.yaml deleted file mode 100644 index 1f01284..0000000 --- a/charts/keep/charts/ingress-nginx/Chart.yaml +++ /dev/null @@ -1,25 +0,0 @@ -annotations: - artifacthub.io/changes: | - - Update Ingress-Nginx version controller-v1.11.3 - artifacthub.io/prerelease: "false" -apiVersion: v2 -appVersion: 1.11.3 -description: Ingress controller for Kubernetes using NGINX as a reverse proxy and - load balancer -home: https://github.com/kubernetes/ingress-nginx -icon: https://upload.wikimedia.org/wikipedia/commons/thumb/c/c5/Nginx_logo.svg/500px-Nginx_logo.svg.png -keywords: -- ingress -- nginx -kubeVersion: '>=1.21.0-0' -maintainers: -- name: cpanato -- name: Gacko -- name: puerco -- name: rikatz -- name: strongjz -- name: tao12345666333 -name: ingress-nginx -sources: -- https://github.com/kubernetes/ingress-nginx -version: 4.11.3 diff --git a/charts/keep/charts/ingress-nginx/OWNERS b/charts/keep/charts/ingress-nginx/OWNERS deleted file mode 100644 index d588ede..0000000 --- a/charts/keep/charts/ingress-nginx/OWNERS +++ /dev/null @@ -1,10 +0,0 @@ -# See the OWNERS docs: https://www.kubernetes.dev/docs/guide/owners - -approvers: -- ingress-nginx-helm-maintainers - -reviewers: -- ingress-nginx-helm-reviewers - -labels: -- area/helm diff --git a/charts/keep/charts/ingress-nginx/README.md b/charts/keep/charts/ingress-nginx/README.md deleted file mode 100644 index f70bd0a..0000000 --- a/charts/keep/charts/ingress-nginx/README.md +++ /dev/null @@ -1,559 +0,0 @@ -# ingress-nginx - -[ingress-nginx](https://github.com/kubernetes/ingress-nginx) Ingress controller for Kubernetes using NGINX as a reverse proxy and load balancer - -![Version: 4.11.3](https://img.shields.io/badge/Version-4.11.3-informational?style=flat-square) ![AppVersion: 1.11.3](https://img.shields.io/badge/AppVersion-1.11.3-informational?style=flat-square) - -To use, add `ingressClassName: nginx` spec field or the `kubernetes.io/ingress.class: nginx` annotation to your Ingress resources. - -This chart bootstraps an ingress-nginx deployment on a [Kubernetes](http://kubernetes.io) cluster using the [Helm](https://helm.sh) package manager. - -## Requirements - -Kubernetes: `>=1.21.0-0` - -## Get Repo Info - -```console -helm repo add ingress-nginx https://kubernetes.github.io/ingress-nginx -helm repo update -``` - -## Install Chart - -**Important:** only helm3 is supported - -```console -helm install [RELEASE_NAME] ingress-nginx/ingress-nginx -``` - -The command deploys ingress-nginx on the Kubernetes cluster in the default configuration. - -_See [configuration](#configuration) below._ - -_See [helm install](https://helm.sh/docs/helm/helm_install/) for command documentation._ - -## Uninstall Chart - -```console -helm uninstall [RELEASE_NAME] -``` - -This removes all the Kubernetes components associated with the chart and deletes the release. - -_See [helm uninstall](https://helm.sh/docs/helm/helm_uninstall/) for command documentation._ - -## Upgrading Chart - -```console -helm upgrade [RELEASE_NAME] [CHART] --install -``` - -_See [helm upgrade](https://helm.sh/docs/helm/helm_upgrade/) for command documentation._ - -### Migrating from stable/nginx-ingress - -There are two main ways to migrate a release from `stable/nginx-ingress` to `ingress-nginx/ingress-nginx` chart: - -1. For Nginx Ingress controllers used for non-critical services, the easiest method is to [uninstall](#uninstall-chart) the old release and [install](#install-chart) the new one -1. For critical services in production that require zero-downtime, you will want to: - 1. [Install](#install-chart) a second Ingress controller - 1. Redirect your DNS traffic from the old controller to the new controller - 1. Log traffic from both controllers during this changeover - 1. [Uninstall](#uninstall-chart) the old controller once traffic has fully drained from it - -Note that there are some different and upgraded configurations between the two charts, described by Rimas Mocevicius from JFrog in the "Upgrading to ingress-nginx Helm chart" section of [Migrating from Helm chart nginx-ingress to ingress-nginx](https://rimusz.net/migrating-to-ingress-nginx). As the `ingress-nginx/ingress-nginx` chart continues to update, you will want to check current differences by running [helm configuration](#configuration) commands on both charts. - -## Configuration - -See [Customizing the Chart Before Installing](https://helm.sh/docs/intro/using_helm/#customizing-the-chart-before-installing). To see all configurable options with detailed comments, visit the chart's [values.yaml](./values.yaml), or run these configuration commands: - -```console -helm show values ingress-nginx/ingress-nginx -``` - -### PodDisruptionBudget - -Note that the PodDisruptionBudget resource will only be defined if the replicaCount is greater than one, -else it would make it impossible to evacuate a node. See [gh issue #7127](https://github.com/helm/charts/issues/7127) for more info. - -### Prometheus Metrics - -The Ingress-Nginx Controller can export Prometheus metrics, by setting `controller.metrics.enabled` to `true`. - -You can add Prometheus annotations to the metrics service using `controller.metrics.service.annotations`. -Alternatively, if you use the Prometheus Operator, you can enable ServiceMonitor creation using `controller.metrics.serviceMonitor.enabled`. And set `controller.metrics.serviceMonitor.additionalLabels.release="prometheus"`. "release=prometheus" should match the label configured in the prometheus servicemonitor ( see `kubectl get servicemonitor prometheus-kube-prom-prometheus -oyaml -n prometheus`) - -### ingress-nginx nginx\_status page/stats server - -Previous versions of this chart had a `controller.stats.*` configuration block, which is now obsolete due to the following changes in Ingress-Nginx Controller: - -- In [0.16.1](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0161), the vts (virtual host traffic status) dashboard was removed -- In [0.23.0](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0230), the status page at port 18080 is now a unix socket webserver only available at localhost. - You can use `curl --unix-socket /tmp/nginx-status-server.sock http://localhost/nginx_status` inside the controller container to access it locally, or use the snippet from [nginx-ingress changelog](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0230) to re-enable the http server - -### ExternalDNS Service Configuration - -Add an [ExternalDNS](https://github.com/kubernetes-sigs/external-dns) annotation to the LoadBalancer service: - -```yaml -controller: - service: - annotations: - external-dns.alpha.kubernetes.io/hostname: kubernetes-example.com. -``` - -### AWS L7 ELB with SSL Termination - -Annotate the controller as shown in the [nginx-ingress l7 patch](https://github.com/kubernetes/ingress-nginx/blob/ab3a789caae65eec4ad6e3b46b19750b481b6bce/deploy/aws/l7/service-l7.yaml): - -```yaml -controller: - service: - targetPorts: - http: http - https: http - annotations: - service.beta.kubernetes.io/aws-load-balancer-ssl-cert: arn:aws:acm:XX-XXXX-X:XXXXXXXXX:certificate/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXX - service.beta.kubernetes.io/aws-load-balancer-backend-protocol: "http" - service.beta.kubernetes.io/aws-load-balancer-ssl-ports: "https" - service.beta.kubernetes.io/aws-load-balancer-connection-idle-timeout: '3600' -``` - -### Additional Internal Load Balancer - -This setup is useful when you need both external and internal load balancers but don't want to have multiple ingress controllers and multiple ingress objects per application. - -By default, the ingress object will point to the external load balancer address, but if correctly configured, you can make use of the internal one if the URL you are looking up resolves to the internal load balancer's URL. - -You'll need to set both the following values: - -`controller.service.internal.enabled` -`controller.service.internal.annotations` - -If one of them is missing the internal load balancer will not be deployed. Example you may have `controller.service.internal.enabled=true` but no annotations set, in this case no action will be taken. - -`controller.service.internal.annotations` varies with the cloud service you're using. - -Example for AWS: - -```yaml -controller: - service: - internal: - enabled: true - annotations: - # Create internal NLB - service.beta.kubernetes.io/aws-load-balancer-scheme: "internal" - # Create internal ELB(Deprecated) - # service.beta.kubernetes.io/aws-load-balancer-internal: "true" - # Any other annotation can be declared here. -``` - -Example for GCE: - -```yaml -controller: - service: - internal: - enabled: true - annotations: - # Create internal LB. More information: https://cloud.google.com/kubernetes-engine/docs/how-to/internal-load-balancing - # For GKE versions 1.17 and later - networking.gke.io/load-balancer-type: "Internal" - # For earlier versions - # cloud.google.com/load-balancer-type: "Internal" - - # Any other annotation can be declared here. -``` - -Example for Azure: - -```yaml -controller: - service: - annotations: - # Create internal LB - service.beta.kubernetes.io/azure-load-balancer-internal: "true" - # Any other annotation can be declared here. -``` - -Example for Oracle Cloud Infrastructure: - -```yaml -controller: - service: - annotations: - # Create internal LB - service.beta.kubernetes.io/oci-load-balancer-internal: "true" - # Any other annotation can be declared here. -``` - -The load balancer annotations of more cloud service providers can be found: [Internal load balancer](https://kubernetes.io/docs/concepts/services-networking/service/#internal-load-balancer). - -An use case for this scenario is having a split-view DNS setup where the public zone CNAME records point to the external balancer URL while the private zone CNAME records point to the internal balancer URL. This way, you only need one ingress kubernetes object. - -Optionally you can set `controller.service.loadBalancerIP` if you need a static IP for the resulting `LoadBalancer`. - -### Ingress Admission Webhooks - -With nginx-ingress-controller version 0.25+, the Ingress-Nginx Controller pod exposes an endpoint that will integrate with the `validatingwebhookconfiguration` Kubernetes feature to prevent bad ingress from being added to the cluster. -**This feature is enabled by default since 0.31.0.** - -With nginx-ingress-controller in 0.25.* work only with kubernetes 1.14+, 0.26 fix [this issue](https://github.com/kubernetes/ingress-nginx/pull/4521) - -#### How the Chart Configures the Hooks -A validating and configuration requires the endpoint to which the request is sent to use TLS. It is possible to set up custom certificates to do this, but in most cases, a self-signed certificate is enough. The setup of this component requires some more complex orchestration when using helm. The steps are created to be idempotent and to allow turning the feature on and off without running into helm quirks. - -1. A pre-install hook provisions a certificate into the same namespace using a format compatible with provisioning using end user certificates. If the certificate already exists, the hook exits. -2. The Ingress-Nginx Controller pod is configured to use a TLS proxy container, which will load that certificate. -3. Validating and Mutating webhook configurations are created in the cluster. -4. A post-install hook reads the CA from the secret created by step 1 and patches the Validating and Mutating webhook configurations. This process will allow a custom CA provisioned by some other process to also be patched into the webhook configurations. The chosen failure policy is also patched into the webhook configurations - -#### Alternatives -It should be possible to use [cert-manager/cert-manager](https://github.com/cert-manager/cert-manager) if a more complete solution is required. - -You can enable automatic self-signed TLS certificate provisioning via cert-manager by setting the `controller.admissionWebhooks.certManager.enabled` value to true. - -Please ensure that cert-manager is correctly installed and configured. - -### Helm Error When Upgrading: spec.clusterIP: Invalid value: "" - -If you are upgrading this chart from a version between 0.31.0 and 1.2.2 then you may get an error like this: - -```console -Error: UPGRADE FAILED: Service "?????-controller" is invalid: spec.clusterIP: Invalid value: "": field is immutable -``` - -Detail of how and why are in [this issue](https://github.com/helm/charts/pull/13646) but to resolve this you can set `xxxx.service.omitClusterIP` to `true` where `xxxx` is the service referenced in the error. - -As of version `1.26.0` of this chart, by simply not providing any clusterIP value, `invalid: spec.clusterIP: Invalid value: "": field is immutable` will no longer occur since `clusterIP: ""` will not be rendered. - -## Values - -| Key | Type | Default | Description | -|-----|------|---------|-------------| -| commonLabels | object | `{}` | | -| controller.addHeaders | object | `{}` | Will add custom headers before sending response traffic to the client according to: https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/#add-headers | -| controller.admissionWebhooks.annotations | object | `{}` | | -| controller.admissionWebhooks.certManager.admissionCert.duration | string | `""` | | -| controller.admissionWebhooks.certManager.enabled | bool | `false` | | -| controller.admissionWebhooks.certManager.rootCert.duration | string | `""` | | -| controller.admissionWebhooks.certificate | string | `"/usr/local/certificates/cert"` | | -| controller.admissionWebhooks.createSecretJob.name | string | `"create"` | | -| controller.admissionWebhooks.createSecretJob.resources | object | `{}` | | -| controller.admissionWebhooks.createSecretJob.securityContext | object | `{"allowPrivilegeEscalation":false,"capabilities":{"drop":["ALL"]},"readOnlyRootFilesystem":true,"runAsNonRoot":true,"runAsUser":65532,"seccompProfile":{"type":"RuntimeDefault"}}` | Security context for secret creation containers | -| controller.admissionWebhooks.enabled | bool | `true` | | -| controller.admissionWebhooks.existingPsp | string | `""` | Use an existing PSP instead of creating one | -| controller.admissionWebhooks.extraEnvs | list | `[]` | Additional environment variables to set | -| controller.admissionWebhooks.failurePolicy | string | `"Fail"` | Admission Webhook failure policy to use | -| controller.admissionWebhooks.key | string | `"/usr/local/certificates/key"` | | -| controller.admissionWebhooks.labels | object | `{}` | Labels to be added to admission webhooks | -| controller.admissionWebhooks.name | string | `"admission"` | | -| controller.admissionWebhooks.namespaceSelector | object | `{}` | | -| controller.admissionWebhooks.objectSelector | object | `{}` | | -| controller.admissionWebhooks.patch.enabled | bool | `true` | | -| controller.admissionWebhooks.patch.image.digest | string | `"sha256:a9f03b34a3cbfbb26d103a14046ab2c5130a80c3d69d526ff8063d2b37b9fd3f"` | | -| controller.admissionWebhooks.patch.image.image | string | `"ingress-nginx/kube-webhook-certgen"` | | -| controller.admissionWebhooks.patch.image.pullPolicy | string | `"IfNotPresent"` | | -| controller.admissionWebhooks.patch.image.registry | string | `"registry.k8s.io"` | | -| controller.admissionWebhooks.patch.image.tag | string | `"v1.4.4"` | | -| controller.admissionWebhooks.patch.labels | object | `{}` | Labels to be added to patch job resources | -| controller.admissionWebhooks.patch.networkPolicy.enabled | bool | `false` | Enable 'networkPolicy' or not | -| controller.admissionWebhooks.patch.nodeSelector."kubernetes.io/os" | string | `"linux"` | | -| controller.admissionWebhooks.patch.podAnnotations | object | `{}` | | -| controller.admissionWebhooks.patch.priorityClassName | string | `""` | Provide a priority class name to the webhook patching job # | -| controller.admissionWebhooks.patch.rbac | object | `{"create":true}` | Admission webhook patch job RBAC | -| controller.admissionWebhooks.patch.rbac.create | bool | `true` | Create RBAC or not | -| controller.admissionWebhooks.patch.securityContext | object | `{}` | Security context for secret creation & webhook patch pods | -| controller.admissionWebhooks.patch.serviceAccount | object | `{"automountServiceAccountToken":true,"create":true,"name":""}` | Admission webhook patch job service account | -| controller.admissionWebhooks.patch.serviceAccount.automountServiceAccountToken | bool | `true` | Auto-mount service account token or not | -| controller.admissionWebhooks.patch.serviceAccount.create | bool | `true` | Create a service account or not | -| controller.admissionWebhooks.patch.serviceAccount.name | string | `""` | Custom service account name | -| controller.admissionWebhooks.patch.tolerations | list | `[]` | | -| controller.admissionWebhooks.patchWebhookJob.name | string | `"patch"` | | -| controller.admissionWebhooks.patchWebhookJob.resources | object | `{}` | | -| controller.admissionWebhooks.patchWebhookJob.securityContext | object | `{"allowPrivilegeEscalation":false,"capabilities":{"drop":["ALL"]},"readOnlyRootFilesystem":true,"runAsNonRoot":true,"runAsUser":65532,"seccompProfile":{"type":"RuntimeDefault"}}` | Security context for webhook patch containers | -| controller.admissionWebhooks.port | int | `8443` | | -| controller.admissionWebhooks.service.annotations | object | `{}` | | -| controller.admissionWebhooks.service.externalIPs | list | `[]` | | -| controller.admissionWebhooks.service.loadBalancerSourceRanges | list | `[]` | | -| controller.admissionWebhooks.service.servicePort | int | `443` | | -| controller.admissionWebhooks.service.type | string | `"ClusterIP"` | | -| controller.affinity | object | `{}` | Affinity and anti-affinity rules for server scheduling to nodes # Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#affinity-and-anti-affinity # | -| controller.allowSnippetAnnotations | bool | `false` | This configuration defines if Ingress Controller should allow users to set their own *-snippet annotations, otherwise this is forbidden / dropped when users add those annotations. Global snippets in ConfigMap are still respected | -| controller.annotations | object | `{}` | Annotations to be added to the controller Deployment or DaemonSet # | -| controller.autoscaling.annotations | object | `{}` | | -| controller.autoscaling.behavior | object | `{}` | | -| controller.autoscaling.enabled | bool | `false` | | -| controller.autoscaling.maxReplicas | int | `11` | | -| controller.autoscaling.minReplicas | int | `1` | | -| controller.autoscaling.targetCPUUtilizationPercentage | int | `50` | | -| controller.autoscaling.targetMemoryUtilizationPercentage | int | `50` | | -| controller.autoscalingTemplate | list | `[]` | | -| controller.config | object | `{}` | Global configuration passed to the ConfigMap consumed by the controller. Values may contain Helm templates. Ref.: https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/ | -| controller.configAnnotations | object | `{}` | Annotations to be added to the controller config configuration configmap. | -| controller.configMapNamespace | string | `""` | Allows customization of the configmap / nginx-configmap namespace; defaults to $(POD_NAMESPACE) | -| controller.containerName | string | `"controller"` | Configures the controller container name | -| controller.containerPort | object | `{"http":80,"https":443}` | Configures the ports that the nginx-controller listens on | -| controller.containerSecurityContext | object | `{}` | Security context for controller containers | -| controller.customTemplate.configMapKey | string | `""` | | -| controller.customTemplate.configMapName | string | `""` | | -| controller.disableLeaderElection | bool | `false` | This configuration disable Nginx Controller Leader Election | -| controller.dnsConfig | object | `{}` | Optionally customize the pod dnsConfig. | -| controller.dnsPolicy | string | `"ClusterFirst"` | Optionally change this to ClusterFirstWithHostNet in case you have 'hostNetwork: true'. By default, while using host network, name resolution uses the host's DNS. If you wish nginx-controller to keep resolving names inside the k8s network, use ClusterFirstWithHostNet. | -| controller.electionID | string | `""` | Election ID to use for status update, by default it uses the controller name combined with a suffix of 'leader' | -| controller.electionTTL | string | `""` | Duration a leader election is valid before it's getting re-elected, e.g. `15s`, `10m` or `1h`. (Default: 30s) | -| controller.enableAnnotationValidations | bool | `false` | | -| controller.enableMimalloc | bool | `true` | Enable mimalloc as a drop-in replacement for malloc. # ref: https://github.com/microsoft/mimalloc # | -| controller.enableTopologyAwareRouting | bool | `false` | This configuration enables Topology Aware Routing feature, used together with service annotation service.kubernetes.io/topology-mode="auto" Defaults to false | -| controller.existingPsp | string | `""` | Use an existing PSP instead of creating one | -| controller.extraArgs | object | `{}` | Additional command line arguments to pass to Ingress-Nginx Controller E.g. to specify the default SSL certificate you can use | -| controller.extraContainers | list | `[]` | Additional containers to be added to the controller pod. See https://github.com/lemonldap-ng-controller/lemonldap-ng-controller as example. | -| controller.extraEnvs | list | `[]` | Additional environment variables to set | -| controller.extraInitContainers | list | `[]` | Containers, which are run before the app containers are started. | -| controller.extraModules | list | `[]` | Modules, which are mounted into the core nginx image. See values.yaml for a sample to add opentelemetry module | -| controller.extraVolumeMounts | list | `[]` | Additional volumeMounts to the controller main container. | -| controller.extraVolumes | list | `[]` | Additional volumes to the controller pod. | -| controller.healthCheckHost | string | `""` | Address to bind the health check endpoint. It is better to set this option to the internal node address if the Ingress-Nginx Controller is running in the `hostNetwork: true` mode. | -| controller.healthCheckPath | string | `"/healthz"` | Path of the health check endpoint. All requests received on the port defined by the healthz-port parameter are forwarded internally to this path. | -| controller.hostAliases | list | `[]` | Optionally customize the pod hostAliases. | -| controller.hostNetwork | bool | `false` | Required for use with CNI based kubernetes installations (such as ones set up by kubeadm), since CNI and hostport don't mix yet. Can be deprecated once https://github.com/kubernetes/kubernetes/issues/23920 is merged | -| controller.hostPort.enabled | bool | `false` | Enable 'hostPort' or not | -| controller.hostPort.ports.http | int | `80` | 'hostPort' http port | -| controller.hostPort.ports.https | int | `443` | 'hostPort' https port | -| controller.hostname | object | `{}` | Optionally customize the pod hostname. | -| controller.image.allowPrivilegeEscalation | bool | `false` | | -| controller.image.chroot | bool | `false` | | -| controller.image.digest | string | `"sha256:d56f135b6462cfc476447cfe564b83a45e8bb7da2774963b00d12161112270b7"` | | -| controller.image.digestChroot | string | `"sha256:22701f0fc0f2dd209ef782f4e281bfe2d8cccd50ededa00aec88e0cdbe7edd14"` | | -| controller.image.image | string | `"ingress-nginx/controller"` | | -| controller.image.pullPolicy | string | `"IfNotPresent"` | | -| controller.image.readOnlyRootFilesystem | bool | `false` | | -| controller.image.registry | string | `"registry.k8s.io"` | | -| controller.image.runAsNonRoot | bool | `true` | | -| controller.image.runAsUser | int | `101` | | -| controller.image.seccompProfile.type | string | `"RuntimeDefault"` | | -| controller.image.tag | string | `"v1.11.3"` | | -| controller.ingressClass | string | `"nginx"` | For backwards compatibility with ingress.class annotation, use ingressClass. Algorithm is as follows, first ingressClassName is considered, if not present, controller looks for ingress.class annotation | -| controller.ingressClassByName | bool | `false` | Process IngressClass per name (additionally as per spec.controller). | -| controller.ingressClassResource | object | `{"aliases":[],"annotations":{},"controllerValue":"k8s.io/ingress-nginx","default":false,"enabled":true,"name":"nginx","parameters":{}}` | This section refers to the creation of the IngressClass resource. IngressClasses are immutable and cannot be changed after creation. We do not support namespaced IngressClasses, yet, so a ClusterRole and a ClusterRoleBinding is required. | -| controller.ingressClassResource.aliases | list | `[]` | Aliases of this IngressClass. Creates copies with identical settings but the respective alias as name. Useful for development environments with only one Ingress Controller but production-like Ingress resources. `default` gets enabled on the original IngressClass only. | -| controller.ingressClassResource.annotations | object | `{}` | Annotations to be added to the IngressClass resource. | -| controller.ingressClassResource.controllerValue | string | `"k8s.io/ingress-nginx"` | Controller of the IngressClass. An Ingress Controller looks for IngressClasses it should reconcile by this value. This value is also being set as the `--controller-class` argument of this Ingress Controller. Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#ingress-class | -| controller.ingressClassResource.default | bool | `false` | If true, Ingresses without `ingressClassName` get assigned to this IngressClass on creation. Ingress creation gets rejected if there are multiple default IngressClasses. Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#default-ingress-class | -| controller.ingressClassResource.enabled | bool | `true` | Create the IngressClass or not | -| controller.ingressClassResource.name | string | `"nginx"` | Name of the IngressClass | -| controller.ingressClassResource.parameters | object | `{}` | A link to a custom resource containing additional configuration for the controller. This is optional if the controller consuming this IngressClass does not require additional parameters. Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#ingress-class | -| controller.keda.apiVersion | string | `"keda.sh/v1alpha1"` | | -| controller.keda.behavior | object | `{}` | | -| controller.keda.cooldownPeriod | int | `300` | | -| controller.keda.enabled | bool | `false` | | -| controller.keda.maxReplicas | int | `11` | | -| controller.keda.minReplicas | int | `1` | | -| controller.keda.pollingInterval | int | `30` | | -| controller.keda.restoreToOriginalReplicaCount | bool | `false` | | -| controller.keda.scaledObject.annotations | object | `{}` | | -| controller.keda.triggers | list | `[]` | | -| controller.kind | string | `"Deployment"` | Use a `DaemonSet` or `Deployment` | -| controller.labels | object | `{}` | Labels to be added to the controller Deployment or DaemonSet and other resources that do not have option to specify labels # | -| controller.lifecycle | object | `{"preStop":{"exec":{"command":["/wait-shutdown"]}}}` | Improve connection draining when ingress controller pod is deleted using a lifecycle hook: With this new hook, we increased the default terminationGracePeriodSeconds from 30 seconds to 300, allowing the draining of connections up to five minutes. If the active connections end before that, the pod will terminate gracefully at that time. To effectively take advantage of this feature, the Configmap feature worker-shutdown-timeout new value is 240s instead of 10s. # | -| controller.livenessProbe.failureThreshold | int | `5` | | -| controller.livenessProbe.httpGet.path | string | `"/healthz"` | | -| controller.livenessProbe.httpGet.port | int | `10254` | | -| controller.livenessProbe.httpGet.scheme | string | `"HTTP"` | | -| controller.livenessProbe.initialDelaySeconds | int | `10` | | -| controller.livenessProbe.periodSeconds | int | `10` | | -| controller.livenessProbe.successThreshold | int | `1` | | -| controller.livenessProbe.timeoutSeconds | int | `1` | | -| controller.maxmindLicenseKey | string | `""` | Maxmind license key to download GeoLite2 Databases. # https://blog.maxmind.com/2019/12/significant-changes-to-accessing-and-using-geolite2-databases/ | -| controller.metrics.enabled | bool | `false` | | -| controller.metrics.port | int | `10254` | | -| controller.metrics.portName | string | `"metrics"` | | -| controller.metrics.prometheusRule.additionalLabels | object | `{}` | | -| controller.metrics.prometheusRule.enabled | bool | `false` | | -| controller.metrics.prometheusRule.rules | list | `[]` | | -| controller.metrics.service.annotations | object | `{}` | | -| controller.metrics.service.externalIPs | list | `[]` | List of IP addresses at which the stats-exporter service is available # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips # | -| controller.metrics.service.labels | object | `{}` | Labels to be added to the metrics service resource | -| controller.metrics.service.loadBalancerSourceRanges | list | `[]` | | -| controller.metrics.service.servicePort | int | `10254` | | -| controller.metrics.service.type | string | `"ClusterIP"` | | -| controller.metrics.serviceMonitor.additionalLabels | object | `{}` | | -| controller.metrics.serviceMonitor.annotations | object | `{}` | Annotations to be added to the ServiceMonitor. | -| controller.metrics.serviceMonitor.enabled | bool | `false` | | -| controller.metrics.serviceMonitor.metricRelabelings | list | `[]` | | -| controller.metrics.serviceMonitor.namespace | string | `""` | | -| controller.metrics.serviceMonitor.namespaceSelector | object | `{}` | | -| controller.metrics.serviceMonitor.relabelings | list | `[]` | | -| controller.metrics.serviceMonitor.scrapeInterval | string | `"30s"` | | -| controller.metrics.serviceMonitor.targetLabels | list | `[]` | | -| controller.minAvailable | int | `1` | Minimum available pods set in PodDisruptionBudget. Define either 'minAvailable' or 'maxUnavailable', never both. | -| controller.minReadySeconds | int | `0` | `minReadySeconds` to avoid killing pods before we are ready # | -| controller.name | string | `"controller"` | | -| controller.networkPolicy.enabled | bool | `false` | Enable 'networkPolicy' or not | -| controller.nodeSelector | object | `{"kubernetes.io/os":"linux"}` | Node labels for controller pod assignment # Ref: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/ # | -| controller.opentelemetry.containerSecurityContext.allowPrivilegeEscalation | bool | `false` | | -| controller.opentelemetry.containerSecurityContext.capabilities.drop[0] | string | `"ALL"` | | -| controller.opentelemetry.containerSecurityContext.readOnlyRootFilesystem | bool | `true` | | -| controller.opentelemetry.containerSecurityContext.runAsNonRoot | bool | `true` | | -| controller.opentelemetry.containerSecurityContext.runAsUser | int | `65532` | The image's default user, inherited from its base image `cgr.dev/chainguard/static`. | -| controller.opentelemetry.containerSecurityContext.seccompProfile.type | string | `"RuntimeDefault"` | | -| controller.opentelemetry.enabled | bool | `false` | | -| controller.opentelemetry.image.digest | string | `"sha256:f7604ac0547ed64d79b98d92133234e66c2c8aade3c1f4809fed5eec1fb7f922"` | | -| controller.opentelemetry.image.distroless | bool | `true` | | -| controller.opentelemetry.image.image | string | `"ingress-nginx/opentelemetry-1.25.3"` | | -| controller.opentelemetry.image.registry | string | `"registry.k8s.io"` | | -| controller.opentelemetry.image.tag | string | `"v20240813-b933310d"` | | -| controller.opentelemetry.name | string | `"opentelemetry"` | | -| controller.opentelemetry.resources | object | `{}` | | -| controller.podAnnotations | object | `{}` | Annotations to be added to controller pods # | -| controller.podLabels | object | `{}` | Labels to add to the pod container metadata | -| controller.podSecurityContext | object | `{}` | Security context for controller pods | -| controller.priorityClassName | string | `""` | | -| controller.proxySetHeaders | object | `{}` | Will add custom headers before sending traffic to backends according to https://github.com/kubernetes/ingress-nginx/tree/main/docs/examples/customization/custom-headers | -| controller.publishService | object | `{"enabled":true,"pathOverride":""}` | Allows customization of the source of the IP address or FQDN to report in the ingress status field. By default, it reads the information provided by the service. If disable, the status field reports the IP address of the node or nodes where an ingress controller pod is running. | -| controller.publishService.enabled | bool | `true` | Enable 'publishService' or not | -| controller.publishService.pathOverride | string | `""` | Allows overriding of the publish service to bind to Must be / | -| controller.readinessProbe.failureThreshold | int | `3` | | -| controller.readinessProbe.httpGet.path | string | `"/healthz"` | | -| controller.readinessProbe.httpGet.port | int | `10254` | | -| controller.readinessProbe.httpGet.scheme | string | `"HTTP"` | | -| controller.readinessProbe.initialDelaySeconds | int | `10` | | -| controller.readinessProbe.periodSeconds | int | `10` | | -| controller.readinessProbe.successThreshold | int | `1` | | -| controller.readinessProbe.timeoutSeconds | int | `1` | | -| controller.replicaCount | int | `1` | | -| controller.reportNodeInternalIp | bool | `false` | Bare-metal considerations via the host network https://kubernetes.github.io/ingress-nginx/deploy/baremetal/#via-the-host-network Ingress status was blank because there is no Service exposing the Ingress-Nginx Controller in a configuration using the host network, the default --publish-service flag used in standard cloud setups does not apply | -| controller.resources.requests.cpu | string | `"100m"` | | -| controller.resources.requests.memory | string | `"90Mi"` | | -| controller.scope.enabled | bool | `false` | Enable 'scope' or not | -| controller.scope.namespace | string | `""` | Namespace to limit the controller to; defaults to $(POD_NAMESPACE) | -| controller.scope.namespaceSelector | string | `""` | When scope.enabled == false, instead of watching all namespaces, we watching namespaces whose labels only match with namespaceSelector. Format like foo=bar. Defaults to empty, means watching all namespaces. | -| controller.service.annotations | object | `{}` | Annotations to be added to the external controller service. See `controller.service.internal.annotations` for annotations to be added to the internal controller service. | -| controller.service.appProtocol | bool | `true` | Declare the app protocol of the external HTTP and HTTPS listeners or not. Supersedes provider-specific annotations for declaring the backend protocol. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#application-protocol | -| controller.service.clusterIP | string | `""` | Pre-defined cluster internal IP address of the external controller service. Take care of collisions with existing services. This value is immutable. Set once, it can not be changed without deleting and re-creating the service. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#choosing-your-own-ip-address | -| controller.service.enableHttp | bool | `true` | Enable the HTTP listener on both controller services or not. | -| controller.service.enableHttps | bool | `true` | Enable the HTTPS listener on both controller services or not. | -| controller.service.enabled | bool | `true` | Enable controller services or not. This does not influence the creation of either the admission webhook or the metrics service. | -| controller.service.external.enabled | bool | `true` | Enable the external controller service or not. Useful for internal-only deployments. | -| controller.service.externalIPs | list | `[]` | List of node IP addresses at which the external controller service is available. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips | -| controller.service.externalTrafficPolicy | string | `""` | External traffic policy of the external controller service. Set to "Local" to preserve source IP on providers supporting it. Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip | -| controller.service.internal.annotations | object | `{}` | Annotations to be added to the internal controller service. Mandatory for the internal controller service to be created. Varies with the cloud service. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#internal-load-balancer | -| controller.service.internal.appProtocol | bool | `true` | Declare the app protocol of the internal HTTP and HTTPS listeners or not. Supersedes provider-specific annotations for declaring the backend protocol. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#application-protocol | -| controller.service.internal.clusterIP | string | `""` | Pre-defined cluster internal IP address of the internal controller service. Take care of collisions with existing services. This value is immutable. Set once, it can not be changed without deleting and re-creating the service. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#choosing-your-own-ip-address | -| controller.service.internal.enabled | bool | `false` | Enable the internal controller service or not. Remember to configure `controller.service.internal.annotations` when enabling this. | -| controller.service.internal.externalIPs | list | `[]` | List of node IP addresses at which the internal controller service is available. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips | -| controller.service.internal.externalTrafficPolicy | string | `""` | External traffic policy of the internal controller service. Set to "Local" to preserve source IP on providers supporting it. Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip | -| controller.service.internal.ipFamilies | list | `["IPv4"]` | List of IP families (e.g. IPv4, IPv6) assigned to the internal controller service. This field is usually assigned automatically based on cluster configuration and the `ipFamilyPolicy` field. Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services | -| controller.service.internal.ipFamilyPolicy | string | `"SingleStack"` | Represents the dual-stack capabilities of the internal controller service. Possible values are SingleStack, PreferDualStack or RequireDualStack. Fields `ipFamilies` and `clusterIP` depend on the value of this field. Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services | -| controller.service.internal.loadBalancerClass | string | `""` | Load balancer class of the internal controller service. Used by cloud providers to select a load balancer implementation other than the cloud provider default. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-class | -| controller.service.internal.loadBalancerIP | string | `""` | Deprecated: Pre-defined IP address of the internal controller service. Used by cloud providers to connect the resulting load balancer service to a pre-existing static IP. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#loadbalancer | -| controller.service.internal.loadBalancerSourceRanges | list | `[]` | Restrict access to the internal controller service. Values must be CIDRs. Allows any source address by default. | -| controller.service.internal.nodePorts.http | string | `""` | Node port allocated for the internal HTTP listener. If left empty, the service controller allocates one from the configured node port range. | -| controller.service.internal.nodePorts.https | string | `""` | Node port allocated for the internal HTTPS listener. If left empty, the service controller allocates one from the configured node port range. | -| controller.service.internal.nodePorts.tcp | object | `{}` | Node port mapping for internal TCP listeners. If left empty, the service controller allocates them from the configured node port range. Example: tcp: 8080: 30080 | -| controller.service.internal.nodePorts.udp | object | `{}` | Node port mapping for internal UDP listeners. If left empty, the service controller allocates them from the configured node port range. Example: udp: 53: 30053 | -| controller.service.internal.ports | object | `{}` | | -| controller.service.internal.sessionAffinity | string | `""` | Session affinity of the internal controller service. Must be either "None" or "ClientIP" if set. Defaults to "None". Ref: https://kubernetes.io/docs/reference/networking/virtual-ips/#session-affinity | -| controller.service.internal.targetPorts | object | `{}` | | -| controller.service.internal.type | string | `""` | Type of the internal controller service. Defaults to the value of `controller.service.type`. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types | -| controller.service.ipFamilies | list | `["IPv4"]` | List of IP families (e.g. IPv4, IPv6) assigned to the external controller service. This field is usually assigned automatically based on cluster configuration and the `ipFamilyPolicy` field. Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services | -| controller.service.ipFamilyPolicy | string | `"SingleStack"` | Represents the dual-stack capabilities of the external controller service. Possible values are SingleStack, PreferDualStack or RequireDualStack. Fields `ipFamilies` and `clusterIP` depend on the value of this field. Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services | -| controller.service.labels | object | `{}` | Labels to be added to both controller services. | -| controller.service.loadBalancerClass | string | `""` | Load balancer class of the external controller service. Used by cloud providers to select a load balancer implementation other than the cloud provider default. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-class | -| controller.service.loadBalancerIP | string | `""` | Deprecated: Pre-defined IP address of the external controller service. Used by cloud providers to connect the resulting load balancer service to a pre-existing static IP. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#loadbalancer | -| controller.service.loadBalancerSourceRanges | list | `[]` | Restrict access to the external controller service. Values must be CIDRs. Allows any source address by default. | -| controller.service.nodePorts.http | string | `""` | Node port allocated for the external HTTP listener. If left empty, the service controller allocates one from the configured node port range. | -| controller.service.nodePorts.https | string | `""` | Node port allocated for the external HTTPS listener. If left empty, the service controller allocates one from the configured node port range. | -| controller.service.nodePorts.tcp | object | `{}` | Node port mapping for external TCP listeners. If left empty, the service controller allocates them from the configured node port range. Example: tcp: 8080: 30080 | -| controller.service.nodePorts.udp | object | `{}` | Node port mapping for external UDP listeners. If left empty, the service controller allocates them from the configured node port range. Example: udp: 53: 30053 | -| controller.service.ports.http | int | `80` | Port the external HTTP listener is published with. | -| controller.service.ports.https | int | `443` | Port the external HTTPS listener is published with. | -| controller.service.sessionAffinity | string | `""` | Session affinity of the external controller service. Must be either "None" or "ClientIP" if set. Defaults to "None". Ref: https://kubernetes.io/docs/reference/networking/virtual-ips/#session-affinity | -| controller.service.targetPorts.http | string | `"http"` | Port of the ingress controller the external HTTP listener is mapped to. | -| controller.service.targetPorts.https | string | `"https"` | Port of the ingress controller the external HTTPS listener is mapped to. | -| controller.service.type | string | `"LoadBalancer"` | Type of the external controller service. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types | -| controller.shareProcessNamespace | bool | `false` | | -| controller.sysctls | object | `{}` | sysctls for controller pods # Ref: https://kubernetes.io/docs/tasks/administer-cluster/sysctl-cluster/ | -| controller.tcp.annotations | object | `{}` | Annotations to be added to the tcp config configmap | -| controller.tcp.configMapNamespace | string | `""` | Allows customization of the tcp-services-configmap; defaults to $(POD_NAMESPACE) | -| controller.terminationGracePeriodSeconds | int | `300` | `terminationGracePeriodSeconds` to avoid killing pods before we are ready # wait up to five minutes for the drain of connections # | -| controller.tolerations | list | `[]` | Node tolerations for server scheduling to nodes with taints # Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/ # | -| controller.topologySpreadConstraints | list | `[]` | Topology spread constraints rely on node labels to identify the topology domain(s) that each Node is in. # Ref: https://kubernetes.io/docs/concepts/workloads/pods/pod-topology-spread-constraints/ # | -| controller.udp.annotations | object | `{}` | Annotations to be added to the udp config configmap | -| controller.udp.configMapNamespace | string | `""` | Allows customization of the udp-services-configmap; defaults to $(POD_NAMESPACE) | -| controller.updateStrategy | object | `{}` | The update strategy to apply to the Deployment or DaemonSet # | -| controller.watchIngressWithoutClass | bool | `false` | Process Ingress objects without ingressClass annotation/ingressClassName field Overrides value for --watch-ingress-without-class flag of the controller binary Defaults to false | -| defaultBackend.affinity | object | `{}` | Affinity and anti-affinity rules for server scheduling to nodes # Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#affinity-and-anti-affinity | -| defaultBackend.autoscaling.annotations | object | `{}` | | -| defaultBackend.autoscaling.enabled | bool | `false` | | -| defaultBackend.autoscaling.maxReplicas | int | `2` | | -| defaultBackend.autoscaling.minReplicas | int | `1` | | -| defaultBackend.autoscaling.targetCPUUtilizationPercentage | int | `50` | | -| defaultBackend.autoscaling.targetMemoryUtilizationPercentage | int | `50` | | -| defaultBackend.containerSecurityContext | object | `{}` | Security context for default backend containers | -| defaultBackend.enabled | bool | `false` | | -| defaultBackend.existingPsp | string | `""` | Use an existing PSP instead of creating one | -| defaultBackend.extraArgs | object | `{}` | | -| defaultBackend.extraConfigMaps | list | `[]` | | -| defaultBackend.extraEnvs | list | `[]` | Additional environment variables to set for defaultBackend pods | -| defaultBackend.extraVolumeMounts | list | `[]` | | -| defaultBackend.extraVolumes | list | `[]` | | -| defaultBackend.image.allowPrivilegeEscalation | bool | `false` | | -| defaultBackend.image.image | string | `"defaultbackend-amd64"` | | -| defaultBackend.image.pullPolicy | string | `"IfNotPresent"` | | -| defaultBackend.image.readOnlyRootFilesystem | bool | `true` | | -| defaultBackend.image.registry | string | `"registry.k8s.io"` | | -| defaultBackend.image.runAsNonRoot | bool | `true` | | -| defaultBackend.image.runAsUser | int | `65534` | | -| defaultBackend.image.seccompProfile.type | string | `"RuntimeDefault"` | | -| defaultBackend.image.tag | string | `"1.5"` | | -| defaultBackend.labels | object | `{}` | Labels to be added to the default backend resources | -| defaultBackend.livenessProbe.failureThreshold | int | `3` | | -| defaultBackend.livenessProbe.initialDelaySeconds | int | `30` | | -| defaultBackend.livenessProbe.periodSeconds | int | `10` | | -| defaultBackend.livenessProbe.successThreshold | int | `1` | | -| defaultBackend.livenessProbe.timeoutSeconds | int | `5` | | -| defaultBackend.minAvailable | int | `1` | Minimum available pods set in PodDisruptionBudget. | -| defaultBackend.minReadySeconds | int | `0` | `minReadySeconds` to avoid killing pods before we are ready # | -| defaultBackend.name | string | `"defaultbackend"` | | -| defaultBackend.networkPolicy.enabled | bool | `false` | Enable 'networkPolicy' or not | -| defaultBackend.nodeSelector | object | `{"kubernetes.io/os":"linux"}` | Node labels for default backend pod assignment # Ref: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/ # | -| defaultBackend.podAnnotations | object | `{}` | Annotations to be added to default backend pods # | -| defaultBackend.podLabels | object | `{}` | Labels to add to the pod container metadata | -| defaultBackend.podSecurityContext | object | `{}` | Security context for default backend pods | -| defaultBackend.port | int | `8080` | | -| defaultBackend.priorityClassName | string | `""` | | -| defaultBackend.readinessProbe.failureThreshold | int | `6` | | -| defaultBackend.readinessProbe.initialDelaySeconds | int | `0` | | -| defaultBackend.readinessProbe.periodSeconds | int | `5` | | -| defaultBackend.readinessProbe.successThreshold | int | `1` | | -| defaultBackend.readinessProbe.timeoutSeconds | int | `5` | | -| defaultBackend.replicaCount | int | `1` | | -| defaultBackend.resources | object | `{}` | | -| defaultBackend.service.annotations | object | `{}` | | -| defaultBackend.service.externalIPs | list | `[]` | List of IP addresses at which the default backend service is available # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips # | -| defaultBackend.service.loadBalancerSourceRanges | list | `[]` | | -| defaultBackend.service.servicePort | int | `80` | | -| defaultBackend.service.type | string | `"ClusterIP"` | | -| defaultBackend.serviceAccount.automountServiceAccountToken | bool | `true` | | -| defaultBackend.serviceAccount.create | bool | `true` | | -| defaultBackend.serviceAccount.name | string | `""` | | -| defaultBackend.tolerations | list | `[]` | Node tolerations for server scheduling to nodes with taints # Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/ # | -| defaultBackend.topologySpreadConstraints | list | `[]` | Topology spread constraints rely on node labels to identify the topology domain(s) that each Node is in. Ref.: https://kubernetes.io/docs/concepts/workloads/pods/pod-topology-spread-constraints/ | -| defaultBackend.updateStrategy | object | `{}` | The update strategy to apply to the Deployment or DaemonSet # | -| dhParam | string | `""` | A base64-encoded Diffie-Hellman parameter. This can be generated with: `openssl dhparam 4096 2> /dev/null | base64` # Ref: https://github.com/kubernetes/ingress-nginx/tree/main/docs/examples/customization/ssl-dh-param | -| imagePullSecrets | list | `[]` | Optional array of imagePullSecrets containing private registry credentials # Ref: https://kubernetes.io/docs/tasks/configure-pod-container/pull-image-private-registry/ | -| namespaceOverride | string | `""` | Override the deployment namespace; defaults to .Release.Namespace | -| podSecurityPolicy.enabled | bool | `false` | | -| portNamePrefix | string | `""` | Prefix for TCP and UDP ports names in ingress controller service # Some cloud providers, like Yandex Cloud may have a requirements for a port name regex to support cloud load balancer integration | -| rbac.create | bool | `true` | | -| rbac.scope | bool | `false` | | -| revisionHistoryLimit | int | `10` | Rollback limit # | -| serviceAccount.annotations | object | `{}` | Annotations for the controller service account | -| serviceAccount.automountServiceAccountToken | bool | `true` | | -| serviceAccount.create | bool | `true` | | -| serviceAccount.name | string | `""` | | -| tcp | object | `{}` | TCP service key-value pairs # Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/exposing-tcp-udp-services.md # | -| udp | object | `{}` | UDP service key-value pairs # Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/exposing-tcp-udp-services.md # | diff --git a/charts/keep/charts/ingress-nginx/README.md.gotmpl b/charts/keep/charts/ingress-nginx/README.md.gotmpl deleted file mode 100644 index 17b029b..0000000 --- a/charts/keep/charts/ingress-nginx/README.md.gotmpl +++ /dev/null @@ -1,229 +0,0 @@ -{{ template "chart.header" . }} -[ingress-nginx](https://github.com/kubernetes/ingress-nginx) Ingress controller for Kubernetes using NGINX as a reverse proxy and load balancer - -{{ template "chart.versionBadge" . }}{{ template "chart.typeBadge" . }}{{ template "chart.appVersionBadge" . }} - -To use, add `ingressClassName: nginx` spec field or the `kubernetes.io/ingress.class: nginx` annotation to your Ingress resources. - -This chart bootstraps an ingress-nginx deployment on a [Kubernetes](http://kubernetes.io) cluster using the [Helm](https://helm.sh) package manager. - -{{ template "chart.requirementsSection" . }} - -## Get Repo Info - -```console -helm repo add ingress-nginx https://kubernetes.github.io/ingress-nginx -helm repo update -``` - -## Install Chart - -**Important:** only helm3 is supported - -```console -helm install [RELEASE_NAME] ingress-nginx/ingress-nginx -``` - -The command deploys ingress-nginx on the Kubernetes cluster in the default configuration. - -_See [configuration](#configuration) below._ - -_See [helm install](https://helm.sh/docs/helm/helm_install/) for command documentation._ - -## Uninstall Chart - -```console -helm uninstall [RELEASE_NAME] -``` - -This removes all the Kubernetes components associated with the chart and deletes the release. - -_See [helm uninstall](https://helm.sh/docs/helm/helm_uninstall/) for command documentation._ - -## Upgrading Chart - -```console -helm upgrade [RELEASE_NAME] [CHART] --install -``` - -_See [helm upgrade](https://helm.sh/docs/helm/helm_upgrade/) for command documentation._ - -### Migrating from stable/nginx-ingress - -There are two main ways to migrate a release from `stable/nginx-ingress` to `ingress-nginx/ingress-nginx` chart: - -1. For Nginx Ingress controllers used for non-critical services, the easiest method is to [uninstall](#uninstall-chart) the old release and [install](#install-chart) the new one -1. For critical services in production that require zero-downtime, you will want to: - 1. [Install](#install-chart) a second Ingress controller - 1. Redirect your DNS traffic from the old controller to the new controller - 1. Log traffic from both controllers during this changeover - 1. [Uninstall](#uninstall-chart) the old controller once traffic has fully drained from it - -Note that there are some different and upgraded configurations between the two charts, described by Rimas Mocevicius from JFrog in the "Upgrading to ingress-nginx Helm chart" section of [Migrating from Helm chart nginx-ingress to ingress-nginx](https://rimusz.net/migrating-to-ingress-nginx). As the `ingress-nginx/ingress-nginx` chart continues to update, you will want to check current differences by running [helm configuration](#configuration) commands on both charts. - -## Configuration - -See [Customizing the Chart Before Installing](https://helm.sh/docs/intro/using_helm/#customizing-the-chart-before-installing). To see all configurable options with detailed comments, visit the chart's [values.yaml](./values.yaml), or run these configuration commands: - -```console -helm show values ingress-nginx/ingress-nginx -``` - -### PodDisruptionBudget - -Note that the PodDisruptionBudget resource will only be defined if the replicaCount is greater than one, -else it would make it impossible to evacuate a node. See [gh issue #7127](https://github.com/helm/charts/issues/7127) for more info. - -### Prometheus Metrics - -The Ingress-Nginx Controller can export Prometheus metrics, by setting `controller.metrics.enabled` to `true`. - -You can add Prometheus annotations to the metrics service using `controller.metrics.service.annotations`. -Alternatively, if you use the Prometheus Operator, you can enable ServiceMonitor creation using `controller.metrics.serviceMonitor.enabled`. And set `controller.metrics.serviceMonitor.additionalLabels.release="prometheus"`. "release=prometheus" should match the label configured in the prometheus servicemonitor ( see `kubectl get servicemonitor prometheus-kube-prom-prometheus -oyaml -n prometheus`) - -### ingress-nginx nginx\_status page/stats server - -Previous versions of this chart had a `controller.stats.*` configuration block, which is now obsolete due to the following changes in Ingress-Nginx Controller: - -- In [0.16.1](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0161), the vts (virtual host traffic status) dashboard was removed -- In [0.23.0](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0230), the status page at port 18080 is now a unix socket webserver only available at localhost. - You can use `curl --unix-socket /tmp/nginx-status-server.sock http://localhost/nginx_status` inside the controller container to access it locally, or use the snippet from [nginx-ingress changelog](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0230) to re-enable the http server - -### ExternalDNS Service Configuration - -Add an [ExternalDNS](https://github.com/kubernetes-sigs/external-dns) annotation to the LoadBalancer service: - -```yaml -controller: - service: - annotations: - external-dns.alpha.kubernetes.io/hostname: kubernetes-example.com. -``` - -### AWS L7 ELB with SSL Termination - -Annotate the controller as shown in the [nginx-ingress l7 patch](https://github.com/kubernetes/ingress-nginx/blob/ab3a789caae65eec4ad6e3b46b19750b481b6bce/deploy/aws/l7/service-l7.yaml): - -```yaml -controller: - service: - targetPorts: - http: http - https: http - annotations: - service.beta.kubernetes.io/aws-load-balancer-ssl-cert: arn:aws:acm:XX-XXXX-X:XXXXXXXXX:certificate/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXX - service.beta.kubernetes.io/aws-load-balancer-backend-protocol: "http" - service.beta.kubernetes.io/aws-load-balancer-ssl-ports: "https" - service.beta.kubernetes.io/aws-load-balancer-connection-idle-timeout: '3600' -``` - -### Additional Internal Load Balancer - -This setup is useful when you need both external and internal load balancers but don't want to have multiple ingress controllers and multiple ingress objects per application. - -By default, the ingress object will point to the external load balancer address, but if correctly configured, you can make use of the internal one if the URL you are looking up resolves to the internal load balancer's URL. - -You'll need to set both the following values: - -`controller.service.internal.enabled` -`controller.service.internal.annotations` - -If one of them is missing the internal load balancer will not be deployed. Example you may have `controller.service.internal.enabled=true` but no annotations set, in this case no action will be taken. - -`controller.service.internal.annotations` varies with the cloud service you're using. - -Example for AWS: - -```yaml -controller: - service: - internal: - enabled: true - annotations: - # Create internal NLB - service.beta.kubernetes.io/aws-load-balancer-scheme: "internal" - # Create internal ELB(Deprecated) - # service.beta.kubernetes.io/aws-load-balancer-internal: "true" - # Any other annotation can be declared here. -``` - -Example for GCE: - -```yaml -controller: - service: - internal: - enabled: true - annotations: - # Create internal LB. More information: https://cloud.google.com/kubernetes-engine/docs/how-to/internal-load-balancing - # For GKE versions 1.17 and later - networking.gke.io/load-balancer-type: "Internal" - # For earlier versions - # cloud.google.com/load-balancer-type: "Internal" - - # Any other annotation can be declared here. -``` - -Example for Azure: - -```yaml -controller: - service: - annotations: - # Create internal LB - service.beta.kubernetes.io/azure-load-balancer-internal: "true" - # Any other annotation can be declared here. -``` - -Example for Oracle Cloud Infrastructure: - -```yaml -controller: - service: - annotations: - # Create internal LB - service.beta.kubernetes.io/oci-load-balancer-internal: "true" - # Any other annotation can be declared here. -``` - -The load balancer annotations of more cloud service providers can be found: [Internal load balancer](https://kubernetes.io/docs/concepts/services-networking/service/#internal-load-balancer). - -An use case for this scenario is having a split-view DNS setup where the public zone CNAME records point to the external balancer URL while the private zone CNAME records point to the internal balancer URL. This way, you only need one ingress kubernetes object. - -Optionally you can set `controller.service.loadBalancerIP` if you need a static IP for the resulting `LoadBalancer`. - -### Ingress Admission Webhooks - -With nginx-ingress-controller version 0.25+, the Ingress-Nginx Controller pod exposes an endpoint that will integrate with the `validatingwebhookconfiguration` Kubernetes feature to prevent bad ingress from being added to the cluster. -**This feature is enabled by default since 0.31.0.** - -With nginx-ingress-controller in 0.25.* work only with kubernetes 1.14+, 0.26 fix [this issue](https://github.com/kubernetes/ingress-nginx/pull/4521) - -#### How the Chart Configures the Hooks -A validating and configuration requires the endpoint to which the request is sent to use TLS. It is possible to set up custom certificates to do this, but in most cases, a self-signed certificate is enough. The setup of this component requires some more complex orchestration when using helm. The steps are created to be idempotent and to allow turning the feature on and off without running into helm quirks. - -1. A pre-install hook provisions a certificate into the same namespace using a format compatible with provisioning using end user certificates. If the certificate already exists, the hook exits. -2. The Ingress-Nginx Controller pod is configured to use a TLS proxy container, which will load that certificate. -3. Validating and Mutating webhook configurations are created in the cluster. -4. A post-install hook reads the CA from the secret created by step 1 and patches the Validating and Mutating webhook configurations. This process will allow a custom CA provisioned by some other process to also be patched into the webhook configurations. The chosen failure policy is also patched into the webhook configurations - -#### Alternatives -It should be possible to use [cert-manager/cert-manager](https://github.com/cert-manager/cert-manager) if a more complete solution is required. - -You can enable automatic self-signed TLS certificate provisioning via cert-manager by setting the `controller.admissionWebhooks.certManager.enabled` value to true. - -Please ensure that cert-manager is correctly installed and configured. - -### Helm Error When Upgrading: spec.clusterIP: Invalid value: "" - -If you are upgrading this chart from a version between 0.31.0 and 1.2.2 then you may get an error like this: - -```console -Error: UPGRADE FAILED: Service "?????-controller" is invalid: spec.clusterIP: Invalid value: "": field is immutable -``` - -Detail of how and why are in [this issue](https://github.com/helm/charts/pull/13646) but to resolve this you can set `xxxx.service.omitClusterIP` to `true` where `xxxx` is the service referenced in the error. - -As of version `1.26.0` of this chart, by simply not providing any clusterIP value, `invalid: spec.clusterIP: Invalid value: "": field is immutable` will no longer occur since `clusterIP: ""` will not be rendered. - -{{ template "chart.valuesSection" . }} diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.10.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.10.0.md deleted file mode 100644 index b42d6c2..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.10.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.10.0 - -* [#5843](https://github.com/kubernetes/ingress-nginx/pull/5843) Update jettech/kube-webhook-certgen image - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.9.1...ingress-nginx-2.10.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.0.md deleted file mode 100644 index e549b38..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.0.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.11.0 - -* [#5879](https://github.com/kubernetes/ingress-nginx/pull/5879) Update helm chart for v0.34.0 -* [#5671](https://github.com/kubernetes/ingress-nginx/pull/5671) Make liveness probe more fault tolerant than readiness probe - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.10.0...ingress-nginx-2.11.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.1.md deleted file mode 100644 index d910d3b..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.11.1 - -* [#5900](https://github.com/kubernetes/ingress-nginx/pull/5900) Release helm chart for v0.34.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.11.0...ingress-nginx-2.11.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.2.md deleted file mode 100644 index 9f78210..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.2.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.11.2 - -* [#5951](https://github.com/kubernetes/ingress-nginx/pull/5951) Bump chart patch version - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.11.1...ingress-nginx-2.11.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.3.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.3.md deleted file mode 100644 index 3447691..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.3.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.11.3 - -* [#6038](https://github.com/kubernetes/ingress-nginx/pull/6038) Bump chart version PATCH - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.11.2...ingress-nginx-2.11.3 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.0.md deleted file mode 100644 index 5cb3888..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.0.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.12.0 - -* [#6039](https://github.com/kubernetes/ingress-nginx/pull/6039) Add configurable serviceMonitor metricRelabelling and targetLabels -* [#6044](https://github.com/kubernetes/ingress-nginx/pull/6044) Fix YAML linting - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.11.3...ingress-nginx-2.12.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.1.md deleted file mode 100644 index 94d121d..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.12.1 - -* [#6075](https://github.com/kubernetes/ingress-nginx/pull/6075) Sync helm chart affinity examples - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.12.0...ingress-nginx-2.12.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.13.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.13.0.md deleted file mode 100644 index 01fe0b1..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.13.0.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.13.0 - -* [#6093](https://github.com/kubernetes/ingress-nginx/pull/6093) Release v0.35.0 -* [#6080](https://github.com/kubernetes/ingress-nginx/pull/6080) Switch images to k8s.gcr.io after Vanity Domain Flip - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.12.1...ingress-nginx-2.13.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.14.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.14.0.md deleted file mode 100644 index 2fb7a5a..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.14.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.14.0 - -* [#6104](https://github.com/kubernetes/ingress-nginx/pull/6104) Misc fixes for nginx-ingress chart for better keel and prometheus-operator integration - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.13.0...ingress-nginx-2.14.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.15.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.15.0.md deleted file mode 100644 index 543a559..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.15.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.15.0 - -* [#6087](https://github.com/kubernetes/ingress-nginx/pull/6087) Adding parameter for externalTrafficPolicy in internal controller service spec - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.14.0...ingress-nginx-2.15.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.16.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.16.0.md deleted file mode 100644 index 996f448..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.16.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.16.0 - -* [#6154](https://github.com/kubernetes/ingress-nginx/pull/6154) add `topologySpreadConstraint` to controller - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.15.0...ingress-nginx-2.16.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.0.md deleted file mode 100644 index 11c5f5f..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.9.0 - -* [#5795](https://github.com/kubernetes/ingress-nginx/pull/5795) Use fully qualified images to avoid cri-o issues - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-TODO...ingress-nginx-2.9.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.1.md deleted file mode 100644 index 7d4314d..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.9.1 - -* [#5823](https://github.com/kubernetes/ingress-nginx/pull/5823) Add quoting to sysctls because numeric values need to be presented as strings (#5823) - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.9.0...ingress-nginx-2.9.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.0.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.0.0.md deleted file mode 100644 index a7d50ee..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.0.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.0.0 - -* [#6167](https://github.com/kubernetes/ingress-nginx/pull/6167) Update chart requirements - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.16.0...ingress-nginx-3.0.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.0.md deleted file mode 100644 index 3369bed..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.10.0 - -* Fix routing regression introduced in 0.41.0 with PathType Exact - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.9.0...ingress-nginx-3.10.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.1.md deleted file mode 100644 index 6ff682e..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.10.1 - -* Fix regression introduced in 0.41.0 with external authentication - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.10.0...ingress-nginx-3.10.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.0.md deleted file mode 100644 index 69ba550..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.11.0 - -* Support Keda Autoscaling - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.10.1...ingress-nginx-3.11.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.1.md deleted file mode 100644 index 4e81f4b..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.11.1 - -* [#6505](https://github.com/kubernetes/ingress-nginx/pull/6505) Reorder HPA resource list to work with GitOps tooling - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.11.0...ingress-nginx-3.11.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.12.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.12.0.md deleted file mode 100644 index 41b9744..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.12.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.12.0 - -* [#6514](https://github.com/kubernetes/ingress-nginx/pull/6514) Remove helm2 support and update docs - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.11.1...ingress-nginx-3.12.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.13.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.13.0.md deleted file mode 100644 index 0855a79..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.13.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.13.0 - -* [#6544](https://github.com/kubernetes/ingress-nginx/pull/6544) Fix default backend HPA name variable - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.12.0...ingress-nginx-3.13.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.14.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.14.0.md deleted file mode 100644 index e07880b..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.14.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.14.0 - -* [#6469](https://github.com/kubernetes/ingress-nginx/pull/6469) Allow custom service names for controller and backend - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.13.0...ingress-nginx-3.14.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.0.md deleted file mode 100644 index 3053a35..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.15.0 - -* [#6586](https://github.com/kubernetes/ingress-nginx/pull/6586) Fix 'maxmindLicenseKey' location in values.yaml - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.14.0...ingress-nginx-3.15.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.1.md deleted file mode 100644 index f11ee0a..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.15.1 - -* Fix chart-releaser action - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.15.0...ingress-nginx-3.15.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.0.md deleted file mode 100644 index fba30b1..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.16.0 - -* [#6646](https://github.com/kubernetes/ingress-nginx/pull/6646) Added LoadBalancerIP value for internal service - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.15.1...helm-chart-3.16.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.1.md deleted file mode 100644 index 650d1b8..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.16.1 - -* Fix chart-releaser action - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.16.0...helm-chart-3.16.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.17.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.17.0.md deleted file mode 100644 index 175c7a2..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.17.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.17.0 - -* Update ingress-nginx v0.42.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.16.1...helm-chart-3.17.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.18.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.18.0.md deleted file mode 100644 index 31b815e..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.18.0.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.18.0 - -* [#6688](https://github.com/kubernetes/ingress-nginx/pull/6688) Allow volume-type emptyDir in controller podsecuritypolicy -* [#6691](https://github.com/kubernetes/ingress-nginx/pull/6691) Improve parsing of helm parameters - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.17.0...helm-chart-3.18.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.19.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.19.0.md deleted file mode 100644 index 0970bf0..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.19.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.19.0 - -* Update ingress-nginx v0.43.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.18.0...helm-chart-3.19.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.0.md deleted file mode 100644 index 4b81ae4..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.20.0 - -* [#6730](https://github.com/kubernetes/ingress-nginx/pull/6730) Do not create HPA for defaultBackend if not enabled. - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.19.0...helm-chart-3.20.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.1.md deleted file mode 100644 index 952bf2b..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.1.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.20.1 - -* Do not create KEDA in case of DaemonSets. -* Fix KEDA v2 definition - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.20.0...helm-chart-3.20.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.21.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.21.0.md deleted file mode 100644 index 25edbef..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.21.0.md +++ /dev/null @@ -1,12 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.21.0 - -* [#6783](https://github.com/kubernetes/ingress-nginx/pull/6783) Add custom annotations to ScaledObject -* [#6761](https://github.com/kubernetes/ingress-nginx/pull/6761) Adding quotes in the serviceAccount name in Helm values -* [#6767](https://github.com/kubernetes/ingress-nginx/pull/6767) Remove ClusterRole when scope option is enabled -* [#6785](https://github.com/kubernetes/ingress-nginx/pull/6785) Update kube-webhook-certgen image to v1.5.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.20.1...helm-chart-3.21.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.22.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.22.0.md deleted file mode 100644 index 147d664..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.22.0.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.22.0 - -* [#6802](https://github.com/kubernetes/ingress-nginx/pull/6802) Add value for configuring a custom Diffie-Hellman parameters file -* [#6815](https://github.com/kubernetes/ingress-nginx/pull/6815) Allow use of numeric namespaces in helm chart - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.21.0...helm-chart-3.22.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.23.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.23.0.md deleted file mode 100644 index 5dcb50f..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.23.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.23.0 - -* Update ingress-nginx v0.44.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.22.0...helm-chart-3.23.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.24.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.24.0.md deleted file mode 100644 index d7db808..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.24.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.24.0 - -* [#6908](https://github.com/kubernetes/ingress-nginx/pull/6908) Add volumes to default-backend deployment - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.23.0...helm-chart-3.24.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.25.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.25.0.md deleted file mode 100644 index f9679a1..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.25.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.25.0 - -* [#6957](https://github.com/kubernetes/ingress-nginx/pull/6957) Add ability to specify automountServiceAccountToken - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.24.0...helm-chart-3.25.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.26.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.26.0.md deleted file mode 100644 index 0c3a1df..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.26.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.26.0 - -* [#6979](https://github.com/kubernetes/ingress-nginx/pull/6979) Changed servicePort value for metrics - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.25.0...helm-chart-3.26.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.27.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.27.0.md deleted file mode 100644 index 8113d7b..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.27.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.27.0 - -* Update ingress-nginx v0.45.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.26.0...helm-chart-3.27.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.28.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.28.0.md deleted file mode 100644 index eee0ccb..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.28.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.28.0 - -* [#6900](https://github.com/kubernetes/ingress-nginx/pull/6900) Support existing PSPs - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.27.0...helm-chart-3.28.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.29.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.29.0.md deleted file mode 100644 index f0fabdc..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.29.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.29.0 - -* [#6945](https://github.com/kubernetes/ingress-nginx/pull/7020) Add option to specify job label for ServiceMonitor - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.28.0...helm-chart-3.29.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.0.md deleted file mode 100644 index 09fab37..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.0.md +++ /dev/null @@ -1,12 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.3.0 - -* [#6203](https://github.com/kubernetes/ingress-nginx/pull/6203) Refactor parsing of key values -* [#6162](https://github.com/kubernetes/ingress-nginx/pull/6162) Add helm chart options to expose metrics service as NodePort -* [#6180](https://github.com/kubernetes/ingress-nginx/pull/6180) Fix helm chart admissionReviewVersions regression -* [#6169](https://github.com/kubernetes/ingress-nginx/pull/6169) Fix Typo in example prometheus rules - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.0.0...ingress-nginx-3.3.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.1.md deleted file mode 100644 index 81f44fd..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.1.md +++ /dev/null @@ -1,12 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.3.1 - -* [#6259](https://github.com/kubernetes/ingress-nginx/pull/6259) Release helm chart -* [#6258](https://github.com/kubernetes/ingress-nginx/pull/6258) Fix chart markdown link -* [#6253](https://github.com/kubernetes/ingress-nginx/pull/6253) Release v0.40.0 -* [#6233](https://github.com/kubernetes/ingress-nginx/pull/6233) Add admission controller e2e test - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.3.0...ingress-nginx-3.3.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.30.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.30.0.md deleted file mode 100644 index 77ad6b4..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.30.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.30.0 - -* [#7092](https://github.com/kubernetes/ingress-nginx/pull/7092) Removes the possibility of using localhost in ExternalNames as endpoints - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.29.0...helm-chart-3.30.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.31.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.31.0.md deleted file mode 100644 index bc07fed..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.31.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.31.0 - -* [7137] https://github.com/kubernetes/ingress-nginx/pull/7137 Add support for custom probes - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.30.0...helm-chart-3.31.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.32.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.32.0.md deleted file mode 100644 index 68f7ed6..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.32.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.32.0 - -* [7117] https://github.com/kubernetes/ingress-nginx/pull/7117 Add annotations for HPA - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.31.0...helm-chart-3.32.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.33.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.33.0.md deleted file mode 100644 index b56c5fc..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.33.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.33.0 - -* [7164] https://github.com/kubernetes/ingress-nginx/pull/7164 Update nginx to v1.20.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.32.0...helm-chart-3.33.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.34.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.34.0.md deleted file mode 100644 index a28cd02..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.34.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.34.0 - -* [7256] https://github.com/kubernetes/ingress-nginx/pull/7256 Add namespace field in the namespace scoped resource templates - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.33.0...helm-chart-3.34.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.4.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.4.0.md deleted file mode 100644 index 3b4ca93..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.4.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.4.0 - -* [#6268](https://github.com/kubernetes/ingress-nginx/pull/6268) Update to 0.40.2 in helm chart #6288 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.3.1...ingress-nginx-3.4.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.0.md deleted file mode 100644 index 44991b3..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.5.0 - -* [#6260](https://github.com/kubernetes/ingress-nginx/pull/6260) Allow Helm Chart to customize admission webhook's annotations, timeoutSeconds, namespaceSelector, objectSelector and cert files locations - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.4.0...ingress-nginx-3.5.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.1.md deleted file mode 100644 index 740f00c..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.5.1 - -* [#6299](https://github.com/kubernetes/ingress-nginx/pull/6299) Fix helm chart release - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.5.0...ingress-nginx-3.5.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.6.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.6.0.md deleted file mode 100644 index 4af7f11..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.6.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.6.0 - -* [#6305](https://github.com/kubernetes/ingress-nginx/pull/6305) Add default linux nodeSelector - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.5.1...ingress-nginx-3.6.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.0.md deleted file mode 100644 index a6b1299..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.7.0 - -* [#6316](https://github.com/kubernetes/ingress-nginx/pull/6316) Numerals in podAnnotations in quotes [#6315](https://github.com/kubernetes/ingress-nginx/issues/6315) - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.6.0...ingress-nginx-3.7.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.1.md deleted file mode 100644 index 6ba12df..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.7.1 - -* [#6326](https://github.com/kubernetes/ingress-nginx/pull/6326) Fix liveness and readiness probe path in daemonset chart - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.7.0...ingress-nginx-3.7.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.8.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.8.0.md deleted file mode 100644 index 8df250a..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.8.0.md +++ /dev/null @@ -1,13 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.8.0 - -* [#6395](https://github.com/kubernetes/ingress-nginx/pull/6395) Update jettech/kube-webhook-certgen image -* [#6377](https://github.com/kubernetes/ingress-nginx/pull/6377) Added loadBalancerSourceRanges for internal lbs -* [#6356](https://github.com/kubernetes/ingress-nginx/pull/6356) Add securitycontext settings on defaultbackend -* [#6401](https://github.com/kubernetes/ingress-nginx/pull/6401) Fix controller service annotations -* [#6403](https://github.com/kubernetes/ingress-nginx/pull/6403) Initial helm chart changelog - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.7.1...ingress-nginx-3.8.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.9.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.9.0.md deleted file mode 100644 index e8c9def..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.9.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.9.0 - -* [#6423](https://github.com/kubernetes/ingress-nginx/pull/6423) Add Default backend HPA autoscaling - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.8.0...ingress-nginx-3.9.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.1.md deleted file mode 100644 index 7a187b3..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.1 - -* [7535] https://github.com/kubernetes/ingress-nginx/pull/7535 Release v1.0.0 ingress-nginx - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.34.0...helm-chart-4.0.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.10.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.10.md deleted file mode 100644 index c5d6516..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.10.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.10 - -* [7964] https://github.com/kubernetes/ingress-nginx/pull/7964 Update controller version to v1.1.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.9...helm-chart-4.0.10 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.11.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.11.md deleted file mode 100644 index 5541823..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.11.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.11 - -* [7873] https://github.com/kubernetes/ingress-nginx/pull/7873 Makes the [appProtocol](https://kubernetes.io/docs/concepts/services-networking/_print/#application-protocol) field optional. - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.10...helm-chart-4.0.11 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.12.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.12.md deleted file mode 100644 index 320f6f5..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.12.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.12 - -* [7978] https://github.com/kubernetes/ingress-nginx/pull/7979 Support custom annotations in admissions Jobs - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.11...helm-chart-4.0.12 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.13.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.13.md deleted file mode 100644 index edd9228..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.13.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.13 - -* [8008] https://github.com/kubernetes/ingress-nginx/pull/8008 Add relabelings in controller-servicemonitor.yaml - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.12...helm-chart-4.0.13 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.14.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.14.md deleted file mode 100644 index e927010..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.14.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.14 - -* [8061] https://github.com/kubernetes/ingress-nginx/pull/8061 Using helm-docs to populate values table in README.md - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.13...helm-chart-4.0.14 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.15.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.15.md deleted file mode 100644 index d3d14a9..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.15.md +++ /dev/null @@ -1,43 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.15 - -* [8120] https://github.com/kubernetes/ingress-nginx/pull/8120 Update go in runner and release v1.1.1 -* [8119] https://github.com/kubernetes/ingress-nginx/pull/8119 Update to go v1.17.6 -* [8118] https://github.com/kubernetes/ingress-nginx/pull/8118 Remove deprecated libraries, update other libs -* [8117] https://github.com/kubernetes/ingress-nginx/pull/8117 Fix codegen errors -* [8115] https://github.com/kubernetes/ingress-nginx/pull/8115 chart/ghaction: set the correct permission to have access to push a release -* [8098] https://github.com/kubernetes/ingress-nginx/pull/8098 generating SHA for CA only certs in backend_ssl.go + comparison of P… -* [8088] https://github.com/kubernetes/ingress-nginx/pull/8088 Fix Edit this page link to use main branch -* [8072] https://github.com/kubernetes/ingress-nginx/pull/8072 Expose GeoIP2 Continent code as variable -* [8061] https://github.com/kubernetes/ingress-nginx/pull/8061 docs(charts): using helm-docs for chart -* [8058] https://github.com/kubernetes/ingress-nginx/pull/8058 Bump github.com/spf13/cobra from 1.2.1 to 1.3.0 -* [8054] https://github.com/kubernetes/ingress-nginx/pull/8054 Bump google.golang.org/grpc from 1.41.0 to 1.43.0 -* [8051] https://github.com/kubernetes/ingress-nginx/pull/8051 align bug report with feature request regarding kind documentation -* [8046] https://github.com/kubernetes/ingress-nginx/pull/8046 Report expired certificates (#8045) -* [8044] https://github.com/kubernetes/ingress-nginx/pull/8044 remove G109 check till gosec resolves issues -* [8042] https://github.com/kubernetes/ingress-nginx/pull/8042 docs_multiple_instances_one_cluster_ticket_7543 -* [8041] https://github.com/kubernetes/ingress-nginx/pull/8041 docs: fix typo'd executable name -* [8035] https://github.com/kubernetes/ingress-nginx/pull/8035 Comment busy owners -* [8029] https://github.com/kubernetes/ingress-nginx/pull/8029 Add stream-snippet as a ConfigMap and Annotation option -* [8023] https://github.com/kubernetes/ingress-nginx/pull/8023 fix nginx compilation flags -* [8021] https://github.com/kubernetes/ingress-nginx/pull/8021 Disable default modsecurity_rules_file if modsecurity-snippet is specified -* [8019] https://github.com/kubernetes/ingress-nginx/pull/8019 Revise main documentation page -* [8018] https://github.com/kubernetes/ingress-nginx/pull/8018 Preserve order of plugin invocation -* [8015] https://github.com/kubernetes/ingress-nginx/pull/8015 Add newline indenting to admission webhook annotations -* [8014] https://github.com/kubernetes/ingress-nginx/pull/8014 Add link to example error page manifest in docs -* [8009] https://github.com/kubernetes/ingress-nginx/pull/8009 Fix spelling in documentation and top-level files -* [8008] https://github.com/kubernetes/ingress-nginx/pull/8008 Add relabelings in controller-servicemonitor.yaml -* [8003] https://github.com/kubernetes/ingress-nginx/pull/8003 Minor improvements (formatting, consistency) in install guide -* [8001] https://github.com/kubernetes/ingress-nginx/pull/8001 fix: go-grpc Dockerfile -* [7999] https://github.com/kubernetes/ingress-nginx/pull/7999 images: use k8s-staging-test-infra/gcb-docker-gcloud -* [7996] https://github.com/kubernetes/ingress-nginx/pull/7996 doc: improvement -* [7983] https://github.com/kubernetes/ingress-nginx/pull/7983 Fix a couple of misspellings in the annotations documentation. -* [7979] https://github.com/kubernetes/ingress-nginx/pull/7979 allow set annotations for admission Jobs -* [7977] https://github.com/kubernetes/ingress-nginx/pull/7977 Add ssl_reject_handshake to default server -* [7975] https://github.com/kubernetes/ingress-nginx/pull/7975 add legacy version update v0.50.0 to main changelog -* [7972] https://github.com/kubernetes/ingress-nginx/pull/7972 updated service upstream definition - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.14...helm-chart-4.0.15 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.18.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.18.md deleted file mode 100644 index 30a8f75..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.18.md +++ /dev/null @@ -1,40 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.18 - -* [8291](https://github.com/kubernetes/ingress-nginx/pull/8291) remove git tag env from cloud build -* [8286](https://github.com/kubernetes/ingress-nginx/pull/8286) Fix OpenTelemetry sidecar image build -* [8277](https://github.com/kubernetes/ingress-nginx/pull/8277) Add OpenSSF Best practices badge -* [8273](https://github.com/kubernetes/ingress-nginx/pull/8273) Issue#8241 -* [8267](https://github.com/kubernetes/ingress-nginx/pull/8267) Add fsGroup value to admission-webhooks/job-patch charts -* [8262](https://github.com/kubernetes/ingress-nginx/pull/8262) Updated confusing error -* [8256](https://github.com/kubernetes/ingress-nginx/pull/8256) fix: deny locations with invalid auth-url annotation -* [8253](https://github.com/kubernetes/ingress-nginx/pull/8253) Add a certificate info metric -* [8236](https://github.com/kubernetes/ingress-nginx/pull/8236) webhook: remove useless code. -* [8227](https://github.com/kubernetes/ingress-nginx/pull/8227) Update libraries in webhook image -* [8225](https://github.com/kubernetes/ingress-nginx/pull/8225) fix inconsistent-label-cardinality for prometheus metrics: nginx_ingress_controller_requests -* [8221](https://github.com/kubernetes/ingress-nginx/pull/8221) Do not validate ingresses with unknown ingress class in admission webhook endpoint -* [8210](https://github.com/kubernetes/ingress-nginx/pull/8210) Bump github.com/prometheus/client_golang from 1.11.0 to 1.12.1 -* [8209](https://github.com/kubernetes/ingress-nginx/pull/8209) Bump google.golang.org/grpc from 1.43.0 to 1.44.0 -* [8204](https://github.com/kubernetes/ingress-nginx/pull/8204) Add Artifact Hub lint -* [8203](https://github.com/kubernetes/ingress-nginx/pull/8203) Fix Indentation of example and link to cert-manager tutorial -* [8201](https://github.com/kubernetes/ingress-nginx/pull/8201) feat(metrics): add path and method labels to requests countera -* [8199](https://github.com/kubernetes/ingress-nginx/pull/8199) use functional options to reduce number of methods creating an EchoDeployment -* [8196](https://github.com/kubernetes/ingress-nginx/pull/8196) docs: fix inconsistent controller annotation -* [8191](https://github.com/kubernetes/ingress-nginx/pull/8191) Using Go install for misspell -* [8186](https://github.com/kubernetes/ingress-nginx/pull/8186) prometheus+grafana using servicemonitor -* [8185](https://github.com/kubernetes/ingress-nginx/pull/8185) Append elements on match, instead of removing for cors-annotations -* [8179](https://github.com/kubernetes/ingress-nginx/pull/8179) Bump github.com/opencontainers/runc from 1.0.3 to 1.1.0 -* [8173](https://github.com/kubernetes/ingress-nginx/pull/8173) Adding annotations to the controller service account -* [8163](https://github.com/kubernetes/ingress-nginx/pull/8163) Update the $req_id placeholder description -* [8162](https://github.com/kubernetes/ingress-nginx/pull/8162) Versioned static manifests -* [8159](https://github.com/kubernetes/ingress-nginx/pull/8159) Adding some geoip variables and default values -* [8155](https://github.com/kubernetes/ingress-nginx/pull/8155) #7271 feat: avoid-pdb-creation-when-default-backend-disabled-and-replicas-gt-1 -* [8151](https://github.com/kubernetes/ingress-nginx/pull/8151) Automatically generate helm docs -* [8143](https://github.com/kubernetes/ingress-nginx/pull/8143) Allow to configure delay before controller exits -* [8136](https://github.com/kubernetes/ingress-nginx/pull/8136) add ingressClass option to helm chart - back compatibility with ingress.class annotations -* [8126](https://github.com/kubernetes/ingress-nginx/pull/8126) Example for JWT - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.15...helm-chart-4.0.18 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.2.md deleted file mode 100644 index 9dbd003..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.2.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.2 - -* [7681] https://github.com/kubernetes/ingress-nginx/pull/7681 Release v1.0.1 of ingress-nginx - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.1...helm-chart-4.0.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.3.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.3.md deleted file mode 100644 index 09b89f6..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.3.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.3 - -* [7707] https://github.com/kubernetes/ingress-nginx/pull/7707 Release v1.0.2 of ingress-nginx - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.2...helm-chart-4.0.3 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.5.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.5.md deleted file mode 100644 index be67704..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.5.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.5 - -* [7740] https://github.com/kubernetes/ingress-nginx/pull/7740 Release v1.0.3 of ingress-nginx - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.3...helm-chart-4.0.5 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.6.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.6.md deleted file mode 100644 index 25276e2..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.6.md +++ /dev/null @@ -1,12 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.6 - -* [7804] https://github.com/kubernetes/ingress-nginx/pull/7804 Release v1.0.4 of ingress-nginx -* [7651] https://github.com/kubernetes/ingress-nginx/pull/7651 Support ipFamilyPolicy and ipFamilies fields in Helm Chart -* [7798] https://github.com/kubernetes/ingress-nginx/pull/7798 Exoscale: use HTTP Healthcheck mode -* [7793] https://github.com/kubernetes/ingress-nginx/pull/7793 Update kube-webhook-certgen to v1.1.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.5...helm-chart-4.0.6 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.7.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.7.md deleted file mode 100644 index 50fd922..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.7.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.7 - -* [7923] https://github.com/kubernetes/ingress-nginx/pull/7923 Release v1.0.5 of ingress-nginx -* [7806] https://github.com/kubernetes/ingress-nginx/pull/7806 Choice option for internal/external loadbalancer type service - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.6...helm-chart-4.0.7 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.9.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.9.md deleted file mode 100644 index f2f725c..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.9.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.9 - -* [6992] https://github.com/kubernetes/ingress-nginx/pull/6992 Add ability to specify labels for all resources - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.7...helm-chart-4.0.9 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.0.md deleted file mode 100644 index 24aaf49..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.0.md +++ /dev/null @@ -1,21 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.1.0 - -* [8481](https://github.com/kubernetes/ingress-nginx/pull/8481) Fix log creation in chroot script -* [8479](https://github.com/kubernetes/ingress-nginx/pull/8479) changed nginx base img tag to img built with alpine3.14.6 -* [8478](https://github.com/kubernetes/ingress-nginx/pull/8478) update base images and protobuf gomod -* [8468](https://github.com/kubernetes/ingress-nginx/pull/8468) Fallback to ngx.var.scheme for redirectScheme with use-forward-headers when X-Forwarded-Proto is empty -* [8456](https://github.com/kubernetes/ingress-nginx/pull/8456) Implement object deep inspector -* [8455](https://github.com/kubernetes/ingress-nginx/pull/8455) Update dependencies -* [8454](https://github.com/kubernetes/ingress-nginx/pull/8454) Update index.md -* [8447](https://github.com/kubernetes/ingress-nginx/pull/8447) typo fixing -* [8446](https://github.com/kubernetes/ingress-nginx/pull/8446) Fix suggested annotation-value-word-blocklist -* [8444](https://github.com/kubernetes/ingress-nginx/pull/8444) replace deprecated topology key in example with current one -* [8443](https://github.com/kubernetes/ingress-nginx/pull/8443) Add dependency review enforcement -* [8434](https://github.com/kubernetes/ingress-nginx/pull/8434) added new auth-tls-match-cn annotation -* [8426](https://github.com/kubernetes/ingress-nginx/pull/8426) Bump github.com/prometheus/common from 0.32.1 to 0.33.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.18...helm-chart-4.1.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.2.md deleted file mode 100644 index 2061855..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.2.md +++ /dev/null @@ -1,11 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.1.2 - -* [8587](https://github.com/kubernetes/ingress-nginx/pull/8587) Add CAP_SYS_CHROOT to DS/PSP when needed -* [8458](https://github.com/kubernetes/ingress-nginx/pull/8458) Add portNamePrefix Helm chart parameter -* [8522](https://github.com/kubernetes/ingress-nginx/pull/8522) Add documentation for controller.service.loadBalancerIP in Helm chart - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.1.0...helm-chart-4.1.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.0.md deleted file mode 100644 index a1f1847..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.10.0 - -* - "Update Ingress-Nginx version controller-v1.10.0" - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.9.1...helm-chart-4.10.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.1.md deleted file mode 100644 index 3a28de0..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.1.md +++ /dev/null @@ -1,11 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.10.1 - -* - "update post submit helm ci and clean up (#11221)" -* - "refactor helm ci tests part I (#11188)" -* - "Update Ingress-Nginx version controller-v1.10.1" - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.10.0...helm-chart-4.10.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.2.md deleted file mode 100644 index 399bd98..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.2.md +++ /dev/null @@ -1,18 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.10.2 - -* Chores: Align security contacts & chart maintainers to actual owners. (#11480) -* Fix helm install on cloud provider admonition block (#11412) -* edited helm-install tips (#11411) -* added info for aws helm install (#11410) -* add workflow to helm release and update ct for branch (#11317) -* Merge pull request #11277 from strongjz/chart-1.10.1 (#11314) -* release helm chart from release branch (#11278) -* update post submit helm ci and clean up (#11221) -* refactor helm ci tests part I (#11188) -* Update Ingress-Nginx version controller-v1.10.2 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.10.1...helm-chart-4.10.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.0.md deleted file mode 100644 index 64108c0..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.0.md +++ /dev/null @@ -1,18 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.11.0 - -* Chores: Align security contacts & chart maintainers to actual owners. (#11465) -* Merge pull request #11277 from strongjz/chart-1.10.1 (#11415) -* Fix helm install on cloud provider admonition block (#11394) -* edited helm-install tips (#11393) -* added info for aws helm install (#11390) -* add workflow to helm release and update ct for branch (#11378) -* release helm chart from release branch (#11276) -* update post submit helm ci and clean up (#11220) -* refactor helm ci tests part I (#11178) -* Update Ingress-Nginx version controller-v1.11.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.10.2...helm-chart-4.11.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.1.md deleted file mode 100644 index 281513e..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.11.1 - -* Update Ingress-Nginx version controller-v1.11.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.11.0...helm-chart-4.11.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.2.md deleted file mode 100644 index c7645a5..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.2.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.11.2 - -* Update Ingress-Nginx version controller-v1.11.2 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.11.1...helm-chart-4.11.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.3.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.3.md deleted file mode 100644 index 18ec6ba..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.3.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.11.3 - -* Update Ingress-Nginx version controller-v1.11.3 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.11.2...helm-chart-4.11.3 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.0.md deleted file mode 100644 index 2074a09..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.0.md +++ /dev/null @@ -1,47 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.2.0 - -* Support for Kubernetes v1.19.0 was removed -* [8810](https://github.com/kubernetes/ingress-nginx/pull/8810) Prepare for v1.3.0 -* [8808](https://github.com/kubernetes/ingress-nginx/pull/8808) revert arch var name -* [8805](https://github.com/kubernetes/ingress-nginx/pull/8805) Bump k8s.io/klog/v2 from 2.60.1 to 2.70.1 -* [8803](https://github.com/kubernetes/ingress-nginx/pull/8803) Update to nginx base with alpine v3.16 -* [8802](https://github.com/kubernetes/ingress-nginx/pull/8802) chore: start v1.3.0 release process -* [8798](https://github.com/kubernetes/ingress-nginx/pull/8798) Add v1.24.0 to test matrix -* [8796](https://github.com/kubernetes/ingress-nginx/pull/8796) fix: add MAC_OS variable for static-check -* [8793](https://github.com/kubernetes/ingress-nginx/pull/8793) changed to alpine-v3.16 -* [8781](https://github.com/kubernetes/ingress-nginx/pull/8781) Bump github.com/stretchr/testify from 1.7.5 to 1.8.0 -* [8778](https://github.com/kubernetes/ingress-nginx/pull/8778) chore: remove stable.txt from release process -* [8775](https://github.com/kubernetes/ingress-nginx/pull/8775) Remove stable -* [8773](https://github.com/kubernetes/ingress-nginx/pull/8773) Bump github/codeql-action from 2.1.14 to 2.1.15 -* [8772](https://github.com/kubernetes/ingress-nginx/pull/8772) Bump ossf/scorecard-action from 1.1.1 to 1.1.2 -* [8771](https://github.com/kubernetes/ingress-nginx/pull/8771) fix bullet md format -* [8770](https://github.com/kubernetes/ingress-nginx/pull/8770) Add condition for monitoring.coreos.com/v1 API -* [8769](https://github.com/kubernetes/ingress-nginx/pull/8769) Fix typos and add links to developer guide -* [8767](https://github.com/kubernetes/ingress-nginx/pull/8767) change v1.2.0 to v1.2.1 in deploy doc URLs -* [8765](https://github.com/kubernetes/ingress-nginx/pull/8765) Bump github/codeql-action from 1.0.26 to 2.1.14 -* [8752](https://github.com/kubernetes/ingress-nginx/pull/8752) Bump github.com/spf13/cobra from 1.4.0 to 1.5.0 -* [8751](https://github.com/kubernetes/ingress-nginx/pull/8751) Bump github.com/stretchr/testify from 1.7.2 to 1.7.5 -* [8750](https://github.com/kubernetes/ingress-nginx/pull/8750) added announcement -* [8740](https://github.com/kubernetes/ingress-nginx/pull/8740) change sha e2etestrunner and echoserver -* [8738](https://github.com/kubernetes/ingress-nginx/pull/8738) Update docs to make it easier for noobs to follow step by step -* [8737](https://github.com/kubernetes/ingress-nginx/pull/8737) updated baseimage sha -* [8736](https://github.com/kubernetes/ingress-nginx/pull/8736) set ld-musl-path -* [8733](https://github.com/kubernetes/ingress-nginx/pull/8733) feat: migrate leaderelection lock to leases -* [8726](https://github.com/kubernetes/ingress-nginx/pull/8726) prometheus metric: upstream_latency_seconds -* [8720](https://github.com/kubernetes/ingress-nginx/pull/8720) Ci pin deps -* [8719](https://github.com/kubernetes/ingress-nginx/pull/8719) Working OpenTelemetry sidecar (base nginx image) -* [8714](https://github.com/kubernetes/ingress-nginx/pull/8714) Create Openssf scorecard -* [8708](https://github.com/kubernetes/ingress-nginx/pull/8708) Bump github.com/prometheus/common from 0.34.0 to 0.35.0 -* [8703](https://github.com/kubernetes/ingress-nginx/pull/8703) Bump actions/dependency-review-action from 1 to 2 -* [8701](https://github.com/kubernetes/ingress-nginx/pull/8701) Fix several typos -* [8699](https://github.com/kubernetes/ingress-nginx/pull/8699) fix the gosec test and a make target for it -* [8698](https://github.com/kubernetes/ingress-nginx/pull/8698) Bump actions/upload-artifact from 2.3.1 to 3.1.0 -* [8697](https://github.com/kubernetes/ingress-nginx/pull/8697) Bump actions/setup-go from 2.2.0 to 3.2.0 -* [8695](https://github.com/kubernetes/ingress-nginx/pull/8695) Bump actions/download-artifact from 2 to 3 -* [8694](https://github.com/kubernetes/ingress-nginx/pull/8694) Bump crazy-max/ghaction-docker-buildx from 1.6.2 to 3.3.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.1.2...helm-chart-4.2.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.1.md deleted file mode 100644 index 7965bb1..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.1.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.2.1 - -* The sha of kube-webhook-certgen image & the opentelemetry image, in values file, was changed to new images built on alpine-v3.16.1 -* [8896](https://github.com/kubernetes/ingress-nginx/pull/8896) updated to new images built today - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.2.0...helm-chart-4.2.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.3.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.3.0.md deleted file mode 100644 index f9dca22..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.3.0.md +++ /dev/null @@ -1,14 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.3.0 - -* Support for Kubernetes v.1.25.0 was added and support for endpoint slices -* Support for Kubernetes v1.20.0 and v1.21.0 was removed -* [8890](https://github.com/kubernetes/ingress-nginx/pull/8890) migrate to endpointslices -* [9059](https://github.com/kubernetes/ingress-nginx/pull/9059) kubewebhookcertgen sha change after go1191 -* [9046](https://github.com/kubernetes/ingress-nginx/pull/9046) Parameterize metrics port name -* [9104](https://github.com/kubernetes/ingress-nginx/pull/9104) Fix yaml formatting error with multiple annotations - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.2.1...helm-chart-4.3.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.4.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.4.0.md deleted file mode 100644 index 20f9e23..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.4.0.md +++ /dev/null @@ -1,12 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.4.0 - -* Adding support for disabling liveness and readiness probes to the Helm chart by @njegosrailic in https://github.com/kubernetes/ingress-nginx/pull/9238 -* add:(admission-webhooks) ability to set securityContext by @ybelMekk in https://github.com/kubernetes/ingress-nginx/pull/9186 -* #7652 - Updated Helm chart to use the fullname for the electionID if not specified. by @FutureMatt in https://github.com/kubernetes/ingress-nginx/pull/9133 -* Rename controller-wehbooks-networkpolicy.yaml. by @Gacko in https://github.com/kubernetes/ingress-nginx/pull/9123 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.3.0...helm-chart-4.4.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.5.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.5.2.md deleted file mode 100644 index b6d8a3b..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.5.2.md +++ /dev/null @@ -1,13 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.5.2 - -* add lint on chart before release (#9570) -* ci: remove setup-helm step (#9404) -* feat(helm): Optionally use cert-manager instead admission patch (#9279) -* run helm release on main only and when the chart/value changes only (#9290) -* Update Ingress-Nginx version controller-v1.6.4 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.4.3...helm-chart-4.5.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.0.md deleted file mode 100644 index 469aaba..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.0.md +++ /dev/null @@ -1,24 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.5.3 - -* docs(helm): fix value key in readme for enabling certManager (#9640) -* Upgrade alpine 3.17.2 -* Upgrade golang 1.20 -* Drop testing/support for Kubernetes 1.23 -* docs(helm): fix value key in readme for enabling certManager (#9640) -* Update Ingress-Nginx version controller-v1.7.0 -* feat: OpenTelemetry module integration (#9062) -* canary-weight-total annotation ignored in rule backends (#9729) -* fix controller psp's volume config (#9740) -* Fix several Helm YAML issues with extraModules and extraInitContainers (#9709) -* Chart: Drop `controller.headers`, rework DH param secret. (#9659) -* Deployment/DaemonSet: Label pods using `ingress-nginx.labels`. (#9732) -* HPA: autoscaling/v2beta1 deprecated, bump apiVersion to v2 for defaultBackend (#9731) -* Fix incorrect annotation name in upstream hashing configuration (#9617) - -* Update Ingress-Nginx version controller-v1.7.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.5.2...helm-chart-4.6.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.1.md deleted file mode 100644 index 57d99b8..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.1.md +++ /dev/null @@ -1,11 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.6.1 - -* [helm] Support custom port configuration for internal service (#9846) -* Adding resource type to default HPA configuration to resolve issues with Terraform helm chart usage (#9803) -* Update Ingress-Nginx version controller-v1.7.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.6.0...helm-chart-4.6.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.0.md deleted file mode 100644 index 9d54070..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.0.md +++ /dev/null @@ -1,14 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.7.0 - -* helm: Fix opentelemetry module installation for daemonset (#9792) -* Update charts/* to keep project name display aligned (#9931) -* HPA: Use capabilities & align manifests. (#9521) -* PodDisruptionBudget spec logic update (#9904) -* add option for annotations in PodDisruptionBudget (#9843) -* Update Ingress-Nginx version controller-v1.8.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.6.1...helm-chart-4.7.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.1.md deleted file mode 100644 index 4d69a71..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.1.md +++ /dev/null @@ -1,12 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.7.1 - -* Added a doc line to the missing helm value service.internal.loadBalancerIP (#9406) -* feat(helm): Add loadBalancerClass (#9562) -* added helmshowvalues example (#10019) -* Update Ingress-Nginx version controller-v1.8.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.7.0...helm-chart-4.7.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.2.md deleted file mode 100644 index 57b17b9..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.2.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.7.2 - -* Update Ingress-Nginx version controller-v1.8.2 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.7.1...helm-chart-4.7.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0-beta.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0-beta.0.md deleted file mode 100644 index 9072a75..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0-beta.0.md +++ /dev/null @@ -1,13 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.8.0-beta.0 - -* ci(helm): fix Helm Chart release action 422 error (#10237) -* helm: Use .Release.Namespace as default for ServiceMonitor namespace (#10249) -* [helm] configure allow to configure hostAliases (#10180) -* [helm] pass service annotations through helm tpl engine (#10084) -* Update Ingress-Nginx version controller-v1.9.0-beta.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.7.2...helm-chart-4.8.0-beta.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0.md deleted file mode 100644 index af8f124..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0.md +++ /dev/null @@ -1,13 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.8.0 - -* ci(helm): fix Helm Chart release action 422 error (#10237) -* helm: Use .Release.Namespace as default for ServiceMonitor namespace (#10249) -* [helm] configure allow to configure hostAliases (#10180) -* [helm] pass service annotations through helm tpl engine (#10084) -* Update Ingress-Nginx version controller-v1.9.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.7.2...helm-chart-4.8.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.1.md deleted file mode 100644 index 53a4493..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.8.1 - -* Update Ingress-Nginx version controller-v1.9.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.8.0...helm-chart-4.8.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.2.md deleted file mode 100644 index 9957c1a..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.2.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.8.2 - -* update nginx base, httpbun, e2e, helm webhook cert gen (#10506) -* Update Ingress-Nginx version controller-v1.9.3 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.8.1...helm-chart-4.8.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.3.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.3.md deleted file mode 100644 index b8d4d56..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.3.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.8.3 - -* Update Ingress-Nginx version controller-v1.9.4 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.8.2...helm-chart-4.8.3 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.0.md deleted file mode 100644 index 5c77298..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.0.md +++ /dev/null @@ -1,13 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.9.0 - -* - "Add controller.metrics.serviceMonitor.annotations in Helm chart" -* - "fix(labels): use complete labels variable on default-backend deployment" -* - "chart: allow setting allocateLoadBalancerNodePorts (#10693)" -* - "[release-1.9] feat(helm): add documentation about metric args (#10695)" -* - "Update Ingress-Nginx version controller-v1.9.5" - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.8.3...helm-chart-4.9.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.1.md deleted file mode 100644 index c6120e7..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.1.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.9.1 - -* - "update web hook cert gen to latest release v20231226-1a7112e06" -* - "Update Ingress-Nginx version controller-v1.9.6" - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.9.0...helm-chart-4.9.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart.md.gotmpl b/charts/keep/charts/ingress-nginx/changelog/helm-chart.md.gotmpl deleted file mode 100644 index ef5add5..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart.md.gotmpl +++ /dev/null @@ -1,11 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### {{ .NewHelmChartVersion }} -{{ with .HelmUpdates }} -{{- range . }} -* {{ . }} -{{- end }} -{{ end }} -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-{{ .PreviousHelmChartVersion }}...helm-chart-{{ .NewHelmChartVersion }} diff --git a/charts/keep/charts/ingress-nginx/ci/admission-webhooks-cert-manager-values.yaml b/charts/keep/charts/ingress-nginx/ci/admission-webhooks-cert-manager-values.yaml deleted file mode 100644 index 7eafd0c..0000000 --- a/charts/keep/charts/ingress-nginx/ci/admission-webhooks-cert-manager-values.yaml +++ /dev/null @@ -1,12 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - admissionWebhooks: - certManager: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-configmap-addheaders-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-configmap-addheaders-values.yaml deleted file mode 100644 index 460a610..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-configmap-addheaders-values.yaml +++ /dev/null @@ -1,11 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - addHeaders: - X-Frame-Options: deny diff --git a/charts/keep/charts/ingress-nginx/ci/controller-configmap-proxyheaders-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-configmap-proxyheaders-values.yaml deleted file mode 100644 index e23a13c..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-configmap-proxyheaders-values.yaml +++ /dev/null @@ -1,11 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - proxySetHeaders: - X-Forwarded-Proto: https diff --git a/charts/keep/charts/ingress-nginx/ci/controller-configmap-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-configmap-values.yaml deleted file mode 100644 index a702989..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-configmap-values.yaml +++ /dev/null @@ -1,11 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - config: - use-proxy-protocol: "true" diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-extra-modules-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-extra-modules-values.yaml deleted file mode 100644 index edf12e7..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-extra-modules-values.yaml +++ /dev/null @@ -1,30 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: DaemonSet - - extraModules: - - name: opentelemetry - image: - registry: registry.k8s.io - image: ingress-nginx/opentelemetry-1.25.3 - tag: v20240813-b933310d - digest: sha256:f7604ac0547ed64d79b98d92133234e66c2c8aade3c1f4809fed5eec1fb7f922 - distroless: true - containerSecurityContext: - runAsNonRoot: true - runAsUser: 65532 - runAsGroup: 65532 - allowPrivilegeEscalation: false - seccompProfile: - type: RuntimeDefault - capabilities: - drop: - - ALL - readOnlyRootFilesystem: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-metrics-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-metrics-values.yaml deleted file mode 100644 index 7a98580..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-metrics-values.yaml +++ /dev/null @@ -1,13 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: DaemonSet - - metrics: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-opentelemetry-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-opentelemetry-values.yaml deleted file mode 100644 index 179ab2a..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-opentelemetry-values.yaml +++ /dev/null @@ -1,13 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: DaemonSet - - opentelemetry: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-podannotations-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-podannotations-values.yaml deleted file mode 100644 index 405992e..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-podannotations-values.yaml +++ /dev/null @@ -1,16 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: DaemonSet - - podAnnotations: - prometheus.io/scrape: "true" - prometheus.io/port: "10254" - prometheus.io/scheme: http - prometheus.io/path: /metrics diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-values.yaml deleted file mode 100644 index d34025c..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-values.yaml +++ /dev/null @@ -1,10 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: DaemonSet diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-extra-modules-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-extra-modules-values.yaml deleted file mode 100644 index d4083cc..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-deployment-extra-modules-values.yaml +++ /dev/null @@ -1,30 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: Deployment - - extraModules: - - name: opentelemetry - image: - registry: registry.k8s.io - image: ingress-nginx/opentelemetry-1.25.3 - tag: v20240813-b933310d - digest: sha256:f7604ac0547ed64d79b98d92133234e66c2c8aade3c1f4809fed5eec1fb7f922 - distroless: true - containerSecurityContext: - runAsNonRoot: true - runAsUser: 65532 - runAsGroup: 65532 - allowPrivilegeEscalation: false - seccompProfile: - type: RuntimeDefault - capabilities: - drop: - - ALL - readOnlyRootFilesystem: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-metrics-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-metrics-values.yaml deleted file mode 100644 index 9c95d34..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-deployment-metrics-values.yaml +++ /dev/null @@ -1,13 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: Deployment - - metrics: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-opentelemetry-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-opentelemetry-values.yaml deleted file mode 100644 index 9443dde..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-deployment-opentelemetry-values.yaml +++ /dev/null @@ -1,13 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: Deployment - - opentelemetry: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-podannotations-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-podannotations-values.yaml deleted file mode 100644 index cf1f261..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-deployment-podannotations-values.yaml +++ /dev/null @@ -1,16 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: Deployment - - podAnnotations: - prometheus.io/scrape: "true" - prometheus.io/port: "10254" - prometheus.io/scheme: http - prometheus.io/path: /metrics diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-values.yaml deleted file mode 100644 index 1b092dc..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-deployment-values.yaml +++ /dev/null @@ -1,10 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: Deployment diff --git a/charts/keep/charts/ingress-nginx/ci/controller-hpa-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-hpa-values.yaml deleted file mode 100644 index 54a0d2f..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-hpa-values.yaml +++ /dev/null @@ -1,18 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - autoscaling: - enabled: true - behavior: - scaleDown: - stabilizationWindowSeconds: 300 - policies: - - type: Pods - value: 1 - periodSeconds: 180 diff --git a/charts/keep/charts/ingress-nginx/ci/controller-ingressclass-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-ingressclass-values.yaml deleted file mode 100644 index c06429f..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-ingressclass-values.yaml +++ /dev/null @@ -1,15 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - ingressClassResource: - name: custom-nginx - default: true - controllerValue: k8s.io/custom-nginx - - watchIngressWithoutClass: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-service-internal-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-service-internal-values.yaml deleted file mode 100644 index 11108fb..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-service-internal-values.yaml +++ /dev/null @@ -1,13 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - internal: - enabled: true - annotations: - service.beta.kubernetes.io/aws-load-balancer-internal: "true" diff --git a/charts/keep/charts/ingress-nginx/ci/controller-service-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-service-values.yaml deleted file mode 100644 index 9039368..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-service-values.yaml +++ /dev/null @@ -1,22 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: NodePort - - nodePorts: - tcp: - 9000: 30090 - udp: - 9001: 30091 - -portNamePrefix: port - -tcp: - 9000: default/test:8080 - -udp: - 9001: default/test:8080 diff --git a/charts/keep/charts/ingress-nginx/ci/deamonset-psp-values.yaml b/charts/keep/charts/ingress-nginx/ci/deamonset-psp-values.yaml deleted file mode 100644 index 8026a63..0000000 --- a/charts/keep/charts/ingress-nginx/ci/deamonset-psp-values.yaml +++ /dev/null @@ -1,13 +0,0 @@ -controller: - kind: DaemonSet - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - admissionWebhooks: - enabled: false - service: - type: ClusterIP - -podSecurityPolicy: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/deamonset-webhook-and-psp-values.yaml b/charts/keep/charts/ingress-nginx/ci/deamonset-webhook-and-psp-values.yaml deleted file mode 100644 index fccdb13..0000000 --- a/charts/keep/charts/ingress-nginx/ci/deamonset-webhook-and-psp-values.yaml +++ /dev/null @@ -1,13 +0,0 @@ -controller: - kind: DaemonSet - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - admissionWebhooks: - enabled: true - service: - type: ClusterIP - -podSecurityPolicy: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/deployment-psp-values.yaml b/charts/keep/charts/ingress-nginx/ci/deployment-psp-values.yaml deleted file mode 100644 index 2f332a7..0000000 --- a/charts/keep/charts/ingress-nginx/ci/deployment-psp-values.yaml +++ /dev/null @@ -1,10 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - service: - type: ClusterIP - -podSecurityPolicy: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/deployment-webhook-and-psp-values.yaml b/charts/keep/charts/ingress-nginx/ci/deployment-webhook-and-psp-values.yaml deleted file mode 100644 index 6195bb3..0000000 --- a/charts/keep/charts/ingress-nginx/ci/deployment-webhook-and-psp-values.yaml +++ /dev/null @@ -1,12 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - admissionWebhooks: - enabled: true - service: - type: ClusterIP - -podSecurityPolicy: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/templates/NOTES.txt b/charts/keep/charts/ingress-nginx/templates/NOTES.txt deleted file mode 100644 index f492300..0000000 --- a/charts/keep/charts/ingress-nginx/templates/NOTES.txt +++ /dev/null @@ -1,73 +0,0 @@ -The ingress-nginx controller has been installed. - -{{- if contains "NodePort" .Values.controller.service.type }} -Get the application URL by running these commands: - -{{- if (not (empty .Values.controller.service.nodePorts.http)) }} - export HTTP_NODE_PORT={{ .Values.controller.service.nodePorts.http }} -{{- else }} - export HTTP_NODE_PORT=$(kubectl get service --namespace {{ include "ingress-nginx.namespace" . }} {{ include "ingress-nginx.controller.fullname" . }} --output jsonpath="{.spec.ports[0].nodePort}") -{{- end }} -{{- if (not (empty .Values.controller.service.nodePorts.https)) }} - export HTTPS_NODE_PORT={{ .Values.controller.service.nodePorts.https }} -{{- else }} - export HTTPS_NODE_PORT=$(kubectl get service --namespace {{ include "ingress-nginx.namespace" . }} {{ include "ingress-nginx.controller.fullname" . }} --output jsonpath="{.spec.ports[1].nodePort}") -{{- end }} - export NODE_IP="$(kubectl get nodes --output jsonpath="{.items[0].status.addresses[1].address}")" - - echo "Visit http://${NODE_IP}:${HTTP_NODE_PORT} to access your application via HTTP." - echo "Visit https://${NODE_IP}:${HTTPS_NODE_PORT} to access your application via HTTPS." -{{- else if contains "LoadBalancer" .Values.controller.service.type }} -It may take a few minutes for the load balancer IP to be available. -You can watch the status by running 'kubectl get service --namespace {{ include "ingress-nginx.namespace" . }} {{ include "ingress-nginx.controller.fullname" . }} --output wide --watch' -{{- else if contains "ClusterIP" .Values.controller.service.type }} -Get the application URL by running these commands: - export POD_NAME="$(kubectl get pods --namespace {{ include "ingress-nginx.namespace" . }} --selector app.kubernetes.io/name={{ include "ingress-nginx.name" . }},app.kubernetes.io/instance={{ .Release.Name }},app.kubernetes.io/component=controller --output jsonpath="{.items[0].metadata.name}")" - kubectl port-forward --namespace {{ include "ingress-nginx.namespace" . }} "${POD_NAME}" 8080:80 - echo "Visit http://127.0.0.1:8080 to access your application." -{{- end }} - -An example Ingress that makes use of the controller: - -{{- $isV1 := semverCompare ">=1" .Chart.AppVersion}} - apiVersion: networking.k8s.io/v1 - kind: Ingress - metadata: - name: example - namespace: foo - {{- if eq $isV1 false }} - annotations: - kubernetes.io/ingress.class: {{ .Values.controller.ingressClass }} - {{- end }} - spec: - {{- if $isV1 }} - ingressClassName: {{ .Values.controller.ingressClassResource.name }} - {{- end }} - rules: - - host: www.example.com - http: - paths: - - pathType: Prefix - backend: - service: - name: exampleService - port: - number: 80 - path: / - # This section is only required if TLS is to be enabled for the Ingress - tls: - - hosts: - - www.example.com - secretName: example-tls - -If TLS is enabled for the Ingress, a Secret containing the certificate and key must also be provided: - - apiVersion: v1 - kind: Secret - metadata: - name: example-tls - namespace: foo - data: - tls.crt: - tls.key: - type: kubernetes.io/tls diff --git a/charts/keep/charts/ingress-nginx/templates/_helpers.tpl b/charts/keep/charts/ingress-nginx/templates/_helpers.tpl deleted file mode 100644 index 24cfd14..0000000 --- a/charts/keep/charts/ingress-nginx/templates/_helpers.tpl +++ /dev/null @@ -1,272 +0,0 @@ -{{/* vim: set filetype=mustache: */}} -{{/* -Expand the name of the chart. -*/}} -{{- define "ingress-nginx.name" -}} -{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" -}} -{{- end -}} - -{{/* -Create chart name and version as used by the chart label. -*/}} -{{- define "ingress-nginx.chart" -}} -{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | 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). -*/}} -{{- define "ingress-nginx.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 -}} - -{{/* -Expand the namespace of the release. -Allows overriding it for multi-namespace deployments in combined charts. -*/}} -{{- define "ingress-nginx.namespace" -}} -{{- default .Release.Namespace .Values.namespaceOverride | trunc 63 | trimSuffix "-" -}} -{{- end -}} - -{{/* -Controller container security context. -*/}} -{{- define "ingress-nginx.controller.containerSecurityContext" -}} -{{- if .Values.controller.containerSecurityContext -}} -{{- toYaml .Values.controller.containerSecurityContext -}} -{{- else -}} -runAsNonRoot: {{ .Values.controller.image.runAsNonRoot }} -runAsUser: {{ .Values.controller.image.runAsUser }} -allowPrivilegeEscalation: {{ or .Values.controller.image.allowPrivilegeEscalation .Values.controller.image.chroot }} -{{- if .Values.controller.image.seccompProfile }} -seccompProfile: {{ toYaml .Values.controller.image.seccompProfile | nindent 2 }} -{{- end }} -capabilities: - drop: - - ALL - add: - - NET_BIND_SERVICE - {{- if .Values.controller.image.chroot }} - {{- if .Values.controller.image.seccompProfile }} - - SYS_ADMIN - {{- end }} - - SYS_CHROOT - {{- end }} -readOnlyRootFilesystem: {{ .Values.controller.image.readOnlyRootFilesystem }} -{{- end -}} -{{- end -}} - -{{/* -Get specific image -*/}} -{{- define "ingress-nginx.image" -}} -{{- if .chroot -}} -{{- printf "%s-chroot" .image -}} -{{- else -}} -{{- printf "%s" .image -}} -{{- end }} -{{- end -}} - -{{/* -Get specific image digest -*/}} -{{- define "ingress-nginx.imageDigest" -}} -{{- if .chroot -}} -{{- if .digestChroot -}} -{{- printf "@%s" .digestChroot -}} -{{- end }} -{{- else -}} -{{ if .digest -}} -{{- printf "@%s" .digest -}} -{{- end -}} -{{- end -}} -{{- end -}} - -{{/* -Create a default fully qualified controller name. -We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). -*/}} -{{- define "ingress-nginx.controller.fullname" -}} -{{- printf "%s-%s" (include "ingress-nginx.fullname" .) .Values.controller.name | trunc 63 | trimSuffix "-" -}} -{{- end -}} - -{{/* -Construct a unique electionID. -Users can provide an override for an explicit electionID if they want via `.Values.controller.electionID` -*/}} -{{- define "ingress-nginx.controller.electionID" -}} -{{- $defElectionID := printf "%s-leader" (include "ingress-nginx.fullname" .) -}} -{{- $electionID := default $defElectionID .Values.controller.electionID -}} -{{- print $electionID -}} -{{- end -}} - -{{/* -Construct the path for the publish-service. - -By convention this will simply use the / to match the name of the -service generated. - -Users can provide an override for an explicit service they want bound via `.Values.controller.publishService.pathOverride` -*/}} -{{- define "ingress-nginx.controller.publishServicePath" -}} -{{- $defServiceName := printf "%s/%s" "$(POD_NAMESPACE)" (include "ingress-nginx.controller.fullname" .) -}} -{{- $servicePath := default $defServiceName .Values.controller.publishService.pathOverride }} -{{- print $servicePath | trimSuffix "-" -}} -{{- end -}} - -{{/* -Common labels -*/}} -{{- define "ingress-nginx.labels" -}} -helm.sh/chart: {{ include "ingress-nginx.chart" . }} -{{ include "ingress-nginx.selectorLabels" . }} -{{- if .Chart.AppVersion }} -app.kubernetes.io/version: {{ .Chart.AppVersion | quote }} -{{- end }} -app.kubernetes.io/part-of: {{ template "ingress-nginx.name" . }} -app.kubernetes.io/managed-by: {{ .Release.Service }} -{{- if .Values.commonLabels}} -{{ toYaml .Values.commonLabels }} -{{- end }} -{{- end -}} - -{{/* -Selector labels -*/}} -{{- define "ingress-nginx.selectorLabels" -}} -app.kubernetes.io/name: {{ include "ingress-nginx.name" . }} -app.kubernetes.io/instance: {{ .Release.Name }} -{{- end -}} - -{{/* -Create the name of the controller service account to use -*/}} -{{- define "ingress-nginx.serviceAccountName" -}} -{{- if .Values.serviceAccount.create -}} - {{ default (include "ingress-nginx.fullname" .) .Values.serviceAccount.name }} -{{- else -}} - {{ default "default" .Values.serviceAccount.name }} -{{- end -}} -{{- end -}} - -{{/* -Create a default fully qualified admission webhook name. -We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). -*/}} -{{- define "ingress-nginx.admissionWebhooks.fullname" -}} -{{- printf "%s-%s" (include "ingress-nginx.fullname" .) .Values.controller.admissionWebhooks.name | trunc 63 | trimSuffix "-" -}} -{{- end -}} - -{{/* -Create the name of the admission webhook patch job service account to use -*/}} -{{- define "ingress-nginx.admissionWebhooks.patch.serviceAccountName" -}} -{{- if .Values.controller.admissionWebhooks.patch.serviceAccount.create -}} - {{ default (include "ingress-nginx.admissionWebhooks.fullname" .) .Values.controller.admissionWebhooks.patch.serviceAccount.name }} -{{- else -}} - {{ default "default" .Values.controller.admissionWebhooks.patch.serviceAccount.name }} -{{- end -}} -{{- end -}} - -{{/* -Create a default fully qualified admission webhook secret creation job name. -We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). -*/}} -{{- define "ingress-nginx.admissionWebhooks.createSecretJob.fullname" -}} -{{- printf "%s-%s" (include "ingress-nginx.admissionWebhooks.fullname" .) .Values.controller.admissionWebhooks.createSecretJob.name | trunc 63 | trimSuffix "-" -}} -{{- end -}} - -{{/* -Create a default fully qualified admission webhook patch job name. -We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). -*/}} -{{- define "ingress-nginx.admissionWebhooks.patchWebhookJob.fullname" -}} -{{- printf "%s-%s" (include "ingress-nginx.admissionWebhooks.fullname" .) .Values.controller.admissionWebhooks.patchWebhookJob.name | trunc 63 | trimSuffix "-" -}} -{{- end -}} - -{{/* -Create a default fully qualified default backend name. -We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). -*/}} -{{- define "ingress-nginx.defaultBackend.fullname" -}} -{{- printf "%s-%s" (include "ingress-nginx.fullname" .) .Values.defaultBackend.name | trunc 63 | trimSuffix "-" -}} -{{- end -}} - -{{/* -Create the name of the default backend service account to use -*/}} -{{- define "ingress-nginx.defaultBackend.serviceAccountName" -}} -{{- if .Values.defaultBackend.serviceAccount.create -}} - {{ default (printf "%s-backend" (include "ingress-nginx.fullname" .)) .Values.defaultBackend.serviceAccount.name }} -{{- else -}} - {{ default "default-backend" .Values.defaultBackend.serviceAccount.name }} -{{- end -}} -{{- end -}} - -{{/* -Default backend container security context. -*/}} -{{- define "ingress-nginx.defaultBackend.containerSecurityContext" -}} -{{- if .Values.defaultBackend.containerSecurityContext -}} -{{- toYaml .Values.defaultBackend.containerSecurityContext -}} -{{- else -}} -runAsNonRoot: {{ .Values.defaultBackend.image.runAsNonRoot }} -runAsUser: {{ .Values.defaultBackend.image.runAsUser }} -allowPrivilegeEscalation: {{ .Values.defaultBackend.image.allowPrivilegeEscalation }} -{{- if .Values.defaultBackend.image.seccompProfile }} -seccompProfile: {{ toYaml .Values.defaultBackend.image.seccompProfile | nindent 2 }} -{{- end }} -capabilities: - drop: - - ALL -readOnlyRootFilesystem: {{ .Values.defaultBackend.image.readOnlyRootFilesystem }} -{{- end -}} -{{- end -}} - -{{/* -Return the appropriate apiGroup for PodSecurityPolicy. -*/}} -{{- define "podSecurityPolicy.apiGroup" -}} -{{- if semverCompare ">=1.14-0" .Capabilities.KubeVersion.GitVersion -}} -{{- print "policy" -}} -{{- else -}} -{{- print "extensions" -}} -{{- end -}} -{{- end -}} - -{{/* -Extra modules. -*/}} -{{- define "extraModules" -}} -- name: {{ .name }} - {{- with .image }} - image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ .image }}{{ end }}:{{ .tag }}{{ if .digest }}@{{ .digest }}{{ end }} - command: - {{- if .distroless }} - - /init_module - {{- else }} - - sh - - -c - - /usr/local/bin/init_module.sh - {{- end }} - {{- end }} - {{- if .containerSecurityContext }} - securityContext: {{ toYaml .containerSecurityContext | nindent 4 }} - {{- end }} - {{- if .resources }} - resources: {{ toYaml .resources | nindent 4 }} - {{- end }} - volumeMounts: - - name: modules - mountPath: /modules_mount -{{- end -}} diff --git a/charts/keep/charts/ingress-nginx/templates/_params.tpl b/charts/keep/charts/ingress-nginx/templates/_params.tpl deleted file mode 100644 index 48569a8..0000000 --- a/charts/keep/charts/ingress-nginx/templates/_params.tpl +++ /dev/null @@ -1,77 +0,0 @@ -{{- define "ingress-nginx.params" -}} -- /nginx-ingress-controller -{{- if .Values.controller.enableAnnotationValidations }} -- --enable-annotation-validation=true -{{- end }} -{{- if .Values.defaultBackend.enabled }} -- --default-backend-service=$(POD_NAMESPACE)/{{ include "ingress-nginx.defaultBackend.fullname" . }} -{{- end }} -{{- if and .Values.controller.publishService.enabled .Values.controller.service.enabled }} -{{- if .Values.controller.service.external.enabled }} -- --publish-service={{ template "ingress-nginx.controller.publishServicePath" . }} -{{- else if .Values.controller.service.internal.enabled }} -- --publish-service={{ template "ingress-nginx.controller.publishServicePath" . }}-internal -{{- end }} -{{- end }} -- --election-id={{ include "ingress-nginx.controller.electionID" . }} -- --controller-class={{ .Values.controller.ingressClassResource.controllerValue }} -{{- if .Values.controller.ingressClass }} -- --ingress-class={{ .Values.controller.ingressClass }} -{{- end }} -- --configmap={{ default "$(POD_NAMESPACE)" .Values.controller.configMapNamespace }}/{{ include "ingress-nginx.controller.fullname" . }} -{{- if .Values.tcp }} -- --tcp-services-configmap={{ default "$(POD_NAMESPACE)" .Values.controller.tcp.configMapNamespace }}/{{ include "ingress-nginx.fullname" . }}-tcp -{{- end }} -{{- if .Values.udp }} -- --udp-services-configmap={{ default "$(POD_NAMESPACE)" .Values.controller.udp.configMapNamespace }}/{{ include "ingress-nginx.fullname" . }}-udp -{{- end }} -{{- if .Values.controller.scope.enabled }} -- --watch-namespace={{ default "$(POD_NAMESPACE)" .Values.controller.scope.namespace }} -{{- end }} -{{- if and (not .Values.controller.scope.enabled) .Values.controller.scope.namespaceSelector }} -- --watch-namespace-selector={{ .Values.controller.scope.namespaceSelector }} -{{- end }} -{{- if and .Values.controller.reportNodeInternalIp .Values.controller.hostNetwork }} -- --report-node-internal-ip-address={{ .Values.controller.reportNodeInternalIp }} -{{- end }} -{{- if .Values.controller.admissionWebhooks.enabled }} -- --validating-webhook=:{{ .Values.controller.admissionWebhooks.port }} -- --validating-webhook-certificate={{ .Values.controller.admissionWebhooks.certificate }} -- --validating-webhook-key={{ .Values.controller.admissionWebhooks.key }} -{{- end }} -{{- if .Values.controller.maxmindLicenseKey }} -- --maxmind-license-key={{ .Values.controller.maxmindLicenseKey }} -{{- end }} -{{- if .Values.controller.healthCheckHost }} -- --healthz-host={{ .Values.controller.healthCheckHost }} -{{- end }} -{{- if not (eq .Values.controller.healthCheckPath "/healthz") }} -- --health-check-path={{ .Values.controller.healthCheckPath }} -{{- end }} -{{- if .Values.controller.ingressClassByName }} -- --ingress-class-by-name=true -{{- end }} -{{- if .Values.controller.watchIngressWithoutClass }} -- --watch-ingress-without-class=true -{{- end }} -{{- if not .Values.controller.metrics.enabled }} -- --enable-metrics={{ .Values.controller.metrics.enabled }} -{{- end }} -{{- if .Values.controller.enableTopologyAwareRouting }} -- --enable-topology-aware-routing=true -{{- end }} -{{- if .Values.controller.disableLeaderElection }} -- --disable-leader-election=true -{{- end }} -{{- if .Values.controller.electionTTL }} -- --election-ttl={{ .Values.controller.electionTTL }} -{{- end }} -{{- range $key, $value := .Values.controller.extraArgs }} -{{- /* Accept keys without values or with false as value */}} -{{- if eq ($value | quote | len) 2 }} -- --{{ $key }} -{{- else }} -- --{{ $key }}={{ $value }} -{{- end }} -{{- end }} -{{- end -}} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/cert-manager.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/cert-manager.yaml deleted file mode 100644 index db2946c..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/cert-manager.yaml +++ /dev/null @@ -1,63 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.certManager.enabled -}} -{{- if not .Values.controller.admissionWebhooks.certManager.issuerRef -}} -# Create a selfsigned Issuer, in order to create a root CA certificate for -# signing webhook serving certificates -apiVersion: cert-manager.io/v1 -kind: Issuer -metadata: - name: {{ include "ingress-nginx.fullname" . }}-self-signed-issuer - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - selfSigned: {} ---- -# Generate a CA Certificate used to sign certificates for the webhook -apiVersion: cert-manager.io/v1 -kind: Certificate -metadata: - name: {{ include "ingress-nginx.fullname" . }}-root-cert - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - secretName: {{ include "ingress-nginx.fullname" . }}-root-cert - duration: {{ .Values.controller.admissionWebhooks.certManager.rootCert.duration | default "43800h0m0s" | quote }} - issuerRef: - name: {{ include "ingress-nginx.fullname" . }}-self-signed-issuer - commonName: "ca.webhook.ingress-nginx" - isCA: true - subject: - organizations: - - ingress-nginx ---- -# Create an Issuer that uses the above generated CA certificate to issue certs -apiVersion: cert-manager.io/v1 -kind: Issuer -metadata: - name: {{ include "ingress-nginx.fullname" . }}-root-issuer - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - ca: - secretName: {{ include "ingress-nginx.fullname" . }}-root-cert -{{- end }} ---- -# generate a server certificate for the apiservices to use -apiVersion: cert-manager.io/v1 -kind: Certificate -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - secretName: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - duration: {{ .Values.controller.admissionWebhooks.certManager.admissionCert.duration | default "8760h0m0s" | quote }} - issuerRef: - {{- if .Values.controller.admissionWebhooks.certManager.issuerRef }} - {{- toYaml .Values.controller.admissionWebhooks.certManager.issuerRef | nindent 4 }} - {{- else }} - name: {{ include "ingress-nginx.fullname" . }}-root-issuer - {{- end }} - dnsNames: - - {{ include "ingress-nginx.controller.fullname" . }}-admission - - {{ include "ingress-nginx.controller.fullname" . }}-admission.{{ include "ingress-nginx.namespace" . }} - - {{ include "ingress-nginx.controller.fullname" . }}-admission.{{ include "ingress-nginx.namespace" . }}.svc - subject: - organizations: - - ingress-nginx-admission -{{- end -}} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml deleted file mode 100644 index a218482..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml +++ /dev/null @@ -1,33 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.rbac.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: ClusterRole -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -rules: - - apiGroups: - - admissionregistration.k8s.io - resources: - - validatingwebhookconfigurations - verbs: - - get - - update -{{- if .Values.podSecurityPolicy.enabled }} - - apiGroups: [{{ template "podSecurityPolicy.apiGroup" . }}] - resources: ['podsecuritypolicies'] - verbs: ['use'] - {{- with .Values.controller.admissionWebhooks.existingPsp }} - resourceNames: [{{ . }}] - {{- else }} - resourceNames: [{{ include "ingress-nginx.admissionWebhooks.fullname" . }}] - {{- end }} -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml deleted file mode 100644 index b893884..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml +++ /dev/null @@ -1,23 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.rbac.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: ClusterRoleBinding -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -roleRef: - apiGroup: rbac.authorization.k8s.io - kind: ClusterRole - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} -subjects: - - kind: ServiceAccount - name: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml deleted file mode 100644 index 1766164..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml +++ /dev/null @@ -1,79 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled (not .Values.controller.admissionWebhooks.certManager.enabled) -}} -apiVersion: batch/v1 -kind: Job -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.createSecretJob.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - annotations: - "helm.sh/hook": pre-install,pre-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - {{- with .Values.controller.admissionWebhooks.annotations }} - {{- toYaml . | nindent 4 }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -spec: -{{- if .Capabilities.APIVersions.Has "batch/v1alpha1" }} - # Alpha feature since k8s 1.12 - ttlSecondsAfterFinished: 0 -{{- end }} - template: - metadata: - name: {{ include "ingress-nginx.admissionWebhooks.createSecretJob.fullname" . }} - {{- if .Values.controller.admissionWebhooks.patch.podAnnotations }} - annotations: {{ toYaml .Values.controller.admissionWebhooks.patch.podAnnotations | nindent 8 }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 8 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 8 }} - {{- end }} - spec: - {{- if .Values.controller.admissionWebhooks.patch.priorityClassName }} - priorityClassName: {{ .Values.controller.admissionWebhooks.patch.priorityClassName }} - {{- end }} - {{- if .Values.imagePullSecrets }} - imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} - {{- end }} - containers: - - name: create - {{- with .Values.controller.admissionWebhooks.patch.image }} - image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ .image }}{{ end }}:{{ .tag }}{{ if .digest }}@{{ .digest }}{{ end }} - {{- end }} - imagePullPolicy: {{ .Values.controller.admissionWebhooks.patch.image.pullPolicy }} - args: - - create - - --host={{ include "ingress-nginx.controller.fullname" . }}-admission,{{ include "ingress-nginx.controller.fullname" . }}-admission.$(POD_NAMESPACE).svc - - --namespace=$(POD_NAMESPACE) - - --secret-name={{ include "ingress-nginx.admissionWebhooks.fullname" . }} - env: - - name: POD_NAMESPACE - valueFrom: - fieldRef: - fieldPath: metadata.namespace - {{- if .Values.controller.admissionWebhooks.extraEnvs }} - {{- toYaml .Values.controller.admissionWebhooks.extraEnvs | nindent 12 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.createSecretJob.securityContext }} - securityContext: {{ toYaml .Values.controller.admissionWebhooks.createSecretJob.securityContext | nindent 12 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.createSecretJob.resources }} - resources: {{ toYaml .Values.controller.admissionWebhooks.createSecretJob.resources | nindent 12 }} - {{- end }} - restartPolicy: OnFailure - serviceAccountName: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} - {{- if .Values.controller.admissionWebhooks.patch.nodeSelector }} - nodeSelector: {{ toYaml .Values.controller.admissionWebhooks.patch.nodeSelector | nindent 8 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.patch.tolerations }} - tolerations: {{ toYaml .Values.controller.admissionWebhooks.patch.tolerations | nindent 8 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.patch.securityContext }} - securityContext: {{ toYaml .Values.controller.admissionWebhooks.patch.securityContext | nindent 8 }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml deleted file mode 100644 index f7d44a2..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml +++ /dev/null @@ -1,81 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled (not .Values.controller.admissionWebhooks.certManager.enabled) -}} -apiVersion: batch/v1 -kind: Job -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.patchWebhookJob.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - annotations: - "helm.sh/hook": post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - {{- with .Values.controller.admissionWebhooks.annotations }} - {{- toYaml . | nindent 4 }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -spec: -{{- if .Capabilities.APIVersions.Has "batch/v1alpha1" }} - # Alpha feature since k8s 1.12 - ttlSecondsAfterFinished: 0 -{{- end }} - template: - metadata: - name: {{ include "ingress-nginx.admissionWebhooks.patchWebhookJob.fullname" . }} - {{- if .Values.controller.admissionWebhooks.patch.podAnnotations }} - annotations: {{ toYaml .Values.controller.admissionWebhooks.patch.podAnnotations | nindent 8 }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 8 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 8 }} - {{- end }} - spec: - {{- if .Values.controller.admissionWebhooks.patch.priorityClassName }} - priorityClassName: {{ .Values.controller.admissionWebhooks.patch.priorityClassName }} - {{- end }} - {{- if .Values.imagePullSecrets }} - imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} - {{- end }} - containers: - - name: patch - {{- with .Values.controller.admissionWebhooks.patch.image }} - image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ .image }}{{ end }}:{{ .tag }}{{ if .digest }}@{{ .digest }}{{ end }} - {{- end }} - imagePullPolicy: {{ .Values.controller.admissionWebhooks.patch.image.pullPolicy }} - args: - - patch - - --webhook-name={{ include "ingress-nginx.admissionWebhooks.fullname" . }} - - --namespace=$(POD_NAMESPACE) - - --patch-mutating=false - - --secret-name={{ include "ingress-nginx.admissionWebhooks.fullname" . }} - - --patch-failure-policy={{ .Values.controller.admissionWebhooks.failurePolicy }} - env: - - name: POD_NAMESPACE - valueFrom: - fieldRef: - fieldPath: metadata.namespace - {{- if .Values.controller.admissionWebhooks.extraEnvs }} - {{- toYaml .Values.controller.admissionWebhooks.extraEnvs | nindent 12 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.patchWebhookJob.securityContext }} - securityContext: {{ toYaml .Values.controller.admissionWebhooks.patchWebhookJob.securityContext | nindent 12 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.patchWebhookJob.resources }} - resources: {{ toYaml .Values.controller.admissionWebhooks.patchWebhookJob.resources | nindent 12 }} - {{- end }} - restartPolicy: OnFailure - serviceAccountName: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} - {{- if .Values.controller.admissionWebhooks.patch.nodeSelector }} - nodeSelector: {{ toYaml .Values.controller.admissionWebhooks.patch.nodeSelector | nindent 8 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.patch.tolerations }} - tolerations: {{ toYaml .Values.controller.admissionWebhooks.patch.tolerations | nindent 8 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.patch.securityContext }} - securityContext: {{ toYaml .Values.controller.admissionWebhooks.patch.securityContext | nindent 8 }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/networkpolicy.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/networkpolicy.yaml deleted file mode 100644 index a8f38df..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/networkpolicy.yaml +++ /dev/null @@ -1,26 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.networkPolicy.enabled (not .Values.controller.admissionWebhooks.certManager.enabled) -}} -apiVersion: networking.k8s.io/v1 -kind: NetworkPolicy -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -spec: - podSelector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: admission-webhook - policyTypes: - - Ingress - - Egress - egress: - - {} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/psp.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/psp.yaml deleted file mode 100644 index 8e5dc72..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/psp.yaml +++ /dev/null @@ -1,52 +0,0 @@ -{{- if (semverCompare "<1.25.0-0" .Capabilities.KubeVersion.Version) }} -{{- if and .Values.podSecurityPolicy.enabled .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled (empty .Values.controller.admissionWebhooks.existingPsp) -}} -apiVersion: policy/v1beta1 -kind: PodSecurityPolicy -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - seccomp.security.alpha.kubernetes.io/allowedProfileNames: "*" - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -spec: - privileged: false - hostPID: false - hostIPC: false - hostNetwork: false - volumes: - - configMap - - downwardAPI - - emptyDir - - secret - - projected - fsGroup: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - readOnlyRootFilesystem: true - runAsUser: - rule: MustRunAsNonRoot - runAsGroup: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - supplementalGroups: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - allowPrivilegeEscalation: false - requiredDropCapabilities: - - ALL - seLinux: - rule: RunAsAny -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml deleted file mode 100644 index c4b23aa..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml +++ /dev/null @@ -1,24 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.rbac.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: Role -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -rules: - - apiGroups: - - "" - resources: - - secrets - verbs: - - get - - create -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml deleted file mode 100644 index 425e8d8..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml +++ /dev/null @@ -1,24 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.rbac.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: RoleBinding -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -roleRef: - apiGroup: rbac.authorization.k8s.io - kind: Role - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} -subjects: - - kind: ServiceAccount - name: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml deleted file mode 100644 index 52f94dc..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml +++ /dev/null @@ -1,17 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.serviceAccount.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} -apiVersion: v1 -kind: ServiceAccount -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -automountServiceAccountToken: {{ .Values.controller.admissionWebhooks.patch.serviceAccount.automountServiceAccountToken }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml deleted file mode 100644 index 0949cea..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml +++ /dev/null @@ -1,54 +0,0 @@ -{{- if .Values.controller.admissionWebhooks.enabled -}} -# before changing this value, check the required kubernetes version -# https://kubernetes.io/docs/reference/access-authn-authz/extensible-admission-controllers/#prerequisites -apiVersion: admissionregistration.k8s.io/v1 -kind: ValidatingWebhookConfiguration -metadata: - annotations: - {{- if .Values.controller.admissionWebhooks.certManager.enabled }} - certmanager.k8s.io/inject-ca-from: {{ printf "%s/%s" (include "ingress-nginx.namespace" .) (include "ingress-nginx.admissionWebhooks.fullname" .) | quote }} - cert-manager.io/inject-ca-from: {{ printf "%s/%s" (include "ingress-nginx.namespace" .) (include "ingress-nginx.admissionWebhooks.fullname" .) | quote }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.annotations }} - {{- toYaml .Values.controller.admissionWebhooks.annotations | nindent 4 }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} -webhooks: - - name: validate.nginx.ingress.kubernetes.io - matchPolicy: Equivalent - rules: - - apiGroups: - - networking.k8s.io - apiVersions: - - v1 - operations: - - CREATE - - UPDATE - resources: - - ingresses - failurePolicy: {{ .Values.controller.admissionWebhooks.failurePolicy | default "Fail" }} - sideEffects: None - admissionReviewVersions: - - v1 - clientConfig: - service: - name: {{ include "ingress-nginx.controller.fullname" . }}-admission - namespace: {{ include "ingress-nginx.namespace" . }} - port: {{ .Values.controller.admissionWebhooks.service.servicePort }} - path: /networking/v1/ingresses - {{- if .Values.controller.admissionWebhooks.timeoutSeconds }} - timeoutSeconds: {{ .Values.controller.admissionWebhooks.timeoutSeconds }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.namespaceSelector }} - namespaceSelector: {{ toYaml .Values.controller.admissionWebhooks.namespaceSelector | nindent 6 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.objectSelector }} - objectSelector: {{ toYaml .Values.controller.admissionWebhooks.objectSelector | nindent 6 }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/clusterrole.yaml b/charts/keep/charts/ingress-nginx/templates/clusterrole.yaml deleted file mode 100644 index 51bc500..0000000 --- a/charts/keep/charts/ingress-nginx/templates/clusterrole.yaml +++ /dev/null @@ -1,102 +0,0 @@ -{{- if .Values.rbac.create }} - -{{- if and .Values.rbac.scope (not .Values.controller.scope.enabled) -}} - {{ required "Invalid configuration: 'rbac.scope' should be equal to 'controller.scope.enabled' (true/false)." (index (dict) ".") }} -{{- end }} - -{{- if not .Values.rbac.scope -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: ClusterRole -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.fullname" . }} -rules: - - apiGroups: - - "" - resources: - - configmaps - - endpoints - - nodes - - pods - - secrets -{{- if not .Values.controller.scope.enabled }} - - namespaces -{{- end}} - verbs: - - list - - watch - - apiGroups: - - coordination.k8s.io - resources: - - leases - verbs: - - list - - watch -{{- if and .Values.controller.scope.enabled .Values.controller.scope.namespace }} - - apiGroups: - - "" - resources: - - namespaces - resourceNames: - - "{{ .Values.controller.scope.namespace }}" - verbs: - - get -{{- end }} - - apiGroups: - - "" - resources: - - nodes - verbs: - - get - - apiGroups: - - "" - resources: - - services - verbs: - - get - - list - - watch - - apiGroups: - - networking.k8s.io - resources: - - ingresses - verbs: - - get - - list - - watch - - apiGroups: - - "" - resources: - - events - verbs: - - create - - patch - - apiGroups: - - networking.k8s.io - resources: - - ingresses/status - verbs: - - update - - apiGroups: - - networking.k8s.io - resources: - - ingressclasses - verbs: - - get - - list - - watch - - apiGroups: - - discovery.k8s.io - resources: - - endpointslices - verbs: - - list - - watch - - get -{{- end }} - -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/clusterrolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/clusterrolebinding.yaml deleted file mode 100644 index 8f91aac..0000000 --- a/charts/keep/charts/ingress-nginx/templates/clusterrolebinding.yaml +++ /dev/null @@ -1,19 +0,0 @@ -{{- if and .Values.rbac.create (not .Values.rbac.scope) -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: ClusterRoleBinding -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.fullname" . }} -roleRef: - apiGroup: rbac.authorization.k8s.io - kind: ClusterRole - name: {{ include "ingress-nginx.fullname" . }} -subjects: - - kind: ServiceAccount - name: {{ template "ingress-nginx.serviceAccountName" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap-addheaders.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap-addheaders.yaml deleted file mode 100644 index 4e4bd13..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-configmap-addheaders.yaml +++ /dev/null @@ -1,14 +0,0 @@ -{{- if .Values.controller.addHeaders -}} -apiVersion: v1 -kind: ConfigMap -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.fullname" . }}-custom-add-headers - namespace: {{ include "ingress-nginx.namespace" . }} -data: {{ toYaml .Values.controller.addHeaders | nindent 2 }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap-proxyheaders.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap-proxyheaders.yaml deleted file mode 100644 index 0a22600..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-configmap-proxyheaders.yaml +++ /dev/null @@ -1,14 +0,0 @@ -{{- if .Values.controller.proxySetHeaders -}} -apiVersion: v1 -kind: ConfigMap -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.fullname" . }}-custom-proxy-headers - namespace: {{ include "ingress-nginx.namespace" . }} -data: {{ toYaml .Values.controller.proxySetHeaders | nindent 2 }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap-tcp.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap-tcp.yaml deleted file mode 100644 index 131a9ad..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-configmap-tcp.yaml +++ /dev/null @@ -1,17 +0,0 @@ -{{- if .Values.tcp -}} -apiVersion: v1 -kind: ConfigMap -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -{{- if .Values.controller.tcp.annotations }} - annotations: {{ toYaml .Values.controller.tcp.annotations | nindent 4 }} -{{- end }} - name: {{ include "ingress-nginx.fullname" . }}-tcp - namespace: {{ include "ingress-nginx.namespace" . }} -data: {{ tpl (toYaml .Values.tcp) . | nindent 2 }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap-udp.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap-udp.yaml deleted file mode 100644 index 7137da9..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-configmap-udp.yaml +++ /dev/null @@ -1,17 +0,0 @@ -{{- if .Values.udp -}} -apiVersion: v1 -kind: ConfigMap -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -{{- if .Values.controller.udp.annotations }} - annotations: {{ toYaml .Values.controller.udp.annotations | nindent 4 }} -{{- end }} - name: {{ include "ingress-nginx.fullname" . }}-udp - namespace: {{ include "ingress-nginx.namespace" . }} -data: {{ tpl (toYaml .Values.udp) . | nindent 2 }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap.yaml deleted file mode 100644 index 22080d1..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-configmap.yaml +++ /dev/null @@ -1,28 +0,0 @@ -apiVersion: v1 -kind: ConfigMap -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -{{- if .Values.controller.configAnnotations }} - annotations: {{ toYaml .Values.controller.configAnnotations | nindent 4 }} -{{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -data: - allow-snippet-annotations: "{{ .Values.controller.allowSnippetAnnotations }}" -{{- if .Values.controller.addHeaders }} - add-headers: {{ include "ingress-nginx.namespace" . }}/{{ include "ingress-nginx.fullname" . }}-custom-add-headers -{{- end }} -{{- if .Values.controller.proxySetHeaders }} - proxy-set-headers: {{ include "ingress-nginx.namespace" . }}/{{ include "ingress-nginx.fullname" . }}-custom-proxy-headers -{{- end }} -{{- if .Values.dhParam }} - ssl-dh-param: {{ include "ingress-nginx.namespace" . }}/{{ include "ingress-nginx.controller.fullname" . }} -{{- end }} -{{- range $key, $value := .Values.controller.config }} - {{- $key | nindent 2 }}: {{ tpl (toString $value) $ | quote }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-daemonset.yaml b/charts/keep/charts/ingress-nginx/templates/controller-daemonset.yaml deleted file mode 100644 index fcc633d..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-daemonset.yaml +++ /dev/null @@ -1,242 +0,0 @@ -{{- if eq .Values.controller.kind "DaemonSet" -}} -apiVersion: apps/v1 -kind: DaemonSet -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - {{- if .Values.controller.annotations }} - annotations: {{ toYaml .Values.controller.annotations | nindent 4 }} - {{- end }} -spec: - selector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: controller - revisionHistoryLimit: {{ .Values.revisionHistoryLimit }} - {{- if .Values.controller.updateStrategy }} - updateStrategy: {{ toYaml .Values.controller.updateStrategy | nindent 4 }} - {{- end }} - minReadySeconds: {{ .Values.controller.minReadySeconds }} - template: - metadata: - {{- if .Values.controller.podAnnotations }} - annotations: - {{- range $key, $value := .Values.controller.podAnnotations }} - {{ $key }}: {{ $value | quote }} - {{- end }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 8 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 8 }} - {{- end }} - {{- if .Values.controller.podLabels }} - {{- toYaml .Values.controller.podLabels | nindent 8 }} - {{- end }} - spec: - {{- if .Values.controller.dnsConfig }} - dnsConfig: {{ toYaml .Values.controller.dnsConfig | nindent 8 }} - {{- end }} - {{- if .Values.controller.hostAliases }} - hostAliases: {{ tpl (toYaml .Values.controller.hostAliases) $ | nindent 8 }} - {{- end }} - {{- if .Values.controller.hostname }} - hostname: {{ toYaml .Values.controller.hostname | nindent 8 }} - {{- end }} - dnsPolicy: {{ .Values.controller.dnsPolicy }} - {{- if .Values.imagePullSecrets }} - imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} - {{- end }} - {{- if .Values.controller.priorityClassName }} - priorityClassName: {{ .Values.controller.priorityClassName | quote }} - {{- end }} - {{- if or .Values.controller.podSecurityContext .Values.controller.sysctls }} - securityContext: - {{- if .Values.controller.podSecurityContext }} - {{- toYaml .Values.controller.podSecurityContext | nindent 8 }} - {{- end }} - {{- if .Values.controller.sysctls }} - sysctls: - {{- range $sysctl, $value := .Values.controller.sysctls }} - - name: {{ $sysctl | quote }} - value: {{ $value | quote }} - {{- end }} - {{- end }} - {{- end }} - {{- if .Values.controller.shareProcessNamespace }} - shareProcessNamespace: {{ .Values.controller.shareProcessNamespace }} - {{- end }} - containers: - - name: {{ .Values.controller.containerName }} - {{- with .Values.controller.image }} - image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ include "ingress-nginx.image" . }}{{ end }}:{{ .tag }}{{ include "ingress-nginx.imageDigest" . }} - {{- end }} - imagePullPolicy: {{ .Values.controller.image.pullPolicy }} - {{- if .Values.controller.lifecycle }} - lifecycle: {{ toYaml .Values.controller.lifecycle | nindent 12 }} - {{- end }} - args: {{ include "ingress-nginx.params" . | nindent 12 }} - securityContext: {{ include "ingress-nginx.controller.containerSecurityContext" . | nindent 12 }} - env: - - name: POD_NAME - valueFrom: - fieldRef: - fieldPath: metadata.name - - name: POD_NAMESPACE - valueFrom: - fieldRef: - fieldPath: metadata.namespace - {{- if .Values.controller.enableMimalloc }} - - name: LD_PRELOAD - value: /usr/local/lib/libmimalloc.so - {{- end }} - {{- if .Values.controller.extraEnvs }} - {{- toYaml .Values.controller.extraEnvs | nindent 12 }} - {{- end }} - {{- if .Values.controller.startupProbe }} - startupProbe: {{ toYaml .Values.controller.startupProbe | nindent 12 }} - {{- end }} - {{- if .Values.controller.livenessProbe }} - livenessProbe: {{ toYaml .Values.controller.livenessProbe | nindent 12 }} - {{- end }} - {{- if .Values.controller.readinessProbe }} - readinessProbe: {{ toYaml .Values.controller.readinessProbe | nindent 12 }} - {{- end }} - ports: - {{- range $key, $value := .Values.controller.containerPort }} - - name: {{ $key }} - containerPort: {{ $value }} - protocol: TCP - {{- if $.Values.controller.hostPort.enabled }} - hostPort: {{ index $.Values.controller.hostPort.ports $key | default $value }} - {{- end }} - {{- end }} - {{- if .Values.controller.metrics.enabled }} - - name: {{ .Values.controller.metrics.portName }} - containerPort: {{ .Values.controller.metrics.port }} - protocol: TCP - {{- end }} - {{- if .Values.controller.admissionWebhooks.enabled }} - - name: webhook - containerPort: {{ .Values.controller.admissionWebhooks.port }} - protocol: TCP - {{- end }} - {{- range $key, $value := .Values.tcp }} - - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp - containerPort: {{ $key }} - protocol: TCP - {{- if $.Values.controller.hostPort.enabled }} - hostPort: {{ $key }} - {{- end }} - {{- end }} - {{- range $key, $value := .Values.udp }} - - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp - containerPort: {{ $key }} - protocol: UDP - {{- if $.Values.controller.hostPort.enabled }} - hostPort: {{ $key }} - {{- end }} - {{- end }} - {{- if (or .Values.controller.customTemplate.configMapName .Values.controller.extraVolumeMounts .Values.controller.admissionWebhooks.enabled .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} - volumeMounts: - {{- if (or .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} - - name: modules - {{- if .Values.controller.image.chroot }} - mountPath: /chroot/modules_mount - {{- else }} - mountPath: /modules_mount - {{- end }} - {{- end }} - {{- if .Values.controller.customTemplate.configMapName }} - - mountPath: /etc/nginx/template - name: nginx-template-volume - readOnly: true - {{- end }} - {{- if .Values.controller.admissionWebhooks.enabled }} - - name: webhook-cert - mountPath: /usr/local/certificates/ - readOnly: true - {{- end }} - {{- if .Values.controller.extraVolumeMounts }} - {{- toYaml .Values.controller.extraVolumeMounts | nindent 12 }} - {{- end }} - {{- end }} - {{- if .Values.controller.resources }} - resources: {{ toYaml .Values.controller.resources | nindent 12 }} - {{- end }} - {{- if .Values.controller.extraContainers }} - {{- toYaml .Values.controller.extraContainers | nindent 8 }} - {{- end }} - {{- if (or .Values.controller.extraInitContainers .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} - initContainers: - {{- if .Values.controller.extraInitContainers }} - {{- toYaml .Values.controller.extraInitContainers | nindent 8 }} - {{- end }} - {{- if .Values.controller.extraModules }} - {{- range .Values.controller.extraModules }} - {{- $containerSecurityContext := .containerSecurityContext | default $.Values.controller.containerSecurityContext }} - {{- include "extraModules" (dict "name" .name "image" .image "containerSecurityContext" $containerSecurityContext "resources" .resources) | nindent 8 }} - {{- end }} - {{- end }} - {{- if .Values.controller.opentelemetry.enabled }} - {{- with .Values.controller.opentelemetry }} - {{- $containerSecurityContext := .containerSecurityContext | default $.Values.controller.containerSecurityContext }} - {{- include "extraModules" (dict "name" .name "image" .image "containerSecurityContext" $containerSecurityContext "resources" .resources) | nindent 8 }} - {{- end }} - {{- end }} - {{- end }} - {{- if .Values.controller.hostNetwork }} - hostNetwork: {{ .Values.controller.hostNetwork }} - {{- end }} - {{- if .Values.controller.nodeSelector }} - nodeSelector: {{ toYaml .Values.controller.nodeSelector | nindent 8 }} - {{- end }} - {{- if .Values.controller.tolerations }} - tolerations: {{ toYaml .Values.controller.tolerations | nindent 8 }} - {{- end }} - {{- if .Values.controller.affinity }} - affinity: {{ tpl (toYaml .Values.controller.affinity) $ | nindent 8 }} - {{- end }} - {{- if .Values.controller.topologySpreadConstraints }} - topologySpreadConstraints: {{ tpl (toYaml .Values.controller.topologySpreadConstraints) $ | nindent 8 }} - {{- end }} - serviceAccountName: {{ template "ingress-nginx.serviceAccountName" . }} - terminationGracePeriodSeconds: {{ .Values.controller.terminationGracePeriodSeconds }} - {{- if (or .Values.controller.customTemplate.configMapName .Values.controller.extraVolumeMounts .Values.controller.admissionWebhooks.enabled .Values.controller.extraVolumes .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} - volumes: - {{- if (or .Values.controller.extraModules .Values.controller.opentelemetry.enabled)}} - - name: modules - emptyDir: {} - {{- end }} - {{- if .Values.controller.customTemplate.configMapName }} - - name: nginx-template-volume - configMap: - name: {{ .Values.controller.customTemplate.configMapName }} - items: - - key: {{ .Values.controller.customTemplate.configMapKey }} - path: nginx.tmpl - {{- end }} - {{- if .Values.controller.admissionWebhooks.enabled }} - - name: webhook-cert - secret: - secretName: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - {{- if .Values.controller.admissionWebhooks.certManager.enabled }} - items: - - key: tls.crt - path: cert - - key: tls.key - path: key - {{- end }} - {{- end }} - {{- if .Values.controller.extraVolumes }} - {{ toYaml .Values.controller.extraVolumes | nindent 8 }} - {{- end }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-deployment.yaml b/charts/keep/charts/ingress-nginx/templates/controller-deployment.yaml deleted file mode 100644 index 5211acd..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-deployment.yaml +++ /dev/null @@ -1,245 +0,0 @@ -{{- if eq .Values.controller.kind "Deployment" -}} -apiVersion: apps/v1 -kind: Deployment -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - {{- if .Values.controller.annotations }} - annotations: {{ toYaml .Values.controller.annotations | nindent 4 }} - {{- end }} -spec: - selector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: controller - {{- if eq .Values.controller.autoscaling.enabled .Values.controller.keda.enabled }} - replicas: {{ .Values.controller.replicaCount }} - {{- end }} - revisionHistoryLimit: {{ .Values.revisionHistoryLimit }} - {{- if .Values.controller.updateStrategy }} - strategy: {{ toYaml .Values.controller.updateStrategy | nindent 4 }} - {{- end }} - minReadySeconds: {{ .Values.controller.minReadySeconds }} - template: - metadata: - {{- if .Values.controller.podAnnotations }} - annotations: - {{- range $key, $value := .Values.controller.podAnnotations }} - {{ $key }}: {{ $value | quote }} - {{- end }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 8 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 8 }} - {{- end }} - {{- if .Values.controller.podLabels }} - {{- toYaml .Values.controller.podLabels | nindent 8 }} - {{- end }} - spec: - {{- if .Values.controller.dnsConfig }} - dnsConfig: {{ toYaml .Values.controller.dnsConfig | nindent 8 }} - {{- end }} - {{- if .Values.controller.hostAliases }} - hostAliases: {{ tpl (toYaml .Values.controller.hostAliases) $ | nindent 8 }} - {{- end }} - {{- if .Values.controller.hostname }} - hostname: {{ toYaml .Values.controller.hostname | nindent 8 }} - {{- end }} - dnsPolicy: {{ .Values.controller.dnsPolicy }} - {{- if .Values.imagePullSecrets }} - imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} - {{- end }} - {{- if .Values.controller.priorityClassName }} - priorityClassName: {{ .Values.controller.priorityClassName | quote }} - {{- end }} - {{- if or .Values.controller.podSecurityContext .Values.controller.sysctls }} - securityContext: - {{- if .Values.controller.podSecurityContext }} - {{- toYaml .Values.controller.podSecurityContext | nindent 8 }} - {{- end }} - {{- if .Values.controller.sysctls }} - sysctls: - {{- range $sysctl, $value := .Values.controller.sysctls }} - - name: {{ $sysctl | quote }} - value: {{ $value | quote }} - {{- end }} - {{- end }} - {{- end }} - {{- if .Values.controller.shareProcessNamespace }} - shareProcessNamespace: {{ .Values.controller.shareProcessNamespace }} - {{- end }} - containers: - - name: {{ .Values.controller.containerName }} - {{- with .Values.controller.image }} - image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ include "ingress-nginx.image" . }}{{ end }}:{{ .tag }}{{ include "ingress-nginx.imageDigest" . }} - {{- end }} - imagePullPolicy: {{ .Values.controller.image.pullPolicy }} - {{- if .Values.controller.lifecycle }} - lifecycle: {{ toYaml .Values.controller.lifecycle | nindent 12 }} - {{- end }} - args: {{ include "ingress-nginx.params" . | nindent 12 }} - securityContext: {{ include "ingress-nginx.controller.containerSecurityContext" . | nindent 12 }} - env: - - name: POD_NAME - valueFrom: - fieldRef: - fieldPath: metadata.name - - name: POD_NAMESPACE - valueFrom: - fieldRef: - fieldPath: metadata.namespace - {{- if .Values.controller.enableMimalloc }} - - name: LD_PRELOAD - value: /usr/local/lib/libmimalloc.so - {{- end }} - {{- if .Values.controller.extraEnvs }} - {{- toYaml .Values.controller.extraEnvs | nindent 12 }} - {{- end }} - {{- if .Values.controller.startupProbe }} - startupProbe: {{ toYaml .Values.controller.startupProbe | nindent 12 }} - {{- end }} - {{- if .Values.controller.livenessProbe }} - livenessProbe: {{ toYaml .Values.controller.livenessProbe | nindent 12 }} - {{- end }} - {{- if .Values.controller.readinessProbe }} - readinessProbe: {{ toYaml .Values.controller.readinessProbe | nindent 12 }} - {{- end }} - ports: - {{- range $key, $value := .Values.controller.containerPort }} - - name: {{ $key }} - containerPort: {{ $value }} - protocol: TCP - {{- if $.Values.controller.hostPort.enabled }} - hostPort: {{ index $.Values.controller.hostPort.ports $key | default $value }} - {{- end }} - {{- end }} - {{- if .Values.controller.metrics.enabled }} - - name: {{ .Values.controller.metrics.portName }} - containerPort: {{ .Values.controller.metrics.port }} - protocol: TCP - {{- end }} - {{- if .Values.controller.admissionWebhooks.enabled }} - - name: webhook - containerPort: {{ .Values.controller.admissionWebhooks.port }} - protocol: TCP - {{- end }} - {{- range $key, $value := .Values.tcp }} - - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp - containerPort: {{ $key }} - protocol: TCP - {{- if $.Values.controller.hostPort.enabled }} - hostPort: {{ $key }} - {{- end }} - {{- end }} - {{- range $key, $value := .Values.udp }} - - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp - containerPort: {{ $key }} - protocol: UDP - {{- if $.Values.controller.hostPort.enabled }} - hostPort: {{ $key }} - {{- end }} - {{- end }} - {{- if (or .Values.controller.customTemplate.configMapName .Values.controller.extraVolumeMounts .Values.controller.admissionWebhooks.enabled .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} - volumeMounts: - {{- if (or .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} - - name: modules - {{- if .Values.controller.image.chroot }} - mountPath: /chroot/modules_mount - {{- else }} - mountPath: /modules_mount - {{- end }} - {{- end }} - {{- if .Values.controller.customTemplate.configMapName }} - - mountPath: /etc/nginx/template - name: nginx-template-volume - readOnly: true - {{- end }} - {{- if .Values.controller.admissionWebhooks.enabled }} - - name: webhook-cert - mountPath: /usr/local/certificates/ - readOnly: true - {{- end }} - {{- if .Values.controller.extraVolumeMounts }} - {{- toYaml .Values.controller.extraVolumeMounts | nindent 12 }} - {{- end }} - {{- end }} - {{- if .Values.controller.resources }} - resources: {{ toYaml .Values.controller.resources | nindent 12 }} - {{- end }} - {{- if .Values.controller.extraContainers }} - {{- toYaml .Values.controller.extraContainers | nindent 8 }} - {{- end }} - {{- if (or .Values.controller.extraInitContainers .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} - initContainers: - {{- if .Values.controller.extraInitContainers }} - {{- toYaml .Values.controller.extraInitContainers | nindent 8 }} - {{- end }} - {{- if .Values.controller.extraModules }} - {{- range .Values.controller.extraModules }} - {{- $containerSecurityContext := .containerSecurityContext | default $.Values.controller.containerSecurityContext }} - {{- include "extraModules" (dict "name" .name "image" .image "containerSecurityContext" $containerSecurityContext "resources" .resources) | nindent 8 }} - {{- end }} - {{- end }} - {{- if .Values.controller.opentelemetry.enabled }} - {{- with .Values.controller.opentelemetry }} - {{- $containerSecurityContext := .containerSecurityContext | default $.Values.controller.containerSecurityContext }} - {{- include "extraModules" (dict "name" .name "image" .image "containerSecurityContext" $containerSecurityContext "resources" .resources) | nindent 8 }} - {{- end }} - {{- end }} - {{- end }} - {{- if .Values.controller.hostNetwork }} - hostNetwork: {{ .Values.controller.hostNetwork }} - {{- end }} - {{- if .Values.controller.nodeSelector }} - nodeSelector: {{ toYaml .Values.controller.nodeSelector | nindent 8 }} - {{- end }} - {{- if .Values.controller.tolerations }} - tolerations: {{ toYaml .Values.controller.tolerations | nindent 8 }} - {{- end }} - {{- if .Values.controller.affinity }} - affinity: {{ tpl (toYaml .Values.controller.affinity) $ | nindent 8 }} - {{- end }} - {{- if .Values.controller.topologySpreadConstraints }} - topologySpreadConstraints: {{ tpl (toYaml .Values.controller.topologySpreadConstraints) $ | nindent 8 }} - {{- end }} - serviceAccountName: {{ template "ingress-nginx.serviceAccountName" . }} - terminationGracePeriodSeconds: {{ .Values.controller.terminationGracePeriodSeconds }} - {{- if (or .Values.controller.customTemplate.configMapName .Values.controller.extraVolumeMounts .Values.controller.admissionWebhooks.enabled .Values.controller.extraVolumes .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} - volumes: - {{- if (or .Values.controller.extraModules .Values.controller.opentelemetry.enabled)}} - - name: modules - emptyDir: {} - {{- end }} - {{- if .Values.controller.customTemplate.configMapName }} - - name: nginx-template-volume - configMap: - name: {{ .Values.controller.customTemplate.configMapName }} - items: - - key: {{ .Values.controller.customTemplate.configMapKey }} - path: nginx.tmpl - {{- end }} - {{- if .Values.controller.admissionWebhooks.enabled }} - - name: webhook-cert - secret: - secretName: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - {{- if .Values.controller.admissionWebhooks.certManager.enabled }} - items: - - key: tls.crt - path: cert - - key: tls.key - path: key - {{- end }} - {{- end }} - {{- if .Values.controller.extraVolumes }} - {{ toYaml .Values.controller.extraVolumes | nindent 8 }} - {{- end }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-hpa.yaml b/charts/keep/charts/ingress-nginx/templates/controller-hpa.yaml deleted file mode 100644 index ec9ad73..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-hpa.yaml +++ /dev/null @@ -1,47 +0,0 @@ -{{- if and (eq .Values.controller.kind "Deployment") .Values.controller.autoscaling.enabled (not .Values.controller.keda.enabled) -}} -apiVersion: {{ ternary "autoscaling/v2" "autoscaling/v2beta2" (.Capabilities.APIVersions.Has "autoscaling/v2") }} -kind: HorizontalPodAutoscaler -metadata: - {{- with .Values.controller.autoscaling.annotations }} - annotations: {{ toYaml . | nindent 4 }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - scaleTargetRef: - apiVersion: apps/v1 - kind: Deployment - name: {{ include "ingress-nginx.controller.fullname" . }} - minReplicas: {{ .Values.controller.autoscaling.minReplicas }} - maxReplicas: {{ .Values.controller.autoscaling.maxReplicas }} - metrics: - {{- with .Values.controller.autoscaling.targetMemoryUtilizationPercentage }} - - type: Resource - resource: - name: memory - target: - type: Utilization - averageUtilization: {{ . }} - {{- end }} - {{- with .Values.controller.autoscaling.targetCPUUtilizationPercentage }} - - type: Resource - resource: - name: cpu - target: - type: Utilization - averageUtilization: {{ . }} - {{- end }} - {{- with .Values.controller.autoscalingTemplate }} - {{- toYaml . | nindent 2 }} - {{- end }} - {{- with .Values.controller.autoscaling.behavior }} - behavior: - {{- toYaml . | nindent 4 }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-ingressclass-aliases.yaml b/charts/keep/charts/ingress-nginx/templates/controller-ingressclass-aliases.yaml deleted file mode 100644 index ffe2231..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-ingressclass-aliases.yaml +++ /dev/null @@ -1,23 +0,0 @@ -{{- if .Values.controller.ingressClassResource.enabled -}} -{{- range .Values.controller.ingressClassResource.aliases }} ---- -apiVersion: networking.k8s.io/v1 -kind: IngressClass -metadata: - labels: - {{- include "ingress-nginx.labels" $ | nindent 4 }} - app.kubernetes.io/component: controller - {{- with $.Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ . }} - {{- if $.Values.controller.ingressClassResource.annotations }} - annotations: {{ toYaml $.Values.controller.ingressClassResource.annotations | nindent 4 }} - {{- end }} -spec: - controller: {{ $.Values.controller.ingressClassResource.controllerValue }} - {{- with $.Values.controller.ingressClassResource.parameters }} - parameters: {{ toYaml . | nindent 4 }} - {{- end }} -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-ingressclass.yaml b/charts/keep/charts/ingress-nginx/templates/controller-ingressclass.yaml deleted file mode 100644 index 98479a5..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-ingressclass.yaml +++ /dev/null @@ -1,26 +0,0 @@ -{{- if .Values.controller.ingressClassResource.enabled -}} -apiVersion: networking.k8s.io/v1 -kind: IngressClass -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ .Values.controller.ingressClassResource.name }} - {{- if or .Values.controller.ingressClassResource.default .Values.controller.ingressClassResource.annotations }} - annotations: - {{- if .Values.controller.ingressClassResource.default }} - ingressclass.kubernetes.io/is-default-class: "true" - {{- end }} - {{- if .Values.controller.ingressClassResource.annotations }} - {{- toYaml .Values.controller.ingressClassResource.annotations | nindent 4 }} - {{- end }} - {{- end }} -spec: - controller: {{ .Values.controller.ingressClassResource.controllerValue }} - {{- with .Values.controller.ingressClassResource.parameters }} - parameters: {{ toYaml . | nindent 4 }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-keda.yaml b/charts/keep/charts/ingress-nginx/templates/controller-keda.yaml deleted file mode 100644 index 24d30fa..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-keda.yaml +++ /dev/null @@ -1,46 +0,0 @@ -{{- if and (eq .Values.controller.kind "Deployment") .Values.controller.keda.enabled (not .Values.controller.autoscaling.enabled) -}} -apiVersion: {{ .Values.controller.keda.apiVersion }} -kind: ScaledObject -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - {{- if .Values.controller.keda.scaledObject.annotations }} - annotations: {{ toYaml .Values.controller.keda.scaledObject.annotations | nindent 4 }} - {{- end }} -spec: - scaleTargetRef: -{{- if eq .Values.controller.keda.apiVersion "keda.k8s.io/v1alpha1" }} - deploymentName: {{ include "ingress-nginx.controller.fullname" . }} -{{- else if eq .Values.controller.keda.apiVersion "keda.sh/v1alpha1" }} - name: {{ include "ingress-nginx.controller.fullname" . }} -{{- end }} - pollingInterval: {{ .Values.controller.keda.pollingInterval }} - cooldownPeriod: {{ .Values.controller.keda.cooldownPeriod }} - minReplicaCount: {{ .Values.controller.keda.minReplicas }} - maxReplicaCount: {{ .Values.controller.keda.maxReplicas }} -{{- with .Values.controller.keda.fallback }} - fallback: - failureThreshold: {{ .failureThreshold | default 3 }} - replicas: {{ .replicas | default $.Values.controller.keda.maxReplicas }} -{{- end }} - triggers: -{{- with .Values.controller.keda.triggers }} -{{ toYaml . | indent 2 }} -{{ end }} - advanced: - restoreToOriginalReplicaCount: {{ .Values.controller.keda.restoreToOriginalReplicaCount }} -{{- if .Values.controller.keda.behavior }} - horizontalPodAutoscalerConfig: - behavior: -{{ with .Values.controller.keda.behavior -}} -{{ toYaml . | indent 8 }} -{{ end }} - -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-networkpolicy.yaml b/charts/keep/charts/ingress-nginx/templates/controller-networkpolicy.yaml deleted file mode 100644 index e68f991..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-networkpolicy.yaml +++ /dev/null @@ -1,45 +0,0 @@ -{{- if .Values.controller.networkPolicy.enabled }} -apiVersion: networking.k8s.io/v1 -kind: NetworkPolicy -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - podSelector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: controller - policyTypes: - - Ingress - - Egress - ingress: - - ports: - {{- range $key, $value := .Values.controller.containerPort }} - - protocol: TCP - port: {{ $value }} - {{- end }} - {{- if .Values.controller.metrics.enabled }} - - protocol: TCP - port: {{ .Values.controller.metrics.port }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.enabled }} - - protocol: TCP - port: {{ .Values.controller.admissionWebhooks.port }} - {{- end }} - {{- range $key, $value := .Values.tcp }} - - protocol: TCP - port: {{ $key }} - {{- end }} - {{- range $key, $value := .Values.udp }} - - protocol: UDP - port: {{ $key }} - {{- end }} - egress: - - {} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml b/charts/keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml deleted file mode 100644 index 8e0181f..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml +++ /dev/null @@ -1,36 +0,0 @@ -# PDB is not supported for DaemonSets. -# https://github.com/kubernetes/kubernetes/issues/108124 -{{- if eq .Values.controller.kind "Deployment" }} -{{- $replicas := .Values.controller.replicaCount }} -{{- if and .Values.controller.autoscaling.enabled (not .Values.controller.keda.enabled) }} -{{- $replicas = .Values.controller.autoscaling.minReplicas }} -{{- else if and .Values.controller.keda.enabled (not .Values.controller.autoscaling.enabled) }} -{{- $replicas = .Values.controller.keda.minReplicas }} -{{- end }} -{{- if gt ($replicas | int) 1 }} -apiVersion: {{ ternary "policy/v1" "policy/v1beta1" (semverCompare ">=1.21.0-0" .Capabilities.KubeVersion.Version) }} -kind: PodDisruptionBudget -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - {{- if .Values.controller.annotations }} - annotations: {{ toYaml .Values.controller.annotations | nindent 4 }} - {{- end }} -spec: - selector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: controller - {{- if and .Values.controller.minAvailable (not (hasKey .Values.controller "maxUnavailable")) }} - minAvailable: {{ .Values.controller.minAvailable }} - {{- else if .Values.controller.maxUnavailable }} - maxUnavailable: {{ .Values.controller.maxUnavailable }} - {{- end }} -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-prometheusrule.yaml b/charts/keep/charts/ingress-nginx/templates/controller-prometheusrule.yaml deleted file mode 100644 index 41684c3..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-prometheusrule.yaml +++ /dev/null @@ -1,23 +0,0 @@ -{{- if and .Values.controller.metrics.enabled .Values.controller.metrics.prometheusRule.enabled -}} -apiVersion: monitoring.coreos.com/v1 -kind: PrometheusRule -metadata: - name: {{ include "ingress-nginx.controller.fullname" . }} -{{- if .Values.controller.metrics.prometheusRule.namespace }} - namespace: {{ .Values.controller.metrics.prometheusRule.namespace }} -{{- else }} - namespace: {{ include "ingress-nginx.namespace" . }} -{{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- if .Values.controller.metrics.prometheusRule.additionalLabels }} - {{- toYaml .Values.controller.metrics.prometheusRule.additionalLabels | nindent 4 }} - {{- end }} -spec: -{{- if .Values.controller.metrics.prometheusRule.rules }} - groups: - - name: {{ template "ingress-nginx.name" . }} - rules: {{- toYaml .Values.controller.metrics.prometheusRule.rules | nindent 4 }} -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-psp.yaml b/charts/keep/charts/ingress-nginx/templates/controller-psp.yaml deleted file mode 100644 index aad1d27..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-psp.yaml +++ /dev/null @@ -1,100 +0,0 @@ -{{- if (semverCompare "<1.25.0-0" .Capabilities.KubeVersion.Version) }} -{{- if and .Values.podSecurityPolicy.enabled (empty .Values.controller.existingPsp) -}} -apiVersion: policy/v1beta1 -kind: PodSecurityPolicy -metadata: - name: {{ include "ingress-nginx.fullname" . }} - annotations: - seccomp.security.alpha.kubernetes.io/allowedProfileNames: "*" - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -spec: - privileged: false - hostPID: false - hostIPC: false - hostNetwork: {{ .Values.controller.hostNetwork }} -{{- if or .Values.controller.hostNetwork .Values.controller.hostPort.enabled }} - hostPorts: - {{- if .Values.controller.hostNetwork }} - {{- range $key, $value := .Values.controller.containerPort }} - # controller.containerPort.{{ $key }} - - min: {{ $value }} - max: {{ $value }} - {{- end }} - {{- else if .Values.controller.hostPort.enabled }} - {{- range $key, $value := .Values.controller.hostPort.ports }} - # controller.hostPort.ports.{{ $key }} - - min: {{ $value }} - max: {{ $value }} - {{- end }} - {{- end }} - {{- if .Values.controller.metrics.enabled }} - # controller.metrics.port - - min: {{ .Values.controller.metrics.port }} - max: {{ .Values.controller.metrics.port }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.enabled }} - # controller.admissionWebhooks.port - - min: {{ .Values.controller.admissionWebhooks.port }} - max: {{ .Values.controller.admissionWebhooks.port }} - {{- end }} - {{- range $key, $value := .Values.tcp }} - # tcp.{{ $key }} - - min: {{ $key }} - max: {{ $key }} - {{- end }} - {{- range $key, $value := .Values.udp }} - # udp.{{ $key }} - - min: {{ $key }} - max: {{ $key }} - {{- end }} -{{- end }} - volumes: - - configMap - - downwardAPI - - emptyDir - - secret - - projected - fsGroup: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - readOnlyRootFilesystem: false - runAsUser: - rule: MustRunAsNonRoot - runAsGroup: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - supplementalGroups: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - allowPrivilegeEscalation: {{ or .Values.controller.image.allowPrivilegeEscalation .Values.controller.image.chroot }} - requiredDropCapabilities: - - ALL - allowedCapabilities: - - NET_BIND_SERVICE - {{- if .Values.controller.image.chroot }} - {{- if .Values.controller.image.seccompProfile }} - - SYS_ADMIN - {{- end }} - - SYS_CHROOT - {{- end }} - seLinux: - rule: RunAsAny -{{- if .Values.controller.sysctls }} - allowedUnsafeSysctls: - {{- range $sysctl, $value := .Values.controller.sysctls }} - - {{ $sysctl }} - {{- end }} -{{- end }} -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-role.yaml b/charts/keep/charts/ingress-nginx/templates/controller-role.yaml deleted file mode 100644 index a94b399..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-role.yaml +++ /dev/null @@ -1,104 +0,0 @@ -{{- if .Values.rbac.create -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: Role -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -rules: - - apiGroups: - - "" - resources: - - namespaces - verbs: - - get - - apiGroups: - - "" - resources: - - configmaps - - pods - - secrets - - endpoints - verbs: - - get - - list - - watch - - apiGroups: - - "" - resources: - - services - verbs: - - get - - list - - watch - - apiGroups: - - networking.k8s.io - resources: - - ingresses - verbs: - - get - - list - - watch - # Omit Ingress status permissions if `--update-status` is disabled. - {{- if ne (index .Values.controller.extraArgs "update-status") "false" }} - - apiGroups: - - networking.k8s.io - resources: - - ingresses/status - verbs: - - update - {{- end }} - - apiGroups: - - networking.k8s.io - resources: - - ingressclasses - verbs: - - get - - list - - watch - - apiGroups: - - coordination.k8s.io - resources: - - leases - resourceNames: - - {{ include "ingress-nginx.controller.electionID" . }} - verbs: - - get - - update - - apiGroups: - - coordination.k8s.io - resources: - - leases - verbs: - - create - - apiGroups: - - "" - resources: - - events - verbs: - - create - - patch - - apiGroups: - - discovery.k8s.io - resources: - - endpointslices - verbs: - - list - - watch - - get -{{- if .Values.podSecurityPolicy.enabled }} - - apiGroups: [{{ template "podSecurityPolicy.apiGroup" . }}] - resources: ['podsecuritypolicies'] - verbs: ['use'] - {{- with .Values.controller.existingPsp }} - resourceNames: [{{ . }}] - {{- else }} - resourceNames: [{{ include "ingress-nginx.fullname" . }}] - {{- end }} -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-rolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/controller-rolebinding.yaml deleted file mode 100644 index 153430a..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-rolebinding.yaml +++ /dev/null @@ -1,21 +0,0 @@ -{{- if .Values.rbac.create -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: RoleBinding -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -roleRef: - apiGroup: rbac.authorization.k8s.io - kind: Role - name: {{ include "ingress-nginx.fullname" . }} -subjects: - - kind: ServiceAccount - name: {{ template "ingress-nginx.serviceAccountName" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-secret.yaml b/charts/keep/charts/ingress-nginx/templates/controller-secret.yaml deleted file mode 100644 index f20f534..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-secret.yaml +++ /dev/null @@ -1,15 +0,0 @@ -{{- if .Values.dhParam -}} -apiVersion: v1 -kind: Secret -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -data: - dhparam.pem: {{ .Values.dhParam }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-service-internal.yaml b/charts/keep/charts/ingress-nginx/templates/controller-service-internal.yaml deleted file mode 100644 index 6d0b47c..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-service-internal.yaml +++ /dev/null @@ -1,105 +0,0 @@ -{{- if and .Values.controller.service.enabled .Values.controller.service.internal.enabled .Values.controller.service.internal.annotations -}} -apiVersion: v1 -kind: Service -metadata: - annotations: - {{- range $key, $value := .Values.controller.service.internal.annotations }} - {{ $key }}: {{ tpl ($value | toString) $ | quote }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- if .Values.controller.service.labels }} - {{- toYaml .Values.controller.service.labels | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }}-internal - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - type: {{ .Values.controller.service.internal.type | default .Values.controller.service.type }} -{{- if .Values.controller.service.internal.clusterIP }} - clusterIP: {{ .Values.controller.service.internal.clusterIP }} -{{- end }} -{{- if .Values.controller.service.internal.externalIPs }} - externalIPs: {{ toYaml .Values.controller.service.internal.externalIPs | nindent 4 }} -{{- end }} -{{- if .Values.controller.service.internal.loadBalancerIP }} - loadBalancerIP: {{ .Values.controller.service.internal.loadBalancerIP }} -{{- end }} -{{- if .Values.controller.service.internal.loadBalancerSourceRanges }} - loadBalancerSourceRanges: {{ toYaml .Values.controller.service.internal.loadBalancerSourceRanges | nindent 4 }} -{{- end }} -{{- if .Values.controller.service.internal.loadBalancerClass }} - loadBalancerClass: {{ .Values.controller.service.internal.loadBalancerClass }} -{{- end }} -{{- if hasKey .Values.controller.service.internal "allocateLoadBalancerNodePorts" }} - allocateLoadBalancerNodePorts: {{ .Values.controller.service.internal.allocateLoadBalancerNodePorts }} -{{- end }} -{{- if .Values.controller.service.internal.externalTrafficPolicy }} - externalTrafficPolicy: {{ .Values.controller.service.internal.externalTrafficPolicy }} -{{- end }} -{{- if .Values.controller.service.internal.sessionAffinity }} - sessionAffinity: {{ .Values.controller.service.internal.sessionAffinity }} -{{- end }} -{{- if .Values.controller.service.internal.healthCheckNodePort }} - healthCheckNodePort: {{ .Values.controller.service.internal.healthCheckNodePort }} -{{- end }} -{{- if semverCompare ">=1.21.0-0" .Capabilities.KubeVersion.Version -}} -{{- if .Values.controller.service.internal.ipFamilyPolicy }} - ipFamilyPolicy: {{ .Values.controller.service.internal.ipFamilyPolicy }} -{{- end }} -{{- if .Values.controller.service.internal.ipFamilies }} - ipFamilies: {{ toYaml .Values.controller.service.internal.ipFamilies | nindent 4 }} -{{- end }} -{{- end }} - ports: - {{- $setNodePorts := (or (eq .Values.controller.service.type "NodePort") (eq .Values.controller.service.type "LoadBalancer")) }} - {{- if .Values.controller.service.enableHttp }} - - name: http - port: {{ .Values.controller.service.internal.ports.http | default .Values.controller.service.ports.http }} - protocol: TCP - targetPort: {{ .Values.controller.service.internal.targetPorts.http | default .Values.controller.service.targetPorts.http }} - {{- if and (semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version) (.Values.controller.service.internal.appProtocol) }} - appProtocol: http - {{- end }} - {{- if (and $setNodePorts (not (empty .Values.controller.service.internal.nodePorts.http))) }} - nodePort: {{ .Values.controller.service.internal.nodePorts.http }} - {{- end }} - {{- end }} - {{- if .Values.controller.service.enableHttps }} - - name: https - port: {{ .Values.controller.service.internal.ports.https | default .Values.controller.service.ports.https }} - protocol: TCP - targetPort: {{ .Values.controller.service.internal.targetPorts.https | default .Values.controller.service.targetPorts.https }} - {{- if and (semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version) (.Values.controller.service.internal.appProtocol) }} - appProtocol: https - {{- end }} - {{- if (and $setNodePorts (not (empty .Values.controller.service.internal.nodePorts.https))) }} - nodePort: {{ .Values.controller.service.internal.nodePorts.https }} - {{- end }} - {{- end }} - {{- range $key, $value := .Values.tcp }} - - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp - port: {{ $key }} - protocol: TCP - targetPort: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp - {{- if $.Values.controller.service.internal.nodePorts.tcp }} - {{- if index $.Values.controller.service.internal.nodePorts.tcp $key }} - nodePort: {{ index $.Values.controller.service.internal.nodePorts.tcp $key }} - {{- end }} - {{- end }} - {{- end }} - {{- range $key, $value := .Values.udp }} - - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp - port: {{ $key }} - protocol: UDP - targetPort: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp - {{- if $.Values.controller.service.internal.nodePorts.udp }} - {{- if index $.Values.controller.service.internal.nodePorts.udp $key }} - nodePort: {{ index $.Values.controller.service.internal.nodePorts.udp $key }} - {{- end }} - {{- end }} - {{- end }} - selector: - {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} - app.kubernetes.io/component: controller -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-service-metrics.yaml b/charts/keep/charts/ingress-nginx/templates/controller-service-metrics.yaml deleted file mode 100644 index 7c15329..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-service-metrics.yaml +++ /dev/null @@ -1,45 +0,0 @@ -{{- if .Values.controller.metrics.enabled -}} -apiVersion: v1 -kind: Service -metadata: -{{- if .Values.controller.metrics.service.annotations }} - annotations: {{ toYaml .Values.controller.metrics.service.annotations | nindent 4 }} -{{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- if .Values.controller.metrics.service.labels }} - {{- toYaml .Values.controller.metrics.service.labels | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }}-metrics - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - type: {{ .Values.controller.metrics.service.type }} -{{- if .Values.controller.metrics.service.clusterIP }} - clusterIP: {{ .Values.controller.metrics.service.clusterIP }} -{{- end }} -{{- if .Values.controller.metrics.service.externalIPs }} - externalIPs: {{ toYaml .Values.controller.metrics.service.externalIPs | nindent 4 }} -{{- end }} -{{- if .Values.controller.metrics.service.loadBalancerIP }} - loadBalancerIP: {{ .Values.controller.metrics.service.loadBalancerIP }} -{{- end }} -{{- if .Values.controller.metrics.service.loadBalancerSourceRanges }} - loadBalancerSourceRanges: {{ toYaml .Values.controller.metrics.service.loadBalancerSourceRanges | nindent 4 }} -{{- end }} -{{- if .Values.controller.metrics.service.externalTrafficPolicy }} - externalTrafficPolicy: {{ .Values.controller.metrics.service.externalTrafficPolicy }} -{{- end }} - ports: - - name: {{ .Values.controller.metrics.portName }} - port: {{ .Values.controller.metrics.service.servicePort }} - protocol: TCP - targetPort: {{ .Values.controller.metrics.portName }} - {{- $setNodePorts := (or (eq .Values.controller.metrics.service.type "NodePort") (eq .Values.controller.metrics.service.type "LoadBalancer")) }} - {{- if (and $setNodePorts (not (empty .Values.controller.metrics.service.nodePort))) }} - nodePort: {{ .Values.controller.metrics.service.nodePort }} - {{- end }} - selector: - {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} - app.kubernetes.io/component: controller -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-service-webhook.yaml b/charts/keep/charts/ingress-nginx/templates/controller-service-webhook.yaml deleted file mode 100644 index 67aac0d..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-service-webhook.yaml +++ /dev/null @@ -1,40 +0,0 @@ -{{- if .Values.controller.admissionWebhooks.enabled -}} -apiVersion: v1 -kind: Service -metadata: -{{- if .Values.controller.admissionWebhooks.service.annotations }} - annotations: {{ toYaml .Values.controller.admissionWebhooks.service.annotations | nindent 4 }} -{{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }}-admission - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - type: {{ .Values.controller.admissionWebhooks.service.type }} -{{- if .Values.controller.admissionWebhooks.service.clusterIP }} - clusterIP: {{ .Values.controller.admissionWebhooks.service.clusterIP }} -{{- end }} -{{- if .Values.controller.admissionWebhooks.service.externalIPs }} - externalIPs: {{ toYaml .Values.controller.admissionWebhooks.service.externalIPs | nindent 4 }} -{{- end }} -{{- if .Values.controller.admissionWebhooks.service.loadBalancerIP }} - loadBalancerIP: {{ .Values.controller.admissionWebhooks.service.loadBalancerIP }} -{{- end }} -{{- if .Values.controller.admissionWebhooks.service.loadBalancerSourceRanges }} - loadBalancerSourceRanges: {{ toYaml .Values.controller.admissionWebhooks.service.loadBalancerSourceRanges | nindent 4 }} -{{- end }} - ports: - - name: https-webhook - port: {{ .Values.controller.admissionWebhooks.service.servicePort }} - targetPort: webhook - {{- if semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version }} - appProtocol: https - {{- end }} - selector: - {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} - app.kubernetes.io/component: controller -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-service.yaml b/charts/keep/charts/ingress-nginx/templates/controller-service.yaml deleted file mode 100644 index cb78a70..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-service.yaml +++ /dev/null @@ -1,105 +0,0 @@ -{{- if and .Values.controller.service.enabled .Values.controller.service.external.enabled -}} -apiVersion: v1 -kind: Service -metadata: - annotations: - {{- range $key, $value := .Values.controller.service.annotations }} - {{ $key }}: {{ tpl ($value | toString) $ | quote }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- if .Values.controller.service.labels }} - {{- toYaml .Values.controller.service.labels | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - type: {{ .Values.controller.service.type }} -{{- if .Values.controller.service.clusterIP }} - clusterIP: {{ .Values.controller.service.clusterIP }} -{{- end }} -{{- if .Values.controller.service.externalIPs }} - externalIPs: {{ toYaml .Values.controller.service.externalIPs | nindent 4 }} -{{- end }} -{{- if .Values.controller.service.loadBalancerIP }} - loadBalancerIP: {{ .Values.controller.service.loadBalancerIP }} -{{- end }} -{{- if .Values.controller.service.loadBalancerSourceRanges }} - loadBalancerSourceRanges: {{ toYaml .Values.controller.service.loadBalancerSourceRanges | nindent 4 }} -{{- end }} -{{- if .Values.controller.service.loadBalancerClass }} - loadBalancerClass: {{ .Values.controller.service.loadBalancerClass }} -{{- end }} -{{- if hasKey .Values.controller.service "allocateLoadBalancerNodePorts" }} - allocateLoadBalancerNodePorts: {{ .Values.controller.service.allocateLoadBalancerNodePorts }} -{{- end }} -{{- if .Values.controller.service.externalTrafficPolicy }} - externalTrafficPolicy: {{ .Values.controller.service.externalTrafficPolicy }} -{{- end }} -{{- if .Values.controller.service.sessionAffinity }} - sessionAffinity: {{ .Values.controller.service.sessionAffinity }} -{{- end }} -{{- if .Values.controller.service.healthCheckNodePort }} - healthCheckNodePort: {{ .Values.controller.service.healthCheckNodePort }} -{{- end }} -{{- if semverCompare ">=1.21.0-0" .Capabilities.KubeVersion.Version -}} -{{- if .Values.controller.service.ipFamilyPolicy }} - ipFamilyPolicy: {{ .Values.controller.service.ipFamilyPolicy }} -{{- end }} -{{- if .Values.controller.service.ipFamilies }} - ipFamilies: {{ toYaml .Values.controller.service.ipFamilies | nindent 4 }} -{{- end }} -{{- end }} - ports: - {{- $setNodePorts := (or (eq .Values.controller.service.type "NodePort") (eq .Values.controller.service.type "LoadBalancer")) }} - {{- if .Values.controller.service.enableHttp }} - - name: http - port: {{ .Values.controller.service.ports.http }} - protocol: TCP - targetPort: {{ .Values.controller.service.targetPorts.http }} - {{- if and (semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version) (.Values.controller.service.appProtocol) }} - appProtocol: http - {{- end }} - {{- if (and $setNodePorts (not (empty .Values.controller.service.nodePorts.http))) }} - nodePort: {{ .Values.controller.service.nodePorts.http }} - {{- end }} - {{- end }} - {{- if .Values.controller.service.enableHttps }} - - name: https - port: {{ .Values.controller.service.ports.https }} - protocol: TCP - targetPort: {{ .Values.controller.service.targetPorts.https }} - {{- if and (semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version) (.Values.controller.service.appProtocol) }} - appProtocol: https - {{- end }} - {{- if (and $setNodePorts (not (empty .Values.controller.service.nodePorts.https))) }} - nodePort: {{ .Values.controller.service.nodePorts.https }} - {{- end }} - {{- end }} - {{- range $key, $value := .Values.tcp }} - - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp - port: {{ $key }} - protocol: TCP - targetPort: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp - {{- if $.Values.controller.service.nodePorts.tcp }} - {{- if index $.Values.controller.service.nodePorts.tcp $key }} - nodePort: {{ index $.Values.controller.service.nodePorts.tcp $key }} - {{- end }} - {{- end }} - {{- end }} - {{- range $key, $value := .Values.udp }} - - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp - port: {{ $key }} - protocol: UDP - targetPort: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp - {{- if $.Values.controller.service.nodePorts.udp }} - {{- if index $.Values.controller.service.nodePorts.udp $key }} - nodePort: {{ index $.Values.controller.service.nodePorts.udp $key }} - {{- end }} - {{- end }} - {{- end }} - selector: - {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} - app.kubernetes.io/component: controller -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml b/charts/keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml deleted file mode 100644 index df83de3..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml +++ /dev/null @@ -1,17 +0,0 @@ -{{- if or .Values.serviceAccount.create -}} -apiVersion: v1 -kind: ServiceAccount -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ template "ingress-nginx.serviceAccountName" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - {{- if .Values.serviceAccount.annotations }} - annotations: {{ toYaml .Values.serviceAccount.annotations | nindent 4 }} - {{- end }} -automountServiceAccountToken: {{ .Values.serviceAccount.automountServiceAccountToken }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-servicemonitor.yaml b/charts/keep/charts/ingress-nginx/templates/controller-servicemonitor.yaml deleted file mode 100644 index 62301da..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-servicemonitor.yaml +++ /dev/null @@ -1,53 +0,0 @@ -{{- if and .Values.controller.metrics.enabled .Values.controller.metrics.serviceMonitor.enabled -}} -apiVersion: monitoring.coreos.com/v1 -kind: ServiceMonitor -metadata: - name: {{ include "ingress-nginx.controller.fullname" . }} -{{- if .Values.controller.metrics.serviceMonitor.namespace }} - namespace: {{ .Values.controller.metrics.serviceMonitor.namespace }} -{{- else }} - namespace: {{ include "ingress-nginx.namespace" . }} -{{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- if .Values.controller.metrics.serviceMonitor.additionalLabels }} - {{- toYaml .Values.controller.metrics.serviceMonitor.additionalLabels | nindent 4 }} - {{- end }} - {{- if .Values.controller.metrics.serviceMonitor.annotations }} - annotations: {{ toYaml .Values.controller.metrics.serviceMonitor.annotations | nindent 4 }} - {{- end }} -spec: - endpoints: - - port: {{ .Values.controller.metrics.portName }} - interval: {{ .Values.controller.metrics.serviceMonitor.scrapeInterval }} - {{- if .Values.controller.metrics.serviceMonitor.honorLabels }} - honorLabels: true - {{- end }} - {{- if .Values.controller.metrics.serviceMonitor.relabelings }} - relabelings: {{ toYaml .Values.controller.metrics.serviceMonitor.relabelings | nindent 8 }} - {{- end }} - {{- if .Values.controller.metrics.serviceMonitor.metricRelabelings }} - metricRelabelings: {{ toYaml .Values.controller.metrics.serviceMonitor.metricRelabelings | nindent 8 }} - {{- end }} -{{- if .Values.controller.metrics.serviceMonitor.jobLabel }} - jobLabel: {{ .Values.controller.metrics.serviceMonitor.jobLabel | quote }} -{{- end }} -{{- if .Values.controller.metrics.serviceMonitor.namespaceSelector }} - namespaceSelector: {{ toYaml .Values.controller.metrics.serviceMonitor.namespaceSelector | nindent 4 }} -{{- else }} - namespaceSelector: - matchNames: - - {{ include "ingress-nginx.namespace" . }} -{{- end }} -{{- if .Values.controller.metrics.serviceMonitor.targetLabels }} - targetLabels: - {{- range .Values.controller.metrics.serviceMonitor.targetLabels }} - - {{ . }} - {{- end }} -{{- end }} - selector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: controller -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-deployment.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-deployment.yaml deleted file mode 100644 index 6755e23..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-deployment.yaml +++ /dev/null @@ -1,119 +0,0 @@ -{{- if .Values.defaultBackend.enabled -}} -apiVersion: apps/v1 -kind: Deployment -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.defaultBackend.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - selector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: default-backend -{{- if not .Values.defaultBackend.autoscaling.enabled }} - replicas: {{ .Values.defaultBackend.replicaCount }} -{{- end }} - revisionHistoryLimit: {{ .Values.revisionHistoryLimit }} - {{- if .Values.defaultBackend.updateStrategy }} - strategy: - {{ toYaml .Values.defaultBackend.updateStrategy | nindent 4 }} - {{- end }} - minReadySeconds: {{ .Values.defaultBackend.minReadySeconds }} - template: - metadata: - {{- if .Values.defaultBackend.podAnnotations }} - annotations: {{ toYaml .Values.defaultBackend.podAnnotations | nindent 8 }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 8 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 8 }} - {{- end }} - {{- if .Values.defaultBackend.podLabels }} - {{- toYaml .Values.defaultBackend.podLabels | nindent 8 }} - {{- end }} - spec: - {{- if .Values.imagePullSecrets }} - imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} - {{- end }} - {{- if .Values.defaultBackend.priorityClassName }} - priorityClassName: {{ .Values.defaultBackend.priorityClassName }} - {{- end }} - {{- if .Values.defaultBackend.podSecurityContext }} - securityContext: {{ toYaml .Values.defaultBackend.podSecurityContext | nindent 8 }} - {{- end }} - containers: - - name: {{ template "ingress-nginx.name" . }}-default-backend - {{- with .Values.defaultBackend.image }} - image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ .image }}{{ end }}:{{ .tag }}{{ if .digest }}@{{ .digest }}{{ end }} - {{- end }} - imagePullPolicy: {{ .Values.defaultBackend.image.pullPolicy }} - {{- if .Values.defaultBackend.extraArgs }} - args: - {{- range $key, $value := .Values.defaultBackend.extraArgs }} - {{- /* Accept keys without values or with false as value */}} - {{- if eq ($value | quote | len) 2 }} - - --{{ $key }} - {{- else }} - - --{{ $key }}={{ $value }} - {{- end }} - {{- end }} - {{- end }} - securityContext: {{ include "ingress-nginx.defaultBackend.containerSecurityContext" . | nindent 12 }} - {{- if .Values.defaultBackend.extraEnvs }} - env: {{ toYaml .Values.defaultBackend.extraEnvs | nindent 12 }} - {{- end }} - livenessProbe: - httpGet: - path: /healthz - port: {{ .Values.defaultBackend.port }} - scheme: HTTP - initialDelaySeconds: {{ .Values.defaultBackend.livenessProbe.initialDelaySeconds }} - periodSeconds: {{ .Values.defaultBackend.livenessProbe.periodSeconds }} - timeoutSeconds: {{ .Values.defaultBackend.livenessProbe.timeoutSeconds }} - successThreshold: {{ .Values.defaultBackend.livenessProbe.successThreshold }} - failureThreshold: {{ .Values.defaultBackend.livenessProbe.failureThreshold }} - readinessProbe: - httpGet: - path: /healthz - port: {{ .Values.defaultBackend.port }} - scheme: HTTP - initialDelaySeconds: {{ .Values.defaultBackend.readinessProbe.initialDelaySeconds }} - periodSeconds: {{ .Values.defaultBackend.readinessProbe.periodSeconds }} - timeoutSeconds: {{ .Values.defaultBackend.readinessProbe.timeoutSeconds }} - successThreshold: {{ .Values.defaultBackend.readinessProbe.successThreshold }} - failureThreshold: {{ .Values.defaultBackend.readinessProbe.failureThreshold }} - ports: - - name: http - containerPort: {{ .Values.defaultBackend.port }} - protocol: TCP - {{- if .Values.defaultBackend.extraVolumeMounts }} - volumeMounts: {{- toYaml .Values.defaultBackend.extraVolumeMounts | nindent 12 }} - {{- end }} - {{- if .Values.defaultBackend.resources }} - resources: {{ toYaml .Values.defaultBackend.resources | nindent 12 }} - {{- end }} - {{- if .Values.defaultBackend.nodeSelector }} - nodeSelector: {{ toYaml .Values.defaultBackend.nodeSelector | nindent 8 }} - {{- end }} - serviceAccountName: {{ include "ingress-nginx.defaultBackend.serviceAccountName" . }} - {{- if .Values.defaultBackend.tolerations }} - tolerations: {{ toYaml .Values.defaultBackend.tolerations | nindent 8 }} - {{- end }} - {{- if .Values.defaultBackend.affinity }} - affinity: {{ tpl (toYaml .Values.defaultBackend.affinity) $ | nindent 8 }} - {{- end }} - {{- if .Values.defaultBackend.topologySpreadConstraints }} - topologySpreadConstraints: {{ tpl (toYaml .Values.defaultBackend.topologySpreadConstraints) $ | nindent 8 }} - {{- end }} - terminationGracePeriodSeconds: 60 - {{- if .Values.defaultBackend.extraVolumes }} - volumes: {{ toYaml .Values.defaultBackend.extraVolumes | nindent 8 }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-extra-configmaps.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-extra-configmaps.yaml deleted file mode 100644 index 9af56cf..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-extra-configmaps.yaml +++ /dev/null @@ -1,23 +0,0 @@ -{{- if .Values.defaultBackend.enabled }} -{{- range .Values.defaultBackend.extraConfigMaps }} ---- -apiVersion: v1 -kind: ConfigMap -metadata: - labels: - {{- include "ingress-nginx.labels" $ | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with $.Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - {{- with .labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ .name }} - namespace: {{ include "ingress-nginx.namespace" $ }} -data: - {{- with .data }} - {{- toYaml . | nindent 2 }} - {{- end }} -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-hpa.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-hpa.yaml deleted file mode 100644 index 49bcdcf..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-hpa.yaml +++ /dev/null @@ -1,40 +0,0 @@ -{{- if and .Values.defaultBackend.enabled .Values.defaultBackend.autoscaling.enabled }} -apiVersion: {{ ternary "autoscaling/v2" "autoscaling/v2beta2" (.Capabilities.APIVersions.Has "autoscaling/v2") }} -kind: HorizontalPodAutoscaler -metadata: - {{- with .Values.defaultBackend.autoscaling.annotations }} - annotations: {{ toYaml . | nindent 4 }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.defaultBackend.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - scaleTargetRef: - apiVersion: apps/v1 - kind: Deployment - name: {{ include "ingress-nginx.defaultBackend.fullname" . }} - minReplicas: {{ .Values.defaultBackend.autoscaling.minReplicas }} - maxReplicas: {{ .Values.defaultBackend.autoscaling.maxReplicas }} - metrics: - {{- with .Values.defaultBackend.autoscaling.targetMemoryUtilizationPercentage }} - - type: Resource - resource: - name: memory - target: - type: Utilization - averageUtilization: {{ . }} - {{- end }} - {{- with .Values.defaultBackend.autoscaling.targetCPUUtilizationPercentage }} - - type: Resource - resource: - name: cpu - target: - type: Utilization - averageUtilization: {{ . }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-networkpolicy.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-networkpolicy.yaml deleted file mode 100644 index 90b3c2b..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-networkpolicy.yaml +++ /dev/null @@ -1,25 +0,0 @@ -{{- if and .Values.defaultBackend.enabled .Values.defaultBackend.networkPolicy.enabled }} -apiVersion: networking.k8s.io/v1 -kind: NetworkPolicy -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.defaultBackend.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - podSelector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: default-backend - policyTypes: - - Ingress - - Egress - ingress: - - ports: - - protocol: TCP - port: {{ .Values.defaultBackend.port }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-poddisruptionbudget.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-poddisruptionbudget.yaml deleted file mode 100644 index c8363fd..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-poddisruptionbudget.yaml +++ /dev/null @@ -1,25 +0,0 @@ -{{- if .Values.defaultBackend.enabled -}} -{{- $replicas := .Values.defaultBackend.replicaCount }} -{{- if .Values.defaultBackend.autoscaling.enabled }} -{{- $replicas = .Values.defaultBackend.autoscaling.minReplicas }} -{{- end }} -{{- if gt ($replicas | int) 1 }} -apiVersion: {{ ternary "policy/v1" "policy/v1beta1" (semverCompare ">=1.21.0-0" .Capabilities.KubeVersion.Version) }} -kind: PodDisruptionBudget -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.defaultBackend.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - selector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: default-backend - minAvailable: {{ .Values.defaultBackend.minAvailable }} -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-psp.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-psp.yaml deleted file mode 100644 index 4241091..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-psp.yaml +++ /dev/null @@ -1,50 +0,0 @@ -{{- if (semverCompare "<1.25.0-0" .Capabilities.KubeVersion.Version) }} -{{- if and .Values.podSecurityPolicy.enabled .Values.defaultBackend.enabled (empty .Values.defaultBackend.existingPsp) -}} -apiVersion: policy/v1beta1 -kind: PodSecurityPolicy -metadata: - name: {{ include "ingress-nginx.fullname" . }}-backend - annotations: - seccomp.security.alpha.kubernetes.io/allowedProfileNames: "*" - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -spec: - privileged: false - hostPID: false - hostIPC: false - hostNetwork: false - volumes: - - configMap - - downwardAPI - - emptyDir - - secret - - projected - fsGroup: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - readOnlyRootFilesystem: true - runAsUser: - rule: MustRunAsNonRoot - runAsGroup: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - supplementalGroups: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - allowPrivilegeEscalation: false - requiredDropCapabilities: - - ALL - seLinux: - rule: RunAsAny -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-role.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-role.yaml deleted file mode 100644 index dd7868a..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-role.yaml +++ /dev/null @@ -1,22 +0,0 @@ -{{- if and .Values.rbac.create .Values.podSecurityPolicy.enabled .Values.defaultBackend.enabled -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: Role -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.fullname" . }}-backend - namespace: {{ include "ingress-nginx.namespace" . }} -rules: - - apiGroups: [{{ template "podSecurityPolicy.apiGroup" . }}] - resources: ['podsecuritypolicies'] - verbs: ['use'] - {{- with .Values.defaultBackend.existingPsp }} - resourceNames: [{{ . }}] - {{- else }} - resourceNames: [{{ include "ingress-nginx.fullname" . }}-backend] - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-rolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-rolebinding.yaml deleted file mode 100644 index 3203b6f..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-rolebinding.yaml +++ /dev/null @@ -1,21 +0,0 @@ -{{- if and .Values.rbac.create .Values.podSecurityPolicy.enabled .Values.defaultBackend.enabled -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: RoleBinding -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.fullname" . }}-backend - namespace: {{ include "ingress-nginx.namespace" . }} -roleRef: - apiGroup: rbac.authorization.k8s.io - kind: Role - name: {{ include "ingress-nginx.fullname" . }}-backend -subjects: - - kind: ServiceAccount - name: {{ template "ingress-nginx.defaultBackend.serviceAccountName" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-service.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-service.yaml deleted file mode 100644 index 65b6b83..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-service.yaml +++ /dev/null @@ -1,41 +0,0 @@ -{{- if .Values.defaultBackend.enabled -}} -apiVersion: v1 -kind: Service -metadata: -{{- if .Values.defaultBackend.service.annotations }} - annotations: {{ toYaml .Values.defaultBackend.service.annotations | nindent 4 }} -{{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.defaultBackend.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - type: {{ .Values.defaultBackend.service.type }} -{{- if .Values.defaultBackend.service.clusterIP }} - clusterIP: {{ .Values.defaultBackend.service.clusterIP }} -{{- end }} -{{- if .Values.defaultBackend.service.externalIPs }} - externalIPs: {{ toYaml .Values.defaultBackend.service.externalIPs | nindent 4 }} -{{- end }} -{{- if .Values.defaultBackend.service.loadBalancerIP }} - loadBalancerIP: {{ .Values.defaultBackend.service.loadBalancerIP }} -{{- end }} -{{- if .Values.defaultBackend.service.loadBalancerSourceRanges }} - loadBalancerSourceRanges: {{ toYaml .Values.defaultBackend.service.loadBalancerSourceRanges | nindent 4 }} -{{- end }} - ports: - - name: http - port: {{ .Values.defaultBackend.service.servicePort }} - protocol: TCP - targetPort: http - {{- if semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version }} - appProtocol: http - {{- end }} - selector: - {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} - app.kubernetes.io/component: default-backend -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-serviceaccount.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-serviceaccount.yaml deleted file mode 100644 index 6fd2d62..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-serviceaccount.yaml +++ /dev/null @@ -1,14 +0,0 @@ -{{- if and .Values.defaultBackend.enabled .Values.defaultBackend.serviceAccount.create -}} -apiVersion: v1 -kind: ServiceAccount -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.defaultBackend.serviceAccountName" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -automountServiceAccountToken: {{ .Values.defaultBackend.serviceAccount.automountServiceAccountToken }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrole_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrole_test.yaml deleted file mode 100644 index d7a8b88..0000000 --- a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrole_test.yaml +++ /dev/null @@ -1,11 +0,0 @@ -suite: Admission Webhooks > Patch Job > ClusterRole -templates: - - admission-webhooks/job-patch/clusterrole.yaml - -tests: - - it: should not create a ClusterRole if `controller.admissionWebhooks.patch.rbac.create` is false - set: - controller.admissionWebhooks.patch.rbac.create: false - asserts: - - hasDocuments: - count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrolebinding_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrolebinding_test.yaml deleted file mode 100644 index d7c3266..0000000 --- a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrolebinding_test.yaml +++ /dev/null @@ -1,11 +0,0 @@ -suite: Admission Webhooks > Patch Job > ClusterRoleBinding -templates: - - admission-webhooks/job-patch/clusterrolebinding.yaml - -tests: - - it: should not create a ClusterRoleBinding if `controller.admissionWebhooks.patch.rbac.create` is false - set: - controller.admissionWebhooks.patch.rbac.create: false - asserts: - - hasDocuments: - count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/role_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/role_test.yaml deleted file mode 100644 index a236f3d..0000000 --- a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/role_test.yaml +++ /dev/null @@ -1,11 +0,0 @@ -suite: Admission Webhooks > Patch Job > Role -templates: - - admission-webhooks/job-patch/role.yaml - -tests: - - it: should not create a Role if `controller.admissionWebhooks.patch.rbac.create` is false - set: - controller.admissionWebhooks.patch.rbac.create: false - asserts: - - hasDocuments: - count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/rolebinding_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/rolebinding_test.yaml deleted file mode 100644 index 74abaa1..0000000 --- a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/rolebinding_test.yaml +++ /dev/null @@ -1,11 +0,0 @@ -suite: Admission Webhooks > Patch Job > RoleBinding -templates: - - admission-webhooks/job-patch/rolebinding.yaml - -tests: - - it: should not create a RoleBinding if `controller.admissionWebhooks.patch.rbac.create` is false - set: - controller.admissionWebhooks.patch.rbac.create: false - asserts: - - hasDocuments: - count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/serviceaccount_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/serviceaccount_test.yaml deleted file mode 100644 index 7c30d1e..0000000 --- a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/serviceaccount_test.yaml +++ /dev/null @@ -1,47 +0,0 @@ -suite: Admission Webhooks > Patch Job > ServiceAccount -templates: - - admission-webhooks/job-patch/serviceaccount.yaml - -tests: - - it: should not create a ServiceAccount if `controller.admissionWebhooks.patch.serviceAccount.create` is false - set: - controller.admissionWebhooks.patch.serviceAccount.create: false - asserts: - - hasDocuments: - count: 0 - - - it: should create a ServiceAccount if `controller.admissionWebhooks.patch.serviceAccount.create` is true - set: - controller.admissionWebhooks.patch.serviceAccount.create: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ServiceAccount - - equal: - path: metadata.name - value: ingress-nginx-admission - - - it: should create a ServiceAccount with specified name if `controller.admissionWebhooks.patch.serviceAccount.name` is set - set: - controller.admissionWebhooks.patch.serviceAccount.name: ingress-nginx-admission-test-sa - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ServiceAccount - - equal: - path: metadata.name - value: ingress-nginx-admission-test-sa - - - it: should create a ServiceAccount with token auto-mounting disabled if `controller.admissionWebhooks.patch.serviceAccount.automountServiceAccountToken` is false - set: - controller.admissionWebhooks.patch.serviceAccount.automountServiceAccountToken: false - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ServiceAccount - - equal: - path: automountServiceAccountToken - value: false diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/validating-webhook_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/validating-webhook_test.yaml deleted file mode 100644 index b9d6d78..0000000 --- a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/validating-webhook_test.yaml +++ /dev/null @@ -1,32 +0,0 @@ -suite: Admission Webhooks > ValidatingWebhookConfiguration -templates: - - admission-webhooks/validating-webhook.yaml - -tests: - - it: should not create a ValidatingWebhookConfiguration if `controller.admissionWebhooks.enabled` is false - set: - controller.admissionWebhooks.enabled: false - asserts: - - hasDocuments: - count: 0 - - - it: should create a ValidatingWebhookConfiguration if `controller.admissionWebhooks.enabled` is true - set: - controller.admissionWebhooks.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ValidatingWebhookConfiguration - - equal: - path: metadata.name - value: RELEASE-NAME-admission - - - it: should create a ValidatingWebhookConfiguration with a custom port if `controller.admissionWebhooks.service.servicePort` is set - set: - controller.admissionWebhooks.enabled: true - controller.admissionWebhooks.service.servicePort: 9443 - asserts: - - equal: - path: webhooks[0].clientConfig.service.port - value: 9443 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-configmap-addheaders_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-configmap-addheaders_test.yaml deleted file mode 100644 index e831d50..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-configmap-addheaders_test.yaml +++ /dev/null @@ -1,27 +0,0 @@ -suite: Controller > ConfigMap > Add Headers -templates: - - controller-configmap-addheaders.yaml - -tests: - - it: should not create a ConfigMap if `controller.addHeaders` is not set - set: - controller.addHeaders: null - asserts: - - hasDocuments: - count: 0 - - - it: should create a ConfigMap if `controller.addHeaders` is set - set: - controller.addHeaders: - X-Another-Custom-Header: Value - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ConfigMap - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-custom-add-headers - - equal: - path: data.X-Another-Custom-Header - value: Value diff --git a/charts/keep/charts/ingress-nginx/tests/controller-configmap-proxyheaders_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-configmap-proxyheaders_test.yaml deleted file mode 100644 index 0634a37..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-configmap-proxyheaders_test.yaml +++ /dev/null @@ -1,27 +0,0 @@ -suite: Controller > ConfigMap > Proxy Headers -templates: - - controller-configmap-proxyheaders.yaml - -tests: - - it: should not create a ConfigMap if `controller.proxySetHeaders` is not set - set: - controller.proxySetHeaders: null - asserts: - - hasDocuments: - count: 0 - - - it: should create a ConfigMap if `controller.proxySetHeaders` is set - set: - controller.proxySetHeaders: - X-Custom-Header: Value - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ConfigMap - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-custom-proxy-headers - - equal: - path: data.X-Custom-Header - value: Value diff --git a/charts/keep/charts/ingress-nginx/tests/controller-configmap_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-configmap_test.yaml deleted file mode 100644 index 168b657..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-configmap_test.yaml +++ /dev/null @@ -1,31 +0,0 @@ -suite: Controller > ConfigMap -templates: - - controller-configmap.yaml - -tests: - - it: should create a ConfigMap - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ConfigMap - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should create a ConfigMap with templated values if `controller.config` contains templates - set: - controller.config: - template: "test.{{ .Release.Namespace }}.svc.kubernetes.local" - integer: 12345 - boolean: true - asserts: - - equal: - path: data.template - value: test.NAMESPACE.svc.kubernetes.local - - equal: - path: data.integer - value: "12345" - - equal: - path: data.boolean - value: "true" diff --git a/charts/keep/charts/ingress-nginx/tests/controller-daemonset_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-daemonset_test.yaml deleted file mode 100644 index 81d067b..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-daemonset_test.yaml +++ /dev/null @@ -1,172 +0,0 @@ -suite: Controller > DaemonSet -templates: - - controller-daemonset.yaml - -tests: - - it: should create a DaemonSet if `controller.kind` is "DaemonSet" - set: - controller.kind: DaemonSet - asserts: - - hasDocuments: - count: 1 - - isKind: - of: DaemonSet - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should create a DaemonSet with argument `--enable-metrics=false` if `controller.metrics.enabled` is false - set: - controller.kind: DaemonSet - controller.metrics.enabled: false - asserts: - - contains: - path: spec.template.spec.containers[0].args - content: --enable-metrics=false - - - it: should create a DaemonSet without argument `--enable-metrics=false` if `controller.metrics.enabled` is true - set: - controller.kind: DaemonSet - controller.metrics.enabled: true - asserts: - - notContains: - path: spec.template.spec.containers[0].args - content: --enable-metrics=false - - - it: should create a DaemonSet with argument `--controller-class=k8s.io/ingress-nginx-internal` if `controller.ingressClassResource.controllerValue` is "k8s.io/ingress-nginx-internal" - set: - controller.kind: DaemonSet - controller.ingressClassResource.controllerValue: k8s.io/ingress-nginx-internal - asserts: - - contains: - path: spec.template.spec.containers[0].args - content: --controller-class=k8s.io/ingress-nginx-internal - - - it: should create a DaemonSet with resource limits if `controller.resources.limits` is set - set: - controller.kind: DaemonSet - controller.resources.limits.cpu: 500m - controller.resources.limits.memory: 512Mi - asserts: - - equal: - path: spec.template.spec.containers[0].resources.limits.cpu - value: 500m - - equal: - path: spec.template.spec.containers[0].resources.limits.memory - value: 512Mi - - - it: should create a DaemonSet with topology spread constraints if `controller.topologySpreadConstraints` is set - set: - controller.kind: DaemonSet - controller.topologySpreadConstraints: - - labelSelector: - matchLabels: - app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - app.kubernetes.io/instance: '{{ .Release.Name }}' - app.kubernetes.io/component: controller - topologyKey: topology.kubernetes.io/zone - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - labelSelector: - matchLabels: - app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - app.kubernetes.io/instance: '{{ .Release.Name }}' - app.kubernetes.io/component: controller - topologyKey: kubernetes.io/hostname - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - asserts: - - equal: - path: spec.template.spec.topologySpreadConstraints - value: - - labelSelector: - matchLabels: - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: RELEASE-NAME - app.kubernetes.io/component: controller - topologyKey: topology.kubernetes.io/zone - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - labelSelector: - matchLabels: - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: RELEASE-NAME - app.kubernetes.io/component: controller - topologyKey: kubernetes.io/hostname - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - - it: should create a DaemonSet with affinity if `controller.affinity` is set - set: - controller.kind: DaemonSet - controller.affinity: - podAntiAffinity: - requiredDuringSchedulingIgnoredDuringExecution: - - labelSelector: - matchExpressions: - - key: app.kubernetes.io/name - operator: In - values: - - '{{ include "ingress-nginx.name" . }}' - - key: app.kubernetes.io/instance - operator: In - values: - - '{{ .Release.Name }}' - - key: app.kubernetes.io/component - operator: In - values: - - controller - topologyKey: kubernetes.io/hostname - asserts: - - equal: - path: spec.template.spec.affinity - value: - podAntiAffinity: - requiredDuringSchedulingIgnoredDuringExecution: - - labelSelector: - matchExpressions: - - key: app.kubernetes.io/name - operator: In - values: - - ingress-nginx - - key: app.kubernetes.io/instance - operator: In - values: - - RELEASE-NAME - - key: app.kubernetes.io/component - operator: In - values: - - controller - topologyKey: kubernetes.io/hostname - - - it: should create a DaemonSet with a custom registry if `controller.image.registry` is set - set: - controller.kind: DaemonSet - controller.image.registry: custom.registry.io - controller.image.tag: v1.0.0-dev - controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: custom.registry.io/ingress-nginx/controller:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - - - it: should create a DaemonSet with a custom image if `controller.image.image` is set - set: - controller.kind: DaemonSet - controller.image.image: custom-repo/custom-image - controller.image.tag: v1.0.0-dev - controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: registry.k8s.io/custom-repo/custom-image:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - - - it: should create a DaemonSet with a custom tag if `controller.image.tag` is set - set: - controller.kind: DaemonSet - controller.image.tag: custom-tag - controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: registry.k8s.io/ingress-nginx/controller:custom-tag@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd diff --git a/charts/keep/charts/ingress-nginx/tests/controller-deployment_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-deployment_test.yaml deleted file mode 100644 index 382aecd..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-deployment_test.yaml +++ /dev/null @@ -1,191 +0,0 @@ -suite: Controller > Deployment -templates: - - controller-deployment.yaml - -tests: - - it: should create a Deployment - asserts: - - hasDocuments: - count: 1 - - isKind: - of: Deployment - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should create a Deployment with 3 replicas if `controller.replicaCount` is 3 - set: - controller.replicaCount: 3 - asserts: - - equal: - path: spec.replicas - value: 3 - - - it: should create a Deployment without replicas if `controller.autoscaling.enabled` is true - set: - controller.autoscaling.enabled: true - asserts: - - notExists: - path: spec.replicas - - - it: should create a Deployment without replicas if `controller.keda.enabled` is true - set: - controller.keda.enabled: true - asserts: - - notExists: - path: spec.replicas - - - it: should create a Deployment with replicas if `controller.autoscaling.enabled` is true and `controller.keda.enabled` is true - set: - controller.autoscaling.enabled: true - controller.keda.enabled: true - asserts: - - exists: - path: spec.replicas - - - it: should create a Deployment with argument `--enable-metrics=false` if `controller.metrics.enabled` is false - set: - controller.metrics.enabled: false - asserts: - - contains: - path: spec.template.spec.containers[0].args - content: --enable-metrics=false - - - it: should create a Deployment without argument `--enable-metrics=false` if `controller.metrics.enabled` is true - set: - controller.metrics.enabled: true - asserts: - - notContains: - path: spec.template.spec.containers[0].args - content: --enable-metrics=false - - - it: should create a Deployment with argument `--controller-class=k8s.io/ingress-nginx-internal` if `controller.ingressClassResource.controllerValue` is "k8s.io/ingress-nginx-internal" - set: - controller.ingressClassResource.controllerValue: k8s.io/ingress-nginx-internal - asserts: - - contains: - path: spec.template.spec.containers[0].args - content: --controller-class=k8s.io/ingress-nginx-internal - - - it: should create a Deployment with resource limits if `controller.resources.limits` is set - set: - controller.resources.limits.cpu: 500m - controller.resources.limits.memory: 512Mi - asserts: - - equal: - path: spec.template.spec.containers[0].resources.limits.cpu - value: 500m - - equal: - path: spec.template.spec.containers[0].resources.limits.memory - value: 512Mi - - - it: should create a Deployment with topology spread constraints if `controller.topologySpreadConstraints` is set - set: - controller.topologySpreadConstraints: - - labelSelector: - matchLabels: - app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - app.kubernetes.io/instance: '{{ .Release.Name }}' - app.kubernetes.io/component: controller - topologyKey: topology.kubernetes.io/zone - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - labelSelector: - matchLabels: - app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - app.kubernetes.io/instance: '{{ .Release.Name }}' - app.kubernetes.io/component: controller - topologyKey: kubernetes.io/hostname - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - asserts: - - equal: - path: spec.template.spec.topologySpreadConstraints - value: - - labelSelector: - matchLabels: - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: RELEASE-NAME - app.kubernetes.io/component: controller - topologyKey: topology.kubernetes.io/zone - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - labelSelector: - matchLabels: - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: RELEASE-NAME - app.kubernetes.io/component: controller - topologyKey: kubernetes.io/hostname - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - - it: should create a Deployment with affinity if `controller.affinity` is set - set: - controller.affinity: - podAntiAffinity: - requiredDuringSchedulingIgnoredDuringExecution: - - labelSelector: - matchExpressions: - - key: app.kubernetes.io/name - operator: In - values: - - '{{ include "ingress-nginx.name" . }}' - - key: app.kubernetes.io/instance - operator: In - values: - - '{{ .Release.Name }}' - - key: app.kubernetes.io/component - operator: In - values: - - controller - topologyKey: kubernetes.io/hostname - asserts: - - equal: - path: spec.template.spec.affinity - value: - podAntiAffinity: - requiredDuringSchedulingIgnoredDuringExecution: - - labelSelector: - matchExpressions: - - key: app.kubernetes.io/name - operator: In - values: - - ingress-nginx - - key: app.kubernetes.io/instance - operator: In - values: - - RELEASE-NAME - - key: app.kubernetes.io/component - operator: In - values: - - controller - topologyKey: kubernetes.io/hostname - - - it: should create a Deployment with a custom registry if `controller.image.registry` is set - set: - controller.image.registry: custom.registry.io - controller.image.tag: v1.0.0-dev - controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: custom.registry.io/ingress-nginx/controller:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - - - it: should create a Deployment with a custom image if `controller.image.image` is set - set: - controller.image.image: custom-repo/custom-image - controller.image.tag: v1.0.0-dev - controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: registry.k8s.io/custom-repo/custom-image:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - - - it: should create a Deployment with a custom tag if `controller.image.tag` is set - set: - controller.image.tag: custom-tag - controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: registry.k8s.io/ingress-nginx/controller:custom-tag@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd diff --git a/charts/keep/charts/ingress-nginx/tests/controller-hpa_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-hpa_test.yaml deleted file mode 100644 index 869d3a6..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-hpa_test.yaml +++ /dev/null @@ -1,31 +0,0 @@ -suite: Controller > HPA -templates: - - controller-hpa.yaml - -tests: - - it: should create an HPA if `controller.autoscaling.enabled` is true - set: - controller.autoscaling.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: HorizontalPodAutoscaler - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should not create an HPA if `controller.autoscaling.enabled` is true and `controller.keda.enabled` is true - set: - controller.autoscaling.enabled: true - controller.keda.enabled: true - asserts: - - hasDocuments: - count: 0 - - - it: should not create an HPA if `controller.kind` is "DaemonSet" - set: - controller.kind: DaemonSet - asserts: - - hasDocuments: - count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-ingressclass-aliases_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-ingressclass-aliases_test.yaml deleted file mode 100644 index 9a4a576..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-ingressclass-aliases_test.yaml +++ /dev/null @@ -1,110 +0,0 @@ -suite: Controller > IngressClass > Aliases -templates: - - controller-ingressclass-aliases.yaml - -tests: - - it: should not create IngressClass aliases - asserts: - - hasDocuments: - count: 0 - - - it: should create an IngressClass alias with name "nginx-alias" if `controller.ingressClassResource.aliases` is set - set: - controller.ingressClassResource.aliases: - - nginx-alias - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx-alias - - - it: should create an IngressClass alias without annotation `ingressclass.kubernetes.io/is-default-class` if `controller.ingressClassResource.default` is true - set: - controller.ingressClassResource.aliases: - - nginx-alias - controller.ingressClassResource.default: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx-alias - - notExists: - path: metadata.annotations["ingressclass.kubernetes.io/is-default-class"] - - - it: should create an IngressClass alias with annotations if `controller.ingressClassResource.annotations` is set - set: - controller.ingressClassResource.aliases: - - nginx-alias - controller.ingressClassResource.annotations: - my-fancy-annotation: has-a-value - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx-alias - - equal: - path: metadata.annotations.my-fancy-annotation - value: has-a-value - - - it: should create an IngressClass alias with controller "k8s.io/ingress-nginx-internal" if `controller.ingressClassResource.controllerValue` is "k8s.io/ingress-nginx-internal" - set: - controller.ingressClassResource.aliases: - - nginx-alias - controller.ingressClassResource.controllerValue: k8s.io/ingress-nginx-internal - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx-alias - - equal: - path: spec.controller - value: k8s.io/ingress-nginx-internal - - - it: should create an IngressClass alias with parameters if `controller.ingressClassResource.parameters` is set - set: - controller.ingressClassResource.aliases: - - nginx-alias - controller.ingressClassResource.parameters: - apiGroup: k8s.example.com - kind: IngressParameters - name: external-lb - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx-alias - - equal: - path: spec.parameters - value: - apiGroup: k8s.example.com - kind: IngressParameters - name: external-lb - - - it: should create two IngressClass aliases if `controller.ingressClassResource.aliases` has two elements - set: - controller.ingressClassResource.aliases: - - nginx-alias-1 - - nginx-alias-2 - asserts: - - hasDocuments: - count: 2 - - isKind: - of: IngressClass - - matchRegex: - path: metadata.name - pattern: nginx-alias-(1|2) diff --git a/charts/keep/charts/ingress-nginx/tests/controller-ingressclass_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-ingressclass_test.yaml deleted file mode 100644 index b3384af..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-ingressclass_test.yaml +++ /dev/null @@ -1,93 +0,0 @@ -suite: Controller > IngressClass -templates: - - controller-ingressclass.yaml - -tests: - - it: should create an IngressClass - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx - - - it: should create an IngressClass with name "nginx-internal" if `controller.ingressClassResource.name` is "nginx-internal" - set: - controller.ingressClassResource.name: nginx-internal - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx-internal - - - it: "should create an IngressClass with annotation `ingressclass.kubernetes.io/is-default-class: \"true\"` if `controller.ingressClassResource.default` is true" - set: - controller.ingressClassResource.default: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx - - equal: - path: metadata.annotations["ingressclass.kubernetes.io/is-default-class"] - value: "true" - - - it: should create an IngressClass with annotations if `controller.ingressClassResource.annotations` is set - set: - controller.ingressClassResource.annotations: - my-fancy-annotation: has-a-value - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx - - equal: - path: metadata.annotations.my-fancy-annotation - value: has-a-value - - - it: should create an IngressClass with controller "k8s.io/ingress-nginx-internal" if `controller.ingressClassResource.controllerValue` is "k8s.io/ingress-nginx-internal" - set: - controller.ingressClassResource.controllerValue: k8s.io/ingress-nginx-internal - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx - - equal: - path: spec.controller - value: k8s.io/ingress-nginx-internal - - - it: should create an IngressClass with parameters if `controller.ingressClassResource.parameters` is set - set: - controller.ingressClassResource.parameters: - apiGroup: k8s.example.com - kind: IngressParameters - name: external-lb - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx - - equal: - path: spec.parameters - value: - apiGroup: k8s.example.com - kind: IngressParameters - name: external-lb diff --git a/charts/keep/charts/ingress-nginx/tests/controller-keda_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-keda_test.yaml deleted file mode 100644 index 8002834..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-keda_test.yaml +++ /dev/null @@ -1,31 +0,0 @@ -suite: Controller > KEDA -templates: - - controller-keda.yaml - -tests: - - it: should create a ScaledObject if `controller.keda.enabled` is true - set: - controller.keda.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ScaledObject - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should not create a ScaledObject if `controller.keda.enabled` is true and `controller.autoscaling.enabled` is true - set: - controller.keda.enabled: true - controller.autoscaling.enabled: true - asserts: - - hasDocuments: - count: 0 - - - it: should not create a ScaledObject if `controller.kind` is "DaemonSet" - set: - controller.kind: DaemonSet - asserts: - - hasDocuments: - count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-networkpolicy_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-networkpolicy_test.yaml deleted file mode 100644 index 5de12e9..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-networkpolicy_test.yaml +++ /dev/null @@ -1,23 +0,0 @@ -suite: Controller > NetworkPolicy -templates: - - controller-networkpolicy.yaml - -tests: - - it: should not create a NetworkPolicy if `controller.networkPolicy.enabled` is false - set: - controller.networkPolicy.enabled: false - asserts: - - hasDocuments: - count: 0 - - - it: should create a NetworkPolicy if `controller.networkPolicy.enabled` is true - set: - controller.networkPolicy.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: NetworkPolicy - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller diff --git a/charts/keep/charts/ingress-nginx/tests/controller-poddisruptionbudget_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-poddisruptionbudget_test.yaml deleted file mode 100644 index f215f35..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-poddisruptionbudget_test.yaml +++ /dev/null @@ -1,89 +0,0 @@ -suite: Controller > PodDisruptionBudget -templates: - - controller-poddisruptionbudget.yaml - -tests: - - it: should create a PodDisruptionBudget if `controller.replicaCount` is greater than 1 - set: - controller.replicaCount: 2 - asserts: - - hasDocuments: - count: 1 - - isKind: - of: PodDisruptionBudget - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should not create a PodDisruptionBudget if `controller.replicaCount` is less than or equal 1 - set: - controller.replicaCount: 1 - asserts: - - hasDocuments: - count: 0 - - - it: should create a PodDisruptionBudget if `controller.autoscaling.enabled` is true and `controller.autoscaling.minReplicas` is greater than 1 - set: - controller.autoscaling.enabled: true - controller.autoscaling.minReplicas: 2 - asserts: - - hasDocuments: - count: 1 - - isKind: - of: PodDisruptionBudget - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should not create a PodDisruptionBudget if `controller.autoscaling.enabled` is true and `controller.autoscaling.minReplicas` is less than or equal 1 - set: - controller.autoscaling.enabled: true - controller.autoscaling.minReplicas: 1 - asserts: - - hasDocuments: - count: 0 - - - it: should create a PodDisruptionBudget if `controller.keda.enabled` is true and `controller.keda.minReplicas` is greater than 1 - set: - controller.keda.enabled: true - controller.keda.minReplicas: 2 - asserts: - - hasDocuments: - count: 1 - - isKind: - of: PodDisruptionBudget - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should not create a PodDisruptionBudget if `controller.keda.enabled` is true and `controller.keda.minReplicas` is less than or equal 1 - set: - controller.keda.enabled: true - controller.keda.minReplicas: 1 - asserts: - - hasDocuments: - count: 0 - - - it: should not create a PodDisruptionBudget if `controller.autoscaling.enabled` is true and `controller.keda.enabled` is true - set: - controller.autoscaling.enabled: true - controller.keda.enabled: true - asserts: - - hasDocuments: - count: 0 - - - it: should create a PodDisruptionBudget without `minAvailable` and with `maxUnavailable` if `controller.minAvailable` and `controller.maxUnavailable` are set - set: - controller.replicaCount: 2 - controller.minAvailable: 1 - controller.maxUnavailable: 1 - asserts: - - hasDocuments: - count: 1 - - isKind: - of: PodDisruptionBudget - - notExists: - path: spec.minAvailable - - equal: - path: spec.maxUnavailable - value: 1 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-prometheusrule_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-prometheusrule_test.yaml deleted file mode 100644 index d60a983..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-prometheusrule_test.yaml +++ /dev/null @@ -1,17 +0,0 @@ -suite: Controller > PrometheusRule -templates: - - controller-prometheusrule.yaml - -tests: - - it: should create a PrometheusRule if `controller.metrics.prometheusRule.enabled` is true - set: - controller.metrics.enabled: true - controller.metrics.prometheusRule.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: PrometheusRule - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller diff --git a/charts/keep/charts/ingress-nginx/tests/controller-service-internal_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-service-internal_test.yaml deleted file mode 100644 index 5465e1a..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-service-internal_test.yaml +++ /dev/null @@ -1,25 +0,0 @@ -suite: Controller > Service > Internal -templates: - - controller-service-internal.yaml - -tests: - - it: should not create an internal Service if `controller.service.internal.enabled` is false - set: - controller.service.internal.enabled: false - asserts: - - hasDocuments: - count: 0 - - - it: should create an internal Service if `controller.service.internal.enabled` is true and `controller.service.internal.annotations` are set - set: - controller.service.internal.enabled: true - controller.service.internal.annotations: - test.annotation: "true" - asserts: - - hasDocuments: - count: 1 - - isKind: - of: Service - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller-internal diff --git a/charts/keep/charts/ingress-nginx/tests/controller-service-metrics_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-service-metrics_test.yaml deleted file mode 100644 index afdb940..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-service-metrics_test.yaml +++ /dev/null @@ -1,23 +0,0 @@ -suite: Controller > Service > Metrics -templates: - - controller-service-metrics.yaml - -tests: - - it: should not create a metrics Service if `controller.metrics.enabled` is false - set: - controller.metrics.enabled: false - asserts: - - hasDocuments: - count: 0 - - - it: should create a metrics Service if `controller.metrics.enabled` is true - set: - controller.metrics.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: Service - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller-metrics diff --git a/charts/keep/charts/ingress-nginx/tests/controller-service-webhook_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-service-webhook_test.yaml deleted file mode 100644 index 1c759ed..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-service-webhook_test.yaml +++ /dev/null @@ -1,32 +0,0 @@ -suite: Controller > Service > Webhook -templates: - - controller-service-webhook.yaml - -tests: - - it: should not create a webhook Service if `controller.admissionWebhooks.enabled` is false - set: - controller.admissionWebhooks.enabled: false - asserts: - - hasDocuments: - count: 0 - - - it: should create a webhook Service if `controller.admissionWebhooks.enabled` is true - set: - controller.admissionWebhooks.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: Service - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller-admission - - - it: should create a webhook Service with a custom port if `controller.admissionWebhooks.service.servicePort` is set - set: - controller.admissionWebhooks.enabled: true - controller.admissionWebhooks.service.servicePort: 9443 - asserts: - - equal: - path: spec.ports[0].port - value: 9443 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-service_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-service_test.yaml deleted file mode 100644 index 10574f2..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-service_test.yaml +++ /dev/null @@ -1,32 +0,0 @@ -suite: Controller > Service -templates: - - controller-service.yaml - -tests: - - it: should not create a Service if `controller.service.external.enabled` is false - set: - controller.service.external.enabled: false - asserts: - - hasDocuments: - count: 0 - - - it: should create a Service if `controller.service.external.enabled` is true - set: - controller.service.external.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: Service - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should create a Service of type "NodePort" if `controller.service.external.enabled` is true and `controller.service.type` is "NodePort" - set: - controller.service.external.enabled: true - controller.service.type: NodePort - asserts: - - equal: - path: spec.type - value: NodePort diff --git a/charts/keep/charts/ingress-nginx/tests/controller-servicemonitor_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-servicemonitor_test.yaml deleted file mode 100644 index 310097c..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-servicemonitor_test.yaml +++ /dev/null @@ -1,29 +0,0 @@ -suite: Controller > ServiceMonitor -templates: - - controller-servicemonitor.yaml - -tests: - - it: should create a ServiceMonitor if `controller.metrics.serviceMonitor.enabled` is true - set: - controller.metrics.enabled: true - controller.metrics.serviceMonitor.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ServiceMonitor - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should create a ServiceMonitor with annotations if `controller.metrics.serviceMonitor.annotations` is set - set: - controller.metrics.enabled: true - controller.metrics.serviceMonitor.enabled: true - controller.metrics.serviceMonitor.annotations: - my-little-annotation: test-value - asserts: - - equal: - path: metadata.annotations - value: - my-little-annotation: test-value diff --git a/charts/keep/charts/ingress-nginx/tests/default-backend-deployment_test.yaml b/charts/keep/charts/ingress-nginx/tests/default-backend-deployment_test.yaml deleted file mode 100644 index 4ba4b03..0000000 --- a/charts/keep/charts/ingress-nginx/tests/default-backend-deployment_test.yaml +++ /dev/null @@ -1,169 +0,0 @@ -suite: Default Backend > Deployment -templates: - - default-backend-deployment.yaml - -tests: - - it: should not create a Deployment if `defaultBackend.enabled` is false - set: - defaultBackend.enabled: false - asserts: - - hasDocuments: - count: 0 - - - it: should create a Deployment if `defaultBackend.enabled` is true - set: - defaultBackend.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: Deployment - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-defaultbackend - - - it: should create a Deployment with 3 replicas if `defaultBackend.replicaCount` is 3 - set: - defaultBackend.enabled: true - defaultBackend.replicaCount: 3 - asserts: - - equal: - path: spec.replicas - value: 3 - - - it: should create a Deployment without replicas if `defaultBackend.autoscaling.enabled` is true - set: - defaultBackend.enabled: true - defaultBackend.autoscaling.enabled: true - asserts: - - notExists: - path: spec.replicas - - - it: should create a Deployment with resource limits if `defaultBackend.resources.limits` is set - set: - defaultBackend.enabled: true - defaultBackend.resources.limits.cpu: 500m - defaultBackend.resources.limits.memory: 512Mi - asserts: - - equal: - path: spec.template.spec.containers[0].resources.limits.cpu - value: 500m - - equal: - path: spec.template.spec.containers[0].resources.limits.memory - value: 512Mi - - - it: should create a Deployment with topology spread constraints if `defaultBackend.topologySpreadConstraints` is set - set: - defaultBackend.enabled: true - defaultBackend.topologySpreadConstraints: - - labelSelector: - matchLabels: - app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - app.kubernetes.io/instance: '{{ .Release.Name }}' - app.kubernetes.io/component: default-backend - topologyKey: topology.kubernetes.io/zone - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - labelSelector: - matchLabels: - app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - app.kubernetes.io/instance: '{{ .Release.Name }}' - app.kubernetes.io/component: default-backend - topologyKey: kubernetes.io/hostname - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - asserts: - - equal: - path: spec.template.spec.topologySpreadConstraints - value: - - labelSelector: - matchLabels: - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: RELEASE-NAME - app.kubernetes.io/component: default-backend - topologyKey: topology.kubernetes.io/zone - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - labelSelector: - matchLabels: - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: RELEASE-NAME - app.kubernetes.io/component: default-backend - topologyKey: kubernetes.io/hostname - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - - it: should create a Deployment with affinity if `defaultBackend.affinity` is set - set: - defaultBackend.enabled: true - defaultBackend.affinity: - podAntiAffinity: - requiredDuringSchedulingIgnoredDuringExecution: - - labelSelector: - matchExpressions: - - key: app.kubernetes.io/name - operator: In - values: - - '{{ include "ingress-nginx.name" . }}' - - key: app.kubernetes.io/instance - operator: In - values: - - '{{ .Release.Name }}' - - key: app.kubernetes.io/component - operator: In - values: - - default-backend - topologyKey: kubernetes.io/hostname - asserts: - - equal: - path: spec.template.spec.affinity - value: - podAntiAffinity: - requiredDuringSchedulingIgnoredDuringExecution: - - labelSelector: - matchExpressions: - - key: app.kubernetes.io/name - operator: In - values: - - ingress-nginx - - key: app.kubernetes.io/instance - operator: In - values: - - RELEASE-NAME - - key: app.kubernetes.io/component - operator: In - values: - - default-backend - topologyKey: kubernetes.io/hostname - - - it: should create a Deployment with a custom registry if `defaultBackend.image.registry` is set - set: - defaultBackend.enabled: true - defaultBackend.image.registry: custom.registry.io - defaultBackend.image.tag: v1.0.0-dev - defaultBackend.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: custom.registry.io/defaultbackend-amd64:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - - - it: should create a Deployment with a custom image if `defaultBackend.image.image` is set - set: - defaultBackend.enabled: true - defaultBackend.image.image: custom-repo/custom-image - defaultBackend.image.tag: v1.0.0-dev - defaultBackend.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: registry.k8s.io/custom-repo/custom-image:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - - - it: should create a Deployment with a custom tag if `defaultBackend.image.tag` is set - set: - defaultBackend.enabled: true - defaultBackend.image.tag: custom-tag - defaultBackend.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: registry.k8s.io/defaultbackend-amd64:custom-tag@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd diff --git a/charts/keep/charts/ingress-nginx/tests/default-backend-extra-configmaps_test.yaml b/charts/keep/charts/ingress-nginx/tests/default-backend-extra-configmaps_test.yaml deleted file mode 100644 index aa600e7..0000000 --- a/charts/keep/charts/ingress-nginx/tests/default-backend-extra-configmaps_test.yaml +++ /dev/null @@ -1,50 +0,0 @@ -suite: Default Backend > Extra ConfigMaps -templates: - - default-backend-extra-configmaps.yaml - -tests: - - it: should not create a ConfigMap if `defaultBackend.extraConfigMaps` is empty - set: - defaultBackend.enabled: true - defaultBackend.extraConfigMaps: [] - asserts: - - hasDocuments: - count: 0 - - - it: should create one ConfigMap if `defaultBackend.extraConfigMaps` has one element - set: - defaultBackend.enabled: true - defaultBackend.extraConfigMaps: - - name: my-configmap-1 - data: - key1: value1 - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ConfigMap - - equal: - path: metadata.name - value: my-configmap-1 - - equal: - path: data.key1 - value: value1 - - - it: should create two ConfigMaps if `defaultBackend.extraConfigMaps` has two elements - set: - defaultBackend.enabled: true - defaultBackend.extraConfigMaps: - - name: my-configmap-1 - data: - key1: value1 - - name: my-configmap-2 - data: - key2: value2 - asserts: - - hasDocuments: - count: 2 - - isKind: - of: ConfigMap - - matchRegex: - path: metadata.name - pattern: my-configmap-(1|2) diff --git a/charts/keep/charts/ingress-nginx/tests/default-backend-poddisruptionbudget_test.yaml b/charts/keep/charts/ingress-nginx/tests/default-backend-poddisruptionbudget_test.yaml deleted file mode 100644 index 0958018..0000000 --- a/charts/keep/charts/ingress-nginx/tests/default-backend-poddisruptionbudget_test.yaml +++ /dev/null @@ -1,48 +0,0 @@ -suite: Default Backend > PodDisruptionBudget -templates: - - default-backend-poddisruptionbudget.yaml - -tests: - - it: should create a PodDisruptionBudget if `defaultBackend.replicaCount` is greater than 1 - set: - defaultBackend.enabled: true - defaultBackend.replicaCount: 2 - asserts: - - hasDocuments: - count: 1 - - isKind: - of: PodDisruptionBudget - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-defaultbackend - - - it: should not create a PodDisruptionBudget if `defaultBackend.replicaCount` is less than or equal 1 - set: - defaultBackend.enabled: true - defaultBackend.replicaCount: 1 - asserts: - - hasDocuments: - count: 0 - - - it: should create a PodDisruptionBudget if `defaultBackend.autoscaling.enabled` is true and `defaultBackend.autoscaling.minReplicas` is greater than 1 - set: - defaultBackend.enabled: true - defaultBackend.autoscaling.enabled: true - defaultBackend.autoscaling.minReplicas: 2 - asserts: - - hasDocuments: - count: 1 - - isKind: - of: PodDisruptionBudget - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-defaultbackend - - - it: should not create a PodDisruptionBudget if `defaultBackend.autoscaling.enabled` is true and `defaultBackend.autoscaling.minReplicas` is less than or equal 1 - set: - defaultBackend.enabled: true - defaultBackend.autoscaling.enabled: true - defaultBackend.autoscaling.minReplicas: 1 - asserts: - - hasDocuments: - count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/default-backend-service_test.yaml b/charts/keep/charts/ingress-nginx/tests/default-backend-service_test.yaml deleted file mode 100644 index f16904f..0000000 --- a/charts/keep/charts/ingress-nginx/tests/default-backend-service_test.yaml +++ /dev/null @@ -1,32 +0,0 @@ -suite: Default Backend > Service -templates: - - default-backend-service.yaml - -tests: - - it: should not create a Service if `defaultBackend.enabled` is false - set: - defaultBackend.enabled: false - asserts: - - hasDocuments: - count: 0 - - - it: should create a Service if `defaultBackend.enabled` is true - set: - defaultBackend.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: Service - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-defaultbackend - - - it: should create a Service with port 80 if `defaultBackend.service.port` is 80 - set: - defaultBackend.enabled: true - defaultBackend.service.port: 80 - asserts: - - equal: - path: spec.ports[0].port - value: 80 diff --git a/charts/keep/charts/ingress-nginx/values.yaml b/charts/keep/charts/ingress-nginx/values.yaml deleted file mode 100644 index f42a682..0000000 --- a/charts/keep/charts/ingress-nginx/values.yaml +++ /dev/null @@ -1,1192 +0,0 @@ -## nginx configuration -## Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/nginx-configuration/index.md -## - -## Overrides for generated resource names -# See templates/_helpers.tpl -# nameOverride: -# fullnameOverride: - -# -- Override the deployment namespace; defaults to .Release.Namespace -namespaceOverride: "" -## Labels to apply to all resources -## -commonLabels: {} -# scmhash: abc123 -# myLabel: aakkmd - -controller: - name: controller - enableAnnotationValidations: false - image: - ## Keep false as default for now! - chroot: false - registry: registry.k8s.io - image: ingress-nginx/controller - ## for backwards compatibility consider setting the full image url via the repository value below - ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail - ## repository: - tag: "v1.11.3" - digest: sha256:d56f135b6462cfc476447cfe564b83a45e8bb7da2774963b00d12161112270b7 - digestChroot: sha256:22701f0fc0f2dd209ef782f4e281bfe2d8cccd50ededa00aec88e0cdbe7edd14 - pullPolicy: IfNotPresent - runAsNonRoot: true - # www-data -> uid 101 - runAsUser: 101 - allowPrivilegeEscalation: false - seccompProfile: - type: RuntimeDefault - readOnlyRootFilesystem: false - # -- Use an existing PSP instead of creating one - existingPsp: "" - # -- Configures the controller container name - containerName: controller - # -- Configures the ports that the nginx-controller listens on - containerPort: - http: 80 - https: 443 - # -- Global configuration passed to the ConfigMap consumed by the controller. Values may contain Helm templates. - # Ref.: https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/ - config: {} - # -- Annotations to be added to the controller config configuration configmap. - configAnnotations: {} - # -- Will add custom headers before sending traffic to backends according to https://github.com/kubernetes/ingress-nginx/tree/main/docs/examples/customization/custom-headers - proxySetHeaders: {} - # -- Will add custom headers before sending response traffic to the client according to: https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/#add-headers - addHeaders: {} - # -- Optionally customize the pod dnsConfig. - dnsConfig: {} - # -- Optionally customize the pod hostAliases. - hostAliases: [] - # - ip: 127.0.0.1 - # hostnames: - # - foo.local - # - bar.local - # - ip: 10.1.2.3 - # hostnames: - # - foo.remote - # - bar.remote - # -- Optionally customize the pod hostname. - hostname: {} - # -- Optionally change this to ClusterFirstWithHostNet in case you have 'hostNetwork: true'. - # By default, while using host network, name resolution uses the host's DNS. If you wish nginx-controller - # to keep resolving names inside the k8s network, use ClusterFirstWithHostNet. - dnsPolicy: ClusterFirst - # -- Bare-metal considerations via the host network https://kubernetes.github.io/ingress-nginx/deploy/baremetal/#via-the-host-network - # Ingress status was blank because there is no Service exposing the Ingress-Nginx Controller in a configuration using the host network, the default --publish-service flag used in standard cloud setups does not apply - reportNodeInternalIp: false - # -- Process Ingress objects without ingressClass annotation/ingressClassName field - # Overrides value for --watch-ingress-without-class flag of the controller binary - # Defaults to false - watchIngressWithoutClass: false - # -- Process IngressClass per name (additionally as per spec.controller). - ingressClassByName: false - # -- This configuration enables Topology Aware Routing feature, used together with service annotation service.kubernetes.io/topology-mode="auto" - # Defaults to false - enableTopologyAwareRouting: false - # -- This configuration disable Nginx Controller Leader Election - disableLeaderElection: false - # -- Duration a leader election is valid before it's getting re-elected, e.g. `15s`, `10m` or `1h`. (Default: 30s) - electionTTL: "" - # -- This configuration defines if Ingress Controller should allow users to set - # their own *-snippet annotations, otherwise this is forbidden / dropped - # when users add those annotations. - # Global snippets in ConfigMap are still respected - allowSnippetAnnotations: false - # -- Required for use with CNI based kubernetes installations (such as ones set up by kubeadm), - # since CNI and hostport don't mix yet. Can be deprecated once https://github.com/kubernetes/kubernetes/issues/23920 - # is merged - hostNetwork: false - ## Use host ports 80 and 443 - ## Disabled by default - hostPort: - # -- Enable 'hostPort' or not - enabled: false - ports: - # -- 'hostPort' http port - http: 80 - # -- 'hostPort' https port - https: 443 - # NetworkPolicy for controller component. - networkPolicy: - # -- Enable 'networkPolicy' or not - enabled: false - # -- Election ID to use for status update, by default it uses the controller name combined with a suffix of 'leader' - electionID: "" - # -- This section refers to the creation of the IngressClass resource. - # IngressClasses are immutable and cannot be changed after creation. - # We do not support namespaced IngressClasses, yet, so a ClusterRole and a ClusterRoleBinding is required. - ingressClassResource: - # -- Name of the IngressClass - name: nginx - # -- Create the IngressClass or not - enabled: true - # -- If true, Ingresses without `ingressClassName` get assigned to this IngressClass on creation. - # Ingress creation gets rejected if there are multiple default IngressClasses. - # Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#default-ingress-class - default: false - # -- Annotations to be added to the IngressClass resource. - annotations: {} - # -- Controller of the IngressClass. An Ingress Controller looks for IngressClasses it should reconcile by this value. - # This value is also being set as the `--controller-class` argument of this Ingress Controller. - # Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#ingress-class - controllerValue: k8s.io/ingress-nginx - # -- Aliases of this IngressClass. Creates copies with identical settings but the respective alias as name. - # Useful for development environments with only one Ingress Controller but production-like Ingress resources. - # `default` gets enabled on the original IngressClass only. - aliases: [] - # aliases: - # - nginx-alias-1 - # - nginx-alias-2 - # -- A link to a custom resource containing additional configuration for the controller. - # This is optional if the controller consuming this IngressClass does not require additional parameters. - # Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#ingress-class - parameters: {} - # parameters: - # apiGroup: k8s.example.com - # kind: IngressParameters - # name: external-lb - # -- For backwards compatibility with ingress.class annotation, use ingressClass. - # Algorithm is as follows, first ingressClassName is considered, if not present, controller looks for ingress.class annotation - ingressClass: nginx - # -- Labels to add to the pod container metadata - podLabels: {} - # key: value - - # -- Security context for controller pods - podSecurityContext: {} - # -- sysctls for controller pods - ## Ref: https://kubernetes.io/docs/tasks/administer-cluster/sysctl-cluster/ - sysctls: {} - # sysctls: - # "net.core.somaxconn": "8192" - # -- Security context for controller containers - containerSecurityContext: {} - # -- Allows customization of the source of the IP address or FQDN to report - # in the ingress status field. By default, it reads the information provided - # by the service. If disable, the status field reports the IP address of the - # node or nodes where an ingress controller pod is running. - publishService: - # -- Enable 'publishService' or not - enabled: true - # -- Allows overriding of the publish service to bind to - # Must be / - pathOverride: "" - # Limit the scope of the controller to a specific namespace - scope: - # -- Enable 'scope' or not - enabled: false - # -- Namespace to limit the controller to; defaults to $(POD_NAMESPACE) - namespace: "" - # -- When scope.enabled == false, instead of watching all namespaces, we watching namespaces whose labels - # only match with namespaceSelector. Format like foo=bar. Defaults to empty, means watching all namespaces. - namespaceSelector: "" - # -- Allows customization of the configmap / nginx-configmap namespace; defaults to $(POD_NAMESPACE) - configMapNamespace: "" - tcp: - # -- Allows customization of the tcp-services-configmap; defaults to $(POD_NAMESPACE) - configMapNamespace: "" - # -- Annotations to be added to the tcp config configmap - annotations: {} - udp: - # -- Allows customization of the udp-services-configmap; defaults to $(POD_NAMESPACE) - configMapNamespace: "" - # -- Annotations to be added to the udp config configmap - annotations: {} - # -- Maxmind license key to download GeoLite2 Databases. - ## https://blog.maxmind.com/2019/12/significant-changes-to-accessing-and-using-geolite2-databases/ - maxmindLicenseKey: "" - # -- Additional command line arguments to pass to Ingress-Nginx Controller - # E.g. to specify the default SSL certificate you can use - extraArgs: {} - ## extraArgs: - ## default-ssl-certificate: "/" - ## time-buckets: "0.005,0.01,0.025,0.05,0.1,0.25,0.5,1,2.5,5,10" - ## length-buckets: "10,20,30,40,50,60,70,80,90,100" - ## size-buckets: "10,100,1000,10000,100000,1e+06,1e+07" - - # -- Additional environment variables to set - extraEnvs: [] - # extraEnvs: - # - name: FOO - # valueFrom: - # secretKeyRef: - # key: FOO - # name: secret-resource - - # -- Use a `DaemonSet` or `Deployment` - kind: Deployment - # -- Annotations to be added to the controller Deployment or DaemonSet - ## - annotations: {} - # keel.sh/pollSchedule: "@every 60m" - - # -- Labels to be added to the controller Deployment or DaemonSet and other resources that do not have option to specify labels - ## - labels: {} - # keel.sh/policy: patch - # keel.sh/trigger: poll - - # -- The update strategy to apply to the Deployment or DaemonSet - ## - updateStrategy: {} - # rollingUpdate: - # maxUnavailable: 1 - # type: RollingUpdate - - # -- `minReadySeconds` to avoid killing pods before we are ready - ## - minReadySeconds: 0 - # -- Node tolerations for server scheduling to nodes with taints - ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/ - ## - tolerations: [] - # - key: "key" - # operator: "Equal|Exists" - # value: "value" - # effect: "NoSchedule|PreferNoSchedule|NoExecute(1.6 only)" - - # -- Affinity and anti-affinity rules for server scheduling to nodes - ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#affinity-and-anti-affinity - ## - affinity: {} - # # An example of preferred pod anti-affinity, weight is in the range 1-100 - # podAntiAffinity: - # preferredDuringSchedulingIgnoredDuringExecution: - # - weight: 100 - # podAffinityTerm: - # labelSelector: - # matchExpressions: - # - key: app.kubernetes.io/name - # operator: In - # values: - # - '{{ include "ingress-nginx.name" . }}' - # - key: app.kubernetes.io/instance - # operator: In - # values: - # - '{{ .Release.Name }}' - # - key: app.kubernetes.io/component - # operator: In - # values: - # - controller - # topologyKey: kubernetes.io/hostname - - # # An example of required pod anti-affinity - # podAntiAffinity: - # requiredDuringSchedulingIgnoredDuringExecution: - # - labelSelector: - # matchExpressions: - # - key: app.kubernetes.io/name - # operator: In - # values: - # - '{{ include "ingress-nginx.name" . }}' - # - key: app.kubernetes.io/instance - # operator: In - # values: - # - '{{ .Release.Name }}' - # - key: app.kubernetes.io/component - # operator: In - # values: - # - controller - # topologyKey: kubernetes.io/hostname - - # -- Topology spread constraints rely on node labels to identify the topology domain(s) that each Node is in. - ## Ref: https://kubernetes.io/docs/concepts/workloads/pods/pod-topology-spread-constraints/ - ## - topologySpreadConstraints: [] - # - labelSelector: - # matchLabels: - # app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - # app.kubernetes.io/instance: '{{ .Release.Name }}' - # app.kubernetes.io/component: controller - # topologyKey: topology.kubernetes.io/zone - # maxSkew: 1 - # whenUnsatisfiable: ScheduleAnyway - # - labelSelector: - # matchLabels: - # app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - # app.kubernetes.io/instance: '{{ .Release.Name }}' - # app.kubernetes.io/component: controller - # topologyKey: kubernetes.io/hostname - # maxSkew: 1 - # whenUnsatisfiable: ScheduleAnyway - - # -- `terminationGracePeriodSeconds` to avoid killing pods before we are ready - ## wait up to five minutes for the drain of connections - ## - terminationGracePeriodSeconds: 300 - # -- Node labels for controller pod assignment - ## Ref: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/ - ## - nodeSelector: - kubernetes.io/os: linux - ## Liveness and readiness probe values - ## Ref: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle/#container-probes - ## - ## startupProbe: - ## httpGet: - ## # should match container.healthCheckPath - ## path: "/healthz" - ## port: 10254 - ## scheme: HTTP - ## initialDelaySeconds: 5 - ## periodSeconds: 5 - ## timeoutSeconds: 2 - ## successThreshold: 1 - ## failureThreshold: 5 - livenessProbe: - httpGet: - # should match container.healthCheckPath - path: "/healthz" - port: 10254 - scheme: HTTP - initialDelaySeconds: 10 - periodSeconds: 10 - timeoutSeconds: 1 - successThreshold: 1 - failureThreshold: 5 - readinessProbe: - httpGet: - # should match container.healthCheckPath - path: "/healthz" - port: 10254 - scheme: HTTP - initialDelaySeconds: 10 - periodSeconds: 10 - timeoutSeconds: 1 - successThreshold: 1 - failureThreshold: 3 - # -- Path of the health check endpoint. All requests received on the port defined by - # the healthz-port parameter are forwarded internally to this path. - healthCheckPath: "/healthz" - # -- Address to bind the health check endpoint. - # It is better to set this option to the internal node address - # if the Ingress-Nginx Controller is running in the `hostNetwork: true` mode. - healthCheckHost: "" - # -- Annotations to be added to controller pods - ## - podAnnotations: {} - replicaCount: 1 - # -- Minimum available pods set in PodDisruptionBudget. - # Define either 'minAvailable' or 'maxUnavailable', never both. - minAvailable: 1 - # -- Maximum unavailable pods set in PodDisruptionBudget. If set, 'minAvailable' is ignored. - # maxUnavailable: 1 - - ## Define requests resources to avoid probe issues due to CPU utilization in busy nodes - ## ref: https://github.com/kubernetes/ingress-nginx/issues/4735#issuecomment-551204903 - ## Ideally, there should be no limits. - ## https://engineering.indeedblog.com/blog/2019/12/cpu-throttling-regression-fix/ - resources: - ## limits: - ## cpu: 100m - ## memory: 90Mi - requests: - cpu: 100m - memory: 90Mi - # Mutually exclusive with keda autoscaling - autoscaling: - enabled: false - annotations: {} - minReplicas: 1 - maxReplicas: 11 - targetCPUUtilizationPercentage: 50 - targetMemoryUtilizationPercentage: 50 - behavior: {} - # scaleDown: - # stabilizationWindowSeconds: 300 - # policies: - # - type: Pods - # value: 1 - # periodSeconds: 180 - # scaleUp: - # stabilizationWindowSeconds: 300 - # policies: - # - type: Pods - # value: 2 - # periodSeconds: 60 - autoscalingTemplate: [] - # Custom or additional autoscaling metrics - # ref: https://kubernetes.io/docs/tasks/run-application/horizontal-pod-autoscale/#support-for-custom-metrics - # - type: Pods - # pods: - # metric: - # name: nginx_ingress_controller_nginx_process_requests_total - # target: - # type: AverageValue - # averageValue: 10000m - - # Mutually exclusive with hpa autoscaling - keda: - apiVersion: "keda.sh/v1alpha1" - ## apiVersion changes with keda 1.x vs 2.x - ## 2.x = keda.sh/v1alpha1 - ## 1.x = keda.k8s.io/v1alpha1 - enabled: false - minReplicas: 1 - maxReplicas: 11 - pollingInterval: 30 - cooldownPeriod: 300 - # fallback: - # failureThreshold: 3 - # replicas: 11 - restoreToOriginalReplicaCount: false - scaledObject: - annotations: {} - # Custom annotations for ScaledObject resource - # annotations: - # key: value - triggers: [] - # - type: prometheus - # metadata: - # serverAddress: http://:9090 - # metricName: http_requests_total - # threshold: '100' - # query: sum(rate(http_requests_total{deployment="my-deployment"}[2m])) - - behavior: {} - # scaleDown: - # stabilizationWindowSeconds: 300 - # policies: - # - type: Pods - # value: 1 - # periodSeconds: 180 - # scaleUp: - # stabilizationWindowSeconds: 300 - # policies: - # - type: Pods - # value: 2 - # periodSeconds: 60 - # -- Enable mimalloc as a drop-in replacement for malloc. - ## ref: https://github.com/microsoft/mimalloc - ## - enableMimalloc: true - ## Override NGINX template - customTemplate: - configMapName: "" - configMapKey: "" - service: - # -- Enable controller services or not. This does not influence the creation of either the admission webhook or the metrics service. - enabled: true - external: - # -- Enable the external controller service or not. Useful for internal-only deployments. - enabled: true - # -- Annotations to be added to the external controller service. See `controller.service.internal.annotations` for annotations to be added to the internal controller service. - annotations: {} - # -- Labels to be added to both controller services. - labels: {} - # -- Type of the external controller service. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types - type: LoadBalancer - # -- Pre-defined cluster internal IP address of the external controller service. Take care of collisions with existing services. - # This value is immutable. Set once, it can not be changed without deleting and re-creating the service. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#choosing-your-own-ip-address - clusterIP: "" - # -- List of node IP addresses at which the external controller service is available. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips - externalIPs: [] - # -- Deprecated: Pre-defined IP address of the external controller service. Used by cloud providers to connect the resulting load balancer service to a pre-existing static IP. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#loadbalancer - loadBalancerIP: "" - # -- Restrict access to the external controller service. Values must be CIDRs. Allows any source address by default. - loadBalancerSourceRanges: [] - # -- Load balancer class of the external controller service. Used by cloud providers to select a load balancer implementation other than the cloud provider default. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-class - loadBalancerClass: "" - # -- Enable node port allocation for the external controller service or not. Applies to type `LoadBalancer` only. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-nodeport-allocation - # allocateLoadBalancerNodePorts: true - - # -- External traffic policy of the external controller service. Set to "Local" to preserve source IP on providers supporting it. - # Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip - externalTrafficPolicy: "" - # -- Session affinity of the external controller service. Must be either "None" or "ClientIP" if set. Defaults to "None". - # Ref: https://kubernetes.io/docs/reference/networking/virtual-ips/#session-affinity - sessionAffinity: "" - # -- Specifies the health check node port (numeric port number) for the external controller service. - # If not specified, the service controller allocates a port from your cluster's node port range. - # Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip - # healthCheckNodePort: 0 - - # -- Represents the dual-stack capabilities of the external controller service. Possible values are SingleStack, PreferDualStack or RequireDualStack. - # Fields `ipFamilies` and `clusterIP` depend on the value of this field. - # Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services - ipFamilyPolicy: SingleStack - # -- List of IP families (e.g. IPv4, IPv6) assigned to the external controller service. This field is usually assigned automatically based on cluster configuration and the `ipFamilyPolicy` field. - # Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services - ipFamilies: - - IPv4 - # -- Enable the HTTP listener on both controller services or not. - enableHttp: true - # -- Enable the HTTPS listener on both controller services or not. - enableHttps: true - ports: - # -- Port the external HTTP listener is published with. - http: 80 - # -- Port the external HTTPS listener is published with. - https: 443 - targetPorts: - # -- Port of the ingress controller the external HTTP listener is mapped to. - http: http - # -- Port of the ingress controller the external HTTPS listener is mapped to. - https: https - # -- Declare the app protocol of the external HTTP and HTTPS listeners or not. Supersedes provider-specific annotations for declaring the backend protocol. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#application-protocol - appProtocol: true - nodePorts: - # -- Node port allocated for the external HTTP listener. If left empty, the service controller allocates one from the configured node port range. - http: "" - # -- Node port allocated for the external HTTPS listener. If left empty, the service controller allocates one from the configured node port range. - https: "" - # -- Node port mapping for external TCP listeners. If left empty, the service controller allocates them from the configured node port range. - # Example: - # tcp: - # 8080: 30080 - tcp: {} - # -- Node port mapping for external UDP listeners. If left empty, the service controller allocates them from the configured node port range. - # Example: - # udp: - # 53: 30053 - udp: {} - internal: - # -- Enable the internal controller service or not. Remember to configure `controller.service.internal.annotations` when enabling this. - enabled: false - # -- Annotations to be added to the internal controller service. Mandatory for the internal controller service to be created. Varies with the cloud service. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#internal-load-balancer - annotations: {} - # -- Type of the internal controller service. - # Defaults to the value of `controller.service.type`. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types - type: "" - # -- Pre-defined cluster internal IP address of the internal controller service. Take care of collisions with existing services. - # This value is immutable. Set once, it can not be changed without deleting and re-creating the service. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#choosing-your-own-ip-address - clusterIP: "" - # -- List of node IP addresses at which the internal controller service is available. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips - externalIPs: [] - # -- Deprecated: Pre-defined IP address of the internal controller service. Used by cloud providers to connect the resulting load balancer service to a pre-existing static IP. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#loadbalancer - loadBalancerIP: "" - # -- Restrict access to the internal controller service. Values must be CIDRs. Allows any source address by default. - loadBalancerSourceRanges: [] - # -- Load balancer class of the internal controller service. Used by cloud providers to select a load balancer implementation other than the cloud provider default. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-class - loadBalancerClass: "" - # -- Enable node port allocation for the internal controller service or not. Applies to type `LoadBalancer` only. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-nodeport-allocation - # allocateLoadBalancerNodePorts: true - - # -- External traffic policy of the internal controller service. Set to "Local" to preserve source IP on providers supporting it. - # Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip - externalTrafficPolicy: "" - # -- Session affinity of the internal controller service. Must be either "None" or "ClientIP" if set. Defaults to "None". - # Ref: https://kubernetes.io/docs/reference/networking/virtual-ips/#session-affinity - sessionAffinity: "" - # -- Specifies the health check node port (numeric port number) for the internal controller service. - # If not specified, the service controller allocates a port from your cluster's node port range. - # Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip - # healthCheckNodePort: 0 - - # -- Represents the dual-stack capabilities of the internal controller service. Possible values are SingleStack, PreferDualStack or RequireDualStack. - # Fields `ipFamilies` and `clusterIP` depend on the value of this field. - # Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services - ipFamilyPolicy: SingleStack - # -- List of IP families (e.g. IPv4, IPv6) assigned to the internal controller service. This field is usually assigned automatically based on cluster configuration and the `ipFamilyPolicy` field. - # Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services - ipFamilies: - - IPv4 - ports: {} - # -- Port the internal HTTP listener is published with. - # Defaults to the value of `controller.service.ports.http`. - # http: 80 - # -- Port the internal HTTPS listener is published with. - # Defaults to the value of `controller.service.ports.https`. - # https: 443 - - targetPorts: {} - # -- Port of the ingress controller the internal HTTP listener is mapped to. - # Defaults to the value of `controller.service.targetPorts.http`. - # http: http - # -- Port of the ingress controller the internal HTTPS listener is mapped to. - # Defaults to the value of `controller.service.targetPorts.https`. - # https: https - - # -- Declare the app protocol of the internal HTTP and HTTPS listeners or not. Supersedes provider-specific annotations for declaring the backend protocol. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#application-protocol - appProtocol: true - nodePorts: - # -- Node port allocated for the internal HTTP listener. If left empty, the service controller allocates one from the configured node port range. - http: "" - # -- Node port allocated for the internal HTTPS listener. If left empty, the service controller allocates one from the configured node port range. - https: "" - # -- Node port mapping for internal TCP listeners. If left empty, the service controller allocates them from the configured node port range. - # Example: - # tcp: - # 8080: 30080 - tcp: {} - # -- Node port mapping for internal UDP listeners. If left empty, the service controller allocates them from the configured node port range. - # Example: - # udp: - # 53: 30053 - udp: {} - # shareProcessNamespace enables process namespace sharing within the pod. - # This can be used for example to signal log rotation using `kill -USR1` from a sidecar. - shareProcessNamespace: false - # -- Additional containers to be added to the controller pod. - # See https://github.com/lemonldap-ng-controller/lemonldap-ng-controller as example. - extraContainers: [] - # - name: my-sidecar - # image: nginx:latest - # - name: lemonldap-ng-controller - # image: lemonldapng/lemonldap-ng-controller:0.2.0 - # args: - # - /lemonldap-ng-controller - # - --alsologtostderr - # - --configmap=$(POD_NAMESPACE)/lemonldap-ng-configuration - # env: - # - name: POD_NAME - # valueFrom: - # fieldRef: - # fieldPath: metadata.name - # - name: POD_NAMESPACE - # valueFrom: - # fieldRef: - # fieldPath: metadata.namespace - # volumeMounts: - # - name: copy-portal-skins - # mountPath: /srv/var/lib/lemonldap-ng/portal/skins - - # -- Additional volumeMounts to the controller main container. - extraVolumeMounts: [] - # - name: copy-portal-skins - # mountPath: /var/lib/lemonldap-ng/portal/skins - - # -- Additional volumes to the controller pod. - extraVolumes: [] - # - name: copy-portal-skins - # emptyDir: {} - - # -- Containers, which are run before the app containers are started. - extraInitContainers: [] - # - name: init-myservice - # image: busybox - # command: ['sh', '-c', 'until nslookup myservice; do echo waiting for myservice; sleep 2; done;'] - - # -- Modules, which are mounted into the core nginx image. See values.yaml for a sample to add opentelemetry module - extraModules: [] - # - name: mytestmodule - # image: - # registry: registry.k8s.io - # image: ingress-nginx/mytestmodule - # ## for backwards compatibility consider setting the full image url via the repository value below - # ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail - # ## repository: - # tag: "v1.0.0" - # digest: "" - # distroless: false - # containerSecurityContext: - # runAsNonRoot: true - # runAsUser: - # allowPrivilegeEscalation: false - # seccompProfile: - # type: RuntimeDefault - # capabilities: - # drop: - # - ALL - # readOnlyRootFilesystem: true - # resources: {} - # - # The image must contain a `/usr/local/bin/init_module.sh` executable, which - # will be executed as initContainers, to move its config files within the - # mounted volume. - - opentelemetry: - enabled: false - name: opentelemetry - image: - registry: registry.k8s.io - image: ingress-nginx/opentelemetry-1.25.3 - ## for backwards compatibility consider setting the full image url via the repository value below - ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail - ## repository: - tag: v20240813-b933310d - digest: sha256:f7604ac0547ed64d79b98d92133234e66c2c8aade3c1f4809fed5eec1fb7f922 - distroless: true - containerSecurityContext: - runAsNonRoot: true - # -- The image's default user, inherited from its base image `cgr.dev/chainguard/static`. - runAsUser: 65532 - allowPrivilegeEscalation: false - seccompProfile: - type: RuntimeDefault - capabilities: - drop: - - ALL - readOnlyRootFilesystem: true - resources: {} - admissionWebhooks: - name: admission - annotations: {} - # ignore-check.kube-linter.io/no-read-only-rootfs: "This deployment needs write access to root filesystem". - - ## Additional annotations to the admission webhooks. - ## These annotations will be added to the ValidatingWebhookConfiguration and - ## the Jobs Spec of the admission webhooks. - enabled: true - # -- Additional environment variables to set - extraEnvs: [] - # extraEnvs: - # - name: FOO - # valueFrom: - # secretKeyRef: - # key: FOO - # name: secret-resource - # -- Admission Webhook failure policy to use - failurePolicy: Fail - # timeoutSeconds: 10 - port: 8443 - certificate: "/usr/local/certificates/cert" - key: "/usr/local/certificates/key" - namespaceSelector: {} - objectSelector: {} - # -- Labels to be added to admission webhooks - labels: {} - # -- Use an existing PSP instead of creating one - existingPsp: "" - service: - annotations: {} - # clusterIP: "" - externalIPs: [] - # loadBalancerIP: "" - loadBalancerSourceRanges: [] - servicePort: 443 - type: ClusterIP - createSecretJob: - name: create - # -- Security context for secret creation containers - securityContext: - runAsNonRoot: true - runAsUser: 65532 - allowPrivilegeEscalation: false - seccompProfile: - type: RuntimeDefault - capabilities: - drop: - - ALL - readOnlyRootFilesystem: true - resources: {} - # limits: - # cpu: 10m - # memory: 20Mi - # requests: - # cpu: 10m - # memory: 20Mi - patchWebhookJob: - name: patch - # -- Security context for webhook patch containers - securityContext: - runAsNonRoot: true - runAsUser: 65532 - allowPrivilegeEscalation: false - seccompProfile: - type: RuntimeDefault - capabilities: - drop: - - ALL - readOnlyRootFilesystem: true - resources: {} - patch: - enabled: true - image: - registry: registry.k8s.io - image: ingress-nginx/kube-webhook-certgen - ## for backwards compatibility consider setting the full image url via the repository value below - ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail - ## repository: - tag: v1.4.4 - digest: sha256:a9f03b34a3cbfbb26d103a14046ab2c5130a80c3d69d526ff8063d2b37b9fd3f - pullPolicy: IfNotPresent - # -- Provide a priority class name to the webhook patching job - ## - priorityClassName: "" - podAnnotations: {} - # NetworkPolicy for webhook patch - networkPolicy: - # -- Enable 'networkPolicy' or not - enabled: false - nodeSelector: - kubernetes.io/os: linux - tolerations: [] - # -- Labels to be added to patch job resources - labels: {} - # -- Security context for secret creation & webhook patch pods - securityContext: {} - # -- Admission webhook patch job RBAC - rbac: - # -- Create RBAC or not - create: true - # -- Admission webhook patch job service account - serviceAccount: - # -- Create a service account or not - create: true - # -- Custom service account name - name: "" - # -- Auto-mount service account token or not - automountServiceAccountToken: true - # Use certmanager to generate webhook certs - certManager: - enabled: false - # self-signed root certificate - rootCert: - # default to be 5y - duration: "" - admissionCert: - # default to be 1y - duration: "" - # issuerRef: - # name: "issuer" - # kind: "ClusterIssuer" - metrics: - port: 10254 - portName: metrics - # if this port is changed, change healthz-port: in extraArgs: accordingly - enabled: false - service: - annotations: {} - # prometheus.io/scrape: "true" - # prometheus.io/port: "10254" - # -- Labels to be added to the metrics service resource - labels: {} - # clusterIP: "" - - # -- List of IP addresses at which the stats-exporter service is available - ## Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips - ## - externalIPs: [] - # loadBalancerIP: "" - loadBalancerSourceRanges: [] - servicePort: 10254 - type: ClusterIP - # externalTrafficPolicy: "" - # nodePort: "" - serviceMonitor: - enabled: false - additionalLabels: {} - # -- Annotations to be added to the ServiceMonitor. - annotations: {} - ## The label to use to retrieve the job name from. - ## jobLabel: "app.kubernetes.io/name" - namespace: "" - namespaceSelector: {} - ## Default: scrape .Release.Namespace or namespaceOverride only - ## To scrape all, use the following: - ## namespaceSelector: - ## any: true - scrapeInterval: 30s - # honorLabels: true - targetLabels: [] - relabelings: [] - metricRelabelings: [] - prometheusRule: - enabled: false - additionalLabels: {} - # namespace: "" - rules: [] - # # These are just examples rules, please adapt them to your needs - # - alert: NGINXConfigFailed - # expr: count(nginx_ingress_controller_config_last_reload_successful == 0) > 0 - # for: 1s - # labels: - # severity: critical - # annotations: - # description: bad ingress config - nginx config test failed - # summary: uninstall the latest ingress changes to allow config reloads to resume - # # By default a fake self-signed certificate is generated as default and - # # it is fine if it expires. If `--default-ssl-certificate` flag is used - # # and a valid certificate passed please do not filter for `host` label! - # # (i.e. delete `{host!="_"}` so also the default SSL certificate is - # # checked for expiration) - # - alert: NGINXCertificateExpiry - # expr: (avg(nginx_ingress_controller_ssl_expire_time_seconds{host!="_"}) by (host) - time()) < 604800 - # for: 1s - # labels: - # severity: critical - # annotations: - # description: ssl certificate(s) will expire in less then a week - # summary: renew expiring certificates to avoid downtime - # - alert: NGINXTooMany500s - # expr: 100 * ( sum( nginx_ingress_controller_requests{status=~"5.+"} ) / sum(nginx_ingress_controller_requests) ) > 5 - # for: 1m - # labels: - # severity: warning - # annotations: - # description: Too many 5XXs - # summary: More than 5% of all requests returned 5XX, this requires your attention - # - alert: NGINXTooMany400s - # expr: 100 * ( sum( nginx_ingress_controller_requests{status=~"4.+"} ) / sum(nginx_ingress_controller_requests) ) > 5 - # for: 1m - # labels: - # severity: warning - # annotations: - # description: Too many 4XXs - # summary: More than 5% of all requests returned 4XX, this requires your attention - # -- Improve connection draining when ingress controller pod is deleted using a lifecycle hook: - # With this new hook, we increased the default terminationGracePeriodSeconds from 30 seconds - # to 300, allowing the draining of connections up to five minutes. - # If the active connections end before that, the pod will terminate gracefully at that time. - # To effectively take advantage of this feature, the Configmap feature - # worker-shutdown-timeout new value is 240s instead of 10s. - ## - lifecycle: - preStop: - exec: - command: - - /wait-shutdown - priorityClassName: "" -# -- Rollback limit -## -revisionHistoryLimit: 10 -## Default 404 backend -## -defaultBackend: - ## - enabled: false - name: defaultbackend - image: - registry: registry.k8s.io - image: defaultbackend-amd64 - ## for backwards compatibility consider setting the full image url via the repository value below - ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail - ## repository: - tag: "1.5" - pullPolicy: IfNotPresent - runAsNonRoot: true - # nobody user -> uid 65534 - runAsUser: 65534 - allowPrivilegeEscalation: false - seccompProfile: - type: RuntimeDefault - readOnlyRootFilesystem: true - # -- Use an existing PSP instead of creating one - existingPsp: "" - extraArgs: {} - serviceAccount: - create: true - name: "" - automountServiceAccountToken: true - # -- Additional environment variables to set for defaultBackend pods - extraEnvs: [] - port: 8080 - ## Readiness and liveness probes for default backend - ## Ref: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-probes/ - ## - livenessProbe: - failureThreshold: 3 - initialDelaySeconds: 30 - periodSeconds: 10 - successThreshold: 1 - timeoutSeconds: 5 - readinessProbe: - failureThreshold: 6 - initialDelaySeconds: 0 - periodSeconds: 5 - successThreshold: 1 - timeoutSeconds: 5 - # -- The update strategy to apply to the Deployment or DaemonSet - ## - updateStrategy: {} - # rollingUpdate: - # maxUnavailable: 1 - # type: RollingUpdate - - # -- `minReadySeconds` to avoid killing pods before we are ready - ## - minReadySeconds: 0 - # -- Node tolerations for server scheduling to nodes with taints - ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/ - ## - tolerations: [] - # - key: "key" - # operator: "Equal|Exists" - # value: "value" - # effect: "NoSchedule|PreferNoSchedule|NoExecute(1.6 only)" - - # -- Affinity and anti-affinity rules for server scheduling to nodes - ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#affinity-and-anti-affinity - affinity: {} - # # An example of preferred pod anti-affinity, weight is in the range 1-100 - # podAntiAffinity: - # preferredDuringSchedulingIgnoredDuringExecution: - # - weight: 100 - # podAffinityTerm: - # labelSelector: - # matchExpressions: - # - key: app.kubernetes.io/name - # operator: In - # values: - # - '{{ include "ingress-nginx.name" . }}' - # - key: app.kubernetes.io/instance - # operator: In - # values: - # - '{{ .Release.Name }}' - # - key: app.kubernetes.io/component - # operator: In - # values: - # - default-backend - # topologyKey: kubernetes.io/hostname - - # # An example of required pod anti-affinity - # podAntiAffinity: - # requiredDuringSchedulingIgnoredDuringExecution: - # - labelSelector: - # matchExpressions: - # - key: app.kubernetes.io/name - # operator: In - # values: - # - '{{ include "ingress-nginx.name" . }}' - # - key: app.kubernetes.io/instance - # operator: In - # values: - # - '{{ .Release.Name }}' - # - key: app.kubernetes.io/component - # operator: In - # values: - # - default-backend - # topologyKey: kubernetes.io/hostname - - # -- Topology spread constraints rely on node labels to identify the topology domain(s) that each Node is in. - # Ref.: https://kubernetes.io/docs/concepts/workloads/pods/pod-topology-spread-constraints/ - topologySpreadConstraints: [] - # - labelSelector: - # matchLabels: - # app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - # app.kubernetes.io/instance: '{{ .Release.Name }}' - # app.kubernetes.io/component: default-backend - # topologyKey: topology.kubernetes.io/zone - # maxSkew: 1 - # whenUnsatisfiable: ScheduleAnyway - # - labelSelector: - # matchLabels: - # app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - # app.kubernetes.io/instance: '{{ .Release.Name }}' - # app.kubernetes.io/component: default-backend - # topologyKey: kubernetes.io/hostname - # maxSkew: 1 - # whenUnsatisfiable: ScheduleAnyway - # -- Security context for default backend pods - podSecurityContext: {} - # -- Security context for default backend containers - containerSecurityContext: {} - # -- Labels to add to the pod container metadata - podLabels: {} - # key: value - - # -- Node labels for default backend pod assignment - ## Ref: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/ - ## - nodeSelector: - kubernetes.io/os: linux - # -- Annotations to be added to default backend pods - ## - podAnnotations: {} - replicaCount: 1 - # -- Minimum available pods set in PodDisruptionBudget. - minAvailable: 1 - resources: {} - # limits: - # cpu: 10m - # memory: 20Mi - # requests: - # cpu: 10m - # memory: 20Mi - - extraVolumeMounts: [] - ## Additional volumeMounts to the default backend container. - # - name: copy-portal-skins - # mountPath: /var/lib/lemonldap-ng/portal/skins - - extraVolumes: [] - ## Additional volumes to the default backend pod. - # - name: copy-portal-skins - # emptyDir: {} - - extraConfigMaps: [] - ## Additional configmaps to the default backend pod. - # - name: my-extra-configmap-1 - # labels: - # type: config-1 - # data: - # extra_file_1.html: | - # - # - name: my-extra-configmap-2 - # labels: - # type: config-2 - # data: - # extra_file_2.html: | - # - - autoscaling: - annotations: {} - enabled: false - minReplicas: 1 - maxReplicas: 2 - targetCPUUtilizationPercentage: 50 - targetMemoryUtilizationPercentage: 50 - # NetworkPolicy for default backend component. - networkPolicy: - # -- Enable 'networkPolicy' or not - enabled: false - service: - annotations: {} - # clusterIP: "" - - # -- List of IP addresses at which the default backend service is available - ## Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips - ## - externalIPs: [] - # loadBalancerIP: "" - loadBalancerSourceRanges: [] - servicePort: 80 - type: ClusterIP - priorityClassName: "" - # -- Labels to be added to the default backend resources - labels: {} -## Enable RBAC as per https://github.com/kubernetes/ingress-nginx/blob/main/docs/deploy/rbac.md and https://github.com/kubernetes/ingress-nginx/issues/266 -rbac: - create: true - scope: false -## If true, create & use Pod Security Policy resources -## https://kubernetes.io/docs/concepts/policy/pod-security-policy/ -podSecurityPolicy: - enabled: false -serviceAccount: - create: true - name: "" - automountServiceAccountToken: true - # -- Annotations for the controller service account - annotations: {} -# -- Optional array of imagePullSecrets containing private registry credentials -## Ref: https://kubernetes.io/docs/tasks/configure-pod-container/pull-image-private-registry/ -imagePullSecrets: [] -# - name: secretName - -# -- TCP service key-value pairs -## Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/exposing-tcp-udp-services.md -## -tcp: {} -# "8080": "default/example-tcp-svc:9000" - -# -- UDP service key-value pairs -## Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/exposing-tcp-udp-services.md -## -udp: {} -# "53": "kube-system/kube-dns:53" - -# -- Prefix for TCP and UDP ports names in ingress controller service -## Some cloud providers, like Yandex Cloud may have a requirements for a port name regex to support cloud load balancer integration -portNamePrefix: "" -# -- (string) A base64-encoded Diffie-Hellman parameter. -# This can be generated with: `openssl dhparam 4096 2> /dev/null | base64` -## Ref: https://github.com/kubernetes/ingress-nginx/tree/main/docs/examples/customization/ssl-dh-param -dhParam: "" From 3831db9d6a5d7ad24e689d8c4f38071387958586 Mon Sep 17 00:00:00 2001 From: shahargl Date: Mon, 21 Oct 2024 15:19:44 +0300 Subject: [PATCH 04/19] feat: wip --- charts/keep/Chart.yaml | 4 +- charts/keep/templates/_helpers.tpl | 36 ++++++- charts/keep/templates/backend-ingress.yaml | 61 ----------- charts/keep/templates/nginx-ingress.yaml | 101 ++++++++++--------- charts/keep/templates/websocket-ingress.yaml | 64 ------------ charts/keep/values.yaml | 42 +++----- 6 files changed, 103 insertions(+), 205 deletions(-) delete mode 100644 charts/keep/templates/backend-ingress.yaml delete mode 100644 charts/keep/templates/websocket-ingress.yaml diff --git a/charts/keep/Chart.yaml b/charts/keep/Chart.yaml index 48c6552..f5ff706 100644 --- a/charts/keep/Chart.yaml +++ b/charts/keep/Chart.yaml @@ -15,8 +15,10 @@ keywords: dependencies: - name: ingress-nginx repository: https://kubernetes.github.io/ingress-nginx - version: 4.11.3 + version: ~4.11.3 condition: ingress-nginx.enabled + tags: + - ingress home: https://platform.keephq.dev/ sources: - https://github.com/keephq/helm-charts diff --git a/charts/keep/templates/_helpers.tpl b/charts/keep/templates/_helpers.tpl index 8e9af09..d7c2687 100644 --- a/charts/keep/templates/_helpers.tpl +++ b/charts/keep/templates/_helpers.tpl @@ -80,21 +80,21 @@ Helper function to find an environment variable in the list Helper function for websocket host (relative) */}} {{- define "keep.websocketPrefix" -}} -{{- coalesce .Values.websocket.ingress.prefix .Values.global.ingress.websocketPrefix "/websocket" -}} +{{- coalesce .Values.global.ingress.websocketPrefix "/websocket" -}} {{- end -}} {{/* Helper function for backend host (relative) */}} {{- define "keep.backendPrefix" -}} -{{- coalesce .Values.backend.ingress.prefix .Values.global.ingress.backendPrefix "/api" -}} +{{- coalesce .Values.global.ingress.backendPrefix "/api" -}} {{- end -}} {{/* Helper function for frontend host (relative) */}} {{- define "keep.frontendPrefix" -}} -{{- coalesce .Values.frontend.ingress.prefix .Values.global.ingress.frontendPrefix "/" -}} +{{- coalesce .Values.global.ingress.frontendPrefix "/" -}} {{- end -}} {{/* @@ -119,4 +119,34 @@ Helper function for API_URL for the frontend {{- else -}} {{- include "keep.backendPrefix" . -}} {{- end -}} +{{- end -}} + + +{{/* +Determine if ingress-nginx should be installed +*/}} +{{- define "keep.shouldInstallIngressNginx" -}} +{{- if .Release.IsInstall -}} + {{- if .Values.preInstallJob.enabled -}} + {{- $jobName := printf "%s-nginx-ingress-check" .Release.Name -}} + {{- $job := (lookup "batch/v1" "Job" .Release.Namespace $jobName) -}} + {{- if $job -}} + {{- if $job.status -}} + {{- if eq (int $job.status.succeeded) 0 -}} + {{- printf "false" -}} + {{- else -}} + {{- printf "true" -}} + {{- end -}} + {{- else -}} + {{- printf "true" -}} + {{- end -}} + {{- else -}} + {{- printf "true" -}} + {{- end -}} + {{- else -}} + {{- printf "true" -}} + {{- end -}} +{{- else -}} + {{- printf "false" -}} +{{- end -}} {{- end -}} \ No newline at end of file diff --git a/charts/keep/templates/backend-ingress.yaml b/charts/keep/templates/backend-ingress.yaml deleted file mode 100644 index 9f6d08d..0000000 --- a/charts/keep/templates/backend-ingress.yaml +++ /dev/null @@ -1,61 +0,0 @@ -{{- if and .Values.backend.enabled .Values.backend.ingress.enabled -}} -{{- $fullName := include "keep.fullname" . -}} -{{- $svcPort := .Values.backend.service.port -}} -{{- if and .Values.backend.ingress.className (not (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion)) }} - {{- if not (hasKey .Values.backend.ingress.annotations "kubernetes.io/ingress.class") }} - {{- $_ := set .Values.backend.ingress.annotations "kubernetes.io/ingress.class" .Values.backend.ingress.className}} - {{- end }} -{{- end }} -{{- if semverCompare ">=1.19-0" .Capabilities.KubeVersion.GitVersion -}} -apiVersion: networking.k8s.io/v1 -{{- else if semverCompare ">=1.14-0" .Capabilities.KubeVersion.GitVersion -}} -apiVersion: networking.k8s.io/v1beta1 -{{- else -}} -apiVersion: extensions/v1beta1 -{{- end }} -kind: Ingress -metadata: - name: {{ $fullName }}-backend - labels: - {{- include "keep.labels" . | nindent 4 }} - {{- with .Values.backend.ingress.annotations }} - annotations: - {{- toYaml . | nindent 4 }} - {{- end }} -spec: - {{- if and .Values.backend.ingress.className (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion) }} - ingressClassName: {{ .Values.backend.ingress.className }} - {{- end }} - {{- if .Values.backend.ingress.tls }} - tls: - {{- range .Values.backend.ingress.tls }} - - hosts: - {{- range .hosts }} - - {{ . | quote }} - {{- end }} - secretName: {{ .secretName }} - {{- end }} - {{- end }} - rules: - {{- range .Values.backend.ingress.hosts }} - - host: {{ .host | quote }} - http: - paths: - {{- range .paths }} - - path: {{ .path }} - {{- if and .pathType (semverCompare ">=1.18-0" $.Capabilities.KubeVersion.GitVersion) }} - pathType: {{ .pathType }} - {{- end }} - backend: - {{- if semverCompare ">=1.19-0" $.Capabilities.KubeVersion.GitVersion }} - service: - name: {{ $fullName }}-backend - port: - number: {{ $svcPort }} - {{- else }} - serviceName: {{ $fullName }}-backend - servicePort: {{ $svcPort }} - {{- end }} - {{- end }} - {{- end }} -{{- end }} diff --git a/charts/keep/templates/nginx-ingress.yaml b/charts/keep/templates/nginx-ingress.yaml index cbf7262..b6d2fc7 100644 --- a/charts/keep/templates/nginx-ingress.yaml +++ b/charts/keep/templates/nginx-ingress.yaml @@ -1,9 +1,5 @@ -{{- if and (or .Values.frontend.enabled .Values.backend.enabled) .Values.frontend.ingress.enabled }} +{{- if .Values.global.ingress.enabled }} {{- $fullName := include "keep.fullname" . }} -{{- $frontendPort := .Values.frontend.service.port }} -{{- $backendPort := .Values.backend.service.port }} -{{- $websocketPort := .Values.websocket.service.port }} - apiVersion: networking.k8s.io/v1 kind: Ingress metadata: @@ -19,23 +15,36 @@ metadata: nginx.ingress.kubernetes.io/proxy-http-version: "1.1" nginx.ingress.kubernetes.io/use-http2: "false" nginx.ingress.kubernetes.io/backend-protocol: "HTTP" - nginx.ingress.kubernetes.io/server-snippets: | - location {{ include "keep.websocketPrefix" . }}/ { - proxy_pass http://{{ $fullName }}-websocket:{{ .Values.websocket.service.port }}; + nginx.ingress.kubernetes.io/configuration-snippet: | + if ($request_uri ~* ^({{ .Values.global.ingress.websocketPrefix }}|{{ .Values.global.ingress.backendPrefix }}|{{ .Values.global.ingress.frontendPrefix }})(/|$)(.*)) { + rewrite ^({{ .Values.global.ingress.websocketPrefix }}|{{ .Values.global.ingress.backendPrefix }}|{{ .Values.global.ingress.frontendPrefix }})(/|$)(.*) /$3 break; + } + nginx.ingress.kubernetes.io/server-snippet: | + {{- if $.Values.websocket.enabled }} + location ^~ {{ .Values.global.ingress.websocketPrefix }} { + rewrite ^{{ .Values.global.ingress.websocketPrefix }}(/|$)(.*) /$2 break; + proxy_pass http://{{ $fullName }}-websocket:{{ $.Values.websocket.service.port }}; + proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; - proxy_set_header Connection "Upgrade"; - proxy_set_header X-Forwarded-For $remote_addr; + proxy_set_header Connection "upgrade"; proxy_set_header Host $host; + proxy_set_header X-Real-IP $remote_addr; + proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; + proxy_set_header X-Forwarded-Proto $scheme; + proxy_set_header X-Forwarded-Host $http_host; proxy_cache_bypass $http_upgrade; } - {{- with .Values.frontend.ingress.annotations }} + {{- end }} + nginx.ingress.kubernetes.io/rewrite-target: /$1 + nginx.ingress.kubernetes.io/use-regex: "true" + {{- with .Values.global.ingress.annotations }} {{- toYaml . | nindent 4 }} {{- end }} spec: - ingressClassName: nginx - {{- if .Values.frontend.ingress.tls }} + ingressClassName: {{ .Values.global.ingress.className }} + {{- if .Values.global.ingress.tls }} tls: - {{- range .Values.frontend.ingress.tls }} + {{- range .Values.global.ingress.tls }} - hosts: {{- range .hosts }} - {{ . | quote }} @@ -44,64 +53,64 @@ spec: {{- end }} {{- end }} rules: - {{- if or .Values.frontend.ingress.hosts .Values.backend.ingress.hosts }} - {{- range $host := (concat .Values.frontend.ingress.hosts .Values.backend.ingress.hosts) }} - - host: {{ $host | quote }} + {{- if .Values.global.ingress.hosts }} + {{- range .Values.global.ingress.hosts }} + - host: {{ .host | quote }} http: paths: - {{- if and $.Values.websocket.enabled $websocketPort }} - - path: {{ include "keep.websocketPrefix" $ }} - pathType: Prefix + {{- if $.Values.websocket.enabled }} + - path: {{ $.Values.global.ingress.websocketPrefix }}(/|$)(.*) + pathType: ImplementationSpecific backend: service: name: {{ $fullName }}-websocket port: - number: {{ $websocketPort }} + number: {{ $.Values.websocket.service.port }} {{- end }} - - path: {{ include "keep.frontendPrefix" $ }} - pathType: Prefix + {{- if $.Values.backend.enabled }} + - path: {{ $.Values.global.ingress.backendPrefix }}(/|$)(.*) + pathType: ImplementationSpecific backend: service: - name: {{ $fullName }}-frontend + name: {{ $fullName }}-backend port: - number: {{ $frontendPort }} - {{- if and $.Values.backend $.Values.backend.enabled }} - - path: {{ include "keep.backendPrefix" $ }} - pathType: Prefix + number: {{ $.Values.backend.service.port }} + {{- end }} + - path: {{ $.Values.global.ingress.frontendPrefix }}(.*) + pathType: ImplementationSpecific backend: service: - name: {{ $fullName }}-backend + name: {{ $fullName }}-frontend port: - number: {{ $backendPort }} - {{- end }} + number: {{ $.Values.frontend.service.port }} {{- end }} {{- else }} - http: paths: - {{- if and $.Values.websocket.enabled $websocketPort }} - - path: {{ include "keep.websocketPrefix" . }} - pathType: Prefix + {{- if $.Values.websocket.enabled }} + - path: {{ $.Values.global.ingress.websocketPrefix }}(/|$)(.*) + pathType: ImplementationSpecific backend: service: name: {{ $fullName }}-websocket port: - number: {{ $websocketPort }} + number: {{ $.Values.websocket.service.port }} {{- end }} - - path: {{ include "keep.frontendPrefix" . }} - pathType: Prefix + {{- if $.Values.backend.enabled }} + - path: {{ $.Values.global.ingress.backendPrefix }}(/|$)(.*) + pathType: ImplementationSpecific backend: service: - name: {{ $fullName }}-frontend + name: {{ $fullName }}-backend port: - number: {{ $frontendPort }} - {{- if and $.Values.backend $.Values.backend.enabled }} - - path: {{ include "keep.backendPrefix" . }} - pathType: Prefix + number: {{ $.Values.backend.service.port }} + {{- end }} + - path: {{ $.Values.global.ingress.frontendPrefix }}(.*) + pathType: ImplementationSpecific backend: service: - name: {{ $fullName }}-backend + name: {{ $fullName }}-frontend port: - number: {{ $backendPort }} - {{- end }} + number: {{ $.Values.frontend.service.port }} {{- end }} -{{- end }} \ No newline at end of file +{{- end }} diff --git a/charts/keep/templates/websocket-ingress.yaml b/charts/keep/templates/websocket-ingress.yaml deleted file mode 100644 index acdba7c..0000000 --- a/charts/keep/templates/websocket-ingress.yaml +++ /dev/null @@ -1,64 +0,0 @@ -{{- if and .Values.websocket.enabled .Values.websocket.ingress.enabled -}} -{{- $fullName := include "keep.fullname" . -}} -{{- $svcPort := .Values.websocket.service.port -}} -{{- if and .Values.websocket.ingress.className (not (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion)) }} - {{- if not (hasKey .Values.websocket.ingress.annotations "kubernetes.io/ingress.class") }} - {{- $_ := set .Values.websocket.ingress.annotations "kubernetes.io/ingress.class" .Values.websocket.ingress.className }} - {{- end }} -{{- end }} -{{- if semverCompare ">=1.19-0" .Capabilities.KubeVersion.GitVersion -}} -apiVersion: networking.k8s.io/v1 -{{- else if semverCompare ">=1.14-0" .Capabilities.KubeVersion.GitVersion -}} -apiVersion: networking.k8s.io/v1beta1 -{{- else -}} -apiVersion: extensions/v1beta1 -{{- end }} -kind: Ingress -metadata: - name: {{ $fullName }}-websocket - labels: - {{- include "keep.labels" . | nindent 4 }} - {{- with .Values.websocket.ingress.annotations }} - annotations: - {{- toYaml . | nindent 4 }} - {{- end }} -spec: - {{- if and .Values.websocket.ingress.className (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion) }} - ingressClassName: {{ .Values.websocket.ingress.className }} - {{- end }} - {{- if .Values.websocket.ingress.tls }} - tls: - {{- range .Values.websocket.ingress.tls }} - - hosts: - {{- range .hosts }} - - {{ . | quote }} - {{- end }} - secretName: {{ .secretName }} - {{- end }} - {{- end }} - rules: - {{- range .Values.websocket.ingress.hosts }} - - host: {{ .host | quote }} - http: - paths: - {{- range .paths }} - - path: {{ .path }} - {{- if and .pathType (semverCompare ">=1.18-0" $.Capabilities.KubeVersion.GitVersion) }} - pathType: {{ .pathType }} - {{- end }} - backend: - {{- if semverCompare ">=1.19-0" $.Capabilities.KubeVersion.GitVersion }} - service: - name: {{ $fullName }}-websocket - port: - number: {{ $svcPort }} - {{- else }} - serviceName: {{ $fullName }}-websocket - servicePort: {{ $svcPort }} - {{- end }} - {{- end }} - {{- end }} - {{- if .Values.websocket.extraIngress -}} - {{ toYaml .Values.websocket.extraIngress | nindent 2 }} - {{- end }} -{{- end }} diff --git a/charts/keep/values.yaml b/charts/keep/values.yaml index 925a706..2ad4466 100644 --- a/charts/keep/values.yaml +++ b/charts/keep/values.yaml @@ -9,15 +9,20 @@ isGKE: false global: ingress: + enabled: true + className: "nginx" + annotations: {} websocketPrefix: "/websocket" - backendPrefix: "/api" + # can't use /api since its "catched" by the nextjs frontend e.g. /api/auth/signin or /api/config + backendPrefix: "/apinew" frontendPrefix: "/" + hosts: [] + tls: [] ingress-nginx: + # install the ingress-nginx controller dependency repo enabled: true controller: - nameOverride: keep-ingress-nginx - fullnameOverride: keep-ingress-nginx service: enabled: true type: LoadBalancer @@ -33,6 +38,7 @@ ingress-nginx: pullPolicy: IfNotPresent certManager: enabled: false + allowSnippetAnnotations: true backend: @@ -79,15 +85,7 @@ backend: service: type: ClusterIP port: 8080 - ingress: - enabled: true - className: "" - annotations: {} - hosts: - - paths: - - path: / - pathType: Prefix - tls: [] + # for openshit route: enabled: false host: chart-example-backend.local @@ -163,15 +161,7 @@ frontend: service: type: ClusterIP port: 3000 - ingress: - enabled: true - className: "nginx" - annotations: {} - hosts: - - paths: - - path: / - pathType: Prefix - tls: [] + # for openshit route: enabled: false host: chart-example.local @@ -262,15 +252,7 @@ websocket: httpGet: path: / port: http - ingress: - enabled: false - className: "nginx" - hosts: - paths: - - path: / - pathType: Prefix - tls: [] - annotations: {} + # for openshit route: enabled: false host: chart-example.local From 77ffc6a81a2e7fb27ae0cc58590318e9a7f6e69f Mon Sep 17 00:00:00 2001 From: shahargl Date: Mon, 21 Oct 2024 15:29:35 +0300 Subject: [PATCH 05/19] feat: wip --- charts/keep/Chart.lock | 4 ++-- charts/keep/values.yaml | 4 ++++ 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/charts/keep/Chart.lock b/charts/keep/Chart.lock index 7189fb1..e1dd07d 100644 --- a/charts/keep/Chart.lock +++ b/charts/keep/Chart.lock @@ -2,5 +2,5 @@ dependencies: - name: ingress-nginx repository: https://kubernetes.github.io/ingress-nginx version: 4.11.3 -digest: sha256:b8a1d7ce0c002bf7b1b31c5a55e5d9a05b4de11638998e871abb336954c3901b -generated: "2024-10-20T14:13:00.322813+03:00" +digest: sha256:c1ab16f763d3eced319e2219971b069907ff7ad0a013d51642f26fcb7cb03a56 +generated: "2024-10-21T15:29:13.494426+03:00" diff --git a/charts/keep/values.yaml b/charts/keep/values.yaml index 2ad4466..6625ba8 100644 --- a/charts/keep/values.yaml +++ b/charts/keep/values.yaml @@ -8,6 +8,8 @@ fullnameOverride: "" isGKE: false global: + # this section controls the ingress resource and not the ingress-nginx controller + # see the ingress-nginx section below for the controller configuration ingress: enabled: true className: "nginx" @@ -19,6 +21,8 @@ global: hosts: [] tls: [] +# this section controls the ingress-nginx **controller** +# and not the ingress resource itself ingress-nginx: # install the ingress-nginx controller dependency repo enabled: true From ff5a1653a4f626815fadd4cf9873941a076b814b Mon Sep 17 00:00:00 2001 From: shahargl Date: Mon, 21 Oct 2024 15:34:49 +0300 Subject: [PATCH 06/19] feat: wip --- charts/keep/Chart.yaml | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/charts/keep/Chart.yaml b/charts/keep/Chart.yaml index f5ff706..4ec00a4 100644 --- a/charts/keep/Chart.yaml +++ b/charts/keep/Chart.yaml @@ -14,7 +14,10 @@ keywords: - monitoring-tool dependencies: - name: ingress-nginx - repository: https://kubernetes.github.io/ingress-nginx + # original from helm repo + # repository: https://kubernetes.github.io/ingress-nginx + # using a local copy of the ingress-nginx chart for now + repository: "file://./charts/ingress-nginx" version: ~4.11.3 condition: ingress-nginx.enabled tags: From 8adc334d59ea4c277c76a62cf35fc71ea040559d Mon Sep 17 00:00:00 2001 From: shahargl Date: Mon, 21 Oct 2024 15:35:58 +0300 Subject: [PATCH 07/19] feat: wip --- charts/keep/Chart.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/charts/keep/Chart.yaml b/charts/keep/Chart.yaml index 4ec00a4..5eacf14 100644 --- a/charts/keep/Chart.yaml +++ b/charts/keep/Chart.yaml @@ -17,7 +17,7 @@ dependencies: # original from helm repo # repository: https://kubernetes.github.io/ingress-nginx # using a local copy of the ingress-nginx chart for now - repository: "file://./charts/ingress-nginx" + repository: "file://./charts/ingress-nginx-4.11.3.tgz" version: ~4.11.3 condition: ingress-nginx.enabled tags: From ef1835f0e7587360e0f15757ae37ad21d098def5 Mon Sep 17 00:00:00 2001 From: shahargl Date: Mon, 21 Oct 2024 15:50:36 +0300 Subject: [PATCH 08/19] feat: wip --- charts/keep/Chart.lock | 6 +- charts/keep/Chart.yaml | 2 +- charts/keep/charts/ingress-nginx-4.11.3.tgz | Bin 58282 -> 58282 bytes charts/keep/charts/ingress-nginx/.helmignore | 23 + charts/keep/charts/ingress-nginx/Chart.yaml | 25 + charts/keep/charts/ingress-nginx/OWNERS | 10 + charts/keep/charts/ingress-nginx/README.md | 559 ++++++++ .../charts/ingress-nginx/README.md.gotmpl | 229 ++++ .../changelog/helm-chart-2.10.0.md | 9 + .../changelog/helm-chart-2.11.0.md | 10 + .../changelog/helm-chart-2.11.1.md | 9 + .../changelog/helm-chart-2.11.2.md | 9 + .../changelog/helm-chart-2.11.3.md | 9 + .../changelog/helm-chart-2.12.0.md | 10 + .../changelog/helm-chart-2.12.1.md | 9 + .../changelog/helm-chart-2.13.0.md | 10 + .../changelog/helm-chart-2.14.0.md | 9 + .../changelog/helm-chart-2.15.0.md | 9 + .../changelog/helm-chart-2.16.0.md | 9 + .../changelog/helm-chart-2.9.0.md | 9 + .../changelog/helm-chart-2.9.1.md | 9 + .../changelog/helm-chart-3.0.0.md | 9 + .../changelog/helm-chart-3.10.0.md | 9 + .../changelog/helm-chart-3.10.1.md | 9 + .../changelog/helm-chart-3.11.0.md | 9 + .../changelog/helm-chart-3.11.1.md | 9 + .../changelog/helm-chart-3.12.0.md | 9 + .../changelog/helm-chart-3.13.0.md | 9 + .../changelog/helm-chart-3.14.0.md | 9 + .../changelog/helm-chart-3.15.0.md | 9 + .../changelog/helm-chart-3.15.1.md | 9 + .../changelog/helm-chart-3.16.0.md | 9 + .../changelog/helm-chart-3.16.1.md | 9 + .../changelog/helm-chart-3.17.0.md | 9 + .../changelog/helm-chart-3.18.0.md | 10 + .../changelog/helm-chart-3.19.0.md | 9 + .../changelog/helm-chart-3.20.0.md | 9 + .../changelog/helm-chart-3.20.1.md | 10 + .../changelog/helm-chart-3.21.0.md | 12 + .../changelog/helm-chart-3.22.0.md | 10 + .../changelog/helm-chart-3.23.0.md | 9 + .../changelog/helm-chart-3.24.0.md | 9 + .../changelog/helm-chart-3.25.0.md | 9 + .../changelog/helm-chart-3.26.0.md | 9 + .../changelog/helm-chart-3.27.0.md | 9 + .../changelog/helm-chart-3.28.0.md | 9 + .../changelog/helm-chart-3.29.0.md | 9 + .../changelog/helm-chart-3.3.0.md | 12 + .../changelog/helm-chart-3.3.1.md | 12 + .../changelog/helm-chart-3.30.0.md | 9 + .../changelog/helm-chart-3.31.0.md | 9 + .../changelog/helm-chart-3.32.0.md | 9 + .../changelog/helm-chart-3.33.0.md | 9 + .../changelog/helm-chart-3.34.0.md | 9 + .../changelog/helm-chart-3.4.0.md | 9 + .../changelog/helm-chart-3.5.0.md | 9 + .../changelog/helm-chart-3.5.1.md | 9 + .../changelog/helm-chart-3.6.0.md | 9 + .../changelog/helm-chart-3.7.0.md | 9 + .../changelog/helm-chart-3.7.1.md | 9 + .../changelog/helm-chart-3.8.0.md | 13 + .../changelog/helm-chart-3.9.0.md | 9 + .../changelog/helm-chart-4.0.1.md | 9 + .../changelog/helm-chart-4.0.10.md | 9 + .../changelog/helm-chart-4.0.11.md | 9 + .../changelog/helm-chart-4.0.12.md | 9 + .../changelog/helm-chart-4.0.13.md | 9 + .../changelog/helm-chart-4.0.14.md | 9 + .../changelog/helm-chart-4.0.15.md | 43 + .../changelog/helm-chart-4.0.18.md | 40 + .../changelog/helm-chart-4.0.2.md | 9 + .../changelog/helm-chart-4.0.3.md | 9 + .../changelog/helm-chart-4.0.5.md | 9 + .../changelog/helm-chart-4.0.6.md | 12 + .../changelog/helm-chart-4.0.7.md | 10 + .../changelog/helm-chart-4.0.9.md | 9 + .../changelog/helm-chart-4.1.0.md | 21 + .../changelog/helm-chart-4.1.2.md | 11 + .../changelog/helm-chart-4.10.0.md | 9 + .../changelog/helm-chart-4.10.1.md | 11 + .../changelog/helm-chart-4.10.2.md | 18 + .../changelog/helm-chart-4.11.0.md | 18 + .../changelog/helm-chart-4.11.1.md | 9 + .../changelog/helm-chart-4.11.2.md | 9 + .../changelog/helm-chart-4.11.3.md | 9 + .../changelog/helm-chart-4.2.0.md | 47 + .../changelog/helm-chart-4.2.1.md | 10 + .../changelog/helm-chart-4.3.0.md | 14 + .../changelog/helm-chart-4.4.0.md | 12 + .../changelog/helm-chart-4.5.2.md | 13 + .../changelog/helm-chart-4.6.0.md | 24 + .../changelog/helm-chart-4.6.1.md | 11 + .../changelog/helm-chart-4.7.0.md | 14 + .../changelog/helm-chart-4.7.1.md | 12 + .../changelog/helm-chart-4.7.2.md | 9 + .../changelog/helm-chart-4.8.0-beta.0.md | 13 + .../changelog/helm-chart-4.8.0.md | 13 + .../changelog/helm-chart-4.8.1.md | 9 + .../changelog/helm-chart-4.8.2.md | 10 + .../changelog/helm-chart-4.8.3.md | 9 + .../changelog/helm-chart-4.9.0.md | 13 + .../changelog/helm-chart-4.9.1.md | 10 + .../changelog/helm-chart.md.gotmpl | 11 + ...dmission-webhooks-cert-manager-values.yaml | 12 + ...ontroller-configmap-addheaders-values.yaml | 11 + ...troller-configmap-proxyheaders-values.yaml | 11 + .../ci/controller-configmap-values.yaml | 11 + ...roller-daemonset-extra-modules-values.yaml | 30 + .../controller-daemonset-metrics-values.yaml | 13 + ...roller-daemonset-opentelemetry-values.yaml | 13 + ...oller-daemonset-podannotations-values.yaml | 16 + .../ci/controller-daemonset-values.yaml | 10 + ...oller-deployment-extra-modules-values.yaml | 30 + .../controller-deployment-metrics-values.yaml | 13 + ...oller-deployment-opentelemetry-values.yaml | 13 + ...ller-deployment-podannotations-values.yaml | 16 + .../ci/controller-deployment-values.yaml | 10 + .../ci/controller-hpa-values.yaml | 18 + .../ci/controller-ingressclass-values.yaml | 15 + .../controller-service-internal-values.yaml | 13 + .../ci/controller-service-values.yaml | 22 + .../ci/deamonset-psp-values.yaml | 13 + .../ci/deamonset-webhook-and-psp-values.yaml | 13 + .../ci/deployment-psp-values.yaml | 10 + .../ci/deployment-webhook-and-psp-values.yaml | 12 + .../charts/ingress-nginx/templates/NOTES.txt | 73 + .../ingress-nginx/templates/_helpers.tpl | 272 ++++ .../ingress-nginx/templates/_params.tpl | 77 ++ .../admission-webhooks/cert-manager.yaml | 63 + .../job-patch/clusterrole.yaml | 33 + .../job-patch/clusterrolebinding.yaml | 23 + .../job-patch/job-createSecret.yaml | 79 ++ .../job-patch/job-patchWebhook.yaml | 81 ++ .../job-patch/networkpolicy.yaml | 26 + .../admission-webhooks/job-patch/psp.yaml | 52 + .../admission-webhooks/job-patch/role.yaml | 24 + .../job-patch/rolebinding.yaml | 24 + .../job-patch/serviceaccount.yaml | 17 + .../validating-webhook.yaml | 54 + .../ingress-nginx/templates/clusterrole.yaml | 102 ++ .../templates/clusterrolebinding.yaml | 19 + .../controller-configmap-addheaders.yaml | 14 + .../controller-configmap-proxyheaders.yaml | 14 + .../templates/controller-configmap-tcp.yaml | 17 + .../templates/controller-configmap-udp.yaml | 17 + .../templates/controller-configmap.yaml | 28 + .../templates/controller-daemonset.yaml | 242 ++++ .../templates/controller-deployment.yaml | 245 ++++ .../templates/controller-hpa.yaml | 47 + .../controller-ingressclass-aliases.yaml | 23 + .../templates/controller-ingressclass.yaml | 26 + .../templates/controller-keda.yaml | 46 + .../templates/controller-networkpolicy.yaml | 45 + .../controller-poddisruptionbudget.yaml | 36 + .../templates/controller-prometheusrule.yaml | 23 + .../templates/controller-psp.yaml | 100 ++ .../templates/controller-role.yaml | 104 ++ .../templates/controller-rolebinding.yaml | 21 + .../templates/controller-secret.yaml | 15 + .../controller-service-internal.yaml | 105 ++ .../templates/controller-service-metrics.yaml | 45 + .../templates/controller-service-webhook.yaml | 40 + .../templates/controller-service.yaml | 105 ++ .../templates/controller-serviceaccount.yaml | 17 + .../templates/controller-servicemonitor.yaml | 53 + .../templates/default-backend-deployment.yaml | 119 ++ .../default-backend-extra-configmaps.yaml | 23 + .../templates/default-backend-hpa.yaml | 40 + .../default-backend-networkpolicy.yaml | 25 + .../default-backend-poddisruptionbudget.yaml | 25 + .../templates/default-backend-psp.yaml | 50 + .../templates/default-backend-role.yaml | 22 + .../default-backend-rolebinding.yaml | 21 + .../templates/default-backend-service.yaml | 41 + .../default-backend-serviceaccount.yaml | 14 + .../job-patch/clusterrole_test.yaml | 11 + .../job-patch/clusterrolebinding_test.yaml | 11 + .../job-patch/role_test.yaml | 11 + .../job-patch/rolebinding_test.yaml | 11 + .../job-patch/serviceaccount_test.yaml | 47 + .../validating-webhook_test.yaml | 32 + .../controller-configmap-addheaders_test.yaml | 27 + ...ontroller-configmap-proxyheaders_test.yaml | 27 + .../tests/controller-configmap_test.yaml | 31 + .../tests/controller-daemonset_test.yaml | 172 +++ .../tests/controller-deployment_test.yaml | 191 +++ .../tests/controller-hpa_test.yaml | 31 + .../controller-ingressclass-aliases_test.yaml | 110 ++ .../tests/controller-ingressclass_test.yaml | 93 ++ .../tests/controller-keda_test.yaml | 31 + .../tests/controller-networkpolicy_test.yaml | 23 + .../controller-poddisruptionbudget_test.yaml | 89 ++ .../tests/controller-prometheusrule_test.yaml | 17 + .../controller-service-internal_test.yaml | 25 + .../controller-service-metrics_test.yaml | 23 + .../controller-service-webhook_test.yaml | 32 + .../tests/controller-service_test.yaml | 32 + .../tests/controller-servicemonitor_test.yaml | 29 + .../default-backend-deployment_test.yaml | 169 +++ ...default-backend-extra-configmaps_test.yaml | 50 + ...ault-backend-poddisruptionbudget_test.yaml | 48 + .../tests/default-backend-service_test.yaml | 32 + charts/keep/charts/ingress-nginx/values.yaml | 1192 +++++++++++++++++ 203 files changed, 7668 insertions(+), 4 deletions(-) create mode 100644 charts/keep/charts/ingress-nginx/.helmignore create mode 100644 charts/keep/charts/ingress-nginx/Chart.yaml create mode 100644 charts/keep/charts/ingress-nginx/OWNERS create mode 100644 charts/keep/charts/ingress-nginx/README.md create mode 100644 charts/keep/charts/ingress-nginx/README.md.gotmpl create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.10.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.2.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.3.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.13.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.14.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.15.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.16.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.0.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.12.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.13.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.14.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.17.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.18.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.19.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.21.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.22.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.23.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.24.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.25.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.26.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.27.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.28.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.29.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.30.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.31.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.32.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.33.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.34.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.4.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.6.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.8.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.9.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.10.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.11.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.12.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.13.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.14.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.15.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.18.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.2.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.3.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.5.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.6.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.7.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.9.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.2.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.2.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.2.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.3.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.3.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.4.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.5.2.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.2.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0-beta.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.2.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.3.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.0.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.1.md create mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart.md.gotmpl create mode 100644 charts/keep/charts/ingress-nginx/ci/admission-webhooks-cert-manager-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-configmap-addheaders-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-configmap-proxyheaders-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-configmap-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-extra-modules-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-metrics-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-opentelemetry-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-podannotations-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-extra-modules-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-metrics-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-opentelemetry-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-podannotations-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-hpa-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-ingressclass-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-service-internal-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/controller-service-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/deamonset-psp-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/deamonset-webhook-and-psp-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/deployment-psp-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/ci/deployment-webhook-and-psp-values.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/NOTES.txt create mode 100644 charts/keep/charts/ingress-nginx/templates/_helpers.tpl create mode 100644 charts/keep/charts/ingress-nginx/templates/_params.tpl create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/cert-manager.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/networkpolicy.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/psp.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/clusterrole.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/clusterrolebinding.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap-addheaders.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap-proxyheaders.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap-tcp.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap-udp.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-daemonset.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-deployment.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-hpa.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-ingressclass-aliases.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-ingressclass.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-keda.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-networkpolicy.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-prometheusrule.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-psp.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-role.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-rolebinding.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-secret.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-service-internal.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-service-metrics.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-service-webhook.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-service.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/controller-servicemonitor.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-deployment.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-extra-configmaps.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-hpa.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-networkpolicy.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-poddisruptionbudget.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-psp.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-role.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-rolebinding.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-service.yaml create mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-serviceaccount.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrole_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrolebinding_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/role_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/rolebinding_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/serviceaccount_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/validating-webhook_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-configmap-addheaders_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-configmap-proxyheaders_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-configmap_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-daemonset_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-deployment_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-hpa_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-ingressclass-aliases_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-ingressclass_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-keda_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-networkpolicy_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-poddisruptionbudget_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-prometheusrule_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-service-internal_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-service-metrics_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-service-webhook_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-service_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/controller-servicemonitor_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/default-backend-deployment_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/default-backend-extra-configmaps_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/default-backend-poddisruptionbudget_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/tests/default-backend-service_test.yaml create mode 100644 charts/keep/charts/ingress-nginx/values.yaml diff --git a/charts/keep/Chart.lock b/charts/keep/Chart.lock index e1dd07d..b041c5e 100644 --- a/charts/keep/Chart.lock +++ b/charts/keep/Chart.lock @@ -1,6 +1,6 @@ dependencies: - name: ingress-nginx - repository: https://kubernetes.github.io/ingress-nginx + repository: file://./charts/ingress-nginx version: 4.11.3 -digest: sha256:c1ab16f763d3eced319e2219971b069907ff7ad0a013d51642f26fcb7cb03a56 -generated: "2024-10-21T15:29:13.494426+03:00" +digest: sha256:ff7ed0c079230e383ec15a0250323236ecaaf321816ccbb8af1fc6b230a161ee +generated: "2024-10-21T15:50:15.923046+03:00" diff --git a/charts/keep/Chart.yaml b/charts/keep/Chart.yaml index 5eacf14..4ec00a4 100644 --- a/charts/keep/Chart.yaml +++ b/charts/keep/Chart.yaml @@ -17,7 +17,7 @@ dependencies: # original from helm repo # repository: https://kubernetes.github.io/ingress-nginx # using a local copy of the ingress-nginx chart for now - repository: "file://./charts/ingress-nginx-4.11.3.tgz" + repository: "file://./charts/ingress-nginx" version: ~4.11.3 condition: ingress-nginx.enabled tags: diff --git a/charts/keep/charts/ingress-nginx-4.11.3.tgz b/charts/keep/charts/ingress-nginx-4.11.3.tgz index 577573363137944b4216cb8243b93a8b40b2e856..444186e75b46d0addc23b8531224f4df7a4e6cbc 100644 GIT binary patch delta 43654 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 SKr}Qo5UlR096+=1.21.0-0' +maintainers: +- name: cpanato +- name: Gacko +- name: puerco +- name: rikatz +- name: strongjz +- name: tao12345666333 +name: ingress-nginx +sources: +- https://github.com/kubernetes/ingress-nginx +version: 4.11.3 diff --git a/charts/keep/charts/ingress-nginx/OWNERS b/charts/keep/charts/ingress-nginx/OWNERS new file mode 100644 index 0000000..d588ede --- /dev/null +++ b/charts/keep/charts/ingress-nginx/OWNERS @@ -0,0 +1,10 @@ +# See the OWNERS docs: https://www.kubernetes.dev/docs/guide/owners + +approvers: +- ingress-nginx-helm-maintainers + +reviewers: +- ingress-nginx-helm-reviewers + +labels: +- area/helm diff --git a/charts/keep/charts/ingress-nginx/README.md b/charts/keep/charts/ingress-nginx/README.md new file mode 100644 index 0000000..f70bd0a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/README.md @@ -0,0 +1,559 @@ +# ingress-nginx + +[ingress-nginx](https://github.com/kubernetes/ingress-nginx) Ingress controller for Kubernetes using NGINX as a reverse proxy and load balancer + +![Version: 4.11.3](https://img.shields.io/badge/Version-4.11.3-informational?style=flat-square) ![AppVersion: 1.11.3](https://img.shields.io/badge/AppVersion-1.11.3-informational?style=flat-square) + +To use, add `ingressClassName: nginx` spec field or the `kubernetes.io/ingress.class: nginx` annotation to your Ingress resources. + +This chart bootstraps an ingress-nginx deployment on a [Kubernetes](http://kubernetes.io) cluster using the [Helm](https://helm.sh) package manager. + +## Requirements + +Kubernetes: `>=1.21.0-0` + +## Get Repo Info + +```console +helm repo add ingress-nginx https://kubernetes.github.io/ingress-nginx +helm repo update +``` + +## Install Chart + +**Important:** only helm3 is supported + +```console +helm install [RELEASE_NAME] ingress-nginx/ingress-nginx +``` + +The command deploys ingress-nginx on the Kubernetes cluster in the default configuration. + +_See [configuration](#configuration) below._ + +_See [helm install](https://helm.sh/docs/helm/helm_install/) for command documentation._ + +## Uninstall Chart + +```console +helm uninstall [RELEASE_NAME] +``` + +This removes all the Kubernetes components associated with the chart and deletes the release. + +_See [helm uninstall](https://helm.sh/docs/helm/helm_uninstall/) for command documentation._ + +## Upgrading Chart + +```console +helm upgrade [RELEASE_NAME] [CHART] --install +``` + +_See [helm upgrade](https://helm.sh/docs/helm/helm_upgrade/) for command documentation._ + +### Migrating from stable/nginx-ingress + +There are two main ways to migrate a release from `stable/nginx-ingress` to `ingress-nginx/ingress-nginx` chart: + +1. For Nginx Ingress controllers used for non-critical services, the easiest method is to [uninstall](#uninstall-chart) the old release and [install](#install-chart) the new one +1. For critical services in production that require zero-downtime, you will want to: + 1. [Install](#install-chart) a second Ingress controller + 1. Redirect your DNS traffic from the old controller to the new controller + 1. Log traffic from both controllers during this changeover + 1. [Uninstall](#uninstall-chart) the old controller once traffic has fully drained from it + +Note that there are some different and upgraded configurations between the two charts, described by Rimas Mocevicius from JFrog in the "Upgrading to ingress-nginx Helm chart" section of [Migrating from Helm chart nginx-ingress to ingress-nginx](https://rimusz.net/migrating-to-ingress-nginx). As the `ingress-nginx/ingress-nginx` chart continues to update, you will want to check current differences by running [helm configuration](#configuration) commands on both charts. + +## Configuration + +See [Customizing the Chart Before Installing](https://helm.sh/docs/intro/using_helm/#customizing-the-chart-before-installing). To see all configurable options with detailed comments, visit the chart's [values.yaml](./values.yaml), or run these configuration commands: + +```console +helm show values ingress-nginx/ingress-nginx +``` + +### PodDisruptionBudget + +Note that the PodDisruptionBudget resource will only be defined if the replicaCount is greater than one, +else it would make it impossible to evacuate a node. See [gh issue #7127](https://github.com/helm/charts/issues/7127) for more info. + +### Prometheus Metrics + +The Ingress-Nginx Controller can export Prometheus metrics, by setting `controller.metrics.enabled` to `true`. + +You can add Prometheus annotations to the metrics service using `controller.metrics.service.annotations`. +Alternatively, if you use the Prometheus Operator, you can enable ServiceMonitor creation using `controller.metrics.serviceMonitor.enabled`. And set `controller.metrics.serviceMonitor.additionalLabels.release="prometheus"`. "release=prometheus" should match the label configured in the prometheus servicemonitor ( see `kubectl get servicemonitor prometheus-kube-prom-prometheus -oyaml -n prometheus`) + +### ingress-nginx nginx\_status page/stats server + +Previous versions of this chart had a `controller.stats.*` configuration block, which is now obsolete due to the following changes in Ingress-Nginx Controller: + +- In [0.16.1](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0161), the vts (virtual host traffic status) dashboard was removed +- In [0.23.0](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0230), the status page at port 18080 is now a unix socket webserver only available at localhost. + You can use `curl --unix-socket /tmp/nginx-status-server.sock http://localhost/nginx_status` inside the controller container to access it locally, or use the snippet from [nginx-ingress changelog](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0230) to re-enable the http server + +### ExternalDNS Service Configuration + +Add an [ExternalDNS](https://github.com/kubernetes-sigs/external-dns) annotation to the LoadBalancer service: + +```yaml +controller: + service: + annotations: + external-dns.alpha.kubernetes.io/hostname: kubernetes-example.com. +``` + +### AWS L7 ELB with SSL Termination + +Annotate the controller as shown in the [nginx-ingress l7 patch](https://github.com/kubernetes/ingress-nginx/blob/ab3a789caae65eec4ad6e3b46b19750b481b6bce/deploy/aws/l7/service-l7.yaml): + +```yaml +controller: + service: + targetPorts: + http: http + https: http + annotations: + service.beta.kubernetes.io/aws-load-balancer-ssl-cert: arn:aws:acm:XX-XXXX-X:XXXXXXXXX:certificate/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXX + service.beta.kubernetes.io/aws-load-balancer-backend-protocol: "http" + service.beta.kubernetes.io/aws-load-balancer-ssl-ports: "https" + service.beta.kubernetes.io/aws-load-balancer-connection-idle-timeout: '3600' +``` + +### Additional Internal Load Balancer + +This setup is useful when you need both external and internal load balancers but don't want to have multiple ingress controllers and multiple ingress objects per application. + +By default, the ingress object will point to the external load balancer address, but if correctly configured, you can make use of the internal one if the URL you are looking up resolves to the internal load balancer's URL. + +You'll need to set both the following values: + +`controller.service.internal.enabled` +`controller.service.internal.annotations` + +If one of them is missing the internal load balancer will not be deployed. Example you may have `controller.service.internal.enabled=true` but no annotations set, in this case no action will be taken. + +`controller.service.internal.annotations` varies with the cloud service you're using. + +Example for AWS: + +```yaml +controller: + service: + internal: + enabled: true + annotations: + # Create internal NLB + service.beta.kubernetes.io/aws-load-balancer-scheme: "internal" + # Create internal ELB(Deprecated) + # service.beta.kubernetes.io/aws-load-balancer-internal: "true" + # Any other annotation can be declared here. +``` + +Example for GCE: + +```yaml +controller: + service: + internal: + enabled: true + annotations: + # Create internal LB. More information: https://cloud.google.com/kubernetes-engine/docs/how-to/internal-load-balancing + # For GKE versions 1.17 and later + networking.gke.io/load-balancer-type: "Internal" + # For earlier versions + # cloud.google.com/load-balancer-type: "Internal" + + # Any other annotation can be declared here. +``` + +Example for Azure: + +```yaml +controller: + service: + annotations: + # Create internal LB + service.beta.kubernetes.io/azure-load-balancer-internal: "true" + # Any other annotation can be declared here. +``` + +Example for Oracle Cloud Infrastructure: + +```yaml +controller: + service: + annotations: + # Create internal LB + service.beta.kubernetes.io/oci-load-balancer-internal: "true" + # Any other annotation can be declared here. +``` + +The load balancer annotations of more cloud service providers can be found: [Internal load balancer](https://kubernetes.io/docs/concepts/services-networking/service/#internal-load-balancer). + +An use case for this scenario is having a split-view DNS setup where the public zone CNAME records point to the external balancer URL while the private zone CNAME records point to the internal balancer URL. This way, you only need one ingress kubernetes object. + +Optionally you can set `controller.service.loadBalancerIP` if you need a static IP for the resulting `LoadBalancer`. + +### Ingress Admission Webhooks + +With nginx-ingress-controller version 0.25+, the Ingress-Nginx Controller pod exposes an endpoint that will integrate with the `validatingwebhookconfiguration` Kubernetes feature to prevent bad ingress from being added to the cluster. +**This feature is enabled by default since 0.31.0.** + +With nginx-ingress-controller in 0.25.* work only with kubernetes 1.14+, 0.26 fix [this issue](https://github.com/kubernetes/ingress-nginx/pull/4521) + +#### How the Chart Configures the Hooks +A validating and configuration requires the endpoint to which the request is sent to use TLS. It is possible to set up custom certificates to do this, but in most cases, a self-signed certificate is enough. The setup of this component requires some more complex orchestration when using helm. The steps are created to be idempotent and to allow turning the feature on and off without running into helm quirks. + +1. A pre-install hook provisions a certificate into the same namespace using a format compatible with provisioning using end user certificates. If the certificate already exists, the hook exits. +2. The Ingress-Nginx Controller pod is configured to use a TLS proxy container, which will load that certificate. +3. Validating and Mutating webhook configurations are created in the cluster. +4. A post-install hook reads the CA from the secret created by step 1 and patches the Validating and Mutating webhook configurations. This process will allow a custom CA provisioned by some other process to also be patched into the webhook configurations. The chosen failure policy is also patched into the webhook configurations + +#### Alternatives +It should be possible to use [cert-manager/cert-manager](https://github.com/cert-manager/cert-manager) if a more complete solution is required. + +You can enable automatic self-signed TLS certificate provisioning via cert-manager by setting the `controller.admissionWebhooks.certManager.enabled` value to true. + +Please ensure that cert-manager is correctly installed and configured. + +### Helm Error When Upgrading: spec.clusterIP: Invalid value: "" + +If you are upgrading this chart from a version between 0.31.0 and 1.2.2 then you may get an error like this: + +```console +Error: UPGRADE FAILED: Service "?????-controller" is invalid: spec.clusterIP: Invalid value: "": field is immutable +``` + +Detail of how and why are in [this issue](https://github.com/helm/charts/pull/13646) but to resolve this you can set `xxxx.service.omitClusterIP` to `true` where `xxxx` is the service referenced in the error. + +As of version `1.26.0` of this chart, by simply not providing any clusterIP value, `invalid: spec.clusterIP: Invalid value: "": field is immutable` will no longer occur since `clusterIP: ""` will not be rendered. + +## Values + +| Key | Type | Default | Description | +|-----|------|---------|-------------| +| commonLabels | object | `{}` | | +| controller.addHeaders | object | `{}` | Will add custom headers before sending response traffic to the client according to: https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/#add-headers | +| controller.admissionWebhooks.annotations | object | `{}` | | +| controller.admissionWebhooks.certManager.admissionCert.duration | string | `""` | | +| controller.admissionWebhooks.certManager.enabled | bool | `false` | | +| controller.admissionWebhooks.certManager.rootCert.duration | string | `""` | | +| controller.admissionWebhooks.certificate | string | `"/usr/local/certificates/cert"` | | +| controller.admissionWebhooks.createSecretJob.name | string | `"create"` | | +| controller.admissionWebhooks.createSecretJob.resources | object | `{}` | | +| controller.admissionWebhooks.createSecretJob.securityContext | object | `{"allowPrivilegeEscalation":false,"capabilities":{"drop":["ALL"]},"readOnlyRootFilesystem":true,"runAsNonRoot":true,"runAsUser":65532,"seccompProfile":{"type":"RuntimeDefault"}}` | Security context for secret creation containers | +| controller.admissionWebhooks.enabled | bool | `true` | | +| controller.admissionWebhooks.existingPsp | string | `""` | Use an existing PSP instead of creating one | +| controller.admissionWebhooks.extraEnvs | list | `[]` | Additional environment variables to set | +| controller.admissionWebhooks.failurePolicy | string | `"Fail"` | Admission Webhook failure policy to use | +| controller.admissionWebhooks.key | string | `"/usr/local/certificates/key"` | | +| controller.admissionWebhooks.labels | object | `{}` | Labels to be added to admission webhooks | +| controller.admissionWebhooks.name | string | `"admission"` | | +| controller.admissionWebhooks.namespaceSelector | object | `{}` | | +| controller.admissionWebhooks.objectSelector | object | `{}` | | +| controller.admissionWebhooks.patch.enabled | bool | `true` | | +| controller.admissionWebhooks.patch.image.digest | string | `"sha256:a9f03b34a3cbfbb26d103a14046ab2c5130a80c3d69d526ff8063d2b37b9fd3f"` | | +| controller.admissionWebhooks.patch.image.image | string | `"ingress-nginx/kube-webhook-certgen"` | | +| controller.admissionWebhooks.patch.image.pullPolicy | string | `"IfNotPresent"` | | +| controller.admissionWebhooks.patch.image.registry | string | `"registry.k8s.io"` | | +| controller.admissionWebhooks.patch.image.tag | string | `"v1.4.4"` | | +| controller.admissionWebhooks.patch.labels | object | `{}` | Labels to be added to patch job resources | +| controller.admissionWebhooks.patch.networkPolicy.enabled | bool | `false` | Enable 'networkPolicy' or not | +| controller.admissionWebhooks.patch.nodeSelector."kubernetes.io/os" | string | `"linux"` | | +| controller.admissionWebhooks.patch.podAnnotations | object | `{}` | | +| controller.admissionWebhooks.patch.priorityClassName | string | `""` | Provide a priority class name to the webhook patching job # | +| controller.admissionWebhooks.patch.rbac | object | `{"create":true}` | Admission webhook patch job RBAC | +| controller.admissionWebhooks.patch.rbac.create | bool | `true` | Create RBAC or not | +| controller.admissionWebhooks.patch.securityContext | object | `{}` | Security context for secret creation & webhook patch pods | +| controller.admissionWebhooks.patch.serviceAccount | object | `{"automountServiceAccountToken":true,"create":true,"name":""}` | Admission webhook patch job service account | +| controller.admissionWebhooks.patch.serviceAccount.automountServiceAccountToken | bool | `true` | Auto-mount service account token or not | +| controller.admissionWebhooks.patch.serviceAccount.create | bool | `true` | Create a service account or not | +| controller.admissionWebhooks.patch.serviceAccount.name | string | `""` | Custom service account name | +| controller.admissionWebhooks.patch.tolerations | list | `[]` | | +| controller.admissionWebhooks.patchWebhookJob.name | string | `"patch"` | | +| controller.admissionWebhooks.patchWebhookJob.resources | object | `{}` | | +| controller.admissionWebhooks.patchWebhookJob.securityContext | object | `{"allowPrivilegeEscalation":false,"capabilities":{"drop":["ALL"]},"readOnlyRootFilesystem":true,"runAsNonRoot":true,"runAsUser":65532,"seccompProfile":{"type":"RuntimeDefault"}}` | Security context for webhook patch containers | +| controller.admissionWebhooks.port | int | `8443` | | +| controller.admissionWebhooks.service.annotations | object | `{}` | | +| controller.admissionWebhooks.service.externalIPs | list | `[]` | | +| controller.admissionWebhooks.service.loadBalancerSourceRanges | list | `[]` | | +| controller.admissionWebhooks.service.servicePort | int | `443` | | +| controller.admissionWebhooks.service.type | string | `"ClusterIP"` | | +| controller.affinity | object | `{}` | Affinity and anti-affinity rules for server scheduling to nodes # Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#affinity-and-anti-affinity # | +| controller.allowSnippetAnnotations | bool | `false` | This configuration defines if Ingress Controller should allow users to set their own *-snippet annotations, otherwise this is forbidden / dropped when users add those annotations. Global snippets in ConfigMap are still respected | +| controller.annotations | object | `{}` | Annotations to be added to the controller Deployment or DaemonSet # | +| controller.autoscaling.annotations | object | `{}` | | +| controller.autoscaling.behavior | object | `{}` | | +| controller.autoscaling.enabled | bool | `false` | | +| controller.autoscaling.maxReplicas | int | `11` | | +| controller.autoscaling.minReplicas | int | `1` | | +| controller.autoscaling.targetCPUUtilizationPercentage | int | `50` | | +| controller.autoscaling.targetMemoryUtilizationPercentage | int | `50` | | +| controller.autoscalingTemplate | list | `[]` | | +| controller.config | object | `{}` | Global configuration passed to the ConfigMap consumed by the controller. Values may contain Helm templates. Ref.: https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/ | +| controller.configAnnotations | object | `{}` | Annotations to be added to the controller config configuration configmap. | +| controller.configMapNamespace | string | `""` | Allows customization of the configmap / nginx-configmap namespace; defaults to $(POD_NAMESPACE) | +| controller.containerName | string | `"controller"` | Configures the controller container name | +| controller.containerPort | object | `{"http":80,"https":443}` | Configures the ports that the nginx-controller listens on | +| controller.containerSecurityContext | object | `{}` | Security context for controller containers | +| controller.customTemplate.configMapKey | string | `""` | | +| controller.customTemplate.configMapName | string | `""` | | +| controller.disableLeaderElection | bool | `false` | This configuration disable Nginx Controller Leader Election | +| controller.dnsConfig | object | `{}` | Optionally customize the pod dnsConfig. | +| controller.dnsPolicy | string | `"ClusterFirst"` | Optionally change this to ClusterFirstWithHostNet in case you have 'hostNetwork: true'. By default, while using host network, name resolution uses the host's DNS. If you wish nginx-controller to keep resolving names inside the k8s network, use ClusterFirstWithHostNet. | +| controller.electionID | string | `""` | Election ID to use for status update, by default it uses the controller name combined with a suffix of 'leader' | +| controller.electionTTL | string | `""` | Duration a leader election is valid before it's getting re-elected, e.g. `15s`, `10m` or `1h`. (Default: 30s) | +| controller.enableAnnotationValidations | bool | `false` | | +| controller.enableMimalloc | bool | `true` | Enable mimalloc as a drop-in replacement for malloc. # ref: https://github.com/microsoft/mimalloc # | +| controller.enableTopologyAwareRouting | bool | `false` | This configuration enables Topology Aware Routing feature, used together with service annotation service.kubernetes.io/topology-mode="auto" Defaults to false | +| controller.existingPsp | string | `""` | Use an existing PSP instead of creating one | +| controller.extraArgs | object | `{}` | Additional command line arguments to pass to Ingress-Nginx Controller E.g. to specify the default SSL certificate you can use | +| controller.extraContainers | list | `[]` | Additional containers to be added to the controller pod. See https://github.com/lemonldap-ng-controller/lemonldap-ng-controller as example. | +| controller.extraEnvs | list | `[]` | Additional environment variables to set | +| controller.extraInitContainers | list | `[]` | Containers, which are run before the app containers are started. | +| controller.extraModules | list | `[]` | Modules, which are mounted into the core nginx image. See values.yaml for a sample to add opentelemetry module | +| controller.extraVolumeMounts | list | `[]` | Additional volumeMounts to the controller main container. | +| controller.extraVolumes | list | `[]` | Additional volumes to the controller pod. | +| controller.healthCheckHost | string | `""` | Address to bind the health check endpoint. It is better to set this option to the internal node address if the Ingress-Nginx Controller is running in the `hostNetwork: true` mode. | +| controller.healthCheckPath | string | `"/healthz"` | Path of the health check endpoint. All requests received on the port defined by the healthz-port parameter are forwarded internally to this path. | +| controller.hostAliases | list | `[]` | Optionally customize the pod hostAliases. | +| controller.hostNetwork | bool | `false` | Required for use with CNI based kubernetes installations (such as ones set up by kubeadm), since CNI and hostport don't mix yet. Can be deprecated once https://github.com/kubernetes/kubernetes/issues/23920 is merged | +| controller.hostPort.enabled | bool | `false` | Enable 'hostPort' or not | +| controller.hostPort.ports.http | int | `80` | 'hostPort' http port | +| controller.hostPort.ports.https | int | `443` | 'hostPort' https port | +| controller.hostname | object | `{}` | Optionally customize the pod hostname. | +| controller.image.allowPrivilegeEscalation | bool | `false` | | +| controller.image.chroot | bool | `false` | | +| controller.image.digest | string | `"sha256:d56f135b6462cfc476447cfe564b83a45e8bb7da2774963b00d12161112270b7"` | | +| controller.image.digestChroot | string | `"sha256:22701f0fc0f2dd209ef782f4e281bfe2d8cccd50ededa00aec88e0cdbe7edd14"` | | +| controller.image.image | string | `"ingress-nginx/controller"` | | +| controller.image.pullPolicy | string | `"IfNotPresent"` | | +| controller.image.readOnlyRootFilesystem | bool | `false` | | +| controller.image.registry | string | `"registry.k8s.io"` | | +| controller.image.runAsNonRoot | bool | `true` | | +| controller.image.runAsUser | int | `101` | | +| controller.image.seccompProfile.type | string | `"RuntimeDefault"` | | +| controller.image.tag | string | `"v1.11.3"` | | +| controller.ingressClass | string | `"nginx"` | For backwards compatibility with ingress.class annotation, use ingressClass. Algorithm is as follows, first ingressClassName is considered, if not present, controller looks for ingress.class annotation | +| controller.ingressClassByName | bool | `false` | Process IngressClass per name (additionally as per spec.controller). | +| controller.ingressClassResource | object | `{"aliases":[],"annotations":{},"controllerValue":"k8s.io/ingress-nginx","default":false,"enabled":true,"name":"nginx","parameters":{}}` | This section refers to the creation of the IngressClass resource. IngressClasses are immutable and cannot be changed after creation. We do not support namespaced IngressClasses, yet, so a ClusterRole and a ClusterRoleBinding is required. | +| controller.ingressClassResource.aliases | list | `[]` | Aliases of this IngressClass. Creates copies with identical settings but the respective alias as name. Useful for development environments with only one Ingress Controller but production-like Ingress resources. `default` gets enabled on the original IngressClass only. | +| controller.ingressClassResource.annotations | object | `{}` | Annotations to be added to the IngressClass resource. | +| controller.ingressClassResource.controllerValue | string | `"k8s.io/ingress-nginx"` | Controller of the IngressClass. An Ingress Controller looks for IngressClasses it should reconcile by this value. This value is also being set as the `--controller-class` argument of this Ingress Controller. Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#ingress-class | +| controller.ingressClassResource.default | bool | `false` | If true, Ingresses without `ingressClassName` get assigned to this IngressClass on creation. Ingress creation gets rejected if there are multiple default IngressClasses. Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#default-ingress-class | +| controller.ingressClassResource.enabled | bool | `true` | Create the IngressClass or not | +| controller.ingressClassResource.name | string | `"nginx"` | Name of the IngressClass | +| controller.ingressClassResource.parameters | object | `{}` | A link to a custom resource containing additional configuration for the controller. This is optional if the controller consuming this IngressClass does not require additional parameters. Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#ingress-class | +| controller.keda.apiVersion | string | `"keda.sh/v1alpha1"` | | +| controller.keda.behavior | object | `{}` | | +| controller.keda.cooldownPeriod | int | `300` | | +| controller.keda.enabled | bool | `false` | | +| controller.keda.maxReplicas | int | `11` | | +| controller.keda.minReplicas | int | `1` | | +| controller.keda.pollingInterval | int | `30` | | +| controller.keda.restoreToOriginalReplicaCount | bool | `false` | | +| controller.keda.scaledObject.annotations | object | `{}` | | +| controller.keda.triggers | list | `[]` | | +| controller.kind | string | `"Deployment"` | Use a `DaemonSet` or `Deployment` | +| controller.labels | object | `{}` | Labels to be added to the controller Deployment or DaemonSet and other resources that do not have option to specify labels # | +| controller.lifecycle | object | `{"preStop":{"exec":{"command":["/wait-shutdown"]}}}` | Improve connection draining when ingress controller pod is deleted using a lifecycle hook: With this new hook, we increased the default terminationGracePeriodSeconds from 30 seconds to 300, allowing the draining of connections up to five minutes. If the active connections end before that, the pod will terminate gracefully at that time. To effectively take advantage of this feature, the Configmap feature worker-shutdown-timeout new value is 240s instead of 10s. # | +| controller.livenessProbe.failureThreshold | int | `5` | | +| controller.livenessProbe.httpGet.path | string | `"/healthz"` | | +| controller.livenessProbe.httpGet.port | int | `10254` | | +| controller.livenessProbe.httpGet.scheme | string | `"HTTP"` | | +| controller.livenessProbe.initialDelaySeconds | int | `10` | | +| controller.livenessProbe.periodSeconds | int | `10` | | +| controller.livenessProbe.successThreshold | int | `1` | | +| controller.livenessProbe.timeoutSeconds | int | `1` | | +| controller.maxmindLicenseKey | string | `""` | Maxmind license key to download GeoLite2 Databases. # https://blog.maxmind.com/2019/12/significant-changes-to-accessing-and-using-geolite2-databases/ | +| controller.metrics.enabled | bool | `false` | | +| controller.metrics.port | int | `10254` | | +| controller.metrics.portName | string | `"metrics"` | | +| controller.metrics.prometheusRule.additionalLabels | object | `{}` | | +| controller.metrics.prometheusRule.enabled | bool | `false` | | +| controller.metrics.prometheusRule.rules | list | `[]` | | +| controller.metrics.service.annotations | object | `{}` | | +| controller.metrics.service.externalIPs | list | `[]` | List of IP addresses at which the stats-exporter service is available # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips # | +| controller.metrics.service.labels | object | `{}` | Labels to be added to the metrics service resource | +| controller.metrics.service.loadBalancerSourceRanges | list | `[]` | | +| controller.metrics.service.servicePort | int | `10254` | | +| controller.metrics.service.type | string | `"ClusterIP"` | | +| controller.metrics.serviceMonitor.additionalLabels | object | `{}` | | +| controller.metrics.serviceMonitor.annotations | object | `{}` | Annotations to be added to the ServiceMonitor. | +| controller.metrics.serviceMonitor.enabled | bool | `false` | | +| controller.metrics.serviceMonitor.metricRelabelings | list | `[]` | | +| controller.metrics.serviceMonitor.namespace | string | `""` | | +| controller.metrics.serviceMonitor.namespaceSelector | object | `{}` | | +| controller.metrics.serviceMonitor.relabelings | list | `[]` | | +| controller.metrics.serviceMonitor.scrapeInterval | string | `"30s"` | | +| controller.metrics.serviceMonitor.targetLabels | list | `[]` | | +| controller.minAvailable | int | `1` | Minimum available pods set in PodDisruptionBudget. Define either 'minAvailable' or 'maxUnavailable', never both. | +| controller.minReadySeconds | int | `0` | `minReadySeconds` to avoid killing pods before we are ready # | +| controller.name | string | `"controller"` | | +| controller.networkPolicy.enabled | bool | `false` | Enable 'networkPolicy' or not | +| controller.nodeSelector | object | `{"kubernetes.io/os":"linux"}` | Node labels for controller pod assignment # Ref: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/ # | +| controller.opentelemetry.containerSecurityContext.allowPrivilegeEscalation | bool | `false` | | +| controller.opentelemetry.containerSecurityContext.capabilities.drop[0] | string | `"ALL"` | | +| controller.opentelemetry.containerSecurityContext.readOnlyRootFilesystem | bool | `true` | | +| controller.opentelemetry.containerSecurityContext.runAsNonRoot | bool | `true` | | +| controller.opentelemetry.containerSecurityContext.runAsUser | int | `65532` | The image's default user, inherited from its base image `cgr.dev/chainguard/static`. | +| controller.opentelemetry.containerSecurityContext.seccompProfile.type | string | `"RuntimeDefault"` | | +| controller.opentelemetry.enabled | bool | `false` | | +| controller.opentelemetry.image.digest | string | `"sha256:f7604ac0547ed64d79b98d92133234e66c2c8aade3c1f4809fed5eec1fb7f922"` | | +| controller.opentelemetry.image.distroless | bool | `true` | | +| controller.opentelemetry.image.image | string | `"ingress-nginx/opentelemetry-1.25.3"` | | +| controller.opentelemetry.image.registry | string | `"registry.k8s.io"` | | +| controller.opentelemetry.image.tag | string | `"v20240813-b933310d"` | | +| controller.opentelemetry.name | string | `"opentelemetry"` | | +| controller.opentelemetry.resources | object | `{}` | | +| controller.podAnnotations | object | `{}` | Annotations to be added to controller pods # | +| controller.podLabels | object | `{}` | Labels to add to the pod container metadata | +| controller.podSecurityContext | object | `{}` | Security context for controller pods | +| controller.priorityClassName | string | `""` | | +| controller.proxySetHeaders | object | `{}` | Will add custom headers before sending traffic to backends according to https://github.com/kubernetes/ingress-nginx/tree/main/docs/examples/customization/custom-headers | +| controller.publishService | object | `{"enabled":true,"pathOverride":""}` | Allows customization of the source of the IP address or FQDN to report in the ingress status field. By default, it reads the information provided by the service. If disable, the status field reports the IP address of the node or nodes where an ingress controller pod is running. | +| controller.publishService.enabled | bool | `true` | Enable 'publishService' or not | +| controller.publishService.pathOverride | string | `""` | Allows overriding of the publish service to bind to Must be / | +| controller.readinessProbe.failureThreshold | int | `3` | | +| controller.readinessProbe.httpGet.path | string | `"/healthz"` | | +| controller.readinessProbe.httpGet.port | int | `10254` | | +| controller.readinessProbe.httpGet.scheme | string | `"HTTP"` | | +| controller.readinessProbe.initialDelaySeconds | int | `10` | | +| controller.readinessProbe.periodSeconds | int | `10` | | +| controller.readinessProbe.successThreshold | int | `1` | | +| controller.readinessProbe.timeoutSeconds | int | `1` | | +| controller.replicaCount | int | `1` | | +| controller.reportNodeInternalIp | bool | `false` | Bare-metal considerations via the host network https://kubernetes.github.io/ingress-nginx/deploy/baremetal/#via-the-host-network Ingress status was blank because there is no Service exposing the Ingress-Nginx Controller in a configuration using the host network, the default --publish-service flag used in standard cloud setups does not apply | +| controller.resources.requests.cpu | string | `"100m"` | | +| controller.resources.requests.memory | string | `"90Mi"` | | +| controller.scope.enabled | bool | `false` | Enable 'scope' or not | +| controller.scope.namespace | string | `""` | Namespace to limit the controller to; defaults to $(POD_NAMESPACE) | +| controller.scope.namespaceSelector | string | `""` | When scope.enabled == false, instead of watching all namespaces, we watching namespaces whose labels only match with namespaceSelector. Format like foo=bar. Defaults to empty, means watching all namespaces. | +| controller.service.annotations | object | `{}` | Annotations to be added to the external controller service. See `controller.service.internal.annotations` for annotations to be added to the internal controller service. | +| controller.service.appProtocol | bool | `true` | Declare the app protocol of the external HTTP and HTTPS listeners or not. Supersedes provider-specific annotations for declaring the backend protocol. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#application-protocol | +| controller.service.clusterIP | string | `""` | Pre-defined cluster internal IP address of the external controller service. Take care of collisions with existing services. This value is immutable. Set once, it can not be changed without deleting and re-creating the service. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#choosing-your-own-ip-address | +| controller.service.enableHttp | bool | `true` | Enable the HTTP listener on both controller services or not. | +| controller.service.enableHttps | bool | `true` | Enable the HTTPS listener on both controller services or not. | +| controller.service.enabled | bool | `true` | Enable controller services or not. This does not influence the creation of either the admission webhook or the metrics service. | +| controller.service.external.enabled | bool | `true` | Enable the external controller service or not. Useful for internal-only deployments. | +| controller.service.externalIPs | list | `[]` | List of node IP addresses at which the external controller service is available. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips | +| controller.service.externalTrafficPolicy | string | `""` | External traffic policy of the external controller service. Set to "Local" to preserve source IP on providers supporting it. Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip | +| controller.service.internal.annotations | object | `{}` | Annotations to be added to the internal controller service. Mandatory for the internal controller service to be created. Varies with the cloud service. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#internal-load-balancer | +| controller.service.internal.appProtocol | bool | `true` | Declare the app protocol of the internal HTTP and HTTPS listeners or not. Supersedes provider-specific annotations for declaring the backend protocol. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#application-protocol | +| controller.service.internal.clusterIP | string | `""` | Pre-defined cluster internal IP address of the internal controller service. Take care of collisions with existing services. This value is immutable. Set once, it can not be changed without deleting and re-creating the service. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#choosing-your-own-ip-address | +| controller.service.internal.enabled | bool | `false` | Enable the internal controller service or not. Remember to configure `controller.service.internal.annotations` when enabling this. | +| controller.service.internal.externalIPs | list | `[]` | List of node IP addresses at which the internal controller service is available. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips | +| controller.service.internal.externalTrafficPolicy | string | `""` | External traffic policy of the internal controller service. Set to "Local" to preserve source IP on providers supporting it. Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip | +| controller.service.internal.ipFamilies | list | `["IPv4"]` | List of IP families (e.g. IPv4, IPv6) assigned to the internal controller service. This field is usually assigned automatically based on cluster configuration and the `ipFamilyPolicy` field. Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services | +| controller.service.internal.ipFamilyPolicy | string | `"SingleStack"` | Represents the dual-stack capabilities of the internal controller service. Possible values are SingleStack, PreferDualStack or RequireDualStack. Fields `ipFamilies` and `clusterIP` depend on the value of this field. Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services | +| controller.service.internal.loadBalancerClass | string | `""` | Load balancer class of the internal controller service. Used by cloud providers to select a load balancer implementation other than the cloud provider default. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-class | +| controller.service.internal.loadBalancerIP | string | `""` | Deprecated: Pre-defined IP address of the internal controller service. Used by cloud providers to connect the resulting load balancer service to a pre-existing static IP. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#loadbalancer | +| controller.service.internal.loadBalancerSourceRanges | list | `[]` | Restrict access to the internal controller service. Values must be CIDRs. Allows any source address by default. | +| controller.service.internal.nodePorts.http | string | `""` | Node port allocated for the internal HTTP listener. If left empty, the service controller allocates one from the configured node port range. | +| controller.service.internal.nodePorts.https | string | `""` | Node port allocated for the internal HTTPS listener. If left empty, the service controller allocates one from the configured node port range. | +| controller.service.internal.nodePorts.tcp | object | `{}` | Node port mapping for internal TCP listeners. If left empty, the service controller allocates them from the configured node port range. Example: tcp: 8080: 30080 | +| controller.service.internal.nodePorts.udp | object | `{}` | Node port mapping for internal UDP listeners. If left empty, the service controller allocates them from the configured node port range. Example: udp: 53: 30053 | +| controller.service.internal.ports | object | `{}` | | +| controller.service.internal.sessionAffinity | string | `""` | Session affinity of the internal controller service. Must be either "None" or "ClientIP" if set. Defaults to "None". Ref: https://kubernetes.io/docs/reference/networking/virtual-ips/#session-affinity | +| controller.service.internal.targetPorts | object | `{}` | | +| controller.service.internal.type | string | `""` | Type of the internal controller service. Defaults to the value of `controller.service.type`. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types | +| controller.service.ipFamilies | list | `["IPv4"]` | List of IP families (e.g. IPv4, IPv6) assigned to the external controller service. This field is usually assigned automatically based on cluster configuration and the `ipFamilyPolicy` field. Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services | +| controller.service.ipFamilyPolicy | string | `"SingleStack"` | Represents the dual-stack capabilities of the external controller service. Possible values are SingleStack, PreferDualStack or RequireDualStack. Fields `ipFamilies` and `clusterIP` depend on the value of this field. Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services | +| controller.service.labels | object | `{}` | Labels to be added to both controller services. | +| controller.service.loadBalancerClass | string | `""` | Load balancer class of the external controller service. Used by cloud providers to select a load balancer implementation other than the cloud provider default. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-class | +| controller.service.loadBalancerIP | string | `""` | Deprecated: Pre-defined IP address of the external controller service. Used by cloud providers to connect the resulting load balancer service to a pre-existing static IP. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#loadbalancer | +| controller.service.loadBalancerSourceRanges | list | `[]` | Restrict access to the external controller service. Values must be CIDRs. Allows any source address by default. | +| controller.service.nodePorts.http | string | `""` | Node port allocated for the external HTTP listener. If left empty, the service controller allocates one from the configured node port range. | +| controller.service.nodePorts.https | string | `""` | Node port allocated for the external HTTPS listener. If left empty, the service controller allocates one from the configured node port range. | +| controller.service.nodePorts.tcp | object | `{}` | Node port mapping for external TCP listeners. If left empty, the service controller allocates them from the configured node port range. Example: tcp: 8080: 30080 | +| controller.service.nodePorts.udp | object | `{}` | Node port mapping for external UDP listeners. If left empty, the service controller allocates them from the configured node port range. Example: udp: 53: 30053 | +| controller.service.ports.http | int | `80` | Port the external HTTP listener is published with. | +| controller.service.ports.https | int | `443` | Port the external HTTPS listener is published with. | +| controller.service.sessionAffinity | string | `""` | Session affinity of the external controller service. Must be either "None" or "ClientIP" if set. Defaults to "None". Ref: https://kubernetes.io/docs/reference/networking/virtual-ips/#session-affinity | +| controller.service.targetPorts.http | string | `"http"` | Port of the ingress controller the external HTTP listener is mapped to. | +| controller.service.targetPorts.https | string | `"https"` | Port of the ingress controller the external HTTPS listener is mapped to. | +| controller.service.type | string | `"LoadBalancer"` | Type of the external controller service. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types | +| controller.shareProcessNamespace | bool | `false` | | +| controller.sysctls | object | `{}` | sysctls for controller pods # Ref: https://kubernetes.io/docs/tasks/administer-cluster/sysctl-cluster/ | +| controller.tcp.annotations | object | `{}` | Annotations to be added to the tcp config configmap | +| controller.tcp.configMapNamespace | string | `""` | Allows customization of the tcp-services-configmap; defaults to $(POD_NAMESPACE) | +| controller.terminationGracePeriodSeconds | int | `300` | `terminationGracePeriodSeconds` to avoid killing pods before we are ready # wait up to five minutes for the drain of connections # | +| controller.tolerations | list | `[]` | Node tolerations for server scheduling to nodes with taints # Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/ # | +| controller.topologySpreadConstraints | list | `[]` | Topology spread constraints rely on node labels to identify the topology domain(s) that each Node is in. # Ref: https://kubernetes.io/docs/concepts/workloads/pods/pod-topology-spread-constraints/ # | +| controller.udp.annotations | object | `{}` | Annotations to be added to the udp config configmap | +| controller.udp.configMapNamespace | string | `""` | Allows customization of the udp-services-configmap; defaults to $(POD_NAMESPACE) | +| controller.updateStrategy | object | `{}` | The update strategy to apply to the Deployment or DaemonSet # | +| controller.watchIngressWithoutClass | bool | `false` | Process Ingress objects without ingressClass annotation/ingressClassName field Overrides value for --watch-ingress-without-class flag of the controller binary Defaults to false | +| defaultBackend.affinity | object | `{}` | Affinity and anti-affinity rules for server scheduling to nodes # Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#affinity-and-anti-affinity | +| defaultBackend.autoscaling.annotations | object | `{}` | | +| defaultBackend.autoscaling.enabled | bool | `false` | | +| defaultBackend.autoscaling.maxReplicas | int | `2` | | +| defaultBackend.autoscaling.minReplicas | int | `1` | | +| defaultBackend.autoscaling.targetCPUUtilizationPercentage | int | `50` | | +| defaultBackend.autoscaling.targetMemoryUtilizationPercentage | int | `50` | | +| defaultBackend.containerSecurityContext | object | `{}` | Security context for default backend containers | +| defaultBackend.enabled | bool | `false` | | +| defaultBackend.existingPsp | string | `""` | Use an existing PSP instead of creating one | +| defaultBackend.extraArgs | object | `{}` | | +| defaultBackend.extraConfigMaps | list | `[]` | | +| defaultBackend.extraEnvs | list | `[]` | Additional environment variables to set for defaultBackend pods | +| defaultBackend.extraVolumeMounts | list | `[]` | | +| defaultBackend.extraVolumes | list | `[]` | | +| defaultBackend.image.allowPrivilegeEscalation | bool | `false` | | +| defaultBackend.image.image | string | `"defaultbackend-amd64"` | | +| defaultBackend.image.pullPolicy | string | `"IfNotPresent"` | | +| defaultBackend.image.readOnlyRootFilesystem | bool | `true` | | +| defaultBackend.image.registry | string | `"registry.k8s.io"` | | +| defaultBackend.image.runAsNonRoot | bool | `true` | | +| defaultBackend.image.runAsUser | int | `65534` | | +| defaultBackend.image.seccompProfile.type | string | `"RuntimeDefault"` | | +| defaultBackend.image.tag | string | `"1.5"` | | +| defaultBackend.labels | object | `{}` | Labels to be added to the default backend resources | +| defaultBackend.livenessProbe.failureThreshold | int | `3` | | +| defaultBackend.livenessProbe.initialDelaySeconds | int | `30` | | +| defaultBackend.livenessProbe.periodSeconds | int | `10` | | +| defaultBackend.livenessProbe.successThreshold | int | `1` | | +| defaultBackend.livenessProbe.timeoutSeconds | int | `5` | | +| defaultBackend.minAvailable | int | `1` | Minimum available pods set in PodDisruptionBudget. | +| defaultBackend.minReadySeconds | int | `0` | `minReadySeconds` to avoid killing pods before we are ready # | +| defaultBackend.name | string | `"defaultbackend"` | | +| defaultBackend.networkPolicy.enabled | bool | `false` | Enable 'networkPolicy' or not | +| defaultBackend.nodeSelector | object | `{"kubernetes.io/os":"linux"}` | Node labels for default backend pod assignment # Ref: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/ # | +| defaultBackend.podAnnotations | object | `{}` | Annotations to be added to default backend pods # | +| defaultBackend.podLabels | object | `{}` | Labels to add to the pod container metadata | +| defaultBackend.podSecurityContext | object | `{}` | Security context for default backend pods | +| defaultBackend.port | int | `8080` | | +| defaultBackend.priorityClassName | string | `""` | | +| defaultBackend.readinessProbe.failureThreshold | int | `6` | | +| defaultBackend.readinessProbe.initialDelaySeconds | int | `0` | | +| defaultBackend.readinessProbe.periodSeconds | int | `5` | | +| defaultBackend.readinessProbe.successThreshold | int | `1` | | +| defaultBackend.readinessProbe.timeoutSeconds | int | `5` | | +| defaultBackend.replicaCount | int | `1` | | +| defaultBackend.resources | object | `{}` | | +| defaultBackend.service.annotations | object | `{}` | | +| defaultBackend.service.externalIPs | list | `[]` | List of IP addresses at which the default backend service is available # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips # | +| defaultBackend.service.loadBalancerSourceRanges | list | `[]` | | +| defaultBackend.service.servicePort | int | `80` | | +| defaultBackend.service.type | string | `"ClusterIP"` | | +| defaultBackend.serviceAccount.automountServiceAccountToken | bool | `true` | | +| defaultBackend.serviceAccount.create | bool | `true` | | +| defaultBackend.serviceAccount.name | string | `""` | | +| defaultBackend.tolerations | list | `[]` | Node tolerations for server scheduling to nodes with taints # Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/ # | +| defaultBackend.topologySpreadConstraints | list | `[]` | Topology spread constraints rely on node labels to identify the topology domain(s) that each Node is in. Ref.: https://kubernetes.io/docs/concepts/workloads/pods/pod-topology-spread-constraints/ | +| defaultBackend.updateStrategy | object | `{}` | The update strategy to apply to the Deployment or DaemonSet # | +| dhParam | string | `""` | A base64-encoded Diffie-Hellman parameter. This can be generated with: `openssl dhparam 4096 2> /dev/null | base64` # Ref: https://github.com/kubernetes/ingress-nginx/tree/main/docs/examples/customization/ssl-dh-param | +| imagePullSecrets | list | `[]` | Optional array of imagePullSecrets containing private registry credentials # Ref: https://kubernetes.io/docs/tasks/configure-pod-container/pull-image-private-registry/ | +| namespaceOverride | string | `""` | Override the deployment namespace; defaults to .Release.Namespace | +| podSecurityPolicy.enabled | bool | `false` | | +| portNamePrefix | string | `""` | Prefix for TCP and UDP ports names in ingress controller service # Some cloud providers, like Yandex Cloud may have a requirements for a port name regex to support cloud load balancer integration | +| rbac.create | bool | `true` | | +| rbac.scope | bool | `false` | | +| revisionHistoryLimit | int | `10` | Rollback limit # | +| serviceAccount.annotations | object | `{}` | Annotations for the controller service account | +| serviceAccount.automountServiceAccountToken | bool | `true` | | +| serviceAccount.create | bool | `true` | | +| serviceAccount.name | string | `""` | | +| tcp | object | `{}` | TCP service key-value pairs # Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/exposing-tcp-udp-services.md # | +| udp | object | `{}` | UDP service key-value pairs # Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/exposing-tcp-udp-services.md # | diff --git a/charts/keep/charts/ingress-nginx/README.md.gotmpl b/charts/keep/charts/ingress-nginx/README.md.gotmpl new file mode 100644 index 0000000..17b029b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/README.md.gotmpl @@ -0,0 +1,229 @@ +{{ template "chart.header" . }} +[ingress-nginx](https://github.com/kubernetes/ingress-nginx) Ingress controller for Kubernetes using NGINX as a reverse proxy and load balancer + +{{ template "chart.versionBadge" . }}{{ template "chart.typeBadge" . }}{{ template "chart.appVersionBadge" . }} + +To use, add `ingressClassName: nginx` spec field or the `kubernetes.io/ingress.class: nginx` annotation to your Ingress resources. + +This chart bootstraps an ingress-nginx deployment on a [Kubernetes](http://kubernetes.io) cluster using the [Helm](https://helm.sh) package manager. + +{{ template "chart.requirementsSection" . }} + +## Get Repo Info + +```console +helm repo add ingress-nginx https://kubernetes.github.io/ingress-nginx +helm repo update +``` + +## Install Chart + +**Important:** only helm3 is supported + +```console +helm install [RELEASE_NAME] ingress-nginx/ingress-nginx +``` + +The command deploys ingress-nginx on the Kubernetes cluster in the default configuration. + +_See [configuration](#configuration) below._ + +_See [helm install](https://helm.sh/docs/helm/helm_install/) for command documentation._ + +## Uninstall Chart + +```console +helm uninstall [RELEASE_NAME] +``` + +This removes all the Kubernetes components associated with the chart and deletes the release. + +_See [helm uninstall](https://helm.sh/docs/helm/helm_uninstall/) for command documentation._ + +## Upgrading Chart + +```console +helm upgrade [RELEASE_NAME] [CHART] --install +``` + +_See [helm upgrade](https://helm.sh/docs/helm/helm_upgrade/) for command documentation._ + +### Migrating from stable/nginx-ingress + +There are two main ways to migrate a release from `stable/nginx-ingress` to `ingress-nginx/ingress-nginx` chart: + +1. For Nginx Ingress controllers used for non-critical services, the easiest method is to [uninstall](#uninstall-chart) the old release and [install](#install-chart) the new one +1. For critical services in production that require zero-downtime, you will want to: + 1. [Install](#install-chart) a second Ingress controller + 1. Redirect your DNS traffic from the old controller to the new controller + 1. Log traffic from both controllers during this changeover + 1. [Uninstall](#uninstall-chart) the old controller once traffic has fully drained from it + +Note that there are some different and upgraded configurations between the two charts, described by Rimas Mocevicius from JFrog in the "Upgrading to ingress-nginx Helm chart" section of [Migrating from Helm chart nginx-ingress to ingress-nginx](https://rimusz.net/migrating-to-ingress-nginx). As the `ingress-nginx/ingress-nginx` chart continues to update, you will want to check current differences by running [helm configuration](#configuration) commands on both charts. + +## Configuration + +See [Customizing the Chart Before Installing](https://helm.sh/docs/intro/using_helm/#customizing-the-chart-before-installing). To see all configurable options with detailed comments, visit the chart's [values.yaml](./values.yaml), or run these configuration commands: + +```console +helm show values ingress-nginx/ingress-nginx +``` + +### PodDisruptionBudget + +Note that the PodDisruptionBudget resource will only be defined if the replicaCount is greater than one, +else it would make it impossible to evacuate a node. See [gh issue #7127](https://github.com/helm/charts/issues/7127) for more info. + +### Prometheus Metrics + +The Ingress-Nginx Controller can export Prometheus metrics, by setting `controller.metrics.enabled` to `true`. + +You can add Prometheus annotations to the metrics service using `controller.metrics.service.annotations`. +Alternatively, if you use the Prometheus Operator, you can enable ServiceMonitor creation using `controller.metrics.serviceMonitor.enabled`. And set `controller.metrics.serviceMonitor.additionalLabels.release="prometheus"`. "release=prometheus" should match the label configured in the prometheus servicemonitor ( see `kubectl get servicemonitor prometheus-kube-prom-prometheus -oyaml -n prometheus`) + +### ingress-nginx nginx\_status page/stats server + +Previous versions of this chart had a `controller.stats.*` configuration block, which is now obsolete due to the following changes in Ingress-Nginx Controller: + +- In [0.16.1](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0161), the vts (virtual host traffic status) dashboard was removed +- In [0.23.0](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0230), the status page at port 18080 is now a unix socket webserver only available at localhost. + You can use `curl --unix-socket /tmp/nginx-status-server.sock http://localhost/nginx_status` inside the controller container to access it locally, or use the snippet from [nginx-ingress changelog](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0230) to re-enable the http server + +### ExternalDNS Service Configuration + +Add an [ExternalDNS](https://github.com/kubernetes-sigs/external-dns) annotation to the LoadBalancer service: + +```yaml +controller: + service: + annotations: + external-dns.alpha.kubernetes.io/hostname: kubernetes-example.com. +``` + +### AWS L7 ELB with SSL Termination + +Annotate the controller as shown in the [nginx-ingress l7 patch](https://github.com/kubernetes/ingress-nginx/blob/ab3a789caae65eec4ad6e3b46b19750b481b6bce/deploy/aws/l7/service-l7.yaml): + +```yaml +controller: + service: + targetPorts: + http: http + https: http + annotations: + service.beta.kubernetes.io/aws-load-balancer-ssl-cert: arn:aws:acm:XX-XXXX-X:XXXXXXXXX:certificate/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXX + service.beta.kubernetes.io/aws-load-balancer-backend-protocol: "http" + service.beta.kubernetes.io/aws-load-balancer-ssl-ports: "https" + service.beta.kubernetes.io/aws-load-balancer-connection-idle-timeout: '3600' +``` + +### Additional Internal Load Balancer + +This setup is useful when you need both external and internal load balancers but don't want to have multiple ingress controllers and multiple ingress objects per application. + +By default, the ingress object will point to the external load balancer address, but if correctly configured, you can make use of the internal one if the URL you are looking up resolves to the internal load balancer's URL. + +You'll need to set both the following values: + +`controller.service.internal.enabled` +`controller.service.internal.annotations` + +If one of them is missing the internal load balancer will not be deployed. Example you may have `controller.service.internal.enabled=true` but no annotations set, in this case no action will be taken. + +`controller.service.internal.annotations` varies with the cloud service you're using. + +Example for AWS: + +```yaml +controller: + service: + internal: + enabled: true + annotations: + # Create internal NLB + service.beta.kubernetes.io/aws-load-balancer-scheme: "internal" + # Create internal ELB(Deprecated) + # service.beta.kubernetes.io/aws-load-balancer-internal: "true" + # Any other annotation can be declared here. +``` + +Example for GCE: + +```yaml +controller: + service: + internal: + enabled: true + annotations: + # Create internal LB. More information: https://cloud.google.com/kubernetes-engine/docs/how-to/internal-load-balancing + # For GKE versions 1.17 and later + networking.gke.io/load-balancer-type: "Internal" + # For earlier versions + # cloud.google.com/load-balancer-type: "Internal" + + # Any other annotation can be declared here. +``` + +Example for Azure: + +```yaml +controller: + service: + annotations: + # Create internal LB + service.beta.kubernetes.io/azure-load-balancer-internal: "true" + # Any other annotation can be declared here. +``` + +Example for Oracle Cloud Infrastructure: + +```yaml +controller: + service: + annotations: + # Create internal LB + service.beta.kubernetes.io/oci-load-balancer-internal: "true" + # Any other annotation can be declared here. +``` + +The load balancer annotations of more cloud service providers can be found: [Internal load balancer](https://kubernetes.io/docs/concepts/services-networking/service/#internal-load-balancer). + +An use case for this scenario is having a split-view DNS setup where the public zone CNAME records point to the external balancer URL while the private zone CNAME records point to the internal balancer URL. This way, you only need one ingress kubernetes object. + +Optionally you can set `controller.service.loadBalancerIP` if you need a static IP for the resulting `LoadBalancer`. + +### Ingress Admission Webhooks + +With nginx-ingress-controller version 0.25+, the Ingress-Nginx Controller pod exposes an endpoint that will integrate with the `validatingwebhookconfiguration` Kubernetes feature to prevent bad ingress from being added to the cluster. +**This feature is enabled by default since 0.31.0.** + +With nginx-ingress-controller in 0.25.* work only with kubernetes 1.14+, 0.26 fix [this issue](https://github.com/kubernetes/ingress-nginx/pull/4521) + +#### How the Chart Configures the Hooks +A validating and configuration requires the endpoint to which the request is sent to use TLS. It is possible to set up custom certificates to do this, but in most cases, a self-signed certificate is enough. The setup of this component requires some more complex orchestration when using helm. The steps are created to be idempotent and to allow turning the feature on and off without running into helm quirks. + +1. A pre-install hook provisions a certificate into the same namespace using a format compatible with provisioning using end user certificates. If the certificate already exists, the hook exits. +2. The Ingress-Nginx Controller pod is configured to use a TLS proxy container, which will load that certificate. +3. Validating and Mutating webhook configurations are created in the cluster. +4. A post-install hook reads the CA from the secret created by step 1 and patches the Validating and Mutating webhook configurations. This process will allow a custom CA provisioned by some other process to also be patched into the webhook configurations. The chosen failure policy is also patched into the webhook configurations + +#### Alternatives +It should be possible to use [cert-manager/cert-manager](https://github.com/cert-manager/cert-manager) if a more complete solution is required. + +You can enable automatic self-signed TLS certificate provisioning via cert-manager by setting the `controller.admissionWebhooks.certManager.enabled` value to true. + +Please ensure that cert-manager is correctly installed and configured. + +### Helm Error When Upgrading: spec.clusterIP: Invalid value: "" + +If you are upgrading this chart from a version between 0.31.0 and 1.2.2 then you may get an error like this: + +```console +Error: UPGRADE FAILED: Service "?????-controller" is invalid: spec.clusterIP: Invalid value: "": field is immutable +``` + +Detail of how and why are in [this issue](https://github.com/helm/charts/pull/13646) but to resolve this you can set `xxxx.service.omitClusterIP` to `true` where `xxxx` is the service referenced in the error. + +As of version `1.26.0` of this chart, by simply not providing any clusterIP value, `invalid: spec.clusterIP: Invalid value: "": field is immutable` will no longer occur since `clusterIP: ""` will not be rendered. + +{{ template "chart.valuesSection" . }} diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.10.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.10.0.md new file mode 100644 index 0000000..b42d6c2 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.10.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.10.0 + +* [#5843](https://github.com/kubernetes/ingress-nginx/pull/5843) Update jettech/kube-webhook-certgen image + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.9.1...ingress-nginx-2.10.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.0.md new file mode 100644 index 0000000..e549b38 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.0.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.11.0 + +* [#5879](https://github.com/kubernetes/ingress-nginx/pull/5879) Update helm chart for v0.34.0 +* [#5671](https://github.com/kubernetes/ingress-nginx/pull/5671) Make liveness probe more fault tolerant than readiness probe + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.10.0...ingress-nginx-2.11.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.1.md new file mode 100644 index 0000000..d910d3b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.11.1 + +* [#5900](https://github.com/kubernetes/ingress-nginx/pull/5900) Release helm chart for v0.34.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.11.0...ingress-nginx-2.11.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.2.md new file mode 100644 index 0000000..9f78210 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.2.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.11.2 + +* [#5951](https://github.com/kubernetes/ingress-nginx/pull/5951) Bump chart patch version + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.11.1...ingress-nginx-2.11.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.3.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.3.md new file mode 100644 index 0000000..3447691 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.3.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.11.3 + +* [#6038](https://github.com/kubernetes/ingress-nginx/pull/6038) Bump chart version PATCH + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.11.2...ingress-nginx-2.11.3 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.0.md new file mode 100644 index 0000000..5cb3888 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.0.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.12.0 + +* [#6039](https://github.com/kubernetes/ingress-nginx/pull/6039) Add configurable serviceMonitor metricRelabelling and targetLabels +* [#6044](https://github.com/kubernetes/ingress-nginx/pull/6044) Fix YAML linting + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.11.3...ingress-nginx-2.12.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.1.md new file mode 100644 index 0000000..94d121d --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.12.1 + +* [#6075](https://github.com/kubernetes/ingress-nginx/pull/6075) Sync helm chart affinity examples + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.12.0...ingress-nginx-2.12.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.13.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.13.0.md new file mode 100644 index 0000000..01fe0b1 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.13.0.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.13.0 + +* [#6093](https://github.com/kubernetes/ingress-nginx/pull/6093) Release v0.35.0 +* [#6080](https://github.com/kubernetes/ingress-nginx/pull/6080) Switch images to k8s.gcr.io after Vanity Domain Flip + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.12.1...ingress-nginx-2.13.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.14.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.14.0.md new file mode 100644 index 0000000..2fb7a5a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.14.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.14.0 + +* [#6104](https://github.com/kubernetes/ingress-nginx/pull/6104) Misc fixes for nginx-ingress chart for better keel and prometheus-operator integration + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.13.0...ingress-nginx-2.14.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.15.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.15.0.md new file mode 100644 index 0000000..543a559 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.15.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.15.0 + +* [#6087](https://github.com/kubernetes/ingress-nginx/pull/6087) Adding parameter for externalTrafficPolicy in internal controller service spec + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.14.0...ingress-nginx-2.15.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.16.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.16.0.md new file mode 100644 index 0000000..996f448 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.16.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.16.0 + +* [#6154](https://github.com/kubernetes/ingress-nginx/pull/6154) add `topologySpreadConstraint` to controller + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.15.0...ingress-nginx-2.16.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.0.md new file mode 100644 index 0000000..11c5f5f --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.9.0 + +* [#5795](https://github.com/kubernetes/ingress-nginx/pull/5795) Use fully qualified images to avoid cri-o issues + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-TODO...ingress-nginx-2.9.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.1.md new file mode 100644 index 0000000..7d4314d --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 2.9.1 + +* [#5823](https://github.com/kubernetes/ingress-nginx/pull/5823) Add quoting to sysctls because numeric values need to be presented as strings (#5823) + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.9.0...ingress-nginx-2.9.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.0.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.0.0.md new file mode 100644 index 0000000..a7d50ee --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.0.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.0.0 + +* [#6167](https://github.com/kubernetes/ingress-nginx/pull/6167) Update chart requirements + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.16.0...ingress-nginx-3.0.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.0.md new file mode 100644 index 0000000..3369bed --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.10.0 + +* Fix routing regression introduced in 0.41.0 with PathType Exact + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.9.0...ingress-nginx-3.10.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.1.md new file mode 100644 index 0000000..6ff682e --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.10.1 + +* Fix regression introduced in 0.41.0 with external authentication + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.10.0...ingress-nginx-3.10.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.0.md new file mode 100644 index 0000000..69ba550 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.11.0 + +* Support Keda Autoscaling + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.10.1...ingress-nginx-3.11.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.1.md new file mode 100644 index 0000000..4e81f4b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.11.1 + +* [#6505](https://github.com/kubernetes/ingress-nginx/pull/6505) Reorder HPA resource list to work with GitOps tooling + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.11.0...ingress-nginx-3.11.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.12.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.12.0.md new file mode 100644 index 0000000..41b9744 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.12.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.12.0 + +* [#6514](https://github.com/kubernetes/ingress-nginx/pull/6514) Remove helm2 support and update docs + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.11.1...ingress-nginx-3.12.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.13.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.13.0.md new file mode 100644 index 0000000..0855a79 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.13.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.13.0 + +* [#6544](https://github.com/kubernetes/ingress-nginx/pull/6544) Fix default backend HPA name variable + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.12.0...ingress-nginx-3.13.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.14.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.14.0.md new file mode 100644 index 0000000..e07880b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.14.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.14.0 + +* [#6469](https://github.com/kubernetes/ingress-nginx/pull/6469) Allow custom service names for controller and backend + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.13.0...ingress-nginx-3.14.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.0.md new file mode 100644 index 0000000..3053a35 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.15.0 + +* [#6586](https://github.com/kubernetes/ingress-nginx/pull/6586) Fix 'maxmindLicenseKey' location in values.yaml + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.14.0...ingress-nginx-3.15.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.1.md new file mode 100644 index 0000000..f11ee0a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.15.1 + +* Fix chart-releaser action + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.15.0...ingress-nginx-3.15.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.0.md new file mode 100644 index 0000000..fba30b1 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.16.0 + +* [#6646](https://github.com/kubernetes/ingress-nginx/pull/6646) Added LoadBalancerIP value for internal service + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.15.1...helm-chart-3.16.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.1.md new file mode 100644 index 0000000..650d1b8 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.16.1 + +* Fix chart-releaser action + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.16.0...helm-chart-3.16.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.17.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.17.0.md new file mode 100644 index 0000000..175c7a2 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.17.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.17.0 + +* Update ingress-nginx v0.42.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.16.1...helm-chart-3.17.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.18.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.18.0.md new file mode 100644 index 0000000..31b815e --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.18.0.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.18.0 + +* [#6688](https://github.com/kubernetes/ingress-nginx/pull/6688) Allow volume-type emptyDir in controller podsecuritypolicy +* [#6691](https://github.com/kubernetes/ingress-nginx/pull/6691) Improve parsing of helm parameters + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.17.0...helm-chart-3.18.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.19.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.19.0.md new file mode 100644 index 0000000..0970bf0 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.19.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.19.0 + +* Update ingress-nginx v0.43.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.18.0...helm-chart-3.19.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.0.md new file mode 100644 index 0000000..4b81ae4 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.20.0 + +* [#6730](https://github.com/kubernetes/ingress-nginx/pull/6730) Do not create HPA for defaultBackend if not enabled. + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.19.0...helm-chart-3.20.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.1.md new file mode 100644 index 0000000..952bf2b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.1.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.20.1 + +* Do not create KEDA in case of DaemonSets. +* Fix KEDA v2 definition + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.20.0...helm-chart-3.20.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.21.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.21.0.md new file mode 100644 index 0000000..25edbef --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.21.0.md @@ -0,0 +1,12 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.21.0 + +* [#6783](https://github.com/kubernetes/ingress-nginx/pull/6783) Add custom annotations to ScaledObject +* [#6761](https://github.com/kubernetes/ingress-nginx/pull/6761) Adding quotes in the serviceAccount name in Helm values +* [#6767](https://github.com/kubernetes/ingress-nginx/pull/6767) Remove ClusterRole when scope option is enabled +* [#6785](https://github.com/kubernetes/ingress-nginx/pull/6785) Update kube-webhook-certgen image to v1.5.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.20.1...helm-chart-3.21.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.22.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.22.0.md new file mode 100644 index 0000000..147d664 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.22.0.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.22.0 + +* [#6802](https://github.com/kubernetes/ingress-nginx/pull/6802) Add value for configuring a custom Diffie-Hellman parameters file +* [#6815](https://github.com/kubernetes/ingress-nginx/pull/6815) Allow use of numeric namespaces in helm chart + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.21.0...helm-chart-3.22.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.23.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.23.0.md new file mode 100644 index 0000000..5dcb50f --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.23.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.23.0 + +* Update ingress-nginx v0.44.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.22.0...helm-chart-3.23.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.24.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.24.0.md new file mode 100644 index 0000000..d7db808 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.24.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.24.0 + +* [#6908](https://github.com/kubernetes/ingress-nginx/pull/6908) Add volumes to default-backend deployment + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.23.0...helm-chart-3.24.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.25.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.25.0.md new file mode 100644 index 0000000..f9679a1 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.25.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.25.0 + +* [#6957](https://github.com/kubernetes/ingress-nginx/pull/6957) Add ability to specify automountServiceAccountToken + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.24.0...helm-chart-3.25.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.26.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.26.0.md new file mode 100644 index 0000000..0c3a1df --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.26.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.26.0 + +* [#6979](https://github.com/kubernetes/ingress-nginx/pull/6979) Changed servicePort value for metrics + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.25.0...helm-chart-3.26.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.27.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.27.0.md new file mode 100644 index 0000000..8113d7b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.27.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.27.0 + +* Update ingress-nginx v0.45.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.26.0...helm-chart-3.27.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.28.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.28.0.md new file mode 100644 index 0000000..eee0ccb --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.28.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.28.0 + +* [#6900](https://github.com/kubernetes/ingress-nginx/pull/6900) Support existing PSPs + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.27.0...helm-chart-3.28.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.29.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.29.0.md new file mode 100644 index 0000000..f0fabdc --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.29.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.29.0 + +* [#6945](https://github.com/kubernetes/ingress-nginx/pull/7020) Add option to specify job label for ServiceMonitor + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.28.0...helm-chart-3.29.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.0.md new file mode 100644 index 0000000..09fab37 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.0.md @@ -0,0 +1,12 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.3.0 + +* [#6203](https://github.com/kubernetes/ingress-nginx/pull/6203) Refactor parsing of key values +* [#6162](https://github.com/kubernetes/ingress-nginx/pull/6162) Add helm chart options to expose metrics service as NodePort +* [#6180](https://github.com/kubernetes/ingress-nginx/pull/6180) Fix helm chart admissionReviewVersions regression +* [#6169](https://github.com/kubernetes/ingress-nginx/pull/6169) Fix Typo in example prometheus rules + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.0.0...ingress-nginx-3.3.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.1.md new file mode 100644 index 0000000..81f44fd --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.1.md @@ -0,0 +1,12 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.3.1 + +* [#6259](https://github.com/kubernetes/ingress-nginx/pull/6259) Release helm chart +* [#6258](https://github.com/kubernetes/ingress-nginx/pull/6258) Fix chart markdown link +* [#6253](https://github.com/kubernetes/ingress-nginx/pull/6253) Release v0.40.0 +* [#6233](https://github.com/kubernetes/ingress-nginx/pull/6233) Add admission controller e2e test + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.3.0...ingress-nginx-3.3.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.30.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.30.0.md new file mode 100644 index 0000000..77ad6b4 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.30.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.30.0 + +* [#7092](https://github.com/kubernetes/ingress-nginx/pull/7092) Removes the possibility of using localhost in ExternalNames as endpoints + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.29.0...helm-chart-3.30.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.31.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.31.0.md new file mode 100644 index 0000000..bc07fed --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.31.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.31.0 + +* [7137] https://github.com/kubernetes/ingress-nginx/pull/7137 Add support for custom probes + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.30.0...helm-chart-3.31.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.32.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.32.0.md new file mode 100644 index 0000000..68f7ed6 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.32.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.32.0 + +* [7117] https://github.com/kubernetes/ingress-nginx/pull/7117 Add annotations for HPA + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.31.0...helm-chart-3.32.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.33.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.33.0.md new file mode 100644 index 0000000..b56c5fc --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.33.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.33.0 + +* [7164] https://github.com/kubernetes/ingress-nginx/pull/7164 Update nginx to v1.20.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.32.0...helm-chart-3.33.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.34.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.34.0.md new file mode 100644 index 0000000..a28cd02 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.34.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.34.0 + +* [7256] https://github.com/kubernetes/ingress-nginx/pull/7256 Add namespace field in the namespace scoped resource templates + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.33.0...helm-chart-3.34.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.4.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.4.0.md new file mode 100644 index 0000000..3b4ca93 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.4.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.4.0 + +* [#6268](https://github.com/kubernetes/ingress-nginx/pull/6268) Update to 0.40.2 in helm chart #6288 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.3.1...ingress-nginx-3.4.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.0.md new file mode 100644 index 0000000..44991b3 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.5.0 + +* [#6260](https://github.com/kubernetes/ingress-nginx/pull/6260) Allow Helm Chart to customize admission webhook's annotations, timeoutSeconds, namespaceSelector, objectSelector and cert files locations + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.4.0...ingress-nginx-3.5.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.1.md new file mode 100644 index 0000000..740f00c --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.5.1 + +* [#6299](https://github.com/kubernetes/ingress-nginx/pull/6299) Fix helm chart release + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.5.0...ingress-nginx-3.5.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.6.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.6.0.md new file mode 100644 index 0000000..4af7f11 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.6.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.6.0 + +* [#6305](https://github.com/kubernetes/ingress-nginx/pull/6305) Add default linux nodeSelector + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.5.1...ingress-nginx-3.6.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.0.md new file mode 100644 index 0000000..a6b1299 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.7.0 + +* [#6316](https://github.com/kubernetes/ingress-nginx/pull/6316) Numerals in podAnnotations in quotes [#6315](https://github.com/kubernetes/ingress-nginx/issues/6315) + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.6.0...ingress-nginx-3.7.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.1.md new file mode 100644 index 0000000..6ba12df --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.7.1 + +* [#6326](https://github.com/kubernetes/ingress-nginx/pull/6326) Fix liveness and readiness probe path in daemonset chart + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.7.0...ingress-nginx-3.7.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.8.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.8.0.md new file mode 100644 index 0000000..8df250a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.8.0.md @@ -0,0 +1,13 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.8.0 + +* [#6395](https://github.com/kubernetes/ingress-nginx/pull/6395) Update jettech/kube-webhook-certgen image +* [#6377](https://github.com/kubernetes/ingress-nginx/pull/6377) Added loadBalancerSourceRanges for internal lbs +* [#6356](https://github.com/kubernetes/ingress-nginx/pull/6356) Add securitycontext settings on defaultbackend +* [#6401](https://github.com/kubernetes/ingress-nginx/pull/6401) Fix controller service annotations +* [#6403](https://github.com/kubernetes/ingress-nginx/pull/6403) Initial helm chart changelog + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.7.1...ingress-nginx-3.8.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.9.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.9.0.md new file mode 100644 index 0000000..e8c9def --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.9.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 3.9.0 + +* [#6423](https://github.com/kubernetes/ingress-nginx/pull/6423) Add Default backend HPA autoscaling + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.8.0...ingress-nginx-3.9.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.1.md new file mode 100644 index 0000000..7a187b3 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.1 + +* [7535] https://github.com/kubernetes/ingress-nginx/pull/7535 Release v1.0.0 ingress-nginx + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.34.0...helm-chart-4.0.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.10.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.10.md new file mode 100644 index 0000000..c5d6516 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.10.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.10 + +* [7964] https://github.com/kubernetes/ingress-nginx/pull/7964 Update controller version to v1.1.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.9...helm-chart-4.0.10 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.11.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.11.md new file mode 100644 index 0000000..5541823 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.11.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.11 + +* [7873] https://github.com/kubernetes/ingress-nginx/pull/7873 Makes the [appProtocol](https://kubernetes.io/docs/concepts/services-networking/_print/#application-protocol) field optional. + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.10...helm-chart-4.0.11 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.12.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.12.md new file mode 100644 index 0000000..320f6f5 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.12.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.12 + +* [7978] https://github.com/kubernetes/ingress-nginx/pull/7979 Support custom annotations in admissions Jobs + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.11...helm-chart-4.0.12 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.13.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.13.md new file mode 100644 index 0000000..edd9228 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.13.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.13 + +* [8008] https://github.com/kubernetes/ingress-nginx/pull/8008 Add relabelings in controller-servicemonitor.yaml + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.12...helm-chart-4.0.13 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.14.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.14.md new file mode 100644 index 0000000..e927010 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.14.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.14 + +* [8061] https://github.com/kubernetes/ingress-nginx/pull/8061 Using helm-docs to populate values table in README.md + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.13...helm-chart-4.0.14 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.15.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.15.md new file mode 100644 index 0000000..d3d14a9 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.15.md @@ -0,0 +1,43 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.15 + +* [8120] https://github.com/kubernetes/ingress-nginx/pull/8120 Update go in runner and release v1.1.1 +* [8119] https://github.com/kubernetes/ingress-nginx/pull/8119 Update to go v1.17.6 +* [8118] https://github.com/kubernetes/ingress-nginx/pull/8118 Remove deprecated libraries, update other libs +* [8117] https://github.com/kubernetes/ingress-nginx/pull/8117 Fix codegen errors +* [8115] https://github.com/kubernetes/ingress-nginx/pull/8115 chart/ghaction: set the correct permission to have access to push a release +* [8098] https://github.com/kubernetes/ingress-nginx/pull/8098 generating SHA for CA only certs in backend_ssl.go + comparison of P… +* [8088] https://github.com/kubernetes/ingress-nginx/pull/8088 Fix Edit this page link to use main branch +* [8072] https://github.com/kubernetes/ingress-nginx/pull/8072 Expose GeoIP2 Continent code as variable +* [8061] https://github.com/kubernetes/ingress-nginx/pull/8061 docs(charts): using helm-docs for chart +* [8058] https://github.com/kubernetes/ingress-nginx/pull/8058 Bump github.com/spf13/cobra from 1.2.1 to 1.3.0 +* [8054] https://github.com/kubernetes/ingress-nginx/pull/8054 Bump google.golang.org/grpc from 1.41.0 to 1.43.0 +* [8051] https://github.com/kubernetes/ingress-nginx/pull/8051 align bug report with feature request regarding kind documentation +* [8046] https://github.com/kubernetes/ingress-nginx/pull/8046 Report expired certificates (#8045) +* [8044] https://github.com/kubernetes/ingress-nginx/pull/8044 remove G109 check till gosec resolves issues +* [8042] https://github.com/kubernetes/ingress-nginx/pull/8042 docs_multiple_instances_one_cluster_ticket_7543 +* [8041] https://github.com/kubernetes/ingress-nginx/pull/8041 docs: fix typo'd executable name +* [8035] https://github.com/kubernetes/ingress-nginx/pull/8035 Comment busy owners +* [8029] https://github.com/kubernetes/ingress-nginx/pull/8029 Add stream-snippet as a ConfigMap and Annotation option +* [8023] https://github.com/kubernetes/ingress-nginx/pull/8023 fix nginx compilation flags +* [8021] https://github.com/kubernetes/ingress-nginx/pull/8021 Disable default modsecurity_rules_file if modsecurity-snippet is specified +* [8019] https://github.com/kubernetes/ingress-nginx/pull/8019 Revise main documentation page +* [8018] https://github.com/kubernetes/ingress-nginx/pull/8018 Preserve order of plugin invocation +* [8015] https://github.com/kubernetes/ingress-nginx/pull/8015 Add newline indenting to admission webhook annotations +* [8014] https://github.com/kubernetes/ingress-nginx/pull/8014 Add link to example error page manifest in docs +* [8009] https://github.com/kubernetes/ingress-nginx/pull/8009 Fix spelling in documentation and top-level files +* [8008] https://github.com/kubernetes/ingress-nginx/pull/8008 Add relabelings in controller-servicemonitor.yaml +* [8003] https://github.com/kubernetes/ingress-nginx/pull/8003 Minor improvements (formatting, consistency) in install guide +* [8001] https://github.com/kubernetes/ingress-nginx/pull/8001 fix: go-grpc Dockerfile +* [7999] https://github.com/kubernetes/ingress-nginx/pull/7999 images: use k8s-staging-test-infra/gcb-docker-gcloud +* [7996] https://github.com/kubernetes/ingress-nginx/pull/7996 doc: improvement +* [7983] https://github.com/kubernetes/ingress-nginx/pull/7983 Fix a couple of misspellings in the annotations documentation. +* [7979] https://github.com/kubernetes/ingress-nginx/pull/7979 allow set annotations for admission Jobs +* [7977] https://github.com/kubernetes/ingress-nginx/pull/7977 Add ssl_reject_handshake to default server +* [7975] https://github.com/kubernetes/ingress-nginx/pull/7975 add legacy version update v0.50.0 to main changelog +* [7972] https://github.com/kubernetes/ingress-nginx/pull/7972 updated service upstream definition + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.14...helm-chart-4.0.15 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.18.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.18.md new file mode 100644 index 0000000..30a8f75 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.18.md @@ -0,0 +1,40 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.18 + +* [8291](https://github.com/kubernetes/ingress-nginx/pull/8291) remove git tag env from cloud build +* [8286](https://github.com/kubernetes/ingress-nginx/pull/8286) Fix OpenTelemetry sidecar image build +* [8277](https://github.com/kubernetes/ingress-nginx/pull/8277) Add OpenSSF Best practices badge +* [8273](https://github.com/kubernetes/ingress-nginx/pull/8273) Issue#8241 +* [8267](https://github.com/kubernetes/ingress-nginx/pull/8267) Add fsGroup value to admission-webhooks/job-patch charts +* [8262](https://github.com/kubernetes/ingress-nginx/pull/8262) Updated confusing error +* [8256](https://github.com/kubernetes/ingress-nginx/pull/8256) fix: deny locations with invalid auth-url annotation +* [8253](https://github.com/kubernetes/ingress-nginx/pull/8253) Add a certificate info metric +* [8236](https://github.com/kubernetes/ingress-nginx/pull/8236) webhook: remove useless code. +* [8227](https://github.com/kubernetes/ingress-nginx/pull/8227) Update libraries in webhook image +* [8225](https://github.com/kubernetes/ingress-nginx/pull/8225) fix inconsistent-label-cardinality for prometheus metrics: nginx_ingress_controller_requests +* [8221](https://github.com/kubernetes/ingress-nginx/pull/8221) Do not validate ingresses with unknown ingress class in admission webhook endpoint +* [8210](https://github.com/kubernetes/ingress-nginx/pull/8210) Bump github.com/prometheus/client_golang from 1.11.0 to 1.12.1 +* [8209](https://github.com/kubernetes/ingress-nginx/pull/8209) Bump google.golang.org/grpc from 1.43.0 to 1.44.0 +* [8204](https://github.com/kubernetes/ingress-nginx/pull/8204) Add Artifact Hub lint +* [8203](https://github.com/kubernetes/ingress-nginx/pull/8203) Fix Indentation of example and link to cert-manager tutorial +* [8201](https://github.com/kubernetes/ingress-nginx/pull/8201) feat(metrics): add path and method labels to requests countera +* [8199](https://github.com/kubernetes/ingress-nginx/pull/8199) use functional options to reduce number of methods creating an EchoDeployment +* [8196](https://github.com/kubernetes/ingress-nginx/pull/8196) docs: fix inconsistent controller annotation +* [8191](https://github.com/kubernetes/ingress-nginx/pull/8191) Using Go install for misspell +* [8186](https://github.com/kubernetes/ingress-nginx/pull/8186) prometheus+grafana using servicemonitor +* [8185](https://github.com/kubernetes/ingress-nginx/pull/8185) Append elements on match, instead of removing for cors-annotations +* [8179](https://github.com/kubernetes/ingress-nginx/pull/8179) Bump github.com/opencontainers/runc from 1.0.3 to 1.1.0 +* [8173](https://github.com/kubernetes/ingress-nginx/pull/8173) Adding annotations to the controller service account +* [8163](https://github.com/kubernetes/ingress-nginx/pull/8163) Update the $req_id placeholder description +* [8162](https://github.com/kubernetes/ingress-nginx/pull/8162) Versioned static manifests +* [8159](https://github.com/kubernetes/ingress-nginx/pull/8159) Adding some geoip variables and default values +* [8155](https://github.com/kubernetes/ingress-nginx/pull/8155) #7271 feat: avoid-pdb-creation-when-default-backend-disabled-and-replicas-gt-1 +* [8151](https://github.com/kubernetes/ingress-nginx/pull/8151) Automatically generate helm docs +* [8143](https://github.com/kubernetes/ingress-nginx/pull/8143) Allow to configure delay before controller exits +* [8136](https://github.com/kubernetes/ingress-nginx/pull/8136) add ingressClass option to helm chart - back compatibility with ingress.class annotations +* [8126](https://github.com/kubernetes/ingress-nginx/pull/8126) Example for JWT + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.15...helm-chart-4.0.18 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.2.md new file mode 100644 index 0000000..9dbd003 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.2.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.2 + +* [7681] https://github.com/kubernetes/ingress-nginx/pull/7681 Release v1.0.1 of ingress-nginx + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.1...helm-chart-4.0.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.3.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.3.md new file mode 100644 index 0000000..09b89f6 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.3.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.3 + +* [7707] https://github.com/kubernetes/ingress-nginx/pull/7707 Release v1.0.2 of ingress-nginx + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.2...helm-chart-4.0.3 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.5.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.5.md new file mode 100644 index 0000000..be67704 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.5.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.5 + +* [7740] https://github.com/kubernetes/ingress-nginx/pull/7740 Release v1.0.3 of ingress-nginx + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.3...helm-chart-4.0.5 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.6.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.6.md new file mode 100644 index 0000000..25276e2 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.6.md @@ -0,0 +1,12 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.6 + +* [7804] https://github.com/kubernetes/ingress-nginx/pull/7804 Release v1.0.4 of ingress-nginx +* [7651] https://github.com/kubernetes/ingress-nginx/pull/7651 Support ipFamilyPolicy and ipFamilies fields in Helm Chart +* [7798] https://github.com/kubernetes/ingress-nginx/pull/7798 Exoscale: use HTTP Healthcheck mode +* [7793] https://github.com/kubernetes/ingress-nginx/pull/7793 Update kube-webhook-certgen to v1.1.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.5...helm-chart-4.0.6 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.7.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.7.md new file mode 100644 index 0000000..50fd922 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.7.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.7 + +* [7923] https://github.com/kubernetes/ingress-nginx/pull/7923 Release v1.0.5 of ingress-nginx +* [7806] https://github.com/kubernetes/ingress-nginx/pull/7806 Choice option for internal/external loadbalancer type service + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.6...helm-chart-4.0.7 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.9.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.9.md new file mode 100644 index 0000000..f2f725c --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.9.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.0.9 + +* [6992] https://github.com/kubernetes/ingress-nginx/pull/6992 Add ability to specify labels for all resources + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.7...helm-chart-4.0.9 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.0.md new file mode 100644 index 0000000..24aaf49 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.0.md @@ -0,0 +1,21 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.1.0 + +* [8481](https://github.com/kubernetes/ingress-nginx/pull/8481) Fix log creation in chroot script +* [8479](https://github.com/kubernetes/ingress-nginx/pull/8479) changed nginx base img tag to img built with alpine3.14.6 +* [8478](https://github.com/kubernetes/ingress-nginx/pull/8478) update base images and protobuf gomod +* [8468](https://github.com/kubernetes/ingress-nginx/pull/8468) Fallback to ngx.var.scheme for redirectScheme with use-forward-headers when X-Forwarded-Proto is empty +* [8456](https://github.com/kubernetes/ingress-nginx/pull/8456) Implement object deep inspector +* [8455](https://github.com/kubernetes/ingress-nginx/pull/8455) Update dependencies +* [8454](https://github.com/kubernetes/ingress-nginx/pull/8454) Update index.md +* [8447](https://github.com/kubernetes/ingress-nginx/pull/8447) typo fixing +* [8446](https://github.com/kubernetes/ingress-nginx/pull/8446) Fix suggested annotation-value-word-blocklist +* [8444](https://github.com/kubernetes/ingress-nginx/pull/8444) replace deprecated topology key in example with current one +* [8443](https://github.com/kubernetes/ingress-nginx/pull/8443) Add dependency review enforcement +* [8434](https://github.com/kubernetes/ingress-nginx/pull/8434) added new auth-tls-match-cn annotation +* [8426](https://github.com/kubernetes/ingress-nginx/pull/8426) Bump github.com/prometheus/common from 0.32.1 to 0.33.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.18...helm-chart-4.1.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.2.md new file mode 100644 index 0000000..2061855 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.2.md @@ -0,0 +1,11 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.1.2 + +* [8587](https://github.com/kubernetes/ingress-nginx/pull/8587) Add CAP_SYS_CHROOT to DS/PSP when needed +* [8458](https://github.com/kubernetes/ingress-nginx/pull/8458) Add portNamePrefix Helm chart parameter +* [8522](https://github.com/kubernetes/ingress-nginx/pull/8522) Add documentation for controller.service.loadBalancerIP in Helm chart + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.1.0...helm-chart-4.1.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.0.md new file mode 100644 index 0000000..a1f1847 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.0.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.10.0 + +* - "Update Ingress-Nginx version controller-v1.10.0" + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.9.1...helm-chart-4.10.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.1.md new file mode 100644 index 0000000..3a28de0 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.1.md @@ -0,0 +1,11 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.10.1 + +* - "update post submit helm ci and clean up (#11221)" +* - "refactor helm ci tests part I (#11188)" +* - "Update Ingress-Nginx version controller-v1.10.1" + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.10.0...helm-chart-4.10.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.2.md new file mode 100644 index 0000000..399bd98 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.2.md @@ -0,0 +1,18 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.10.2 + +* Chores: Align security contacts & chart maintainers to actual owners. (#11480) +* Fix helm install on cloud provider admonition block (#11412) +* edited helm-install tips (#11411) +* added info for aws helm install (#11410) +* add workflow to helm release and update ct for branch (#11317) +* Merge pull request #11277 from strongjz/chart-1.10.1 (#11314) +* release helm chart from release branch (#11278) +* update post submit helm ci and clean up (#11221) +* refactor helm ci tests part I (#11188) +* Update Ingress-Nginx version controller-v1.10.2 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.10.1...helm-chart-4.10.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.0.md new file mode 100644 index 0000000..64108c0 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.0.md @@ -0,0 +1,18 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.11.0 + +* Chores: Align security contacts & chart maintainers to actual owners. (#11465) +* Merge pull request #11277 from strongjz/chart-1.10.1 (#11415) +* Fix helm install on cloud provider admonition block (#11394) +* edited helm-install tips (#11393) +* added info for aws helm install (#11390) +* add workflow to helm release and update ct for branch (#11378) +* release helm chart from release branch (#11276) +* update post submit helm ci and clean up (#11220) +* refactor helm ci tests part I (#11178) +* Update Ingress-Nginx version controller-v1.11.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.10.2...helm-chart-4.11.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.1.md new file mode 100644 index 0000000..281513e --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.11.1 + +* Update Ingress-Nginx version controller-v1.11.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.11.0...helm-chart-4.11.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.2.md new file mode 100644 index 0000000..c7645a5 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.2.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.11.2 + +* Update Ingress-Nginx version controller-v1.11.2 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.11.1...helm-chart-4.11.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.3.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.3.md new file mode 100644 index 0000000..18ec6ba --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.3.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.11.3 + +* Update Ingress-Nginx version controller-v1.11.3 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.11.2...helm-chart-4.11.3 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.0.md new file mode 100644 index 0000000..2074a09 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.0.md @@ -0,0 +1,47 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.2.0 + +* Support for Kubernetes v1.19.0 was removed +* [8810](https://github.com/kubernetes/ingress-nginx/pull/8810) Prepare for v1.3.0 +* [8808](https://github.com/kubernetes/ingress-nginx/pull/8808) revert arch var name +* [8805](https://github.com/kubernetes/ingress-nginx/pull/8805) Bump k8s.io/klog/v2 from 2.60.1 to 2.70.1 +* [8803](https://github.com/kubernetes/ingress-nginx/pull/8803) Update to nginx base with alpine v3.16 +* [8802](https://github.com/kubernetes/ingress-nginx/pull/8802) chore: start v1.3.0 release process +* [8798](https://github.com/kubernetes/ingress-nginx/pull/8798) Add v1.24.0 to test matrix +* [8796](https://github.com/kubernetes/ingress-nginx/pull/8796) fix: add MAC_OS variable for static-check +* [8793](https://github.com/kubernetes/ingress-nginx/pull/8793) changed to alpine-v3.16 +* [8781](https://github.com/kubernetes/ingress-nginx/pull/8781) Bump github.com/stretchr/testify from 1.7.5 to 1.8.0 +* [8778](https://github.com/kubernetes/ingress-nginx/pull/8778) chore: remove stable.txt from release process +* [8775](https://github.com/kubernetes/ingress-nginx/pull/8775) Remove stable +* [8773](https://github.com/kubernetes/ingress-nginx/pull/8773) Bump github/codeql-action from 2.1.14 to 2.1.15 +* [8772](https://github.com/kubernetes/ingress-nginx/pull/8772) Bump ossf/scorecard-action from 1.1.1 to 1.1.2 +* [8771](https://github.com/kubernetes/ingress-nginx/pull/8771) fix bullet md format +* [8770](https://github.com/kubernetes/ingress-nginx/pull/8770) Add condition for monitoring.coreos.com/v1 API +* [8769](https://github.com/kubernetes/ingress-nginx/pull/8769) Fix typos and add links to developer guide +* [8767](https://github.com/kubernetes/ingress-nginx/pull/8767) change v1.2.0 to v1.2.1 in deploy doc URLs +* [8765](https://github.com/kubernetes/ingress-nginx/pull/8765) Bump github/codeql-action from 1.0.26 to 2.1.14 +* [8752](https://github.com/kubernetes/ingress-nginx/pull/8752) Bump github.com/spf13/cobra from 1.4.0 to 1.5.0 +* [8751](https://github.com/kubernetes/ingress-nginx/pull/8751) Bump github.com/stretchr/testify from 1.7.2 to 1.7.5 +* [8750](https://github.com/kubernetes/ingress-nginx/pull/8750) added announcement +* [8740](https://github.com/kubernetes/ingress-nginx/pull/8740) change sha e2etestrunner and echoserver +* [8738](https://github.com/kubernetes/ingress-nginx/pull/8738) Update docs to make it easier for noobs to follow step by step +* [8737](https://github.com/kubernetes/ingress-nginx/pull/8737) updated baseimage sha +* [8736](https://github.com/kubernetes/ingress-nginx/pull/8736) set ld-musl-path +* [8733](https://github.com/kubernetes/ingress-nginx/pull/8733) feat: migrate leaderelection lock to leases +* [8726](https://github.com/kubernetes/ingress-nginx/pull/8726) prometheus metric: upstream_latency_seconds +* [8720](https://github.com/kubernetes/ingress-nginx/pull/8720) Ci pin deps +* [8719](https://github.com/kubernetes/ingress-nginx/pull/8719) Working OpenTelemetry sidecar (base nginx image) +* [8714](https://github.com/kubernetes/ingress-nginx/pull/8714) Create Openssf scorecard +* [8708](https://github.com/kubernetes/ingress-nginx/pull/8708) Bump github.com/prometheus/common from 0.34.0 to 0.35.0 +* [8703](https://github.com/kubernetes/ingress-nginx/pull/8703) Bump actions/dependency-review-action from 1 to 2 +* [8701](https://github.com/kubernetes/ingress-nginx/pull/8701) Fix several typos +* [8699](https://github.com/kubernetes/ingress-nginx/pull/8699) fix the gosec test and a make target for it +* [8698](https://github.com/kubernetes/ingress-nginx/pull/8698) Bump actions/upload-artifact from 2.3.1 to 3.1.0 +* [8697](https://github.com/kubernetes/ingress-nginx/pull/8697) Bump actions/setup-go from 2.2.0 to 3.2.0 +* [8695](https://github.com/kubernetes/ingress-nginx/pull/8695) Bump actions/download-artifact from 2 to 3 +* [8694](https://github.com/kubernetes/ingress-nginx/pull/8694) Bump crazy-max/ghaction-docker-buildx from 1.6.2 to 3.3.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.1.2...helm-chart-4.2.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.1.md new file mode 100644 index 0000000..7965bb1 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.1.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.2.1 + +* The sha of kube-webhook-certgen image & the opentelemetry image, in values file, was changed to new images built on alpine-v3.16.1 +* [8896](https://github.com/kubernetes/ingress-nginx/pull/8896) updated to new images built today + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.2.0...helm-chart-4.2.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.3.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.3.0.md new file mode 100644 index 0000000..f9dca22 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.3.0.md @@ -0,0 +1,14 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.3.0 + +* Support for Kubernetes v.1.25.0 was added and support for endpoint slices +* Support for Kubernetes v1.20.0 and v1.21.0 was removed +* [8890](https://github.com/kubernetes/ingress-nginx/pull/8890) migrate to endpointslices +* [9059](https://github.com/kubernetes/ingress-nginx/pull/9059) kubewebhookcertgen sha change after go1191 +* [9046](https://github.com/kubernetes/ingress-nginx/pull/9046) Parameterize metrics port name +* [9104](https://github.com/kubernetes/ingress-nginx/pull/9104) Fix yaml formatting error with multiple annotations + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.2.1...helm-chart-4.3.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.4.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.4.0.md new file mode 100644 index 0000000..20f9e23 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.4.0.md @@ -0,0 +1,12 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.4.0 + +* Adding support for disabling liveness and readiness probes to the Helm chart by @njegosrailic in https://github.com/kubernetes/ingress-nginx/pull/9238 +* add:(admission-webhooks) ability to set securityContext by @ybelMekk in https://github.com/kubernetes/ingress-nginx/pull/9186 +* #7652 - Updated Helm chart to use the fullname for the electionID if not specified. by @FutureMatt in https://github.com/kubernetes/ingress-nginx/pull/9133 +* Rename controller-wehbooks-networkpolicy.yaml. by @Gacko in https://github.com/kubernetes/ingress-nginx/pull/9123 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.3.0...helm-chart-4.4.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.5.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.5.2.md new file mode 100644 index 0000000..b6d8a3b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.5.2.md @@ -0,0 +1,13 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.5.2 + +* add lint on chart before release (#9570) +* ci: remove setup-helm step (#9404) +* feat(helm): Optionally use cert-manager instead admission patch (#9279) +* run helm release on main only and when the chart/value changes only (#9290) +* Update Ingress-Nginx version controller-v1.6.4 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.4.3...helm-chart-4.5.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.0.md new file mode 100644 index 0000000..469aaba --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.0.md @@ -0,0 +1,24 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.5.3 + +* docs(helm): fix value key in readme for enabling certManager (#9640) +* Upgrade alpine 3.17.2 +* Upgrade golang 1.20 +* Drop testing/support for Kubernetes 1.23 +* docs(helm): fix value key in readme for enabling certManager (#9640) +* Update Ingress-Nginx version controller-v1.7.0 +* feat: OpenTelemetry module integration (#9062) +* canary-weight-total annotation ignored in rule backends (#9729) +* fix controller psp's volume config (#9740) +* Fix several Helm YAML issues with extraModules and extraInitContainers (#9709) +* Chart: Drop `controller.headers`, rework DH param secret. (#9659) +* Deployment/DaemonSet: Label pods using `ingress-nginx.labels`. (#9732) +* HPA: autoscaling/v2beta1 deprecated, bump apiVersion to v2 for defaultBackend (#9731) +* Fix incorrect annotation name in upstream hashing configuration (#9617) + +* Update Ingress-Nginx version controller-v1.7.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.5.2...helm-chart-4.6.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.1.md new file mode 100644 index 0000000..57d99b8 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.1.md @@ -0,0 +1,11 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.6.1 + +* [helm] Support custom port configuration for internal service (#9846) +* Adding resource type to default HPA configuration to resolve issues with Terraform helm chart usage (#9803) +* Update Ingress-Nginx version controller-v1.7.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.6.0...helm-chart-4.6.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.0.md new file mode 100644 index 0000000..9d54070 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.0.md @@ -0,0 +1,14 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.7.0 + +* helm: Fix opentelemetry module installation for daemonset (#9792) +* Update charts/* to keep project name display aligned (#9931) +* HPA: Use capabilities & align manifests. (#9521) +* PodDisruptionBudget spec logic update (#9904) +* add option for annotations in PodDisruptionBudget (#9843) +* Update Ingress-Nginx version controller-v1.8.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.6.1...helm-chart-4.7.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.1.md new file mode 100644 index 0000000..4d69a71 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.1.md @@ -0,0 +1,12 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.7.1 + +* Added a doc line to the missing helm value service.internal.loadBalancerIP (#9406) +* feat(helm): Add loadBalancerClass (#9562) +* added helmshowvalues example (#10019) +* Update Ingress-Nginx version controller-v1.8.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.7.0...helm-chart-4.7.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.2.md new file mode 100644 index 0000000..57b17b9 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.2.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.7.2 + +* Update Ingress-Nginx version controller-v1.8.2 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.7.1...helm-chart-4.7.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0-beta.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0-beta.0.md new file mode 100644 index 0000000..9072a75 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0-beta.0.md @@ -0,0 +1,13 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.8.0-beta.0 + +* ci(helm): fix Helm Chart release action 422 error (#10237) +* helm: Use .Release.Namespace as default for ServiceMonitor namespace (#10249) +* [helm] configure allow to configure hostAliases (#10180) +* [helm] pass service annotations through helm tpl engine (#10084) +* Update Ingress-Nginx version controller-v1.9.0-beta.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.7.2...helm-chart-4.8.0-beta.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0.md new file mode 100644 index 0000000..af8f124 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0.md @@ -0,0 +1,13 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.8.0 + +* ci(helm): fix Helm Chart release action 422 error (#10237) +* helm: Use .Release.Namespace as default for ServiceMonitor namespace (#10249) +* [helm] configure allow to configure hostAliases (#10180) +* [helm] pass service annotations through helm tpl engine (#10084) +* Update Ingress-Nginx version controller-v1.9.0 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.7.2...helm-chart-4.8.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.1.md new file mode 100644 index 0000000..53a4493 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.1.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.8.1 + +* Update Ingress-Nginx version controller-v1.9.1 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.8.0...helm-chart-4.8.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.2.md new file mode 100644 index 0000000..9957c1a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.2.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.8.2 + +* update nginx base, httpbun, e2e, helm webhook cert gen (#10506) +* Update Ingress-Nginx version controller-v1.9.3 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.8.1...helm-chart-4.8.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.3.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.3.md new file mode 100644 index 0000000..b8d4d56 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.3.md @@ -0,0 +1,9 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.8.3 + +* Update Ingress-Nginx version controller-v1.9.4 + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.8.2...helm-chart-4.8.3 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.0.md new file mode 100644 index 0000000..5c77298 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.0.md @@ -0,0 +1,13 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.9.0 + +* - "Add controller.metrics.serviceMonitor.annotations in Helm chart" +* - "fix(labels): use complete labels variable on default-backend deployment" +* - "chart: allow setting allocateLoadBalancerNodePorts (#10693)" +* - "[release-1.9] feat(helm): add documentation about metric args (#10695)" +* - "Update Ingress-Nginx version controller-v1.9.5" + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.8.3...helm-chart-4.9.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.1.md new file mode 100644 index 0000000..c6120e7 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.1.md @@ -0,0 +1,10 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### 4.9.1 + +* - "update web hook cert gen to latest release v20231226-1a7112e06" +* - "Update Ingress-Nginx version controller-v1.9.6" + +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.9.0...helm-chart-4.9.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart.md.gotmpl b/charts/keep/charts/ingress-nginx/changelog/helm-chart.md.gotmpl new file mode 100644 index 0000000..ef5add5 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/changelog/helm-chart.md.gotmpl @@ -0,0 +1,11 @@ +# Changelog + +This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). + +### {{ .NewHelmChartVersion }} +{{ with .HelmUpdates }} +{{- range . }} +* {{ . }} +{{- end }} +{{ end }} +**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-{{ .PreviousHelmChartVersion }}...helm-chart-{{ .NewHelmChartVersion }} diff --git a/charts/keep/charts/ingress-nginx/ci/admission-webhooks-cert-manager-values.yaml b/charts/keep/charts/ingress-nginx/ci/admission-webhooks-cert-manager-values.yaml new file mode 100644 index 0000000..7eafd0c --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/admission-webhooks-cert-manager-values.yaml @@ -0,0 +1,12 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + admissionWebhooks: + certManager: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-configmap-addheaders-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-configmap-addheaders-values.yaml new file mode 100644 index 0000000..460a610 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-configmap-addheaders-values.yaml @@ -0,0 +1,11 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + addHeaders: + X-Frame-Options: deny diff --git a/charts/keep/charts/ingress-nginx/ci/controller-configmap-proxyheaders-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-configmap-proxyheaders-values.yaml new file mode 100644 index 0000000..e23a13c --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-configmap-proxyheaders-values.yaml @@ -0,0 +1,11 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + proxySetHeaders: + X-Forwarded-Proto: https diff --git a/charts/keep/charts/ingress-nginx/ci/controller-configmap-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-configmap-values.yaml new file mode 100644 index 0000000..a702989 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-configmap-values.yaml @@ -0,0 +1,11 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + config: + use-proxy-protocol: "true" diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-extra-modules-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-extra-modules-values.yaml new file mode 100644 index 0000000..edf12e7 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-extra-modules-values.yaml @@ -0,0 +1,30 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: DaemonSet + + extraModules: + - name: opentelemetry + image: + registry: registry.k8s.io + image: ingress-nginx/opentelemetry-1.25.3 + tag: v20240813-b933310d + digest: sha256:f7604ac0547ed64d79b98d92133234e66c2c8aade3c1f4809fed5eec1fb7f922 + distroless: true + containerSecurityContext: + runAsNonRoot: true + runAsUser: 65532 + runAsGroup: 65532 + allowPrivilegeEscalation: false + seccompProfile: + type: RuntimeDefault + capabilities: + drop: + - ALL + readOnlyRootFilesystem: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-metrics-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-metrics-values.yaml new file mode 100644 index 0000000..7a98580 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-metrics-values.yaml @@ -0,0 +1,13 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: DaemonSet + + metrics: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-opentelemetry-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-opentelemetry-values.yaml new file mode 100644 index 0000000..179ab2a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-opentelemetry-values.yaml @@ -0,0 +1,13 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: DaemonSet + + opentelemetry: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-podannotations-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-podannotations-values.yaml new file mode 100644 index 0000000..405992e --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-podannotations-values.yaml @@ -0,0 +1,16 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: DaemonSet + + podAnnotations: + prometheus.io/scrape: "true" + prometheus.io/port: "10254" + prometheus.io/scheme: http + prometheus.io/path: /metrics diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-values.yaml new file mode 100644 index 0000000..d34025c --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-values.yaml @@ -0,0 +1,10 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: DaemonSet diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-extra-modules-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-extra-modules-values.yaml new file mode 100644 index 0000000..d4083cc --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-deployment-extra-modules-values.yaml @@ -0,0 +1,30 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: Deployment + + extraModules: + - name: opentelemetry + image: + registry: registry.k8s.io + image: ingress-nginx/opentelemetry-1.25.3 + tag: v20240813-b933310d + digest: sha256:f7604ac0547ed64d79b98d92133234e66c2c8aade3c1f4809fed5eec1fb7f922 + distroless: true + containerSecurityContext: + runAsNonRoot: true + runAsUser: 65532 + runAsGroup: 65532 + allowPrivilegeEscalation: false + seccompProfile: + type: RuntimeDefault + capabilities: + drop: + - ALL + readOnlyRootFilesystem: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-metrics-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-metrics-values.yaml new file mode 100644 index 0000000..9c95d34 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-deployment-metrics-values.yaml @@ -0,0 +1,13 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: Deployment + + metrics: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-opentelemetry-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-opentelemetry-values.yaml new file mode 100644 index 0000000..9443dde --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-deployment-opentelemetry-values.yaml @@ -0,0 +1,13 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: Deployment + + opentelemetry: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-podannotations-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-podannotations-values.yaml new file mode 100644 index 0000000..cf1f261 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-deployment-podannotations-values.yaml @@ -0,0 +1,16 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: Deployment + + podAnnotations: + prometheus.io/scrape: "true" + prometheus.io/port: "10254" + prometheus.io/scheme: http + prometheus.io/path: /metrics diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-values.yaml new file mode 100644 index 0000000..1b092dc --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-deployment-values.yaml @@ -0,0 +1,10 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + kind: Deployment diff --git a/charts/keep/charts/ingress-nginx/ci/controller-hpa-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-hpa-values.yaml new file mode 100644 index 0000000..54a0d2f --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-hpa-values.yaml @@ -0,0 +1,18 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + autoscaling: + enabled: true + behavior: + scaleDown: + stabilizationWindowSeconds: 300 + policies: + - type: Pods + value: 1 + periodSeconds: 180 diff --git a/charts/keep/charts/ingress-nginx/ci/controller-ingressclass-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-ingressclass-values.yaml new file mode 100644 index 0000000..c06429f --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-ingressclass-values.yaml @@ -0,0 +1,15 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + ingressClassResource: + name: custom-nginx + default: true + controllerValue: k8s.io/custom-nginx + + watchIngressWithoutClass: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-service-internal-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-service-internal-values.yaml new file mode 100644 index 0000000..11108fb --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-service-internal-values.yaml @@ -0,0 +1,13 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: ClusterIP + + internal: + enabled: true + annotations: + service.beta.kubernetes.io/aws-load-balancer-internal: "true" diff --git a/charts/keep/charts/ingress-nginx/ci/controller-service-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-service-values.yaml new file mode 100644 index 0000000..9039368 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/controller-service-values.yaml @@ -0,0 +1,22 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + + service: + type: NodePort + + nodePorts: + tcp: + 9000: 30090 + udp: + 9001: 30091 + +portNamePrefix: port + +tcp: + 9000: default/test:8080 + +udp: + 9001: default/test:8080 diff --git a/charts/keep/charts/ingress-nginx/ci/deamonset-psp-values.yaml b/charts/keep/charts/ingress-nginx/ci/deamonset-psp-values.yaml new file mode 100644 index 0000000..8026a63 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/deamonset-psp-values.yaml @@ -0,0 +1,13 @@ +controller: + kind: DaemonSet + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + admissionWebhooks: + enabled: false + service: + type: ClusterIP + +podSecurityPolicy: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/deamonset-webhook-and-psp-values.yaml b/charts/keep/charts/ingress-nginx/ci/deamonset-webhook-and-psp-values.yaml new file mode 100644 index 0000000..fccdb13 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/deamonset-webhook-and-psp-values.yaml @@ -0,0 +1,13 @@ +controller: + kind: DaemonSet + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + admissionWebhooks: + enabled: true + service: + type: ClusterIP + +podSecurityPolicy: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/deployment-psp-values.yaml b/charts/keep/charts/ingress-nginx/ci/deployment-psp-values.yaml new file mode 100644 index 0000000..2f332a7 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/deployment-psp-values.yaml @@ -0,0 +1,10 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + service: + type: ClusterIP + +podSecurityPolicy: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/deployment-webhook-and-psp-values.yaml b/charts/keep/charts/ingress-nginx/ci/deployment-webhook-and-psp-values.yaml new file mode 100644 index 0000000..6195bb3 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/ci/deployment-webhook-and-psp-values.yaml @@ -0,0 +1,12 @@ +controller: + image: + repository: ingress-controller/controller + tag: 1.0.0-dev + digest: null + admissionWebhooks: + enabled: true + service: + type: ClusterIP + +podSecurityPolicy: + enabled: true diff --git a/charts/keep/charts/ingress-nginx/templates/NOTES.txt b/charts/keep/charts/ingress-nginx/templates/NOTES.txt new file mode 100644 index 0000000..f492300 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/NOTES.txt @@ -0,0 +1,73 @@ +The ingress-nginx controller has been installed. + +{{- if contains "NodePort" .Values.controller.service.type }} +Get the application URL by running these commands: + +{{- if (not (empty .Values.controller.service.nodePorts.http)) }} + export HTTP_NODE_PORT={{ .Values.controller.service.nodePorts.http }} +{{- else }} + export HTTP_NODE_PORT=$(kubectl get service --namespace {{ include "ingress-nginx.namespace" . }} {{ include "ingress-nginx.controller.fullname" . }} --output jsonpath="{.spec.ports[0].nodePort}") +{{- end }} +{{- if (not (empty .Values.controller.service.nodePorts.https)) }} + export HTTPS_NODE_PORT={{ .Values.controller.service.nodePorts.https }} +{{- else }} + export HTTPS_NODE_PORT=$(kubectl get service --namespace {{ include "ingress-nginx.namespace" . }} {{ include "ingress-nginx.controller.fullname" . }} --output jsonpath="{.spec.ports[1].nodePort}") +{{- end }} + export NODE_IP="$(kubectl get nodes --output jsonpath="{.items[0].status.addresses[1].address}")" + + echo "Visit http://${NODE_IP}:${HTTP_NODE_PORT} to access your application via HTTP." + echo "Visit https://${NODE_IP}:${HTTPS_NODE_PORT} to access your application via HTTPS." +{{- else if contains "LoadBalancer" .Values.controller.service.type }} +It may take a few minutes for the load balancer IP to be available. +You can watch the status by running 'kubectl get service --namespace {{ include "ingress-nginx.namespace" . }} {{ include "ingress-nginx.controller.fullname" . }} --output wide --watch' +{{- else if contains "ClusterIP" .Values.controller.service.type }} +Get the application URL by running these commands: + export POD_NAME="$(kubectl get pods --namespace {{ include "ingress-nginx.namespace" . }} --selector app.kubernetes.io/name={{ include "ingress-nginx.name" . }},app.kubernetes.io/instance={{ .Release.Name }},app.kubernetes.io/component=controller --output jsonpath="{.items[0].metadata.name}")" + kubectl port-forward --namespace {{ include "ingress-nginx.namespace" . }} "${POD_NAME}" 8080:80 + echo "Visit http://127.0.0.1:8080 to access your application." +{{- end }} + +An example Ingress that makes use of the controller: + +{{- $isV1 := semverCompare ">=1" .Chart.AppVersion}} + apiVersion: networking.k8s.io/v1 + kind: Ingress + metadata: + name: example + namespace: foo + {{- if eq $isV1 false }} + annotations: + kubernetes.io/ingress.class: {{ .Values.controller.ingressClass }} + {{- end }} + spec: + {{- if $isV1 }} + ingressClassName: {{ .Values.controller.ingressClassResource.name }} + {{- end }} + rules: + - host: www.example.com + http: + paths: + - pathType: Prefix + backend: + service: + name: exampleService + port: + number: 80 + path: / + # This section is only required if TLS is to be enabled for the Ingress + tls: + - hosts: + - www.example.com + secretName: example-tls + +If TLS is enabled for the Ingress, a Secret containing the certificate and key must also be provided: + + apiVersion: v1 + kind: Secret + metadata: + name: example-tls + namespace: foo + data: + tls.crt: + tls.key: + type: kubernetes.io/tls diff --git a/charts/keep/charts/ingress-nginx/templates/_helpers.tpl b/charts/keep/charts/ingress-nginx/templates/_helpers.tpl new file mode 100644 index 0000000..24cfd14 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/_helpers.tpl @@ -0,0 +1,272 @@ +{{/* vim: set filetype=mustache: */}} +{{/* +Expand the name of the chart. +*/}} +{{- define "ingress-nginx.name" -}} +{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" -}} +{{- end -}} + +{{/* +Create chart name and version as used by the chart label. +*/}} +{{- define "ingress-nginx.chart" -}} +{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | 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). +*/}} +{{- define "ingress-nginx.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 -}} + +{{/* +Expand the namespace of the release. +Allows overriding it for multi-namespace deployments in combined charts. +*/}} +{{- define "ingress-nginx.namespace" -}} +{{- default .Release.Namespace .Values.namespaceOverride | trunc 63 | trimSuffix "-" -}} +{{- end -}} + +{{/* +Controller container security context. +*/}} +{{- define "ingress-nginx.controller.containerSecurityContext" -}} +{{- if .Values.controller.containerSecurityContext -}} +{{- toYaml .Values.controller.containerSecurityContext -}} +{{- else -}} +runAsNonRoot: {{ .Values.controller.image.runAsNonRoot }} +runAsUser: {{ .Values.controller.image.runAsUser }} +allowPrivilegeEscalation: {{ or .Values.controller.image.allowPrivilegeEscalation .Values.controller.image.chroot }} +{{- if .Values.controller.image.seccompProfile }} +seccompProfile: {{ toYaml .Values.controller.image.seccompProfile | nindent 2 }} +{{- end }} +capabilities: + drop: + - ALL + add: + - NET_BIND_SERVICE + {{- if .Values.controller.image.chroot }} + {{- if .Values.controller.image.seccompProfile }} + - SYS_ADMIN + {{- end }} + - SYS_CHROOT + {{- end }} +readOnlyRootFilesystem: {{ .Values.controller.image.readOnlyRootFilesystem }} +{{- end -}} +{{- end -}} + +{{/* +Get specific image +*/}} +{{- define "ingress-nginx.image" -}} +{{- if .chroot -}} +{{- printf "%s-chroot" .image -}} +{{- else -}} +{{- printf "%s" .image -}} +{{- end }} +{{- end -}} + +{{/* +Get specific image digest +*/}} +{{- define "ingress-nginx.imageDigest" -}} +{{- if .chroot -}} +{{- if .digestChroot -}} +{{- printf "@%s" .digestChroot -}} +{{- end }} +{{- else -}} +{{ if .digest -}} +{{- printf "@%s" .digest -}} +{{- end -}} +{{- end -}} +{{- end -}} + +{{/* +Create a default fully qualified controller name. +We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). +*/}} +{{- define "ingress-nginx.controller.fullname" -}} +{{- printf "%s-%s" (include "ingress-nginx.fullname" .) .Values.controller.name | trunc 63 | trimSuffix "-" -}} +{{- end -}} + +{{/* +Construct a unique electionID. +Users can provide an override for an explicit electionID if they want via `.Values.controller.electionID` +*/}} +{{- define "ingress-nginx.controller.electionID" -}} +{{- $defElectionID := printf "%s-leader" (include "ingress-nginx.fullname" .) -}} +{{- $electionID := default $defElectionID .Values.controller.electionID -}} +{{- print $electionID -}} +{{- end -}} + +{{/* +Construct the path for the publish-service. + +By convention this will simply use the / to match the name of the +service generated. + +Users can provide an override for an explicit service they want bound via `.Values.controller.publishService.pathOverride` +*/}} +{{- define "ingress-nginx.controller.publishServicePath" -}} +{{- $defServiceName := printf "%s/%s" "$(POD_NAMESPACE)" (include "ingress-nginx.controller.fullname" .) -}} +{{- $servicePath := default $defServiceName .Values.controller.publishService.pathOverride }} +{{- print $servicePath | trimSuffix "-" -}} +{{- end -}} + +{{/* +Common labels +*/}} +{{- define "ingress-nginx.labels" -}} +helm.sh/chart: {{ include "ingress-nginx.chart" . }} +{{ include "ingress-nginx.selectorLabels" . }} +{{- if .Chart.AppVersion }} +app.kubernetes.io/version: {{ .Chart.AppVersion | quote }} +{{- end }} +app.kubernetes.io/part-of: {{ template "ingress-nginx.name" . }} +app.kubernetes.io/managed-by: {{ .Release.Service }} +{{- if .Values.commonLabels}} +{{ toYaml .Values.commonLabels }} +{{- end }} +{{- end -}} + +{{/* +Selector labels +*/}} +{{- define "ingress-nginx.selectorLabels" -}} +app.kubernetes.io/name: {{ include "ingress-nginx.name" . }} +app.kubernetes.io/instance: {{ .Release.Name }} +{{- end -}} + +{{/* +Create the name of the controller service account to use +*/}} +{{- define "ingress-nginx.serviceAccountName" -}} +{{- if .Values.serviceAccount.create -}} + {{ default (include "ingress-nginx.fullname" .) .Values.serviceAccount.name }} +{{- else -}} + {{ default "default" .Values.serviceAccount.name }} +{{- end -}} +{{- end -}} + +{{/* +Create a default fully qualified admission webhook name. +We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). +*/}} +{{- define "ingress-nginx.admissionWebhooks.fullname" -}} +{{- printf "%s-%s" (include "ingress-nginx.fullname" .) .Values.controller.admissionWebhooks.name | trunc 63 | trimSuffix "-" -}} +{{- end -}} + +{{/* +Create the name of the admission webhook patch job service account to use +*/}} +{{- define "ingress-nginx.admissionWebhooks.patch.serviceAccountName" -}} +{{- if .Values.controller.admissionWebhooks.patch.serviceAccount.create -}} + {{ default (include "ingress-nginx.admissionWebhooks.fullname" .) .Values.controller.admissionWebhooks.patch.serviceAccount.name }} +{{- else -}} + {{ default "default" .Values.controller.admissionWebhooks.patch.serviceAccount.name }} +{{- end -}} +{{- end -}} + +{{/* +Create a default fully qualified admission webhook secret creation job name. +We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). +*/}} +{{- define "ingress-nginx.admissionWebhooks.createSecretJob.fullname" -}} +{{- printf "%s-%s" (include "ingress-nginx.admissionWebhooks.fullname" .) .Values.controller.admissionWebhooks.createSecretJob.name | trunc 63 | trimSuffix "-" -}} +{{- end -}} + +{{/* +Create a default fully qualified admission webhook patch job name. +We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). +*/}} +{{- define "ingress-nginx.admissionWebhooks.patchWebhookJob.fullname" -}} +{{- printf "%s-%s" (include "ingress-nginx.admissionWebhooks.fullname" .) .Values.controller.admissionWebhooks.patchWebhookJob.name | trunc 63 | trimSuffix "-" -}} +{{- end -}} + +{{/* +Create a default fully qualified default backend name. +We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). +*/}} +{{- define "ingress-nginx.defaultBackend.fullname" -}} +{{- printf "%s-%s" (include "ingress-nginx.fullname" .) .Values.defaultBackend.name | trunc 63 | trimSuffix "-" -}} +{{- end -}} + +{{/* +Create the name of the default backend service account to use +*/}} +{{- define "ingress-nginx.defaultBackend.serviceAccountName" -}} +{{- if .Values.defaultBackend.serviceAccount.create -}} + {{ default (printf "%s-backend" (include "ingress-nginx.fullname" .)) .Values.defaultBackend.serviceAccount.name }} +{{- else -}} + {{ default "default-backend" .Values.defaultBackend.serviceAccount.name }} +{{- end -}} +{{- end -}} + +{{/* +Default backend container security context. +*/}} +{{- define "ingress-nginx.defaultBackend.containerSecurityContext" -}} +{{- if .Values.defaultBackend.containerSecurityContext -}} +{{- toYaml .Values.defaultBackend.containerSecurityContext -}} +{{- else -}} +runAsNonRoot: {{ .Values.defaultBackend.image.runAsNonRoot }} +runAsUser: {{ .Values.defaultBackend.image.runAsUser }} +allowPrivilegeEscalation: {{ .Values.defaultBackend.image.allowPrivilegeEscalation }} +{{- if .Values.defaultBackend.image.seccompProfile }} +seccompProfile: {{ toYaml .Values.defaultBackend.image.seccompProfile | nindent 2 }} +{{- end }} +capabilities: + drop: + - ALL +readOnlyRootFilesystem: {{ .Values.defaultBackend.image.readOnlyRootFilesystem }} +{{- end -}} +{{- end -}} + +{{/* +Return the appropriate apiGroup for PodSecurityPolicy. +*/}} +{{- define "podSecurityPolicy.apiGroup" -}} +{{- if semverCompare ">=1.14-0" .Capabilities.KubeVersion.GitVersion -}} +{{- print "policy" -}} +{{- else -}} +{{- print "extensions" -}} +{{- end -}} +{{- end -}} + +{{/* +Extra modules. +*/}} +{{- define "extraModules" -}} +- name: {{ .name }} + {{- with .image }} + image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ .image }}{{ end }}:{{ .tag }}{{ if .digest }}@{{ .digest }}{{ end }} + command: + {{- if .distroless }} + - /init_module + {{- else }} + - sh + - -c + - /usr/local/bin/init_module.sh + {{- end }} + {{- end }} + {{- if .containerSecurityContext }} + securityContext: {{ toYaml .containerSecurityContext | nindent 4 }} + {{- end }} + {{- if .resources }} + resources: {{ toYaml .resources | nindent 4 }} + {{- end }} + volumeMounts: + - name: modules + mountPath: /modules_mount +{{- end -}} diff --git a/charts/keep/charts/ingress-nginx/templates/_params.tpl b/charts/keep/charts/ingress-nginx/templates/_params.tpl new file mode 100644 index 0000000..48569a8 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/_params.tpl @@ -0,0 +1,77 @@ +{{- define "ingress-nginx.params" -}} +- /nginx-ingress-controller +{{- if .Values.controller.enableAnnotationValidations }} +- --enable-annotation-validation=true +{{- end }} +{{- if .Values.defaultBackend.enabled }} +- --default-backend-service=$(POD_NAMESPACE)/{{ include "ingress-nginx.defaultBackend.fullname" . }} +{{- end }} +{{- if and .Values.controller.publishService.enabled .Values.controller.service.enabled }} +{{- if .Values.controller.service.external.enabled }} +- --publish-service={{ template "ingress-nginx.controller.publishServicePath" . }} +{{- else if .Values.controller.service.internal.enabled }} +- --publish-service={{ template "ingress-nginx.controller.publishServicePath" . }}-internal +{{- end }} +{{- end }} +- --election-id={{ include "ingress-nginx.controller.electionID" . }} +- --controller-class={{ .Values.controller.ingressClassResource.controllerValue }} +{{- if .Values.controller.ingressClass }} +- --ingress-class={{ .Values.controller.ingressClass }} +{{- end }} +- --configmap={{ default "$(POD_NAMESPACE)" .Values.controller.configMapNamespace }}/{{ include "ingress-nginx.controller.fullname" . }} +{{- if .Values.tcp }} +- --tcp-services-configmap={{ default "$(POD_NAMESPACE)" .Values.controller.tcp.configMapNamespace }}/{{ include "ingress-nginx.fullname" . }}-tcp +{{- end }} +{{- if .Values.udp }} +- --udp-services-configmap={{ default "$(POD_NAMESPACE)" .Values.controller.udp.configMapNamespace }}/{{ include "ingress-nginx.fullname" . }}-udp +{{- end }} +{{- if .Values.controller.scope.enabled }} +- --watch-namespace={{ default "$(POD_NAMESPACE)" .Values.controller.scope.namespace }} +{{- end }} +{{- if and (not .Values.controller.scope.enabled) .Values.controller.scope.namespaceSelector }} +- --watch-namespace-selector={{ .Values.controller.scope.namespaceSelector }} +{{- end }} +{{- if and .Values.controller.reportNodeInternalIp .Values.controller.hostNetwork }} +- --report-node-internal-ip-address={{ .Values.controller.reportNodeInternalIp }} +{{- end }} +{{- if .Values.controller.admissionWebhooks.enabled }} +- --validating-webhook=:{{ .Values.controller.admissionWebhooks.port }} +- --validating-webhook-certificate={{ .Values.controller.admissionWebhooks.certificate }} +- --validating-webhook-key={{ .Values.controller.admissionWebhooks.key }} +{{- end }} +{{- if .Values.controller.maxmindLicenseKey }} +- --maxmind-license-key={{ .Values.controller.maxmindLicenseKey }} +{{- end }} +{{- if .Values.controller.healthCheckHost }} +- --healthz-host={{ .Values.controller.healthCheckHost }} +{{- end }} +{{- if not (eq .Values.controller.healthCheckPath "/healthz") }} +- --health-check-path={{ .Values.controller.healthCheckPath }} +{{- end }} +{{- if .Values.controller.ingressClassByName }} +- --ingress-class-by-name=true +{{- end }} +{{- if .Values.controller.watchIngressWithoutClass }} +- --watch-ingress-without-class=true +{{- end }} +{{- if not .Values.controller.metrics.enabled }} +- --enable-metrics={{ .Values.controller.metrics.enabled }} +{{- end }} +{{- if .Values.controller.enableTopologyAwareRouting }} +- --enable-topology-aware-routing=true +{{- end }} +{{- if .Values.controller.disableLeaderElection }} +- --disable-leader-election=true +{{- end }} +{{- if .Values.controller.electionTTL }} +- --election-ttl={{ .Values.controller.electionTTL }} +{{- end }} +{{- range $key, $value := .Values.controller.extraArgs }} +{{- /* Accept keys without values or with false as value */}} +{{- if eq ($value | quote | len) 2 }} +- --{{ $key }} +{{- else }} +- --{{ $key }}={{ $value }} +{{- end }} +{{- end }} +{{- end -}} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/cert-manager.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/cert-manager.yaml new file mode 100644 index 0000000..db2946c --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/cert-manager.yaml @@ -0,0 +1,63 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.certManager.enabled -}} +{{- if not .Values.controller.admissionWebhooks.certManager.issuerRef -}} +# Create a selfsigned Issuer, in order to create a root CA certificate for +# signing webhook serving certificates +apiVersion: cert-manager.io/v1 +kind: Issuer +metadata: + name: {{ include "ingress-nginx.fullname" . }}-self-signed-issuer + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + selfSigned: {} +--- +# Generate a CA Certificate used to sign certificates for the webhook +apiVersion: cert-manager.io/v1 +kind: Certificate +metadata: + name: {{ include "ingress-nginx.fullname" . }}-root-cert + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + secretName: {{ include "ingress-nginx.fullname" . }}-root-cert + duration: {{ .Values.controller.admissionWebhooks.certManager.rootCert.duration | default "43800h0m0s" | quote }} + issuerRef: + name: {{ include "ingress-nginx.fullname" . }}-self-signed-issuer + commonName: "ca.webhook.ingress-nginx" + isCA: true + subject: + organizations: + - ingress-nginx +--- +# Create an Issuer that uses the above generated CA certificate to issue certs +apiVersion: cert-manager.io/v1 +kind: Issuer +metadata: + name: {{ include "ingress-nginx.fullname" . }}-root-issuer + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + ca: + secretName: {{ include "ingress-nginx.fullname" . }}-root-cert +{{- end }} +--- +# generate a server certificate for the apiservices to use +apiVersion: cert-manager.io/v1 +kind: Certificate +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + secretName: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + duration: {{ .Values.controller.admissionWebhooks.certManager.admissionCert.duration | default "8760h0m0s" | quote }} + issuerRef: + {{- if .Values.controller.admissionWebhooks.certManager.issuerRef }} + {{- toYaml .Values.controller.admissionWebhooks.certManager.issuerRef | nindent 4 }} + {{- else }} + name: {{ include "ingress-nginx.fullname" . }}-root-issuer + {{- end }} + dnsNames: + - {{ include "ingress-nginx.controller.fullname" . }}-admission + - {{ include "ingress-nginx.controller.fullname" . }}-admission.{{ include "ingress-nginx.namespace" . }} + - {{ include "ingress-nginx.controller.fullname" . }}-admission.{{ include "ingress-nginx.namespace" . }}.svc + subject: + organizations: + - ingress-nginx-admission +{{- end -}} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml new file mode 100644 index 0000000..a218482 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml @@ -0,0 +1,33 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.rbac.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +rules: + - apiGroups: + - admissionregistration.k8s.io + resources: + - validatingwebhookconfigurations + verbs: + - get + - update +{{- if .Values.podSecurityPolicy.enabled }} + - apiGroups: [{{ template "podSecurityPolicy.apiGroup" . }}] + resources: ['podsecuritypolicies'] + verbs: ['use'] + {{- with .Values.controller.admissionWebhooks.existingPsp }} + resourceNames: [{{ . }}] + {{- else }} + resourceNames: [{{ include "ingress-nginx.admissionWebhooks.fullname" . }}] + {{- end }} +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml new file mode 100644 index 0000000..b893884 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml @@ -0,0 +1,23 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.rbac.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} +subjects: + - kind: ServiceAccount + name: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml new file mode 100644 index 0000000..1766164 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml @@ -0,0 +1,79 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled (not .Values.controller.admissionWebhooks.certManager.enabled) -}} +apiVersion: batch/v1 +kind: Job +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.createSecretJob.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + annotations: + "helm.sh/hook": pre-install,pre-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + {{- with .Values.controller.admissionWebhooks.annotations }} + {{- toYaml . | nindent 4 }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +spec: +{{- if .Capabilities.APIVersions.Has "batch/v1alpha1" }} + # Alpha feature since k8s 1.12 + ttlSecondsAfterFinished: 0 +{{- end }} + template: + metadata: + name: {{ include "ingress-nginx.admissionWebhooks.createSecretJob.fullname" . }} + {{- if .Values.controller.admissionWebhooks.patch.podAnnotations }} + annotations: {{ toYaml .Values.controller.admissionWebhooks.patch.podAnnotations | nindent 8 }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 8 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 8 }} + {{- end }} + spec: + {{- if .Values.controller.admissionWebhooks.patch.priorityClassName }} + priorityClassName: {{ .Values.controller.admissionWebhooks.patch.priorityClassName }} + {{- end }} + {{- if .Values.imagePullSecrets }} + imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} + {{- end }} + containers: + - name: create + {{- with .Values.controller.admissionWebhooks.patch.image }} + image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ .image }}{{ end }}:{{ .tag }}{{ if .digest }}@{{ .digest }}{{ end }} + {{- end }} + imagePullPolicy: {{ .Values.controller.admissionWebhooks.patch.image.pullPolicy }} + args: + - create + - --host={{ include "ingress-nginx.controller.fullname" . }}-admission,{{ include "ingress-nginx.controller.fullname" . }}-admission.$(POD_NAMESPACE).svc + - --namespace=$(POD_NAMESPACE) + - --secret-name={{ include "ingress-nginx.admissionWebhooks.fullname" . }} + env: + - name: POD_NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + {{- if .Values.controller.admissionWebhooks.extraEnvs }} + {{- toYaml .Values.controller.admissionWebhooks.extraEnvs | nindent 12 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.createSecretJob.securityContext }} + securityContext: {{ toYaml .Values.controller.admissionWebhooks.createSecretJob.securityContext | nindent 12 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.createSecretJob.resources }} + resources: {{ toYaml .Values.controller.admissionWebhooks.createSecretJob.resources | nindent 12 }} + {{- end }} + restartPolicy: OnFailure + serviceAccountName: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} + {{- if .Values.controller.admissionWebhooks.patch.nodeSelector }} + nodeSelector: {{ toYaml .Values.controller.admissionWebhooks.patch.nodeSelector | nindent 8 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.patch.tolerations }} + tolerations: {{ toYaml .Values.controller.admissionWebhooks.patch.tolerations | nindent 8 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.patch.securityContext }} + securityContext: {{ toYaml .Values.controller.admissionWebhooks.patch.securityContext | nindent 8 }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml new file mode 100644 index 0000000..f7d44a2 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml @@ -0,0 +1,81 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled (not .Values.controller.admissionWebhooks.certManager.enabled) -}} +apiVersion: batch/v1 +kind: Job +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.patchWebhookJob.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + annotations: + "helm.sh/hook": post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + {{- with .Values.controller.admissionWebhooks.annotations }} + {{- toYaml . | nindent 4 }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +spec: +{{- if .Capabilities.APIVersions.Has "batch/v1alpha1" }} + # Alpha feature since k8s 1.12 + ttlSecondsAfterFinished: 0 +{{- end }} + template: + metadata: + name: {{ include "ingress-nginx.admissionWebhooks.patchWebhookJob.fullname" . }} + {{- if .Values.controller.admissionWebhooks.patch.podAnnotations }} + annotations: {{ toYaml .Values.controller.admissionWebhooks.patch.podAnnotations | nindent 8 }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 8 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 8 }} + {{- end }} + spec: + {{- if .Values.controller.admissionWebhooks.patch.priorityClassName }} + priorityClassName: {{ .Values.controller.admissionWebhooks.patch.priorityClassName }} + {{- end }} + {{- if .Values.imagePullSecrets }} + imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} + {{- end }} + containers: + - name: patch + {{- with .Values.controller.admissionWebhooks.patch.image }} + image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ .image }}{{ end }}:{{ .tag }}{{ if .digest }}@{{ .digest }}{{ end }} + {{- end }} + imagePullPolicy: {{ .Values.controller.admissionWebhooks.patch.image.pullPolicy }} + args: + - patch + - --webhook-name={{ include "ingress-nginx.admissionWebhooks.fullname" . }} + - --namespace=$(POD_NAMESPACE) + - --patch-mutating=false + - --secret-name={{ include "ingress-nginx.admissionWebhooks.fullname" . }} + - --patch-failure-policy={{ .Values.controller.admissionWebhooks.failurePolicy }} + env: + - name: POD_NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + {{- if .Values.controller.admissionWebhooks.extraEnvs }} + {{- toYaml .Values.controller.admissionWebhooks.extraEnvs | nindent 12 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.patchWebhookJob.securityContext }} + securityContext: {{ toYaml .Values.controller.admissionWebhooks.patchWebhookJob.securityContext | nindent 12 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.patchWebhookJob.resources }} + resources: {{ toYaml .Values.controller.admissionWebhooks.patchWebhookJob.resources | nindent 12 }} + {{- end }} + restartPolicy: OnFailure + serviceAccountName: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} + {{- if .Values.controller.admissionWebhooks.patch.nodeSelector }} + nodeSelector: {{ toYaml .Values.controller.admissionWebhooks.patch.nodeSelector | nindent 8 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.patch.tolerations }} + tolerations: {{ toYaml .Values.controller.admissionWebhooks.patch.tolerations | nindent 8 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.patch.securityContext }} + securityContext: {{ toYaml .Values.controller.admissionWebhooks.patch.securityContext | nindent 8 }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/networkpolicy.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/networkpolicy.yaml new file mode 100644 index 0000000..a8f38df --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/networkpolicy.yaml @@ -0,0 +1,26 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.networkPolicy.enabled (not .Values.controller.admissionWebhooks.certManager.enabled) -}} +apiVersion: networking.k8s.io/v1 +kind: NetworkPolicy +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +spec: + podSelector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: admission-webhook + policyTypes: + - Ingress + - Egress + egress: + - {} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/psp.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/psp.yaml new file mode 100644 index 0000000..8e5dc72 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/psp.yaml @@ -0,0 +1,52 @@ +{{- if (semverCompare "<1.25.0-0" .Capabilities.KubeVersion.Version) }} +{{- if and .Values.podSecurityPolicy.enabled .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled (empty .Values.controller.admissionWebhooks.existingPsp) -}} +apiVersion: policy/v1beta1 +kind: PodSecurityPolicy +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + seccomp.security.alpha.kubernetes.io/allowedProfileNames: "*" + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +spec: + privileged: false + hostPID: false + hostIPC: false + hostNetwork: false + volumes: + - configMap + - downwardAPI + - emptyDir + - secret + - projected + fsGroup: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + readOnlyRootFilesystem: true + runAsUser: + rule: MustRunAsNonRoot + runAsGroup: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + supplementalGroups: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + allowPrivilegeEscalation: false + requiredDropCapabilities: + - ALL + seLinux: + rule: RunAsAny +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml new file mode 100644 index 0000000..c4b23aa --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml @@ -0,0 +1,24 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.rbac.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +rules: + - apiGroups: + - "" + resources: + - secrets + verbs: + - get + - create +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml new file mode 100644 index 0000000..425e8d8 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml @@ -0,0 +1,24 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.rbac.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} +subjects: + - kind: ServiceAccount + name: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml new file mode 100644 index 0000000..52f94dc --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml @@ -0,0 +1,17 @@ +{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.serviceAccount.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} +apiVersion: v1 +kind: ServiceAccount +metadata: + name: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + annotations: + "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade + "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.patch.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +automountServiceAccountToken: {{ .Values.controller.admissionWebhooks.patch.serviceAccount.automountServiceAccountToken }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml new file mode 100644 index 0000000..0949cea --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml @@ -0,0 +1,54 @@ +{{- if .Values.controller.admissionWebhooks.enabled -}} +# before changing this value, check the required kubernetes version +# https://kubernetes.io/docs/reference/access-authn-authz/extensible-admission-controllers/#prerequisites +apiVersion: admissionregistration.k8s.io/v1 +kind: ValidatingWebhookConfiguration +metadata: + annotations: + {{- if .Values.controller.admissionWebhooks.certManager.enabled }} + certmanager.k8s.io/inject-ca-from: {{ printf "%s/%s" (include "ingress-nginx.namespace" .) (include "ingress-nginx.admissionWebhooks.fullname" .) | quote }} + cert-manager.io/inject-ca-from: {{ printf "%s/%s" (include "ingress-nginx.namespace" .) (include "ingress-nginx.admissionWebhooks.fullname" .) | quote }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.annotations }} + {{- toYaml .Values.controller.admissionWebhooks.annotations | nindent 4 }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: admission-webhook + {{- with .Values.controller.admissionWebhooks.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} +webhooks: + - name: validate.nginx.ingress.kubernetes.io + matchPolicy: Equivalent + rules: + - apiGroups: + - networking.k8s.io + apiVersions: + - v1 + operations: + - CREATE + - UPDATE + resources: + - ingresses + failurePolicy: {{ .Values.controller.admissionWebhooks.failurePolicy | default "Fail" }} + sideEffects: None + admissionReviewVersions: + - v1 + clientConfig: + service: + name: {{ include "ingress-nginx.controller.fullname" . }}-admission + namespace: {{ include "ingress-nginx.namespace" . }} + port: {{ .Values.controller.admissionWebhooks.service.servicePort }} + path: /networking/v1/ingresses + {{- if .Values.controller.admissionWebhooks.timeoutSeconds }} + timeoutSeconds: {{ .Values.controller.admissionWebhooks.timeoutSeconds }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.namespaceSelector }} + namespaceSelector: {{ toYaml .Values.controller.admissionWebhooks.namespaceSelector | nindent 6 }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.objectSelector }} + objectSelector: {{ toYaml .Values.controller.admissionWebhooks.objectSelector | nindent 6 }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/clusterrole.yaml b/charts/keep/charts/ingress-nginx/templates/clusterrole.yaml new file mode 100644 index 0000000..51bc500 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/clusterrole.yaml @@ -0,0 +1,102 @@ +{{- if .Values.rbac.create }} + +{{- if and .Values.rbac.scope (not .Values.controller.scope.enabled) -}} + {{ required "Invalid configuration: 'rbac.scope' should be equal to 'controller.scope.enabled' (true/false)." (index (dict) ".") }} +{{- end }} + +{{- if not .Values.rbac.scope -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.fullname" . }} +rules: + - apiGroups: + - "" + resources: + - configmaps + - endpoints + - nodes + - pods + - secrets +{{- if not .Values.controller.scope.enabled }} + - namespaces +{{- end}} + verbs: + - list + - watch + - apiGroups: + - coordination.k8s.io + resources: + - leases + verbs: + - list + - watch +{{- if and .Values.controller.scope.enabled .Values.controller.scope.namespace }} + - apiGroups: + - "" + resources: + - namespaces + resourceNames: + - "{{ .Values.controller.scope.namespace }}" + verbs: + - get +{{- end }} + - apiGroups: + - "" + resources: + - nodes + verbs: + - get + - apiGroups: + - "" + resources: + - services + verbs: + - get + - list + - watch + - apiGroups: + - networking.k8s.io + resources: + - ingresses + verbs: + - get + - list + - watch + - apiGroups: + - "" + resources: + - events + verbs: + - create + - patch + - apiGroups: + - networking.k8s.io + resources: + - ingresses/status + verbs: + - update + - apiGroups: + - networking.k8s.io + resources: + - ingressclasses + verbs: + - get + - list + - watch + - apiGroups: + - discovery.k8s.io + resources: + - endpointslices + verbs: + - list + - watch + - get +{{- end }} + +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/clusterrolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/clusterrolebinding.yaml new file mode 100644 index 0000000..8f91aac --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/clusterrolebinding.yaml @@ -0,0 +1,19 @@ +{{- if and .Values.rbac.create (not .Values.rbac.scope) -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.fullname" . }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: {{ include "ingress-nginx.fullname" . }} +subjects: + - kind: ServiceAccount + name: {{ template "ingress-nginx.serviceAccountName" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap-addheaders.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap-addheaders.yaml new file mode 100644 index 0000000..4e4bd13 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-configmap-addheaders.yaml @@ -0,0 +1,14 @@ +{{- if .Values.controller.addHeaders -}} +apiVersion: v1 +kind: ConfigMap +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.fullname" . }}-custom-add-headers + namespace: {{ include "ingress-nginx.namespace" . }} +data: {{ toYaml .Values.controller.addHeaders | nindent 2 }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap-proxyheaders.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap-proxyheaders.yaml new file mode 100644 index 0000000..0a22600 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-configmap-proxyheaders.yaml @@ -0,0 +1,14 @@ +{{- if .Values.controller.proxySetHeaders -}} +apiVersion: v1 +kind: ConfigMap +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.fullname" . }}-custom-proxy-headers + namespace: {{ include "ingress-nginx.namespace" . }} +data: {{ toYaml .Values.controller.proxySetHeaders | nindent 2 }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap-tcp.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap-tcp.yaml new file mode 100644 index 0000000..131a9ad --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-configmap-tcp.yaml @@ -0,0 +1,17 @@ +{{- if .Values.tcp -}} +apiVersion: v1 +kind: ConfigMap +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +{{- if .Values.controller.tcp.annotations }} + annotations: {{ toYaml .Values.controller.tcp.annotations | nindent 4 }} +{{- end }} + name: {{ include "ingress-nginx.fullname" . }}-tcp + namespace: {{ include "ingress-nginx.namespace" . }} +data: {{ tpl (toYaml .Values.tcp) . | nindent 2 }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap-udp.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap-udp.yaml new file mode 100644 index 0000000..7137da9 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-configmap-udp.yaml @@ -0,0 +1,17 @@ +{{- if .Values.udp -}} +apiVersion: v1 +kind: ConfigMap +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +{{- if .Values.controller.udp.annotations }} + annotations: {{ toYaml .Values.controller.udp.annotations | nindent 4 }} +{{- end }} + name: {{ include "ingress-nginx.fullname" . }}-udp + namespace: {{ include "ingress-nginx.namespace" . }} +data: {{ tpl (toYaml .Values.udp) . | nindent 2 }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap.yaml new file mode 100644 index 0000000..22080d1 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-configmap.yaml @@ -0,0 +1,28 @@ +apiVersion: v1 +kind: ConfigMap +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +{{- if .Values.controller.configAnnotations }} + annotations: {{ toYaml .Values.controller.configAnnotations | nindent 4 }} +{{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +data: + allow-snippet-annotations: "{{ .Values.controller.allowSnippetAnnotations }}" +{{- if .Values.controller.addHeaders }} + add-headers: {{ include "ingress-nginx.namespace" . }}/{{ include "ingress-nginx.fullname" . }}-custom-add-headers +{{- end }} +{{- if .Values.controller.proxySetHeaders }} + proxy-set-headers: {{ include "ingress-nginx.namespace" . }}/{{ include "ingress-nginx.fullname" . }}-custom-proxy-headers +{{- end }} +{{- if .Values.dhParam }} + ssl-dh-param: {{ include "ingress-nginx.namespace" . }}/{{ include "ingress-nginx.controller.fullname" . }} +{{- end }} +{{- range $key, $value := .Values.controller.config }} + {{- $key | nindent 2 }}: {{ tpl (toString $value) $ | quote }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-daemonset.yaml b/charts/keep/charts/ingress-nginx/templates/controller-daemonset.yaml new file mode 100644 index 0000000..fcc633d --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-daemonset.yaml @@ -0,0 +1,242 @@ +{{- if eq .Values.controller.kind "DaemonSet" -}} +apiVersion: apps/v1 +kind: DaemonSet +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + {{- if .Values.controller.annotations }} + annotations: {{ toYaml .Values.controller.annotations | nindent 4 }} + {{- end }} +spec: + selector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: controller + revisionHistoryLimit: {{ .Values.revisionHistoryLimit }} + {{- if .Values.controller.updateStrategy }} + updateStrategy: {{ toYaml .Values.controller.updateStrategy | nindent 4 }} + {{- end }} + minReadySeconds: {{ .Values.controller.minReadySeconds }} + template: + metadata: + {{- if .Values.controller.podAnnotations }} + annotations: + {{- range $key, $value := .Values.controller.podAnnotations }} + {{ $key }}: {{ $value | quote }} + {{- end }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 8 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 8 }} + {{- end }} + {{- if .Values.controller.podLabels }} + {{- toYaml .Values.controller.podLabels | nindent 8 }} + {{- end }} + spec: + {{- if .Values.controller.dnsConfig }} + dnsConfig: {{ toYaml .Values.controller.dnsConfig | nindent 8 }} + {{- end }} + {{- if .Values.controller.hostAliases }} + hostAliases: {{ tpl (toYaml .Values.controller.hostAliases) $ | nindent 8 }} + {{- end }} + {{- if .Values.controller.hostname }} + hostname: {{ toYaml .Values.controller.hostname | nindent 8 }} + {{- end }} + dnsPolicy: {{ .Values.controller.dnsPolicy }} + {{- if .Values.imagePullSecrets }} + imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} + {{- end }} + {{- if .Values.controller.priorityClassName }} + priorityClassName: {{ .Values.controller.priorityClassName | quote }} + {{- end }} + {{- if or .Values.controller.podSecurityContext .Values.controller.sysctls }} + securityContext: + {{- if .Values.controller.podSecurityContext }} + {{- toYaml .Values.controller.podSecurityContext | nindent 8 }} + {{- end }} + {{- if .Values.controller.sysctls }} + sysctls: + {{- range $sysctl, $value := .Values.controller.sysctls }} + - name: {{ $sysctl | quote }} + value: {{ $value | quote }} + {{- end }} + {{- end }} + {{- end }} + {{- if .Values.controller.shareProcessNamespace }} + shareProcessNamespace: {{ .Values.controller.shareProcessNamespace }} + {{- end }} + containers: + - name: {{ .Values.controller.containerName }} + {{- with .Values.controller.image }} + image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ include "ingress-nginx.image" . }}{{ end }}:{{ .tag }}{{ include "ingress-nginx.imageDigest" . }} + {{- end }} + imagePullPolicy: {{ .Values.controller.image.pullPolicy }} + {{- if .Values.controller.lifecycle }} + lifecycle: {{ toYaml .Values.controller.lifecycle | nindent 12 }} + {{- end }} + args: {{ include "ingress-nginx.params" . | nindent 12 }} + securityContext: {{ include "ingress-nginx.controller.containerSecurityContext" . | nindent 12 }} + env: + - name: POD_NAME + valueFrom: + fieldRef: + fieldPath: metadata.name + - name: POD_NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + {{- if .Values.controller.enableMimalloc }} + - name: LD_PRELOAD + value: /usr/local/lib/libmimalloc.so + {{- end }} + {{- if .Values.controller.extraEnvs }} + {{- toYaml .Values.controller.extraEnvs | nindent 12 }} + {{- end }} + {{- if .Values.controller.startupProbe }} + startupProbe: {{ toYaml .Values.controller.startupProbe | nindent 12 }} + {{- end }} + {{- if .Values.controller.livenessProbe }} + livenessProbe: {{ toYaml .Values.controller.livenessProbe | nindent 12 }} + {{- end }} + {{- if .Values.controller.readinessProbe }} + readinessProbe: {{ toYaml .Values.controller.readinessProbe | nindent 12 }} + {{- end }} + ports: + {{- range $key, $value := .Values.controller.containerPort }} + - name: {{ $key }} + containerPort: {{ $value }} + protocol: TCP + {{- if $.Values.controller.hostPort.enabled }} + hostPort: {{ index $.Values.controller.hostPort.ports $key | default $value }} + {{- end }} + {{- end }} + {{- if .Values.controller.metrics.enabled }} + - name: {{ .Values.controller.metrics.portName }} + containerPort: {{ .Values.controller.metrics.port }} + protocol: TCP + {{- end }} + {{- if .Values.controller.admissionWebhooks.enabled }} + - name: webhook + containerPort: {{ .Values.controller.admissionWebhooks.port }} + protocol: TCP + {{- end }} + {{- range $key, $value := .Values.tcp }} + - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp + containerPort: {{ $key }} + protocol: TCP + {{- if $.Values.controller.hostPort.enabled }} + hostPort: {{ $key }} + {{- end }} + {{- end }} + {{- range $key, $value := .Values.udp }} + - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp + containerPort: {{ $key }} + protocol: UDP + {{- if $.Values.controller.hostPort.enabled }} + hostPort: {{ $key }} + {{- end }} + {{- end }} + {{- if (or .Values.controller.customTemplate.configMapName .Values.controller.extraVolumeMounts .Values.controller.admissionWebhooks.enabled .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} + volumeMounts: + {{- if (or .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} + - name: modules + {{- if .Values.controller.image.chroot }} + mountPath: /chroot/modules_mount + {{- else }} + mountPath: /modules_mount + {{- end }} + {{- end }} + {{- if .Values.controller.customTemplate.configMapName }} + - mountPath: /etc/nginx/template + name: nginx-template-volume + readOnly: true + {{- end }} + {{- if .Values.controller.admissionWebhooks.enabled }} + - name: webhook-cert + mountPath: /usr/local/certificates/ + readOnly: true + {{- end }} + {{- if .Values.controller.extraVolumeMounts }} + {{- toYaml .Values.controller.extraVolumeMounts | nindent 12 }} + {{- end }} + {{- end }} + {{- if .Values.controller.resources }} + resources: {{ toYaml .Values.controller.resources | nindent 12 }} + {{- end }} + {{- if .Values.controller.extraContainers }} + {{- toYaml .Values.controller.extraContainers | nindent 8 }} + {{- end }} + {{- if (or .Values.controller.extraInitContainers .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} + initContainers: + {{- if .Values.controller.extraInitContainers }} + {{- toYaml .Values.controller.extraInitContainers | nindent 8 }} + {{- end }} + {{- if .Values.controller.extraModules }} + {{- range .Values.controller.extraModules }} + {{- $containerSecurityContext := .containerSecurityContext | default $.Values.controller.containerSecurityContext }} + {{- include "extraModules" (dict "name" .name "image" .image "containerSecurityContext" $containerSecurityContext "resources" .resources) | nindent 8 }} + {{- end }} + {{- end }} + {{- if .Values.controller.opentelemetry.enabled }} + {{- with .Values.controller.opentelemetry }} + {{- $containerSecurityContext := .containerSecurityContext | default $.Values.controller.containerSecurityContext }} + {{- include "extraModules" (dict "name" .name "image" .image "containerSecurityContext" $containerSecurityContext "resources" .resources) | nindent 8 }} + {{- end }} + {{- end }} + {{- end }} + {{- if .Values.controller.hostNetwork }} + hostNetwork: {{ .Values.controller.hostNetwork }} + {{- end }} + {{- if .Values.controller.nodeSelector }} + nodeSelector: {{ toYaml .Values.controller.nodeSelector | nindent 8 }} + {{- end }} + {{- if .Values.controller.tolerations }} + tolerations: {{ toYaml .Values.controller.tolerations | nindent 8 }} + {{- end }} + {{- if .Values.controller.affinity }} + affinity: {{ tpl (toYaml .Values.controller.affinity) $ | nindent 8 }} + {{- end }} + {{- if .Values.controller.topologySpreadConstraints }} + topologySpreadConstraints: {{ tpl (toYaml .Values.controller.topologySpreadConstraints) $ | nindent 8 }} + {{- end }} + serviceAccountName: {{ template "ingress-nginx.serviceAccountName" . }} + terminationGracePeriodSeconds: {{ .Values.controller.terminationGracePeriodSeconds }} + {{- if (or .Values.controller.customTemplate.configMapName .Values.controller.extraVolumeMounts .Values.controller.admissionWebhooks.enabled .Values.controller.extraVolumes .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} + volumes: + {{- if (or .Values.controller.extraModules .Values.controller.opentelemetry.enabled)}} + - name: modules + emptyDir: {} + {{- end }} + {{- if .Values.controller.customTemplate.configMapName }} + - name: nginx-template-volume + configMap: + name: {{ .Values.controller.customTemplate.configMapName }} + items: + - key: {{ .Values.controller.customTemplate.configMapKey }} + path: nginx.tmpl + {{- end }} + {{- if .Values.controller.admissionWebhooks.enabled }} + - name: webhook-cert + secret: + secretName: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + {{- if .Values.controller.admissionWebhooks.certManager.enabled }} + items: + - key: tls.crt + path: cert + - key: tls.key + path: key + {{- end }} + {{- end }} + {{- if .Values.controller.extraVolumes }} + {{ toYaml .Values.controller.extraVolumes | nindent 8 }} + {{- end }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-deployment.yaml b/charts/keep/charts/ingress-nginx/templates/controller-deployment.yaml new file mode 100644 index 0000000..5211acd --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-deployment.yaml @@ -0,0 +1,245 @@ +{{- if eq .Values.controller.kind "Deployment" -}} +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + {{- if .Values.controller.annotations }} + annotations: {{ toYaml .Values.controller.annotations | nindent 4 }} + {{- end }} +spec: + selector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: controller + {{- if eq .Values.controller.autoscaling.enabled .Values.controller.keda.enabled }} + replicas: {{ .Values.controller.replicaCount }} + {{- end }} + revisionHistoryLimit: {{ .Values.revisionHistoryLimit }} + {{- if .Values.controller.updateStrategy }} + strategy: {{ toYaml .Values.controller.updateStrategy | nindent 4 }} + {{- end }} + minReadySeconds: {{ .Values.controller.minReadySeconds }} + template: + metadata: + {{- if .Values.controller.podAnnotations }} + annotations: + {{- range $key, $value := .Values.controller.podAnnotations }} + {{ $key }}: {{ $value | quote }} + {{- end }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 8 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 8 }} + {{- end }} + {{- if .Values.controller.podLabels }} + {{- toYaml .Values.controller.podLabels | nindent 8 }} + {{- end }} + spec: + {{- if .Values.controller.dnsConfig }} + dnsConfig: {{ toYaml .Values.controller.dnsConfig | nindent 8 }} + {{- end }} + {{- if .Values.controller.hostAliases }} + hostAliases: {{ tpl (toYaml .Values.controller.hostAliases) $ | nindent 8 }} + {{- end }} + {{- if .Values.controller.hostname }} + hostname: {{ toYaml .Values.controller.hostname | nindent 8 }} + {{- end }} + dnsPolicy: {{ .Values.controller.dnsPolicy }} + {{- if .Values.imagePullSecrets }} + imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} + {{- end }} + {{- if .Values.controller.priorityClassName }} + priorityClassName: {{ .Values.controller.priorityClassName | quote }} + {{- end }} + {{- if or .Values.controller.podSecurityContext .Values.controller.sysctls }} + securityContext: + {{- if .Values.controller.podSecurityContext }} + {{- toYaml .Values.controller.podSecurityContext | nindent 8 }} + {{- end }} + {{- if .Values.controller.sysctls }} + sysctls: + {{- range $sysctl, $value := .Values.controller.sysctls }} + - name: {{ $sysctl | quote }} + value: {{ $value | quote }} + {{- end }} + {{- end }} + {{- end }} + {{- if .Values.controller.shareProcessNamespace }} + shareProcessNamespace: {{ .Values.controller.shareProcessNamespace }} + {{- end }} + containers: + - name: {{ .Values.controller.containerName }} + {{- with .Values.controller.image }} + image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ include "ingress-nginx.image" . }}{{ end }}:{{ .tag }}{{ include "ingress-nginx.imageDigest" . }} + {{- end }} + imagePullPolicy: {{ .Values.controller.image.pullPolicy }} + {{- if .Values.controller.lifecycle }} + lifecycle: {{ toYaml .Values.controller.lifecycle | nindent 12 }} + {{- end }} + args: {{ include "ingress-nginx.params" . | nindent 12 }} + securityContext: {{ include "ingress-nginx.controller.containerSecurityContext" . | nindent 12 }} + env: + - name: POD_NAME + valueFrom: + fieldRef: + fieldPath: metadata.name + - name: POD_NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + {{- if .Values.controller.enableMimalloc }} + - name: LD_PRELOAD + value: /usr/local/lib/libmimalloc.so + {{- end }} + {{- if .Values.controller.extraEnvs }} + {{- toYaml .Values.controller.extraEnvs | nindent 12 }} + {{- end }} + {{- if .Values.controller.startupProbe }} + startupProbe: {{ toYaml .Values.controller.startupProbe | nindent 12 }} + {{- end }} + {{- if .Values.controller.livenessProbe }} + livenessProbe: {{ toYaml .Values.controller.livenessProbe | nindent 12 }} + {{- end }} + {{- if .Values.controller.readinessProbe }} + readinessProbe: {{ toYaml .Values.controller.readinessProbe | nindent 12 }} + {{- end }} + ports: + {{- range $key, $value := .Values.controller.containerPort }} + - name: {{ $key }} + containerPort: {{ $value }} + protocol: TCP + {{- if $.Values.controller.hostPort.enabled }} + hostPort: {{ index $.Values.controller.hostPort.ports $key | default $value }} + {{- end }} + {{- end }} + {{- if .Values.controller.metrics.enabled }} + - name: {{ .Values.controller.metrics.portName }} + containerPort: {{ .Values.controller.metrics.port }} + protocol: TCP + {{- end }} + {{- if .Values.controller.admissionWebhooks.enabled }} + - name: webhook + containerPort: {{ .Values.controller.admissionWebhooks.port }} + protocol: TCP + {{- end }} + {{- range $key, $value := .Values.tcp }} + - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp + containerPort: {{ $key }} + protocol: TCP + {{- if $.Values.controller.hostPort.enabled }} + hostPort: {{ $key }} + {{- end }} + {{- end }} + {{- range $key, $value := .Values.udp }} + - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp + containerPort: {{ $key }} + protocol: UDP + {{- if $.Values.controller.hostPort.enabled }} + hostPort: {{ $key }} + {{- end }} + {{- end }} + {{- if (or .Values.controller.customTemplate.configMapName .Values.controller.extraVolumeMounts .Values.controller.admissionWebhooks.enabled .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} + volumeMounts: + {{- if (or .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} + - name: modules + {{- if .Values.controller.image.chroot }} + mountPath: /chroot/modules_mount + {{- else }} + mountPath: /modules_mount + {{- end }} + {{- end }} + {{- if .Values.controller.customTemplate.configMapName }} + - mountPath: /etc/nginx/template + name: nginx-template-volume + readOnly: true + {{- end }} + {{- if .Values.controller.admissionWebhooks.enabled }} + - name: webhook-cert + mountPath: /usr/local/certificates/ + readOnly: true + {{- end }} + {{- if .Values.controller.extraVolumeMounts }} + {{- toYaml .Values.controller.extraVolumeMounts | nindent 12 }} + {{- end }} + {{- end }} + {{- if .Values.controller.resources }} + resources: {{ toYaml .Values.controller.resources | nindent 12 }} + {{- end }} + {{- if .Values.controller.extraContainers }} + {{- toYaml .Values.controller.extraContainers | nindent 8 }} + {{- end }} + {{- if (or .Values.controller.extraInitContainers .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} + initContainers: + {{- if .Values.controller.extraInitContainers }} + {{- toYaml .Values.controller.extraInitContainers | nindent 8 }} + {{- end }} + {{- if .Values.controller.extraModules }} + {{- range .Values.controller.extraModules }} + {{- $containerSecurityContext := .containerSecurityContext | default $.Values.controller.containerSecurityContext }} + {{- include "extraModules" (dict "name" .name "image" .image "containerSecurityContext" $containerSecurityContext "resources" .resources) | nindent 8 }} + {{- end }} + {{- end }} + {{- if .Values.controller.opentelemetry.enabled }} + {{- with .Values.controller.opentelemetry }} + {{- $containerSecurityContext := .containerSecurityContext | default $.Values.controller.containerSecurityContext }} + {{- include "extraModules" (dict "name" .name "image" .image "containerSecurityContext" $containerSecurityContext "resources" .resources) | nindent 8 }} + {{- end }} + {{- end }} + {{- end }} + {{- if .Values.controller.hostNetwork }} + hostNetwork: {{ .Values.controller.hostNetwork }} + {{- end }} + {{- if .Values.controller.nodeSelector }} + nodeSelector: {{ toYaml .Values.controller.nodeSelector | nindent 8 }} + {{- end }} + {{- if .Values.controller.tolerations }} + tolerations: {{ toYaml .Values.controller.tolerations | nindent 8 }} + {{- end }} + {{- if .Values.controller.affinity }} + affinity: {{ tpl (toYaml .Values.controller.affinity) $ | nindent 8 }} + {{- end }} + {{- if .Values.controller.topologySpreadConstraints }} + topologySpreadConstraints: {{ tpl (toYaml .Values.controller.topologySpreadConstraints) $ | nindent 8 }} + {{- end }} + serviceAccountName: {{ template "ingress-nginx.serviceAccountName" . }} + terminationGracePeriodSeconds: {{ .Values.controller.terminationGracePeriodSeconds }} + {{- if (or .Values.controller.customTemplate.configMapName .Values.controller.extraVolumeMounts .Values.controller.admissionWebhooks.enabled .Values.controller.extraVolumes .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} + volumes: + {{- if (or .Values.controller.extraModules .Values.controller.opentelemetry.enabled)}} + - name: modules + emptyDir: {} + {{- end }} + {{- if .Values.controller.customTemplate.configMapName }} + - name: nginx-template-volume + configMap: + name: {{ .Values.controller.customTemplate.configMapName }} + items: + - key: {{ .Values.controller.customTemplate.configMapKey }} + path: nginx.tmpl + {{- end }} + {{- if .Values.controller.admissionWebhooks.enabled }} + - name: webhook-cert + secret: + secretName: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} + {{- if .Values.controller.admissionWebhooks.certManager.enabled }} + items: + - key: tls.crt + path: cert + - key: tls.key + path: key + {{- end }} + {{- end }} + {{- if .Values.controller.extraVolumes }} + {{ toYaml .Values.controller.extraVolumes | nindent 8 }} + {{- end }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-hpa.yaml b/charts/keep/charts/ingress-nginx/templates/controller-hpa.yaml new file mode 100644 index 0000000..ec9ad73 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-hpa.yaml @@ -0,0 +1,47 @@ +{{- if and (eq .Values.controller.kind "Deployment") .Values.controller.autoscaling.enabled (not .Values.controller.keda.enabled) -}} +apiVersion: {{ ternary "autoscaling/v2" "autoscaling/v2beta2" (.Capabilities.APIVersions.Has "autoscaling/v2") }} +kind: HorizontalPodAutoscaler +metadata: + {{- with .Values.controller.autoscaling.annotations }} + annotations: {{ toYaml . | nindent 4 }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + scaleTargetRef: + apiVersion: apps/v1 + kind: Deployment + name: {{ include "ingress-nginx.controller.fullname" . }} + minReplicas: {{ .Values.controller.autoscaling.minReplicas }} + maxReplicas: {{ .Values.controller.autoscaling.maxReplicas }} + metrics: + {{- with .Values.controller.autoscaling.targetMemoryUtilizationPercentage }} + - type: Resource + resource: + name: memory + target: + type: Utilization + averageUtilization: {{ . }} + {{- end }} + {{- with .Values.controller.autoscaling.targetCPUUtilizationPercentage }} + - type: Resource + resource: + name: cpu + target: + type: Utilization + averageUtilization: {{ . }} + {{- end }} + {{- with .Values.controller.autoscalingTemplate }} + {{- toYaml . | nindent 2 }} + {{- end }} + {{- with .Values.controller.autoscaling.behavior }} + behavior: + {{- toYaml . | nindent 4 }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-ingressclass-aliases.yaml b/charts/keep/charts/ingress-nginx/templates/controller-ingressclass-aliases.yaml new file mode 100644 index 0000000..ffe2231 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-ingressclass-aliases.yaml @@ -0,0 +1,23 @@ +{{- if .Values.controller.ingressClassResource.enabled -}} +{{- range .Values.controller.ingressClassResource.aliases }} +--- +apiVersion: networking.k8s.io/v1 +kind: IngressClass +metadata: + labels: + {{- include "ingress-nginx.labels" $ | nindent 4 }} + app.kubernetes.io/component: controller + {{- with $.Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ . }} + {{- if $.Values.controller.ingressClassResource.annotations }} + annotations: {{ toYaml $.Values.controller.ingressClassResource.annotations | nindent 4 }} + {{- end }} +spec: + controller: {{ $.Values.controller.ingressClassResource.controllerValue }} + {{- with $.Values.controller.ingressClassResource.parameters }} + parameters: {{ toYaml . | nindent 4 }} + {{- end }} +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-ingressclass.yaml b/charts/keep/charts/ingress-nginx/templates/controller-ingressclass.yaml new file mode 100644 index 0000000..98479a5 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-ingressclass.yaml @@ -0,0 +1,26 @@ +{{- if .Values.controller.ingressClassResource.enabled -}} +apiVersion: networking.k8s.io/v1 +kind: IngressClass +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ .Values.controller.ingressClassResource.name }} + {{- if or .Values.controller.ingressClassResource.default .Values.controller.ingressClassResource.annotations }} + annotations: + {{- if .Values.controller.ingressClassResource.default }} + ingressclass.kubernetes.io/is-default-class: "true" + {{- end }} + {{- if .Values.controller.ingressClassResource.annotations }} + {{- toYaml .Values.controller.ingressClassResource.annotations | nindent 4 }} + {{- end }} + {{- end }} +spec: + controller: {{ .Values.controller.ingressClassResource.controllerValue }} + {{- with .Values.controller.ingressClassResource.parameters }} + parameters: {{ toYaml . | nindent 4 }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-keda.yaml b/charts/keep/charts/ingress-nginx/templates/controller-keda.yaml new file mode 100644 index 0000000..24d30fa --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-keda.yaml @@ -0,0 +1,46 @@ +{{- if and (eq .Values.controller.kind "Deployment") .Values.controller.keda.enabled (not .Values.controller.autoscaling.enabled) -}} +apiVersion: {{ .Values.controller.keda.apiVersion }} +kind: ScaledObject +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + {{- if .Values.controller.keda.scaledObject.annotations }} + annotations: {{ toYaml .Values.controller.keda.scaledObject.annotations | nindent 4 }} + {{- end }} +spec: + scaleTargetRef: +{{- if eq .Values.controller.keda.apiVersion "keda.k8s.io/v1alpha1" }} + deploymentName: {{ include "ingress-nginx.controller.fullname" . }} +{{- else if eq .Values.controller.keda.apiVersion "keda.sh/v1alpha1" }} + name: {{ include "ingress-nginx.controller.fullname" . }} +{{- end }} + pollingInterval: {{ .Values.controller.keda.pollingInterval }} + cooldownPeriod: {{ .Values.controller.keda.cooldownPeriod }} + minReplicaCount: {{ .Values.controller.keda.minReplicas }} + maxReplicaCount: {{ .Values.controller.keda.maxReplicas }} +{{- with .Values.controller.keda.fallback }} + fallback: + failureThreshold: {{ .failureThreshold | default 3 }} + replicas: {{ .replicas | default $.Values.controller.keda.maxReplicas }} +{{- end }} + triggers: +{{- with .Values.controller.keda.triggers }} +{{ toYaml . | indent 2 }} +{{ end }} + advanced: + restoreToOriginalReplicaCount: {{ .Values.controller.keda.restoreToOriginalReplicaCount }} +{{- if .Values.controller.keda.behavior }} + horizontalPodAutoscalerConfig: + behavior: +{{ with .Values.controller.keda.behavior -}} +{{ toYaml . | indent 8 }} +{{ end }} + +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-networkpolicy.yaml b/charts/keep/charts/ingress-nginx/templates/controller-networkpolicy.yaml new file mode 100644 index 0000000..e68f991 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-networkpolicy.yaml @@ -0,0 +1,45 @@ +{{- if .Values.controller.networkPolicy.enabled }} +apiVersion: networking.k8s.io/v1 +kind: NetworkPolicy +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + podSelector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: controller + policyTypes: + - Ingress + - Egress + ingress: + - ports: + {{- range $key, $value := .Values.controller.containerPort }} + - protocol: TCP + port: {{ $value }} + {{- end }} + {{- if .Values.controller.metrics.enabled }} + - protocol: TCP + port: {{ .Values.controller.metrics.port }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.enabled }} + - protocol: TCP + port: {{ .Values.controller.admissionWebhooks.port }} + {{- end }} + {{- range $key, $value := .Values.tcp }} + - protocol: TCP + port: {{ $key }} + {{- end }} + {{- range $key, $value := .Values.udp }} + - protocol: UDP + port: {{ $key }} + {{- end }} + egress: + - {} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml b/charts/keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml new file mode 100644 index 0000000..8e0181f --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml @@ -0,0 +1,36 @@ +# PDB is not supported for DaemonSets. +# https://github.com/kubernetes/kubernetes/issues/108124 +{{- if eq .Values.controller.kind "Deployment" }} +{{- $replicas := .Values.controller.replicaCount }} +{{- if and .Values.controller.autoscaling.enabled (not .Values.controller.keda.enabled) }} +{{- $replicas = .Values.controller.autoscaling.minReplicas }} +{{- else if and .Values.controller.keda.enabled (not .Values.controller.autoscaling.enabled) }} +{{- $replicas = .Values.controller.keda.minReplicas }} +{{- end }} +{{- if gt ($replicas | int) 1 }} +apiVersion: {{ ternary "policy/v1" "policy/v1beta1" (semverCompare ">=1.21.0-0" .Capabilities.KubeVersion.Version) }} +kind: PodDisruptionBudget +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + {{- if .Values.controller.annotations }} + annotations: {{ toYaml .Values.controller.annotations | nindent 4 }} + {{- end }} +spec: + selector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: controller + {{- if and .Values.controller.minAvailable (not (hasKey .Values.controller "maxUnavailable")) }} + minAvailable: {{ .Values.controller.minAvailable }} + {{- else if .Values.controller.maxUnavailable }} + maxUnavailable: {{ .Values.controller.maxUnavailable }} + {{- end }} +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-prometheusrule.yaml b/charts/keep/charts/ingress-nginx/templates/controller-prometheusrule.yaml new file mode 100644 index 0000000..41684c3 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-prometheusrule.yaml @@ -0,0 +1,23 @@ +{{- if and .Values.controller.metrics.enabled .Values.controller.metrics.prometheusRule.enabled -}} +apiVersion: monitoring.coreos.com/v1 +kind: PrometheusRule +metadata: + name: {{ include "ingress-nginx.controller.fullname" . }} +{{- if .Values.controller.metrics.prometheusRule.namespace }} + namespace: {{ .Values.controller.metrics.prometheusRule.namespace }} +{{- else }} + namespace: {{ include "ingress-nginx.namespace" . }} +{{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- if .Values.controller.metrics.prometheusRule.additionalLabels }} + {{- toYaml .Values.controller.metrics.prometheusRule.additionalLabels | nindent 4 }} + {{- end }} +spec: +{{- if .Values.controller.metrics.prometheusRule.rules }} + groups: + - name: {{ template "ingress-nginx.name" . }} + rules: {{- toYaml .Values.controller.metrics.prometheusRule.rules | nindent 4 }} +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-psp.yaml b/charts/keep/charts/ingress-nginx/templates/controller-psp.yaml new file mode 100644 index 0000000..aad1d27 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-psp.yaml @@ -0,0 +1,100 @@ +{{- if (semverCompare "<1.25.0-0" .Capabilities.KubeVersion.Version) }} +{{- if and .Values.podSecurityPolicy.enabled (empty .Values.controller.existingPsp) -}} +apiVersion: policy/v1beta1 +kind: PodSecurityPolicy +metadata: + name: {{ include "ingress-nginx.fullname" . }} + annotations: + seccomp.security.alpha.kubernetes.io/allowedProfileNames: "*" + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +spec: + privileged: false + hostPID: false + hostIPC: false + hostNetwork: {{ .Values.controller.hostNetwork }} +{{- if or .Values.controller.hostNetwork .Values.controller.hostPort.enabled }} + hostPorts: + {{- if .Values.controller.hostNetwork }} + {{- range $key, $value := .Values.controller.containerPort }} + # controller.containerPort.{{ $key }} + - min: {{ $value }} + max: {{ $value }} + {{- end }} + {{- else if .Values.controller.hostPort.enabled }} + {{- range $key, $value := .Values.controller.hostPort.ports }} + # controller.hostPort.ports.{{ $key }} + - min: {{ $value }} + max: {{ $value }} + {{- end }} + {{- end }} + {{- if .Values.controller.metrics.enabled }} + # controller.metrics.port + - min: {{ .Values.controller.metrics.port }} + max: {{ .Values.controller.metrics.port }} + {{- end }} + {{- if .Values.controller.admissionWebhooks.enabled }} + # controller.admissionWebhooks.port + - min: {{ .Values.controller.admissionWebhooks.port }} + max: {{ .Values.controller.admissionWebhooks.port }} + {{- end }} + {{- range $key, $value := .Values.tcp }} + # tcp.{{ $key }} + - min: {{ $key }} + max: {{ $key }} + {{- end }} + {{- range $key, $value := .Values.udp }} + # udp.{{ $key }} + - min: {{ $key }} + max: {{ $key }} + {{- end }} +{{- end }} + volumes: + - configMap + - downwardAPI + - emptyDir + - secret + - projected + fsGroup: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + readOnlyRootFilesystem: false + runAsUser: + rule: MustRunAsNonRoot + runAsGroup: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + supplementalGroups: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + allowPrivilegeEscalation: {{ or .Values.controller.image.allowPrivilegeEscalation .Values.controller.image.chroot }} + requiredDropCapabilities: + - ALL + allowedCapabilities: + - NET_BIND_SERVICE + {{- if .Values.controller.image.chroot }} + {{- if .Values.controller.image.seccompProfile }} + - SYS_ADMIN + {{- end }} + - SYS_CHROOT + {{- end }} + seLinux: + rule: RunAsAny +{{- if .Values.controller.sysctls }} + allowedUnsafeSysctls: + {{- range $sysctl, $value := .Values.controller.sysctls }} + - {{ $sysctl }} + {{- end }} +{{- end }} +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-role.yaml b/charts/keep/charts/ingress-nginx/templates/controller-role.yaml new file mode 100644 index 0000000..a94b399 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-role.yaml @@ -0,0 +1,104 @@ +{{- if .Values.rbac.create -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +rules: + - apiGroups: + - "" + resources: + - namespaces + verbs: + - get + - apiGroups: + - "" + resources: + - configmaps + - pods + - secrets + - endpoints + verbs: + - get + - list + - watch + - apiGroups: + - "" + resources: + - services + verbs: + - get + - list + - watch + - apiGroups: + - networking.k8s.io + resources: + - ingresses + verbs: + - get + - list + - watch + # Omit Ingress status permissions if `--update-status` is disabled. + {{- if ne (index .Values.controller.extraArgs "update-status") "false" }} + - apiGroups: + - networking.k8s.io + resources: + - ingresses/status + verbs: + - update + {{- end }} + - apiGroups: + - networking.k8s.io + resources: + - ingressclasses + verbs: + - get + - list + - watch + - apiGroups: + - coordination.k8s.io + resources: + - leases + resourceNames: + - {{ include "ingress-nginx.controller.electionID" . }} + verbs: + - get + - update + - apiGroups: + - coordination.k8s.io + resources: + - leases + verbs: + - create + - apiGroups: + - "" + resources: + - events + verbs: + - create + - patch + - apiGroups: + - discovery.k8s.io + resources: + - endpointslices + verbs: + - list + - watch + - get +{{- if .Values.podSecurityPolicy.enabled }} + - apiGroups: [{{ template "podSecurityPolicy.apiGroup" . }}] + resources: ['podsecuritypolicies'] + verbs: ['use'] + {{- with .Values.controller.existingPsp }} + resourceNames: [{{ . }}] + {{- else }} + resourceNames: [{{ include "ingress-nginx.fullname" . }}] + {{- end }} +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-rolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/controller-rolebinding.yaml new file mode 100644 index 0000000..153430a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-rolebinding.yaml @@ -0,0 +1,21 @@ +{{- if .Values.rbac.create -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: {{ include "ingress-nginx.fullname" . }} +subjects: + - kind: ServiceAccount + name: {{ template "ingress-nginx.serviceAccountName" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-secret.yaml b/charts/keep/charts/ingress-nginx/templates/controller-secret.yaml new file mode 100644 index 0000000..f20f534 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-secret.yaml @@ -0,0 +1,15 @@ +{{- if .Values.dhParam -}} +apiVersion: v1 +kind: Secret +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +data: + dhparam.pem: {{ .Values.dhParam }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-service-internal.yaml b/charts/keep/charts/ingress-nginx/templates/controller-service-internal.yaml new file mode 100644 index 0000000..6d0b47c --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-service-internal.yaml @@ -0,0 +1,105 @@ +{{- if and .Values.controller.service.enabled .Values.controller.service.internal.enabled .Values.controller.service.internal.annotations -}} +apiVersion: v1 +kind: Service +metadata: + annotations: + {{- range $key, $value := .Values.controller.service.internal.annotations }} + {{ $key }}: {{ tpl ($value | toString) $ | quote }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- if .Values.controller.service.labels }} + {{- toYaml .Values.controller.service.labels | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }}-internal + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + type: {{ .Values.controller.service.internal.type | default .Values.controller.service.type }} +{{- if .Values.controller.service.internal.clusterIP }} + clusterIP: {{ .Values.controller.service.internal.clusterIP }} +{{- end }} +{{- if .Values.controller.service.internal.externalIPs }} + externalIPs: {{ toYaml .Values.controller.service.internal.externalIPs | nindent 4 }} +{{- end }} +{{- if .Values.controller.service.internal.loadBalancerIP }} + loadBalancerIP: {{ .Values.controller.service.internal.loadBalancerIP }} +{{- end }} +{{- if .Values.controller.service.internal.loadBalancerSourceRanges }} + loadBalancerSourceRanges: {{ toYaml .Values.controller.service.internal.loadBalancerSourceRanges | nindent 4 }} +{{- end }} +{{- if .Values.controller.service.internal.loadBalancerClass }} + loadBalancerClass: {{ .Values.controller.service.internal.loadBalancerClass }} +{{- end }} +{{- if hasKey .Values.controller.service.internal "allocateLoadBalancerNodePorts" }} + allocateLoadBalancerNodePorts: {{ .Values.controller.service.internal.allocateLoadBalancerNodePorts }} +{{- end }} +{{- if .Values.controller.service.internal.externalTrafficPolicy }} + externalTrafficPolicy: {{ .Values.controller.service.internal.externalTrafficPolicy }} +{{- end }} +{{- if .Values.controller.service.internal.sessionAffinity }} + sessionAffinity: {{ .Values.controller.service.internal.sessionAffinity }} +{{- end }} +{{- if .Values.controller.service.internal.healthCheckNodePort }} + healthCheckNodePort: {{ .Values.controller.service.internal.healthCheckNodePort }} +{{- end }} +{{- if semverCompare ">=1.21.0-0" .Capabilities.KubeVersion.Version -}} +{{- if .Values.controller.service.internal.ipFamilyPolicy }} + ipFamilyPolicy: {{ .Values.controller.service.internal.ipFamilyPolicy }} +{{- end }} +{{- if .Values.controller.service.internal.ipFamilies }} + ipFamilies: {{ toYaml .Values.controller.service.internal.ipFamilies | nindent 4 }} +{{- end }} +{{- end }} + ports: + {{- $setNodePorts := (or (eq .Values.controller.service.type "NodePort") (eq .Values.controller.service.type "LoadBalancer")) }} + {{- if .Values.controller.service.enableHttp }} + - name: http + port: {{ .Values.controller.service.internal.ports.http | default .Values.controller.service.ports.http }} + protocol: TCP + targetPort: {{ .Values.controller.service.internal.targetPorts.http | default .Values.controller.service.targetPorts.http }} + {{- if and (semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version) (.Values.controller.service.internal.appProtocol) }} + appProtocol: http + {{- end }} + {{- if (and $setNodePorts (not (empty .Values.controller.service.internal.nodePorts.http))) }} + nodePort: {{ .Values.controller.service.internal.nodePorts.http }} + {{- end }} + {{- end }} + {{- if .Values.controller.service.enableHttps }} + - name: https + port: {{ .Values.controller.service.internal.ports.https | default .Values.controller.service.ports.https }} + protocol: TCP + targetPort: {{ .Values.controller.service.internal.targetPorts.https | default .Values.controller.service.targetPorts.https }} + {{- if and (semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version) (.Values.controller.service.internal.appProtocol) }} + appProtocol: https + {{- end }} + {{- if (and $setNodePorts (not (empty .Values.controller.service.internal.nodePorts.https))) }} + nodePort: {{ .Values.controller.service.internal.nodePorts.https }} + {{- end }} + {{- end }} + {{- range $key, $value := .Values.tcp }} + - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp + port: {{ $key }} + protocol: TCP + targetPort: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp + {{- if $.Values.controller.service.internal.nodePorts.tcp }} + {{- if index $.Values.controller.service.internal.nodePorts.tcp $key }} + nodePort: {{ index $.Values.controller.service.internal.nodePorts.tcp $key }} + {{- end }} + {{- end }} + {{- end }} + {{- range $key, $value := .Values.udp }} + - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp + port: {{ $key }} + protocol: UDP + targetPort: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp + {{- if $.Values.controller.service.internal.nodePorts.udp }} + {{- if index $.Values.controller.service.internal.nodePorts.udp $key }} + nodePort: {{ index $.Values.controller.service.internal.nodePorts.udp $key }} + {{- end }} + {{- end }} + {{- end }} + selector: + {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} + app.kubernetes.io/component: controller +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-service-metrics.yaml b/charts/keep/charts/ingress-nginx/templates/controller-service-metrics.yaml new file mode 100644 index 0000000..7c15329 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-service-metrics.yaml @@ -0,0 +1,45 @@ +{{- if .Values.controller.metrics.enabled -}} +apiVersion: v1 +kind: Service +metadata: +{{- if .Values.controller.metrics.service.annotations }} + annotations: {{ toYaml .Values.controller.metrics.service.annotations | nindent 4 }} +{{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- if .Values.controller.metrics.service.labels }} + {{- toYaml .Values.controller.metrics.service.labels | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }}-metrics + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + type: {{ .Values.controller.metrics.service.type }} +{{- if .Values.controller.metrics.service.clusterIP }} + clusterIP: {{ .Values.controller.metrics.service.clusterIP }} +{{- end }} +{{- if .Values.controller.metrics.service.externalIPs }} + externalIPs: {{ toYaml .Values.controller.metrics.service.externalIPs | nindent 4 }} +{{- end }} +{{- if .Values.controller.metrics.service.loadBalancerIP }} + loadBalancerIP: {{ .Values.controller.metrics.service.loadBalancerIP }} +{{- end }} +{{- if .Values.controller.metrics.service.loadBalancerSourceRanges }} + loadBalancerSourceRanges: {{ toYaml .Values.controller.metrics.service.loadBalancerSourceRanges | nindent 4 }} +{{- end }} +{{- if .Values.controller.metrics.service.externalTrafficPolicy }} + externalTrafficPolicy: {{ .Values.controller.metrics.service.externalTrafficPolicy }} +{{- end }} + ports: + - name: {{ .Values.controller.metrics.portName }} + port: {{ .Values.controller.metrics.service.servicePort }} + protocol: TCP + targetPort: {{ .Values.controller.metrics.portName }} + {{- $setNodePorts := (or (eq .Values.controller.metrics.service.type "NodePort") (eq .Values.controller.metrics.service.type "LoadBalancer")) }} + {{- if (and $setNodePorts (not (empty .Values.controller.metrics.service.nodePort))) }} + nodePort: {{ .Values.controller.metrics.service.nodePort }} + {{- end }} + selector: + {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} + app.kubernetes.io/component: controller +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-service-webhook.yaml b/charts/keep/charts/ingress-nginx/templates/controller-service-webhook.yaml new file mode 100644 index 0000000..67aac0d --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-service-webhook.yaml @@ -0,0 +1,40 @@ +{{- if .Values.controller.admissionWebhooks.enabled -}} +apiVersion: v1 +kind: Service +metadata: +{{- if .Values.controller.admissionWebhooks.service.annotations }} + annotations: {{ toYaml .Values.controller.admissionWebhooks.service.annotations | nindent 4 }} +{{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }}-admission + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + type: {{ .Values.controller.admissionWebhooks.service.type }} +{{- if .Values.controller.admissionWebhooks.service.clusterIP }} + clusterIP: {{ .Values.controller.admissionWebhooks.service.clusterIP }} +{{- end }} +{{- if .Values.controller.admissionWebhooks.service.externalIPs }} + externalIPs: {{ toYaml .Values.controller.admissionWebhooks.service.externalIPs | nindent 4 }} +{{- end }} +{{- if .Values.controller.admissionWebhooks.service.loadBalancerIP }} + loadBalancerIP: {{ .Values.controller.admissionWebhooks.service.loadBalancerIP }} +{{- end }} +{{- if .Values.controller.admissionWebhooks.service.loadBalancerSourceRanges }} + loadBalancerSourceRanges: {{ toYaml .Values.controller.admissionWebhooks.service.loadBalancerSourceRanges | nindent 4 }} +{{- end }} + ports: + - name: https-webhook + port: {{ .Values.controller.admissionWebhooks.service.servicePort }} + targetPort: webhook + {{- if semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version }} + appProtocol: https + {{- end }} + selector: + {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} + app.kubernetes.io/component: controller +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-service.yaml b/charts/keep/charts/ingress-nginx/templates/controller-service.yaml new file mode 100644 index 0000000..cb78a70 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-service.yaml @@ -0,0 +1,105 @@ +{{- if and .Values.controller.service.enabled .Values.controller.service.external.enabled -}} +apiVersion: v1 +kind: Service +metadata: + annotations: + {{- range $key, $value := .Values.controller.service.annotations }} + {{ $key }}: {{ tpl ($value | toString) $ | quote }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- if .Values.controller.service.labels }} + {{- toYaml .Values.controller.service.labels | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.controller.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + type: {{ .Values.controller.service.type }} +{{- if .Values.controller.service.clusterIP }} + clusterIP: {{ .Values.controller.service.clusterIP }} +{{- end }} +{{- if .Values.controller.service.externalIPs }} + externalIPs: {{ toYaml .Values.controller.service.externalIPs | nindent 4 }} +{{- end }} +{{- if .Values.controller.service.loadBalancerIP }} + loadBalancerIP: {{ .Values.controller.service.loadBalancerIP }} +{{- end }} +{{- if .Values.controller.service.loadBalancerSourceRanges }} + loadBalancerSourceRanges: {{ toYaml .Values.controller.service.loadBalancerSourceRanges | nindent 4 }} +{{- end }} +{{- if .Values.controller.service.loadBalancerClass }} + loadBalancerClass: {{ .Values.controller.service.loadBalancerClass }} +{{- end }} +{{- if hasKey .Values.controller.service "allocateLoadBalancerNodePorts" }} + allocateLoadBalancerNodePorts: {{ .Values.controller.service.allocateLoadBalancerNodePorts }} +{{- end }} +{{- if .Values.controller.service.externalTrafficPolicy }} + externalTrafficPolicy: {{ .Values.controller.service.externalTrafficPolicy }} +{{- end }} +{{- if .Values.controller.service.sessionAffinity }} + sessionAffinity: {{ .Values.controller.service.sessionAffinity }} +{{- end }} +{{- if .Values.controller.service.healthCheckNodePort }} + healthCheckNodePort: {{ .Values.controller.service.healthCheckNodePort }} +{{- end }} +{{- if semverCompare ">=1.21.0-0" .Capabilities.KubeVersion.Version -}} +{{- if .Values.controller.service.ipFamilyPolicy }} + ipFamilyPolicy: {{ .Values.controller.service.ipFamilyPolicy }} +{{- end }} +{{- if .Values.controller.service.ipFamilies }} + ipFamilies: {{ toYaml .Values.controller.service.ipFamilies | nindent 4 }} +{{- end }} +{{- end }} + ports: + {{- $setNodePorts := (or (eq .Values.controller.service.type "NodePort") (eq .Values.controller.service.type "LoadBalancer")) }} + {{- if .Values.controller.service.enableHttp }} + - name: http + port: {{ .Values.controller.service.ports.http }} + protocol: TCP + targetPort: {{ .Values.controller.service.targetPorts.http }} + {{- if and (semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version) (.Values.controller.service.appProtocol) }} + appProtocol: http + {{- end }} + {{- if (and $setNodePorts (not (empty .Values.controller.service.nodePorts.http))) }} + nodePort: {{ .Values.controller.service.nodePorts.http }} + {{- end }} + {{- end }} + {{- if .Values.controller.service.enableHttps }} + - name: https + port: {{ .Values.controller.service.ports.https }} + protocol: TCP + targetPort: {{ .Values.controller.service.targetPorts.https }} + {{- if and (semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version) (.Values.controller.service.appProtocol) }} + appProtocol: https + {{- end }} + {{- if (and $setNodePorts (not (empty .Values.controller.service.nodePorts.https))) }} + nodePort: {{ .Values.controller.service.nodePorts.https }} + {{- end }} + {{- end }} + {{- range $key, $value := .Values.tcp }} + - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp + port: {{ $key }} + protocol: TCP + targetPort: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp + {{- if $.Values.controller.service.nodePorts.tcp }} + {{- if index $.Values.controller.service.nodePorts.tcp $key }} + nodePort: {{ index $.Values.controller.service.nodePorts.tcp $key }} + {{- end }} + {{- end }} + {{- end }} + {{- range $key, $value := .Values.udp }} + - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp + port: {{ $key }} + protocol: UDP + targetPort: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp + {{- if $.Values.controller.service.nodePorts.udp }} + {{- if index $.Values.controller.service.nodePorts.udp $key }} + nodePort: {{ index $.Values.controller.service.nodePorts.udp $key }} + {{- end }} + {{- end }} + {{- end }} + selector: + {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} + app.kubernetes.io/component: controller +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml b/charts/keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml new file mode 100644 index 0000000..df83de3 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml @@ -0,0 +1,17 @@ +{{- if or .Values.serviceAccount.create -}} +apiVersion: v1 +kind: ServiceAccount +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- with .Values.controller.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ template "ingress-nginx.serviceAccountName" . }} + namespace: {{ include "ingress-nginx.namespace" . }} + {{- if .Values.serviceAccount.annotations }} + annotations: {{ toYaml .Values.serviceAccount.annotations | nindent 4 }} + {{- end }} +automountServiceAccountToken: {{ .Values.serviceAccount.automountServiceAccountToken }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-servicemonitor.yaml b/charts/keep/charts/ingress-nginx/templates/controller-servicemonitor.yaml new file mode 100644 index 0000000..62301da --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/controller-servicemonitor.yaml @@ -0,0 +1,53 @@ +{{- if and .Values.controller.metrics.enabled .Values.controller.metrics.serviceMonitor.enabled -}} +apiVersion: monitoring.coreos.com/v1 +kind: ServiceMonitor +metadata: + name: {{ include "ingress-nginx.controller.fullname" . }} +{{- if .Values.controller.metrics.serviceMonitor.namespace }} + namespace: {{ .Values.controller.metrics.serviceMonitor.namespace }} +{{- else }} + namespace: {{ include "ingress-nginx.namespace" . }} +{{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: controller + {{- if .Values.controller.metrics.serviceMonitor.additionalLabels }} + {{- toYaml .Values.controller.metrics.serviceMonitor.additionalLabels | nindent 4 }} + {{- end }} + {{- if .Values.controller.metrics.serviceMonitor.annotations }} + annotations: {{ toYaml .Values.controller.metrics.serviceMonitor.annotations | nindent 4 }} + {{- end }} +spec: + endpoints: + - port: {{ .Values.controller.metrics.portName }} + interval: {{ .Values.controller.metrics.serviceMonitor.scrapeInterval }} + {{- if .Values.controller.metrics.serviceMonitor.honorLabels }} + honorLabels: true + {{- end }} + {{- if .Values.controller.metrics.serviceMonitor.relabelings }} + relabelings: {{ toYaml .Values.controller.metrics.serviceMonitor.relabelings | nindent 8 }} + {{- end }} + {{- if .Values.controller.metrics.serviceMonitor.metricRelabelings }} + metricRelabelings: {{ toYaml .Values.controller.metrics.serviceMonitor.metricRelabelings | nindent 8 }} + {{- end }} +{{- if .Values.controller.metrics.serviceMonitor.jobLabel }} + jobLabel: {{ .Values.controller.metrics.serviceMonitor.jobLabel | quote }} +{{- end }} +{{- if .Values.controller.metrics.serviceMonitor.namespaceSelector }} + namespaceSelector: {{ toYaml .Values.controller.metrics.serviceMonitor.namespaceSelector | nindent 4 }} +{{- else }} + namespaceSelector: + matchNames: + - {{ include "ingress-nginx.namespace" . }} +{{- end }} +{{- if .Values.controller.metrics.serviceMonitor.targetLabels }} + targetLabels: + {{- range .Values.controller.metrics.serviceMonitor.targetLabels }} + - {{ . }} + {{- end }} +{{- end }} + selector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: controller +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-deployment.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-deployment.yaml new file mode 100644 index 0000000..6755e23 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-deployment.yaml @@ -0,0 +1,119 @@ +{{- if .Values.defaultBackend.enabled -}} +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.defaultBackend.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + selector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: default-backend +{{- if not .Values.defaultBackend.autoscaling.enabled }} + replicas: {{ .Values.defaultBackend.replicaCount }} +{{- end }} + revisionHistoryLimit: {{ .Values.revisionHistoryLimit }} + {{- if .Values.defaultBackend.updateStrategy }} + strategy: + {{ toYaml .Values.defaultBackend.updateStrategy | nindent 4 }} + {{- end }} + minReadySeconds: {{ .Values.defaultBackend.minReadySeconds }} + template: + metadata: + {{- if .Values.defaultBackend.podAnnotations }} + annotations: {{ toYaml .Values.defaultBackend.podAnnotations | nindent 8 }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 8 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 8 }} + {{- end }} + {{- if .Values.defaultBackend.podLabels }} + {{- toYaml .Values.defaultBackend.podLabels | nindent 8 }} + {{- end }} + spec: + {{- if .Values.imagePullSecrets }} + imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} + {{- end }} + {{- if .Values.defaultBackend.priorityClassName }} + priorityClassName: {{ .Values.defaultBackend.priorityClassName }} + {{- end }} + {{- if .Values.defaultBackend.podSecurityContext }} + securityContext: {{ toYaml .Values.defaultBackend.podSecurityContext | nindent 8 }} + {{- end }} + containers: + - name: {{ template "ingress-nginx.name" . }}-default-backend + {{- with .Values.defaultBackend.image }} + image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ .image }}{{ end }}:{{ .tag }}{{ if .digest }}@{{ .digest }}{{ end }} + {{- end }} + imagePullPolicy: {{ .Values.defaultBackend.image.pullPolicy }} + {{- if .Values.defaultBackend.extraArgs }} + args: + {{- range $key, $value := .Values.defaultBackend.extraArgs }} + {{- /* Accept keys without values or with false as value */}} + {{- if eq ($value | quote | len) 2 }} + - --{{ $key }} + {{- else }} + - --{{ $key }}={{ $value }} + {{- end }} + {{- end }} + {{- end }} + securityContext: {{ include "ingress-nginx.defaultBackend.containerSecurityContext" . | nindent 12 }} + {{- if .Values.defaultBackend.extraEnvs }} + env: {{ toYaml .Values.defaultBackend.extraEnvs | nindent 12 }} + {{- end }} + livenessProbe: + httpGet: + path: /healthz + port: {{ .Values.defaultBackend.port }} + scheme: HTTP + initialDelaySeconds: {{ .Values.defaultBackend.livenessProbe.initialDelaySeconds }} + periodSeconds: {{ .Values.defaultBackend.livenessProbe.periodSeconds }} + timeoutSeconds: {{ .Values.defaultBackend.livenessProbe.timeoutSeconds }} + successThreshold: {{ .Values.defaultBackend.livenessProbe.successThreshold }} + failureThreshold: {{ .Values.defaultBackend.livenessProbe.failureThreshold }} + readinessProbe: + httpGet: + path: /healthz + port: {{ .Values.defaultBackend.port }} + scheme: HTTP + initialDelaySeconds: {{ .Values.defaultBackend.readinessProbe.initialDelaySeconds }} + periodSeconds: {{ .Values.defaultBackend.readinessProbe.periodSeconds }} + timeoutSeconds: {{ .Values.defaultBackend.readinessProbe.timeoutSeconds }} + successThreshold: {{ .Values.defaultBackend.readinessProbe.successThreshold }} + failureThreshold: {{ .Values.defaultBackend.readinessProbe.failureThreshold }} + ports: + - name: http + containerPort: {{ .Values.defaultBackend.port }} + protocol: TCP + {{- if .Values.defaultBackend.extraVolumeMounts }} + volumeMounts: {{- toYaml .Values.defaultBackend.extraVolumeMounts | nindent 12 }} + {{- end }} + {{- if .Values.defaultBackend.resources }} + resources: {{ toYaml .Values.defaultBackend.resources | nindent 12 }} + {{- end }} + {{- if .Values.defaultBackend.nodeSelector }} + nodeSelector: {{ toYaml .Values.defaultBackend.nodeSelector | nindent 8 }} + {{- end }} + serviceAccountName: {{ include "ingress-nginx.defaultBackend.serviceAccountName" . }} + {{- if .Values.defaultBackend.tolerations }} + tolerations: {{ toYaml .Values.defaultBackend.tolerations | nindent 8 }} + {{- end }} + {{- if .Values.defaultBackend.affinity }} + affinity: {{ tpl (toYaml .Values.defaultBackend.affinity) $ | nindent 8 }} + {{- end }} + {{- if .Values.defaultBackend.topologySpreadConstraints }} + topologySpreadConstraints: {{ tpl (toYaml .Values.defaultBackend.topologySpreadConstraints) $ | nindent 8 }} + {{- end }} + terminationGracePeriodSeconds: 60 + {{- if .Values.defaultBackend.extraVolumes }} + volumes: {{ toYaml .Values.defaultBackend.extraVolumes | nindent 8 }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-extra-configmaps.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-extra-configmaps.yaml new file mode 100644 index 0000000..9af56cf --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-extra-configmaps.yaml @@ -0,0 +1,23 @@ +{{- if .Values.defaultBackend.enabled }} +{{- range .Values.defaultBackend.extraConfigMaps }} +--- +apiVersion: v1 +kind: ConfigMap +metadata: + labels: + {{- include "ingress-nginx.labels" $ | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with $.Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + {{- with .labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ .name }} + namespace: {{ include "ingress-nginx.namespace" $ }} +data: + {{- with .data }} + {{- toYaml . | nindent 2 }} + {{- end }} +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-hpa.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-hpa.yaml new file mode 100644 index 0000000..49bcdcf --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-hpa.yaml @@ -0,0 +1,40 @@ +{{- if and .Values.defaultBackend.enabled .Values.defaultBackend.autoscaling.enabled }} +apiVersion: {{ ternary "autoscaling/v2" "autoscaling/v2beta2" (.Capabilities.APIVersions.Has "autoscaling/v2") }} +kind: HorizontalPodAutoscaler +metadata: + {{- with .Values.defaultBackend.autoscaling.annotations }} + annotations: {{ toYaml . | nindent 4 }} + {{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.defaultBackend.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + scaleTargetRef: + apiVersion: apps/v1 + kind: Deployment + name: {{ include "ingress-nginx.defaultBackend.fullname" . }} + minReplicas: {{ .Values.defaultBackend.autoscaling.minReplicas }} + maxReplicas: {{ .Values.defaultBackend.autoscaling.maxReplicas }} + metrics: + {{- with .Values.defaultBackend.autoscaling.targetMemoryUtilizationPercentage }} + - type: Resource + resource: + name: memory + target: + type: Utilization + averageUtilization: {{ . }} + {{- end }} + {{- with .Values.defaultBackend.autoscaling.targetCPUUtilizationPercentage }} + - type: Resource + resource: + name: cpu + target: + type: Utilization + averageUtilization: {{ . }} + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-networkpolicy.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-networkpolicy.yaml new file mode 100644 index 0000000..90b3c2b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-networkpolicy.yaml @@ -0,0 +1,25 @@ +{{- if and .Values.defaultBackend.enabled .Values.defaultBackend.networkPolicy.enabled }} +apiVersion: networking.k8s.io/v1 +kind: NetworkPolicy +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.defaultBackend.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + podSelector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: default-backend + policyTypes: + - Ingress + - Egress + ingress: + - ports: + - protocol: TCP + port: {{ .Values.defaultBackend.port }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-poddisruptionbudget.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-poddisruptionbudget.yaml new file mode 100644 index 0000000..c8363fd --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-poddisruptionbudget.yaml @@ -0,0 +1,25 @@ +{{- if .Values.defaultBackend.enabled -}} +{{- $replicas := .Values.defaultBackend.replicaCount }} +{{- if .Values.defaultBackend.autoscaling.enabled }} +{{- $replicas = .Values.defaultBackend.autoscaling.minReplicas }} +{{- end }} +{{- if gt ($replicas | int) 1 }} +apiVersion: {{ ternary "policy/v1" "policy/v1beta1" (semverCompare ">=1.21.0-0" .Capabilities.KubeVersion.Version) }} +kind: PodDisruptionBudget +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.defaultBackend.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + selector: + matchLabels: + {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} + app.kubernetes.io/component: default-backend + minAvailable: {{ .Values.defaultBackend.minAvailable }} +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-psp.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-psp.yaml new file mode 100644 index 0000000..4241091 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-psp.yaml @@ -0,0 +1,50 @@ +{{- if (semverCompare "<1.25.0-0" .Capabilities.KubeVersion.Version) }} +{{- if and .Values.podSecurityPolicy.enabled .Values.defaultBackend.enabled (empty .Values.defaultBackend.existingPsp) -}} +apiVersion: policy/v1beta1 +kind: PodSecurityPolicy +metadata: + name: {{ include "ingress-nginx.fullname" . }}-backend + annotations: + seccomp.security.alpha.kubernetes.io/allowedProfileNames: "*" + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} +spec: + privileged: false + hostPID: false + hostIPC: false + hostNetwork: false + volumes: + - configMap + - downwardAPI + - emptyDir + - secret + - projected + fsGroup: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + readOnlyRootFilesystem: true + runAsUser: + rule: MustRunAsNonRoot + runAsGroup: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + supplementalGroups: + rule: MustRunAs + ranges: + - min: 1 + max: 65535 + allowPrivilegeEscalation: false + requiredDropCapabilities: + - ALL + seLinux: + rule: RunAsAny +{{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-role.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-role.yaml new file mode 100644 index 0000000..dd7868a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-role.yaml @@ -0,0 +1,22 @@ +{{- if and .Values.rbac.create .Values.podSecurityPolicy.enabled .Values.defaultBackend.enabled -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.fullname" . }}-backend + namespace: {{ include "ingress-nginx.namespace" . }} +rules: + - apiGroups: [{{ template "podSecurityPolicy.apiGroup" . }}] + resources: ['podsecuritypolicies'] + verbs: ['use'] + {{- with .Values.defaultBackend.existingPsp }} + resourceNames: [{{ . }}] + {{- else }} + resourceNames: [{{ include "ingress-nginx.fullname" . }}-backend] + {{- end }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-rolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-rolebinding.yaml new file mode 100644 index 0000000..3203b6f --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-rolebinding.yaml @@ -0,0 +1,21 @@ +{{- if and .Values.rbac.create .Values.podSecurityPolicy.enabled .Values.defaultBackend.enabled -}} +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.fullname" . }}-backend + namespace: {{ include "ingress-nginx.namespace" . }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: {{ include "ingress-nginx.fullname" . }}-backend +subjects: + - kind: ServiceAccount + name: {{ template "ingress-nginx.defaultBackend.serviceAccountName" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-service.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-service.yaml new file mode 100644 index 0000000..65b6b83 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-service.yaml @@ -0,0 +1,41 @@ +{{- if .Values.defaultBackend.enabled -}} +apiVersion: v1 +kind: Service +metadata: +{{- if .Values.defaultBackend.service.annotations }} + annotations: {{ toYaml .Values.defaultBackend.service.annotations | nindent 4 }} +{{- end }} + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.defaultBackend.fullname" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +spec: + type: {{ .Values.defaultBackend.service.type }} +{{- if .Values.defaultBackend.service.clusterIP }} + clusterIP: {{ .Values.defaultBackend.service.clusterIP }} +{{- end }} +{{- if .Values.defaultBackend.service.externalIPs }} + externalIPs: {{ toYaml .Values.defaultBackend.service.externalIPs | nindent 4 }} +{{- end }} +{{- if .Values.defaultBackend.service.loadBalancerIP }} + loadBalancerIP: {{ .Values.defaultBackend.service.loadBalancerIP }} +{{- end }} +{{- if .Values.defaultBackend.service.loadBalancerSourceRanges }} + loadBalancerSourceRanges: {{ toYaml .Values.defaultBackend.service.loadBalancerSourceRanges | nindent 4 }} +{{- end }} + ports: + - name: http + port: {{ .Values.defaultBackend.service.servicePort }} + protocol: TCP + targetPort: http + {{- if semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version }} + appProtocol: http + {{- end }} + selector: + {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} + app.kubernetes.io/component: default-backend +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-serviceaccount.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-serviceaccount.yaml new file mode 100644 index 0000000..6fd2d62 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/templates/default-backend-serviceaccount.yaml @@ -0,0 +1,14 @@ +{{- if and .Values.defaultBackend.enabled .Values.defaultBackend.serviceAccount.create -}} +apiVersion: v1 +kind: ServiceAccount +metadata: + labels: + {{- include "ingress-nginx.labels" . | nindent 4 }} + app.kubernetes.io/component: default-backend + {{- with .Values.defaultBackend.labels }} + {{- toYaml . | nindent 4 }} + {{- end }} + name: {{ include "ingress-nginx.defaultBackend.serviceAccountName" . }} + namespace: {{ include "ingress-nginx.namespace" . }} +automountServiceAccountToken: {{ .Values.defaultBackend.serviceAccount.automountServiceAccountToken }} +{{- end }} diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrole_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrole_test.yaml new file mode 100644 index 0000000..d7a8b88 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrole_test.yaml @@ -0,0 +1,11 @@ +suite: Admission Webhooks > Patch Job > ClusterRole +templates: + - admission-webhooks/job-patch/clusterrole.yaml + +tests: + - it: should not create a ClusterRole if `controller.admissionWebhooks.patch.rbac.create` is false + set: + controller.admissionWebhooks.patch.rbac.create: false + asserts: + - hasDocuments: + count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrolebinding_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrolebinding_test.yaml new file mode 100644 index 0000000..d7c3266 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrolebinding_test.yaml @@ -0,0 +1,11 @@ +suite: Admission Webhooks > Patch Job > ClusterRoleBinding +templates: + - admission-webhooks/job-patch/clusterrolebinding.yaml + +tests: + - it: should not create a ClusterRoleBinding if `controller.admissionWebhooks.patch.rbac.create` is false + set: + controller.admissionWebhooks.patch.rbac.create: false + asserts: + - hasDocuments: + count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/role_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/role_test.yaml new file mode 100644 index 0000000..a236f3d --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/role_test.yaml @@ -0,0 +1,11 @@ +suite: Admission Webhooks > Patch Job > Role +templates: + - admission-webhooks/job-patch/role.yaml + +tests: + - it: should not create a Role if `controller.admissionWebhooks.patch.rbac.create` is false + set: + controller.admissionWebhooks.patch.rbac.create: false + asserts: + - hasDocuments: + count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/rolebinding_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/rolebinding_test.yaml new file mode 100644 index 0000000..74abaa1 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/rolebinding_test.yaml @@ -0,0 +1,11 @@ +suite: Admission Webhooks > Patch Job > RoleBinding +templates: + - admission-webhooks/job-patch/rolebinding.yaml + +tests: + - it: should not create a RoleBinding if `controller.admissionWebhooks.patch.rbac.create` is false + set: + controller.admissionWebhooks.patch.rbac.create: false + asserts: + - hasDocuments: + count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/serviceaccount_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/serviceaccount_test.yaml new file mode 100644 index 0000000..7c30d1e --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/serviceaccount_test.yaml @@ -0,0 +1,47 @@ +suite: Admission Webhooks > Patch Job > ServiceAccount +templates: + - admission-webhooks/job-patch/serviceaccount.yaml + +tests: + - it: should not create a ServiceAccount if `controller.admissionWebhooks.patch.serviceAccount.create` is false + set: + controller.admissionWebhooks.patch.serviceAccount.create: false + asserts: + - hasDocuments: + count: 0 + + - it: should create a ServiceAccount if `controller.admissionWebhooks.patch.serviceAccount.create` is true + set: + controller.admissionWebhooks.patch.serviceAccount.create: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ServiceAccount + - equal: + path: metadata.name + value: ingress-nginx-admission + + - it: should create a ServiceAccount with specified name if `controller.admissionWebhooks.patch.serviceAccount.name` is set + set: + controller.admissionWebhooks.patch.serviceAccount.name: ingress-nginx-admission-test-sa + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ServiceAccount + - equal: + path: metadata.name + value: ingress-nginx-admission-test-sa + + - it: should create a ServiceAccount with token auto-mounting disabled if `controller.admissionWebhooks.patch.serviceAccount.automountServiceAccountToken` is false + set: + controller.admissionWebhooks.patch.serviceAccount.automountServiceAccountToken: false + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ServiceAccount + - equal: + path: automountServiceAccountToken + value: false diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/validating-webhook_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/validating-webhook_test.yaml new file mode 100644 index 0000000..b9d6d78 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/validating-webhook_test.yaml @@ -0,0 +1,32 @@ +suite: Admission Webhooks > ValidatingWebhookConfiguration +templates: + - admission-webhooks/validating-webhook.yaml + +tests: + - it: should not create a ValidatingWebhookConfiguration if `controller.admissionWebhooks.enabled` is false + set: + controller.admissionWebhooks.enabled: false + asserts: + - hasDocuments: + count: 0 + + - it: should create a ValidatingWebhookConfiguration if `controller.admissionWebhooks.enabled` is true + set: + controller.admissionWebhooks.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ValidatingWebhookConfiguration + - equal: + path: metadata.name + value: RELEASE-NAME-admission + + - it: should create a ValidatingWebhookConfiguration with a custom port if `controller.admissionWebhooks.service.servicePort` is set + set: + controller.admissionWebhooks.enabled: true + controller.admissionWebhooks.service.servicePort: 9443 + asserts: + - equal: + path: webhooks[0].clientConfig.service.port + value: 9443 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-configmap-addheaders_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-configmap-addheaders_test.yaml new file mode 100644 index 0000000..e831d50 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-configmap-addheaders_test.yaml @@ -0,0 +1,27 @@ +suite: Controller > ConfigMap > Add Headers +templates: + - controller-configmap-addheaders.yaml + +tests: + - it: should not create a ConfigMap if `controller.addHeaders` is not set + set: + controller.addHeaders: null + asserts: + - hasDocuments: + count: 0 + + - it: should create a ConfigMap if `controller.addHeaders` is set + set: + controller.addHeaders: + X-Another-Custom-Header: Value + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ConfigMap + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-custom-add-headers + - equal: + path: data.X-Another-Custom-Header + value: Value diff --git a/charts/keep/charts/ingress-nginx/tests/controller-configmap-proxyheaders_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-configmap-proxyheaders_test.yaml new file mode 100644 index 0000000..0634a37 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-configmap-proxyheaders_test.yaml @@ -0,0 +1,27 @@ +suite: Controller > ConfigMap > Proxy Headers +templates: + - controller-configmap-proxyheaders.yaml + +tests: + - it: should not create a ConfigMap if `controller.proxySetHeaders` is not set + set: + controller.proxySetHeaders: null + asserts: + - hasDocuments: + count: 0 + + - it: should create a ConfigMap if `controller.proxySetHeaders` is set + set: + controller.proxySetHeaders: + X-Custom-Header: Value + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ConfigMap + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-custom-proxy-headers + - equal: + path: data.X-Custom-Header + value: Value diff --git a/charts/keep/charts/ingress-nginx/tests/controller-configmap_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-configmap_test.yaml new file mode 100644 index 0000000..168b657 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-configmap_test.yaml @@ -0,0 +1,31 @@ +suite: Controller > ConfigMap +templates: + - controller-configmap.yaml + +tests: + - it: should create a ConfigMap + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ConfigMap + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should create a ConfigMap with templated values if `controller.config` contains templates + set: + controller.config: + template: "test.{{ .Release.Namespace }}.svc.kubernetes.local" + integer: 12345 + boolean: true + asserts: + - equal: + path: data.template + value: test.NAMESPACE.svc.kubernetes.local + - equal: + path: data.integer + value: "12345" + - equal: + path: data.boolean + value: "true" diff --git a/charts/keep/charts/ingress-nginx/tests/controller-daemonset_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-daemonset_test.yaml new file mode 100644 index 0000000..81d067b --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-daemonset_test.yaml @@ -0,0 +1,172 @@ +suite: Controller > DaemonSet +templates: + - controller-daemonset.yaml + +tests: + - it: should create a DaemonSet if `controller.kind` is "DaemonSet" + set: + controller.kind: DaemonSet + asserts: + - hasDocuments: + count: 1 + - isKind: + of: DaemonSet + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should create a DaemonSet with argument `--enable-metrics=false` if `controller.metrics.enabled` is false + set: + controller.kind: DaemonSet + controller.metrics.enabled: false + asserts: + - contains: + path: spec.template.spec.containers[0].args + content: --enable-metrics=false + + - it: should create a DaemonSet without argument `--enable-metrics=false` if `controller.metrics.enabled` is true + set: + controller.kind: DaemonSet + controller.metrics.enabled: true + asserts: + - notContains: + path: spec.template.spec.containers[0].args + content: --enable-metrics=false + + - it: should create a DaemonSet with argument `--controller-class=k8s.io/ingress-nginx-internal` if `controller.ingressClassResource.controllerValue` is "k8s.io/ingress-nginx-internal" + set: + controller.kind: DaemonSet + controller.ingressClassResource.controllerValue: k8s.io/ingress-nginx-internal + asserts: + - contains: + path: spec.template.spec.containers[0].args + content: --controller-class=k8s.io/ingress-nginx-internal + + - it: should create a DaemonSet with resource limits if `controller.resources.limits` is set + set: + controller.kind: DaemonSet + controller.resources.limits.cpu: 500m + controller.resources.limits.memory: 512Mi + asserts: + - equal: + path: spec.template.spec.containers[0].resources.limits.cpu + value: 500m + - equal: + path: spec.template.spec.containers[0].resources.limits.memory + value: 512Mi + + - it: should create a DaemonSet with topology spread constraints if `controller.topologySpreadConstraints` is set + set: + controller.kind: DaemonSet + controller.topologySpreadConstraints: + - labelSelector: + matchLabels: + app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + app.kubernetes.io/instance: '{{ .Release.Name }}' + app.kubernetes.io/component: controller + topologyKey: topology.kubernetes.io/zone + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + - labelSelector: + matchLabels: + app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + app.kubernetes.io/instance: '{{ .Release.Name }}' + app.kubernetes.io/component: controller + topologyKey: kubernetes.io/hostname + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + asserts: + - equal: + path: spec.template.spec.topologySpreadConstraints + value: + - labelSelector: + matchLabels: + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: RELEASE-NAME + app.kubernetes.io/component: controller + topologyKey: topology.kubernetes.io/zone + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + - labelSelector: + matchLabels: + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: RELEASE-NAME + app.kubernetes.io/component: controller + topologyKey: kubernetes.io/hostname + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + + - it: should create a DaemonSet with affinity if `controller.affinity` is set + set: + controller.kind: DaemonSet + controller.affinity: + podAntiAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + - labelSelector: + matchExpressions: + - key: app.kubernetes.io/name + operator: In + values: + - '{{ include "ingress-nginx.name" . }}' + - key: app.kubernetes.io/instance + operator: In + values: + - '{{ .Release.Name }}' + - key: app.kubernetes.io/component + operator: In + values: + - controller + topologyKey: kubernetes.io/hostname + asserts: + - equal: + path: spec.template.spec.affinity + value: + podAntiAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + - labelSelector: + matchExpressions: + - key: app.kubernetes.io/name + operator: In + values: + - ingress-nginx + - key: app.kubernetes.io/instance + operator: In + values: + - RELEASE-NAME + - key: app.kubernetes.io/component + operator: In + values: + - controller + topologyKey: kubernetes.io/hostname + + - it: should create a DaemonSet with a custom registry if `controller.image.registry` is set + set: + controller.kind: DaemonSet + controller.image.registry: custom.registry.io + controller.image.tag: v1.0.0-dev + controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: custom.registry.io/ingress-nginx/controller:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + + - it: should create a DaemonSet with a custom image if `controller.image.image` is set + set: + controller.kind: DaemonSet + controller.image.image: custom-repo/custom-image + controller.image.tag: v1.0.0-dev + controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: registry.k8s.io/custom-repo/custom-image:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + + - it: should create a DaemonSet with a custom tag if `controller.image.tag` is set + set: + controller.kind: DaemonSet + controller.image.tag: custom-tag + controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: registry.k8s.io/ingress-nginx/controller:custom-tag@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd diff --git a/charts/keep/charts/ingress-nginx/tests/controller-deployment_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-deployment_test.yaml new file mode 100644 index 0000000..382aecd --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-deployment_test.yaml @@ -0,0 +1,191 @@ +suite: Controller > Deployment +templates: + - controller-deployment.yaml + +tests: + - it: should create a Deployment + asserts: + - hasDocuments: + count: 1 + - isKind: + of: Deployment + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should create a Deployment with 3 replicas if `controller.replicaCount` is 3 + set: + controller.replicaCount: 3 + asserts: + - equal: + path: spec.replicas + value: 3 + + - it: should create a Deployment without replicas if `controller.autoscaling.enabled` is true + set: + controller.autoscaling.enabled: true + asserts: + - notExists: + path: spec.replicas + + - it: should create a Deployment without replicas if `controller.keda.enabled` is true + set: + controller.keda.enabled: true + asserts: + - notExists: + path: spec.replicas + + - it: should create a Deployment with replicas if `controller.autoscaling.enabled` is true and `controller.keda.enabled` is true + set: + controller.autoscaling.enabled: true + controller.keda.enabled: true + asserts: + - exists: + path: spec.replicas + + - it: should create a Deployment with argument `--enable-metrics=false` if `controller.metrics.enabled` is false + set: + controller.metrics.enabled: false + asserts: + - contains: + path: spec.template.spec.containers[0].args + content: --enable-metrics=false + + - it: should create a Deployment without argument `--enable-metrics=false` if `controller.metrics.enabled` is true + set: + controller.metrics.enabled: true + asserts: + - notContains: + path: spec.template.spec.containers[0].args + content: --enable-metrics=false + + - it: should create a Deployment with argument `--controller-class=k8s.io/ingress-nginx-internal` if `controller.ingressClassResource.controllerValue` is "k8s.io/ingress-nginx-internal" + set: + controller.ingressClassResource.controllerValue: k8s.io/ingress-nginx-internal + asserts: + - contains: + path: spec.template.spec.containers[0].args + content: --controller-class=k8s.io/ingress-nginx-internal + + - it: should create a Deployment with resource limits if `controller.resources.limits` is set + set: + controller.resources.limits.cpu: 500m + controller.resources.limits.memory: 512Mi + asserts: + - equal: + path: spec.template.spec.containers[0].resources.limits.cpu + value: 500m + - equal: + path: spec.template.spec.containers[0].resources.limits.memory + value: 512Mi + + - it: should create a Deployment with topology spread constraints if `controller.topologySpreadConstraints` is set + set: + controller.topologySpreadConstraints: + - labelSelector: + matchLabels: + app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + app.kubernetes.io/instance: '{{ .Release.Name }}' + app.kubernetes.io/component: controller + topologyKey: topology.kubernetes.io/zone + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + - labelSelector: + matchLabels: + app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + app.kubernetes.io/instance: '{{ .Release.Name }}' + app.kubernetes.io/component: controller + topologyKey: kubernetes.io/hostname + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + asserts: + - equal: + path: spec.template.spec.topologySpreadConstraints + value: + - labelSelector: + matchLabels: + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: RELEASE-NAME + app.kubernetes.io/component: controller + topologyKey: topology.kubernetes.io/zone + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + - labelSelector: + matchLabels: + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: RELEASE-NAME + app.kubernetes.io/component: controller + topologyKey: kubernetes.io/hostname + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + + - it: should create a Deployment with affinity if `controller.affinity` is set + set: + controller.affinity: + podAntiAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + - labelSelector: + matchExpressions: + - key: app.kubernetes.io/name + operator: In + values: + - '{{ include "ingress-nginx.name" . }}' + - key: app.kubernetes.io/instance + operator: In + values: + - '{{ .Release.Name }}' + - key: app.kubernetes.io/component + operator: In + values: + - controller + topologyKey: kubernetes.io/hostname + asserts: + - equal: + path: spec.template.spec.affinity + value: + podAntiAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + - labelSelector: + matchExpressions: + - key: app.kubernetes.io/name + operator: In + values: + - ingress-nginx + - key: app.kubernetes.io/instance + operator: In + values: + - RELEASE-NAME + - key: app.kubernetes.io/component + operator: In + values: + - controller + topologyKey: kubernetes.io/hostname + + - it: should create a Deployment with a custom registry if `controller.image.registry` is set + set: + controller.image.registry: custom.registry.io + controller.image.tag: v1.0.0-dev + controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: custom.registry.io/ingress-nginx/controller:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + + - it: should create a Deployment with a custom image if `controller.image.image` is set + set: + controller.image.image: custom-repo/custom-image + controller.image.tag: v1.0.0-dev + controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: registry.k8s.io/custom-repo/custom-image:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + + - it: should create a Deployment with a custom tag if `controller.image.tag` is set + set: + controller.image.tag: custom-tag + controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: registry.k8s.io/ingress-nginx/controller:custom-tag@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd diff --git a/charts/keep/charts/ingress-nginx/tests/controller-hpa_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-hpa_test.yaml new file mode 100644 index 0000000..869d3a6 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-hpa_test.yaml @@ -0,0 +1,31 @@ +suite: Controller > HPA +templates: + - controller-hpa.yaml + +tests: + - it: should create an HPA if `controller.autoscaling.enabled` is true + set: + controller.autoscaling.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: HorizontalPodAutoscaler + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should not create an HPA if `controller.autoscaling.enabled` is true and `controller.keda.enabled` is true + set: + controller.autoscaling.enabled: true + controller.keda.enabled: true + asserts: + - hasDocuments: + count: 0 + + - it: should not create an HPA if `controller.kind` is "DaemonSet" + set: + controller.kind: DaemonSet + asserts: + - hasDocuments: + count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-ingressclass-aliases_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-ingressclass-aliases_test.yaml new file mode 100644 index 0000000..9a4a576 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-ingressclass-aliases_test.yaml @@ -0,0 +1,110 @@ +suite: Controller > IngressClass > Aliases +templates: + - controller-ingressclass-aliases.yaml + +tests: + - it: should not create IngressClass aliases + asserts: + - hasDocuments: + count: 0 + + - it: should create an IngressClass alias with name "nginx-alias" if `controller.ingressClassResource.aliases` is set + set: + controller.ingressClassResource.aliases: + - nginx-alias + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx-alias + + - it: should create an IngressClass alias without annotation `ingressclass.kubernetes.io/is-default-class` if `controller.ingressClassResource.default` is true + set: + controller.ingressClassResource.aliases: + - nginx-alias + controller.ingressClassResource.default: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx-alias + - notExists: + path: metadata.annotations["ingressclass.kubernetes.io/is-default-class"] + + - it: should create an IngressClass alias with annotations if `controller.ingressClassResource.annotations` is set + set: + controller.ingressClassResource.aliases: + - nginx-alias + controller.ingressClassResource.annotations: + my-fancy-annotation: has-a-value + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx-alias + - equal: + path: metadata.annotations.my-fancy-annotation + value: has-a-value + + - it: should create an IngressClass alias with controller "k8s.io/ingress-nginx-internal" if `controller.ingressClassResource.controllerValue` is "k8s.io/ingress-nginx-internal" + set: + controller.ingressClassResource.aliases: + - nginx-alias + controller.ingressClassResource.controllerValue: k8s.io/ingress-nginx-internal + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx-alias + - equal: + path: spec.controller + value: k8s.io/ingress-nginx-internal + + - it: should create an IngressClass alias with parameters if `controller.ingressClassResource.parameters` is set + set: + controller.ingressClassResource.aliases: + - nginx-alias + controller.ingressClassResource.parameters: + apiGroup: k8s.example.com + kind: IngressParameters + name: external-lb + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx-alias + - equal: + path: spec.parameters + value: + apiGroup: k8s.example.com + kind: IngressParameters + name: external-lb + + - it: should create two IngressClass aliases if `controller.ingressClassResource.aliases` has two elements + set: + controller.ingressClassResource.aliases: + - nginx-alias-1 + - nginx-alias-2 + asserts: + - hasDocuments: + count: 2 + - isKind: + of: IngressClass + - matchRegex: + path: metadata.name + pattern: nginx-alias-(1|2) diff --git a/charts/keep/charts/ingress-nginx/tests/controller-ingressclass_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-ingressclass_test.yaml new file mode 100644 index 0000000..b3384af --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-ingressclass_test.yaml @@ -0,0 +1,93 @@ +suite: Controller > IngressClass +templates: + - controller-ingressclass.yaml + +tests: + - it: should create an IngressClass + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx + + - it: should create an IngressClass with name "nginx-internal" if `controller.ingressClassResource.name` is "nginx-internal" + set: + controller.ingressClassResource.name: nginx-internal + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx-internal + + - it: "should create an IngressClass with annotation `ingressclass.kubernetes.io/is-default-class: \"true\"` if `controller.ingressClassResource.default` is true" + set: + controller.ingressClassResource.default: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx + - equal: + path: metadata.annotations["ingressclass.kubernetes.io/is-default-class"] + value: "true" + + - it: should create an IngressClass with annotations if `controller.ingressClassResource.annotations` is set + set: + controller.ingressClassResource.annotations: + my-fancy-annotation: has-a-value + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx + - equal: + path: metadata.annotations.my-fancy-annotation + value: has-a-value + + - it: should create an IngressClass with controller "k8s.io/ingress-nginx-internal" if `controller.ingressClassResource.controllerValue` is "k8s.io/ingress-nginx-internal" + set: + controller.ingressClassResource.controllerValue: k8s.io/ingress-nginx-internal + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx + - equal: + path: spec.controller + value: k8s.io/ingress-nginx-internal + + - it: should create an IngressClass with parameters if `controller.ingressClassResource.parameters` is set + set: + controller.ingressClassResource.parameters: + apiGroup: k8s.example.com + kind: IngressParameters + name: external-lb + asserts: + - hasDocuments: + count: 1 + - isKind: + of: IngressClass + - equal: + path: metadata.name + value: nginx + - equal: + path: spec.parameters + value: + apiGroup: k8s.example.com + kind: IngressParameters + name: external-lb diff --git a/charts/keep/charts/ingress-nginx/tests/controller-keda_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-keda_test.yaml new file mode 100644 index 0000000..8002834 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-keda_test.yaml @@ -0,0 +1,31 @@ +suite: Controller > KEDA +templates: + - controller-keda.yaml + +tests: + - it: should create a ScaledObject if `controller.keda.enabled` is true + set: + controller.keda.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ScaledObject + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should not create a ScaledObject if `controller.keda.enabled` is true and `controller.autoscaling.enabled` is true + set: + controller.keda.enabled: true + controller.autoscaling.enabled: true + asserts: + - hasDocuments: + count: 0 + + - it: should not create a ScaledObject if `controller.kind` is "DaemonSet" + set: + controller.kind: DaemonSet + asserts: + - hasDocuments: + count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-networkpolicy_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-networkpolicy_test.yaml new file mode 100644 index 0000000..5de12e9 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-networkpolicy_test.yaml @@ -0,0 +1,23 @@ +suite: Controller > NetworkPolicy +templates: + - controller-networkpolicy.yaml + +tests: + - it: should not create a NetworkPolicy if `controller.networkPolicy.enabled` is false + set: + controller.networkPolicy.enabled: false + asserts: + - hasDocuments: + count: 0 + + - it: should create a NetworkPolicy if `controller.networkPolicy.enabled` is true + set: + controller.networkPolicy.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: NetworkPolicy + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller diff --git a/charts/keep/charts/ingress-nginx/tests/controller-poddisruptionbudget_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-poddisruptionbudget_test.yaml new file mode 100644 index 0000000..f215f35 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-poddisruptionbudget_test.yaml @@ -0,0 +1,89 @@ +suite: Controller > PodDisruptionBudget +templates: + - controller-poddisruptionbudget.yaml + +tests: + - it: should create a PodDisruptionBudget if `controller.replicaCount` is greater than 1 + set: + controller.replicaCount: 2 + asserts: + - hasDocuments: + count: 1 + - isKind: + of: PodDisruptionBudget + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should not create a PodDisruptionBudget if `controller.replicaCount` is less than or equal 1 + set: + controller.replicaCount: 1 + asserts: + - hasDocuments: + count: 0 + + - it: should create a PodDisruptionBudget if `controller.autoscaling.enabled` is true and `controller.autoscaling.minReplicas` is greater than 1 + set: + controller.autoscaling.enabled: true + controller.autoscaling.minReplicas: 2 + asserts: + - hasDocuments: + count: 1 + - isKind: + of: PodDisruptionBudget + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should not create a PodDisruptionBudget if `controller.autoscaling.enabled` is true and `controller.autoscaling.minReplicas` is less than or equal 1 + set: + controller.autoscaling.enabled: true + controller.autoscaling.minReplicas: 1 + asserts: + - hasDocuments: + count: 0 + + - it: should create a PodDisruptionBudget if `controller.keda.enabled` is true and `controller.keda.minReplicas` is greater than 1 + set: + controller.keda.enabled: true + controller.keda.minReplicas: 2 + asserts: + - hasDocuments: + count: 1 + - isKind: + of: PodDisruptionBudget + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should not create a PodDisruptionBudget if `controller.keda.enabled` is true and `controller.keda.minReplicas` is less than or equal 1 + set: + controller.keda.enabled: true + controller.keda.minReplicas: 1 + asserts: + - hasDocuments: + count: 0 + + - it: should not create a PodDisruptionBudget if `controller.autoscaling.enabled` is true and `controller.keda.enabled` is true + set: + controller.autoscaling.enabled: true + controller.keda.enabled: true + asserts: + - hasDocuments: + count: 0 + + - it: should create a PodDisruptionBudget without `minAvailable` and with `maxUnavailable` if `controller.minAvailable` and `controller.maxUnavailable` are set + set: + controller.replicaCount: 2 + controller.minAvailable: 1 + controller.maxUnavailable: 1 + asserts: + - hasDocuments: + count: 1 + - isKind: + of: PodDisruptionBudget + - notExists: + path: spec.minAvailable + - equal: + path: spec.maxUnavailable + value: 1 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-prometheusrule_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-prometheusrule_test.yaml new file mode 100644 index 0000000..d60a983 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-prometheusrule_test.yaml @@ -0,0 +1,17 @@ +suite: Controller > PrometheusRule +templates: + - controller-prometheusrule.yaml + +tests: + - it: should create a PrometheusRule if `controller.metrics.prometheusRule.enabled` is true + set: + controller.metrics.enabled: true + controller.metrics.prometheusRule.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: PrometheusRule + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller diff --git a/charts/keep/charts/ingress-nginx/tests/controller-service-internal_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-service-internal_test.yaml new file mode 100644 index 0000000..5465e1a --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-service-internal_test.yaml @@ -0,0 +1,25 @@ +suite: Controller > Service > Internal +templates: + - controller-service-internal.yaml + +tests: + - it: should not create an internal Service if `controller.service.internal.enabled` is false + set: + controller.service.internal.enabled: false + asserts: + - hasDocuments: + count: 0 + + - it: should create an internal Service if `controller.service.internal.enabled` is true and `controller.service.internal.annotations` are set + set: + controller.service.internal.enabled: true + controller.service.internal.annotations: + test.annotation: "true" + asserts: + - hasDocuments: + count: 1 + - isKind: + of: Service + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller-internal diff --git a/charts/keep/charts/ingress-nginx/tests/controller-service-metrics_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-service-metrics_test.yaml new file mode 100644 index 0000000..afdb940 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-service-metrics_test.yaml @@ -0,0 +1,23 @@ +suite: Controller > Service > Metrics +templates: + - controller-service-metrics.yaml + +tests: + - it: should not create a metrics Service if `controller.metrics.enabled` is false + set: + controller.metrics.enabled: false + asserts: + - hasDocuments: + count: 0 + + - it: should create a metrics Service if `controller.metrics.enabled` is true + set: + controller.metrics.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: Service + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller-metrics diff --git a/charts/keep/charts/ingress-nginx/tests/controller-service-webhook_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-service-webhook_test.yaml new file mode 100644 index 0000000..1c759ed --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-service-webhook_test.yaml @@ -0,0 +1,32 @@ +suite: Controller > Service > Webhook +templates: + - controller-service-webhook.yaml + +tests: + - it: should not create a webhook Service if `controller.admissionWebhooks.enabled` is false + set: + controller.admissionWebhooks.enabled: false + asserts: + - hasDocuments: + count: 0 + + - it: should create a webhook Service if `controller.admissionWebhooks.enabled` is true + set: + controller.admissionWebhooks.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: Service + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller-admission + + - it: should create a webhook Service with a custom port if `controller.admissionWebhooks.service.servicePort` is set + set: + controller.admissionWebhooks.enabled: true + controller.admissionWebhooks.service.servicePort: 9443 + asserts: + - equal: + path: spec.ports[0].port + value: 9443 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-service_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-service_test.yaml new file mode 100644 index 0000000..10574f2 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-service_test.yaml @@ -0,0 +1,32 @@ +suite: Controller > Service +templates: + - controller-service.yaml + +tests: + - it: should not create a Service if `controller.service.external.enabled` is false + set: + controller.service.external.enabled: false + asserts: + - hasDocuments: + count: 0 + + - it: should create a Service if `controller.service.external.enabled` is true + set: + controller.service.external.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: Service + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should create a Service of type "NodePort" if `controller.service.external.enabled` is true and `controller.service.type` is "NodePort" + set: + controller.service.external.enabled: true + controller.service.type: NodePort + asserts: + - equal: + path: spec.type + value: NodePort diff --git a/charts/keep/charts/ingress-nginx/tests/controller-servicemonitor_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-servicemonitor_test.yaml new file mode 100644 index 0000000..310097c --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/controller-servicemonitor_test.yaml @@ -0,0 +1,29 @@ +suite: Controller > ServiceMonitor +templates: + - controller-servicemonitor.yaml + +tests: + - it: should create a ServiceMonitor if `controller.metrics.serviceMonitor.enabled` is true + set: + controller.metrics.enabled: true + controller.metrics.serviceMonitor.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ServiceMonitor + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-controller + + - it: should create a ServiceMonitor with annotations if `controller.metrics.serviceMonitor.annotations` is set + set: + controller.metrics.enabled: true + controller.metrics.serviceMonitor.enabled: true + controller.metrics.serviceMonitor.annotations: + my-little-annotation: test-value + asserts: + - equal: + path: metadata.annotations + value: + my-little-annotation: test-value diff --git a/charts/keep/charts/ingress-nginx/tests/default-backend-deployment_test.yaml b/charts/keep/charts/ingress-nginx/tests/default-backend-deployment_test.yaml new file mode 100644 index 0000000..4ba4b03 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/default-backend-deployment_test.yaml @@ -0,0 +1,169 @@ +suite: Default Backend > Deployment +templates: + - default-backend-deployment.yaml + +tests: + - it: should not create a Deployment if `defaultBackend.enabled` is false + set: + defaultBackend.enabled: false + asserts: + - hasDocuments: + count: 0 + + - it: should create a Deployment if `defaultBackend.enabled` is true + set: + defaultBackend.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: Deployment + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-defaultbackend + + - it: should create a Deployment with 3 replicas if `defaultBackend.replicaCount` is 3 + set: + defaultBackend.enabled: true + defaultBackend.replicaCount: 3 + asserts: + - equal: + path: spec.replicas + value: 3 + + - it: should create a Deployment without replicas if `defaultBackend.autoscaling.enabled` is true + set: + defaultBackend.enabled: true + defaultBackend.autoscaling.enabled: true + asserts: + - notExists: + path: spec.replicas + + - it: should create a Deployment with resource limits if `defaultBackend.resources.limits` is set + set: + defaultBackend.enabled: true + defaultBackend.resources.limits.cpu: 500m + defaultBackend.resources.limits.memory: 512Mi + asserts: + - equal: + path: spec.template.spec.containers[0].resources.limits.cpu + value: 500m + - equal: + path: spec.template.spec.containers[0].resources.limits.memory + value: 512Mi + + - it: should create a Deployment with topology spread constraints if `defaultBackend.topologySpreadConstraints` is set + set: + defaultBackend.enabled: true + defaultBackend.topologySpreadConstraints: + - labelSelector: + matchLabels: + app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + app.kubernetes.io/instance: '{{ .Release.Name }}' + app.kubernetes.io/component: default-backend + topologyKey: topology.kubernetes.io/zone + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + - labelSelector: + matchLabels: + app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + app.kubernetes.io/instance: '{{ .Release.Name }}' + app.kubernetes.io/component: default-backend + topologyKey: kubernetes.io/hostname + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + asserts: + - equal: + path: spec.template.spec.topologySpreadConstraints + value: + - labelSelector: + matchLabels: + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: RELEASE-NAME + app.kubernetes.io/component: default-backend + topologyKey: topology.kubernetes.io/zone + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + - labelSelector: + matchLabels: + app.kubernetes.io/name: ingress-nginx + app.kubernetes.io/instance: RELEASE-NAME + app.kubernetes.io/component: default-backend + topologyKey: kubernetes.io/hostname + maxSkew: 1 + whenUnsatisfiable: ScheduleAnyway + + - it: should create a Deployment with affinity if `defaultBackend.affinity` is set + set: + defaultBackend.enabled: true + defaultBackend.affinity: + podAntiAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + - labelSelector: + matchExpressions: + - key: app.kubernetes.io/name + operator: In + values: + - '{{ include "ingress-nginx.name" . }}' + - key: app.kubernetes.io/instance + operator: In + values: + - '{{ .Release.Name }}' + - key: app.kubernetes.io/component + operator: In + values: + - default-backend + topologyKey: kubernetes.io/hostname + asserts: + - equal: + path: spec.template.spec.affinity + value: + podAntiAffinity: + requiredDuringSchedulingIgnoredDuringExecution: + - labelSelector: + matchExpressions: + - key: app.kubernetes.io/name + operator: In + values: + - ingress-nginx + - key: app.kubernetes.io/instance + operator: In + values: + - RELEASE-NAME + - key: app.kubernetes.io/component + operator: In + values: + - default-backend + topologyKey: kubernetes.io/hostname + + - it: should create a Deployment with a custom registry if `defaultBackend.image.registry` is set + set: + defaultBackend.enabled: true + defaultBackend.image.registry: custom.registry.io + defaultBackend.image.tag: v1.0.0-dev + defaultBackend.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: custom.registry.io/defaultbackend-amd64:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + + - it: should create a Deployment with a custom image if `defaultBackend.image.image` is set + set: + defaultBackend.enabled: true + defaultBackend.image.image: custom-repo/custom-image + defaultBackend.image.tag: v1.0.0-dev + defaultBackend.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: registry.k8s.io/custom-repo/custom-image:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + + - it: should create a Deployment with a custom tag if `defaultBackend.image.tag` is set + set: + defaultBackend.enabled: true + defaultBackend.image.tag: custom-tag + defaultBackend.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd + asserts: + - equal: + path: spec.template.spec.containers[0].image + value: registry.k8s.io/defaultbackend-amd64:custom-tag@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd diff --git a/charts/keep/charts/ingress-nginx/tests/default-backend-extra-configmaps_test.yaml b/charts/keep/charts/ingress-nginx/tests/default-backend-extra-configmaps_test.yaml new file mode 100644 index 0000000..aa600e7 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/default-backend-extra-configmaps_test.yaml @@ -0,0 +1,50 @@ +suite: Default Backend > Extra ConfigMaps +templates: + - default-backend-extra-configmaps.yaml + +tests: + - it: should not create a ConfigMap if `defaultBackend.extraConfigMaps` is empty + set: + defaultBackend.enabled: true + defaultBackend.extraConfigMaps: [] + asserts: + - hasDocuments: + count: 0 + + - it: should create one ConfigMap if `defaultBackend.extraConfigMaps` has one element + set: + defaultBackend.enabled: true + defaultBackend.extraConfigMaps: + - name: my-configmap-1 + data: + key1: value1 + asserts: + - hasDocuments: + count: 1 + - isKind: + of: ConfigMap + - equal: + path: metadata.name + value: my-configmap-1 + - equal: + path: data.key1 + value: value1 + + - it: should create two ConfigMaps if `defaultBackend.extraConfigMaps` has two elements + set: + defaultBackend.enabled: true + defaultBackend.extraConfigMaps: + - name: my-configmap-1 + data: + key1: value1 + - name: my-configmap-2 + data: + key2: value2 + asserts: + - hasDocuments: + count: 2 + - isKind: + of: ConfigMap + - matchRegex: + path: metadata.name + pattern: my-configmap-(1|2) diff --git a/charts/keep/charts/ingress-nginx/tests/default-backend-poddisruptionbudget_test.yaml b/charts/keep/charts/ingress-nginx/tests/default-backend-poddisruptionbudget_test.yaml new file mode 100644 index 0000000..0958018 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/default-backend-poddisruptionbudget_test.yaml @@ -0,0 +1,48 @@ +suite: Default Backend > PodDisruptionBudget +templates: + - default-backend-poddisruptionbudget.yaml + +tests: + - it: should create a PodDisruptionBudget if `defaultBackend.replicaCount` is greater than 1 + set: + defaultBackend.enabled: true + defaultBackend.replicaCount: 2 + asserts: + - hasDocuments: + count: 1 + - isKind: + of: PodDisruptionBudget + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-defaultbackend + + - it: should not create a PodDisruptionBudget if `defaultBackend.replicaCount` is less than or equal 1 + set: + defaultBackend.enabled: true + defaultBackend.replicaCount: 1 + asserts: + - hasDocuments: + count: 0 + + - it: should create a PodDisruptionBudget if `defaultBackend.autoscaling.enabled` is true and `defaultBackend.autoscaling.minReplicas` is greater than 1 + set: + defaultBackend.enabled: true + defaultBackend.autoscaling.enabled: true + defaultBackend.autoscaling.minReplicas: 2 + asserts: + - hasDocuments: + count: 1 + - isKind: + of: PodDisruptionBudget + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-defaultbackend + + - it: should not create a PodDisruptionBudget if `defaultBackend.autoscaling.enabled` is true and `defaultBackend.autoscaling.minReplicas` is less than or equal 1 + set: + defaultBackend.enabled: true + defaultBackend.autoscaling.enabled: true + defaultBackend.autoscaling.minReplicas: 1 + asserts: + - hasDocuments: + count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/default-backend-service_test.yaml b/charts/keep/charts/ingress-nginx/tests/default-backend-service_test.yaml new file mode 100644 index 0000000..f16904f --- /dev/null +++ b/charts/keep/charts/ingress-nginx/tests/default-backend-service_test.yaml @@ -0,0 +1,32 @@ +suite: Default Backend > Service +templates: + - default-backend-service.yaml + +tests: + - it: should not create a Service if `defaultBackend.enabled` is false + set: + defaultBackend.enabled: false + asserts: + - hasDocuments: + count: 0 + + - it: should create a Service if `defaultBackend.enabled` is true + set: + defaultBackend.enabled: true + asserts: + - hasDocuments: + count: 1 + - isKind: + of: Service + - equal: + path: metadata.name + value: RELEASE-NAME-ingress-nginx-defaultbackend + + - it: should create a Service with port 80 if `defaultBackend.service.port` is 80 + set: + defaultBackend.enabled: true + defaultBackend.service.port: 80 + asserts: + - equal: + path: spec.ports[0].port + value: 80 diff --git a/charts/keep/charts/ingress-nginx/values.yaml b/charts/keep/charts/ingress-nginx/values.yaml new file mode 100644 index 0000000..f42a682 --- /dev/null +++ b/charts/keep/charts/ingress-nginx/values.yaml @@ -0,0 +1,1192 @@ +## nginx configuration +## Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/nginx-configuration/index.md +## + +## Overrides for generated resource names +# See templates/_helpers.tpl +# nameOverride: +# fullnameOverride: + +# -- Override the deployment namespace; defaults to .Release.Namespace +namespaceOverride: "" +## Labels to apply to all resources +## +commonLabels: {} +# scmhash: abc123 +# myLabel: aakkmd + +controller: + name: controller + enableAnnotationValidations: false + image: + ## Keep false as default for now! + chroot: false + registry: registry.k8s.io + image: ingress-nginx/controller + ## for backwards compatibility consider setting the full image url via the repository value below + ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail + ## repository: + tag: "v1.11.3" + digest: sha256:d56f135b6462cfc476447cfe564b83a45e8bb7da2774963b00d12161112270b7 + digestChroot: sha256:22701f0fc0f2dd209ef782f4e281bfe2d8cccd50ededa00aec88e0cdbe7edd14 + pullPolicy: IfNotPresent + runAsNonRoot: true + # www-data -> uid 101 + runAsUser: 101 + allowPrivilegeEscalation: false + seccompProfile: + type: RuntimeDefault + readOnlyRootFilesystem: false + # -- Use an existing PSP instead of creating one + existingPsp: "" + # -- Configures the controller container name + containerName: controller + # -- Configures the ports that the nginx-controller listens on + containerPort: + http: 80 + https: 443 + # -- Global configuration passed to the ConfigMap consumed by the controller. Values may contain Helm templates. + # Ref.: https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/ + config: {} + # -- Annotations to be added to the controller config configuration configmap. + configAnnotations: {} + # -- Will add custom headers before sending traffic to backends according to https://github.com/kubernetes/ingress-nginx/tree/main/docs/examples/customization/custom-headers + proxySetHeaders: {} + # -- Will add custom headers before sending response traffic to the client according to: https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/#add-headers + addHeaders: {} + # -- Optionally customize the pod dnsConfig. + dnsConfig: {} + # -- Optionally customize the pod hostAliases. + hostAliases: [] + # - ip: 127.0.0.1 + # hostnames: + # - foo.local + # - bar.local + # - ip: 10.1.2.3 + # hostnames: + # - foo.remote + # - bar.remote + # -- Optionally customize the pod hostname. + hostname: {} + # -- Optionally change this to ClusterFirstWithHostNet in case you have 'hostNetwork: true'. + # By default, while using host network, name resolution uses the host's DNS. If you wish nginx-controller + # to keep resolving names inside the k8s network, use ClusterFirstWithHostNet. + dnsPolicy: ClusterFirst + # -- Bare-metal considerations via the host network https://kubernetes.github.io/ingress-nginx/deploy/baremetal/#via-the-host-network + # Ingress status was blank because there is no Service exposing the Ingress-Nginx Controller in a configuration using the host network, the default --publish-service flag used in standard cloud setups does not apply + reportNodeInternalIp: false + # -- Process Ingress objects without ingressClass annotation/ingressClassName field + # Overrides value for --watch-ingress-without-class flag of the controller binary + # Defaults to false + watchIngressWithoutClass: false + # -- Process IngressClass per name (additionally as per spec.controller). + ingressClassByName: false + # -- This configuration enables Topology Aware Routing feature, used together with service annotation service.kubernetes.io/topology-mode="auto" + # Defaults to false + enableTopologyAwareRouting: false + # -- This configuration disable Nginx Controller Leader Election + disableLeaderElection: false + # -- Duration a leader election is valid before it's getting re-elected, e.g. `15s`, `10m` or `1h`. (Default: 30s) + electionTTL: "" + # -- This configuration defines if Ingress Controller should allow users to set + # their own *-snippet annotations, otherwise this is forbidden / dropped + # when users add those annotations. + # Global snippets in ConfigMap are still respected + allowSnippetAnnotations: false + # -- Required for use with CNI based kubernetes installations (such as ones set up by kubeadm), + # since CNI and hostport don't mix yet. Can be deprecated once https://github.com/kubernetes/kubernetes/issues/23920 + # is merged + hostNetwork: false + ## Use host ports 80 and 443 + ## Disabled by default + hostPort: + # -- Enable 'hostPort' or not + enabled: false + ports: + # -- 'hostPort' http port + http: 80 + # -- 'hostPort' https port + https: 443 + # NetworkPolicy for controller component. + networkPolicy: + # -- Enable 'networkPolicy' or not + enabled: false + # -- Election ID to use for status update, by default it uses the controller name combined with a suffix of 'leader' + electionID: "" + # -- This section refers to the creation of the IngressClass resource. + # IngressClasses are immutable and cannot be changed after creation. + # We do not support namespaced IngressClasses, yet, so a ClusterRole and a ClusterRoleBinding is required. + ingressClassResource: + # -- Name of the IngressClass + name: nginx + # -- Create the IngressClass or not + enabled: true + # -- If true, Ingresses without `ingressClassName` get assigned to this IngressClass on creation. + # Ingress creation gets rejected if there are multiple default IngressClasses. + # Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#default-ingress-class + default: false + # -- Annotations to be added to the IngressClass resource. + annotations: {} + # -- Controller of the IngressClass. An Ingress Controller looks for IngressClasses it should reconcile by this value. + # This value is also being set as the `--controller-class` argument of this Ingress Controller. + # Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#ingress-class + controllerValue: k8s.io/ingress-nginx + # -- Aliases of this IngressClass. Creates copies with identical settings but the respective alias as name. + # Useful for development environments with only one Ingress Controller but production-like Ingress resources. + # `default` gets enabled on the original IngressClass only. + aliases: [] + # aliases: + # - nginx-alias-1 + # - nginx-alias-2 + # -- A link to a custom resource containing additional configuration for the controller. + # This is optional if the controller consuming this IngressClass does not require additional parameters. + # Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#ingress-class + parameters: {} + # parameters: + # apiGroup: k8s.example.com + # kind: IngressParameters + # name: external-lb + # -- For backwards compatibility with ingress.class annotation, use ingressClass. + # Algorithm is as follows, first ingressClassName is considered, if not present, controller looks for ingress.class annotation + ingressClass: nginx + # -- Labels to add to the pod container metadata + podLabels: {} + # key: value + + # -- Security context for controller pods + podSecurityContext: {} + # -- sysctls for controller pods + ## Ref: https://kubernetes.io/docs/tasks/administer-cluster/sysctl-cluster/ + sysctls: {} + # sysctls: + # "net.core.somaxconn": "8192" + # -- Security context for controller containers + containerSecurityContext: {} + # -- Allows customization of the source of the IP address or FQDN to report + # in the ingress status field. By default, it reads the information provided + # by the service. If disable, the status field reports the IP address of the + # node or nodes where an ingress controller pod is running. + publishService: + # -- Enable 'publishService' or not + enabled: true + # -- Allows overriding of the publish service to bind to + # Must be / + pathOverride: "" + # Limit the scope of the controller to a specific namespace + scope: + # -- Enable 'scope' or not + enabled: false + # -- Namespace to limit the controller to; defaults to $(POD_NAMESPACE) + namespace: "" + # -- When scope.enabled == false, instead of watching all namespaces, we watching namespaces whose labels + # only match with namespaceSelector. Format like foo=bar. Defaults to empty, means watching all namespaces. + namespaceSelector: "" + # -- Allows customization of the configmap / nginx-configmap namespace; defaults to $(POD_NAMESPACE) + configMapNamespace: "" + tcp: + # -- Allows customization of the tcp-services-configmap; defaults to $(POD_NAMESPACE) + configMapNamespace: "" + # -- Annotations to be added to the tcp config configmap + annotations: {} + udp: + # -- Allows customization of the udp-services-configmap; defaults to $(POD_NAMESPACE) + configMapNamespace: "" + # -- Annotations to be added to the udp config configmap + annotations: {} + # -- Maxmind license key to download GeoLite2 Databases. + ## https://blog.maxmind.com/2019/12/significant-changes-to-accessing-and-using-geolite2-databases/ + maxmindLicenseKey: "" + # -- Additional command line arguments to pass to Ingress-Nginx Controller + # E.g. to specify the default SSL certificate you can use + extraArgs: {} + ## extraArgs: + ## default-ssl-certificate: "/" + ## time-buckets: "0.005,0.01,0.025,0.05,0.1,0.25,0.5,1,2.5,5,10" + ## length-buckets: "10,20,30,40,50,60,70,80,90,100" + ## size-buckets: "10,100,1000,10000,100000,1e+06,1e+07" + + # -- Additional environment variables to set + extraEnvs: [] + # extraEnvs: + # - name: FOO + # valueFrom: + # secretKeyRef: + # key: FOO + # name: secret-resource + + # -- Use a `DaemonSet` or `Deployment` + kind: Deployment + # -- Annotations to be added to the controller Deployment or DaemonSet + ## + annotations: {} + # keel.sh/pollSchedule: "@every 60m" + + # -- Labels to be added to the controller Deployment or DaemonSet and other resources that do not have option to specify labels + ## + labels: {} + # keel.sh/policy: patch + # keel.sh/trigger: poll + + # -- The update strategy to apply to the Deployment or DaemonSet + ## + updateStrategy: {} + # rollingUpdate: + # maxUnavailable: 1 + # type: RollingUpdate + + # -- `minReadySeconds` to avoid killing pods before we are ready + ## + minReadySeconds: 0 + # -- Node tolerations for server scheduling to nodes with taints + ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/ + ## + tolerations: [] + # - key: "key" + # operator: "Equal|Exists" + # value: "value" + # effect: "NoSchedule|PreferNoSchedule|NoExecute(1.6 only)" + + # -- Affinity and anti-affinity rules for server scheduling to nodes + ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#affinity-and-anti-affinity + ## + affinity: {} + # # An example of preferred pod anti-affinity, weight is in the range 1-100 + # podAntiAffinity: + # preferredDuringSchedulingIgnoredDuringExecution: + # - weight: 100 + # podAffinityTerm: + # labelSelector: + # matchExpressions: + # - key: app.kubernetes.io/name + # operator: In + # values: + # - '{{ include "ingress-nginx.name" . }}' + # - key: app.kubernetes.io/instance + # operator: In + # values: + # - '{{ .Release.Name }}' + # - key: app.kubernetes.io/component + # operator: In + # values: + # - controller + # topologyKey: kubernetes.io/hostname + + # # An example of required pod anti-affinity + # podAntiAffinity: + # requiredDuringSchedulingIgnoredDuringExecution: + # - labelSelector: + # matchExpressions: + # - key: app.kubernetes.io/name + # operator: In + # values: + # - '{{ include "ingress-nginx.name" . }}' + # - key: app.kubernetes.io/instance + # operator: In + # values: + # - '{{ .Release.Name }}' + # - key: app.kubernetes.io/component + # operator: In + # values: + # - controller + # topologyKey: kubernetes.io/hostname + + # -- Topology spread constraints rely on node labels to identify the topology domain(s) that each Node is in. + ## Ref: https://kubernetes.io/docs/concepts/workloads/pods/pod-topology-spread-constraints/ + ## + topologySpreadConstraints: [] + # - labelSelector: + # matchLabels: + # app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + # app.kubernetes.io/instance: '{{ .Release.Name }}' + # app.kubernetes.io/component: controller + # topologyKey: topology.kubernetes.io/zone + # maxSkew: 1 + # whenUnsatisfiable: ScheduleAnyway + # - labelSelector: + # matchLabels: + # app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + # app.kubernetes.io/instance: '{{ .Release.Name }}' + # app.kubernetes.io/component: controller + # topologyKey: kubernetes.io/hostname + # maxSkew: 1 + # whenUnsatisfiable: ScheduleAnyway + + # -- `terminationGracePeriodSeconds` to avoid killing pods before we are ready + ## wait up to five minutes for the drain of connections + ## + terminationGracePeriodSeconds: 300 + # -- Node labels for controller pod assignment + ## Ref: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/ + ## + nodeSelector: + kubernetes.io/os: linux + ## Liveness and readiness probe values + ## Ref: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle/#container-probes + ## + ## startupProbe: + ## httpGet: + ## # should match container.healthCheckPath + ## path: "/healthz" + ## port: 10254 + ## scheme: HTTP + ## initialDelaySeconds: 5 + ## periodSeconds: 5 + ## timeoutSeconds: 2 + ## successThreshold: 1 + ## failureThreshold: 5 + livenessProbe: + httpGet: + # should match container.healthCheckPath + path: "/healthz" + port: 10254 + scheme: HTTP + initialDelaySeconds: 10 + periodSeconds: 10 + timeoutSeconds: 1 + successThreshold: 1 + failureThreshold: 5 + readinessProbe: + httpGet: + # should match container.healthCheckPath + path: "/healthz" + port: 10254 + scheme: HTTP + initialDelaySeconds: 10 + periodSeconds: 10 + timeoutSeconds: 1 + successThreshold: 1 + failureThreshold: 3 + # -- Path of the health check endpoint. All requests received on the port defined by + # the healthz-port parameter are forwarded internally to this path. + healthCheckPath: "/healthz" + # -- Address to bind the health check endpoint. + # It is better to set this option to the internal node address + # if the Ingress-Nginx Controller is running in the `hostNetwork: true` mode. + healthCheckHost: "" + # -- Annotations to be added to controller pods + ## + podAnnotations: {} + replicaCount: 1 + # -- Minimum available pods set in PodDisruptionBudget. + # Define either 'minAvailable' or 'maxUnavailable', never both. + minAvailable: 1 + # -- Maximum unavailable pods set in PodDisruptionBudget. If set, 'minAvailable' is ignored. + # maxUnavailable: 1 + + ## Define requests resources to avoid probe issues due to CPU utilization in busy nodes + ## ref: https://github.com/kubernetes/ingress-nginx/issues/4735#issuecomment-551204903 + ## Ideally, there should be no limits. + ## https://engineering.indeedblog.com/blog/2019/12/cpu-throttling-regression-fix/ + resources: + ## limits: + ## cpu: 100m + ## memory: 90Mi + requests: + cpu: 100m + memory: 90Mi + # Mutually exclusive with keda autoscaling + autoscaling: + enabled: false + annotations: {} + minReplicas: 1 + maxReplicas: 11 + targetCPUUtilizationPercentage: 50 + targetMemoryUtilizationPercentage: 50 + behavior: {} + # scaleDown: + # stabilizationWindowSeconds: 300 + # policies: + # - type: Pods + # value: 1 + # periodSeconds: 180 + # scaleUp: + # stabilizationWindowSeconds: 300 + # policies: + # - type: Pods + # value: 2 + # periodSeconds: 60 + autoscalingTemplate: [] + # Custom or additional autoscaling metrics + # ref: https://kubernetes.io/docs/tasks/run-application/horizontal-pod-autoscale/#support-for-custom-metrics + # - type: Pods + # pods: + # metric: + # name: nginx_ingress_controller_nginx_process_requests_total + # target: + # type: AverageValue + # averageValue: 10000m + + # Mutually exclusive with hpa autoscaling + keda: + apiVersion: "keda.sh/v1alpha1" + ## apiVersion changes with keda 1.x vs 2.x + ## 2.x = keda.sh/v1alpha1 + ## 1.x = keda.k8s.io/v1alpha1 + enabled: false + minReplicas: 1 + maxReplicas: 11 + pollingInterval: 30 + cooldownPeriod: 300 + # fallback: + # failureThreshold: 3 + # replicas: 11 + restoreToOriginalReplicaCount: false + scaledObject: + annotations: {} + # Custom annotations for ScaledObject resource + # annotations: + # key: value + triggers: [] + # - type: prometheus + # metadata: + # serverAddress: http://:9090 + # metricName: http_requests_total + # threshold: '100' + # query: sum(rate(http_requests_total{deployment="my-deployment"}[2m])) + + behavior: {} + # scaleDown: + # stabilizationWindowSeconds: 300 + # policies: + # - type: Pods + # value: 1 + # periodSeconds: 180 + # scaleUp: + # stabilizationWindowSeconds: 300 + # policies: + # - type: Pods + # value: 2 + # periodSeconds: 60 + # -- Enable mimalloc as a drop-in replacement for malloc. + ## ref: https://github.com/microsoft/mimalloc + ## + enableMimalloc: true + ## Override NGINX template + customTemplate: + configMapName: "" + configMapKey: "" + service: + # -- Enable controller services or not. This does not influence the creation of either the admission webhook or the metrics service. + enabled: true + external: + # -- Enable the external controller service or not. Useful for internal-only deployments. + enabled: true + # -- Annotations to be added to the external controller service. See `controller.service.internal.annotations` for annotations to be added to the internal controller service. + annotations: {} + # -- Labels to be added to both controller services. + labels: {} + # -- Type of the external controller service. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types + type: LoadBalancer + # -- Pre-defined cluster internal IP address of the external controller service. Take care of collisions with existing services. + # This value is immutable. Set once, it can not be changed without deleting and re-creating the service. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#choosing-your-own-ip-address + clusterIP: "" + # -- List of node IP addresses at which the external controller service is available. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips + externalIPs: [] + # -- Deprecated: Pre-defined IP address of the external controller service. Used by cloud providers to connect the resulting load balancer service to a pre-existing static IP. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#loadbalancer + loadBalancerIP: "" + # -- Restrict access to the external controller service. Values must be CIDRs. Allows any source address by default. + loadBalancerSourceRanges: [] + # -- Load balancer class of the external controller service. Used by cloud providers to select a load balancer implementation other than the cloud provider default. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-class + loadBalancerClass: "" + # -- Enable node port allocation for the external controller service or not. Applies to type `LoadBalancer` only. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-nodeport-allocation + # allocateLoadBalancerNodePorts: true + + # -- External traffic policy of the external controller service. Set to "Local" to preserve source IP on providers supporting it. + # Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip + externalTrafficPolicy: "" + # -- Session affinity of the external controller service. Must be either "None" or "ClientIP" if set. Defaults to "None". + # Ref: https://kubernetes.io/docs/reference/networking/virtual-ips/#session-affinity + sessionAffinity: "" + # -- Specifies the health check node port (numeric port number) for the external controller service. + # If not specified, the service controller allocates a port from your cluster's node port range. + # Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip + # healthCheckNodePort: 0 + + # -- Represents the dual-stack capabilities of the external controller service. Possible values are SingleStack, PreferDualStack or RequireDualStack. + # Fields `ipFamilies` and `clusterIP` depend on the value of this field. + # Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services + ipFamilyPolicy: SingleStack + # -- List of IP families (e.g. IPv4, IPv6) assigned to the external controller service. This field is usually assigned automatically based on cluster configuration and the `ipFamilyPolicy` field. + # Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services + ipFamilies: + - IPv4 + # -- Enable the HTTP listener on both controller services or not. + enableHttp: true + # -- Enable the HTTPS listener on both controller services or not. + enableHttps: true + ports: + # -- Port the external HTTP listener is published with. + http: 80 + # -- Port the external HTTPS listener is published with. + https: 443 + targetPorts: + # -- Port of the ingress controller the external HTTP listener is mapped to. + http: http + # -- Port of the ingress controller the external HTTPS listener is mapped to. + https: https + # -- Declare the app protocol of the external HTTP and HTTPS listeners or not. Supersedes provider-specific annotations for declaring the backend protocol. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#application-protocol + appProtocol: true + nodePorts: + # -- Node port allocated for the external HTTP listener. If left empty, the service controller allocates one from the configured node port range. + http: "" + # -- Node port allocated for the external HTTPS listener. If left empty, the service controller allocates one from the configured node port range. + https: "" + # -- Node port mapping for external TCP listeners. If left empty, the service controller allocates them from the configured node port range. + # Example: + # tcp: + # 8080: 30080 + tcp: {} + # -- Node port mapping for external UDP listeners. If left empty, the service controller allocates them from the configured node port range. + # Example: + # udp: + # 53: 30053 + udp: {} + internal: + # -- Enable the internal controller service or not. Remember to configure `controller.service.internal.annotations` when enabling this. + enabled: false + # -- Annotations to be added to the internal controller service. Mandatory for the internal controller service to be created. Varies with the cloud service. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#internal-load-balancer + annotations: {} + # -- Type of the internal controller service. + # Defaults to the value of `controller.service.type`. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types + type: "" + # -- Pre-defined cluster internal IP address of the internal controller service. Take care of collisions with existing services. + # This value is immutable. Set once, it can not be changed without deleting and re-creating the service. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#choosing-your-own-ip-address + clusterIP: "" + # -- List of node IP addresses at which the internal controller service is available. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips + externalIPs: [] + # -- Deprecated: Pre-defined IP address of the internal controller service. Used by cloud providers to connect the resulting load balancer service to a pre-existing static IP. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#loadbalancer + loadBalancerIP: "" + # -- Restrict access to the internal controller service. Values must be CIDRs. Allows any source address by default. + loadBalancerSourceRanges: [] + # -- Load balancer class of the internal controller service. Used by cloud providers to select a load balancer implementation other than the cloud provider default. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-class + loadBalancerClass: "" + # -- Enable node port allocation for the internal controller service or not. Applies to type `LoadBalancer` only. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-nodeport-allocation + # allocateLoadBalancerNodePorts: true + + # -- External traffic policy of the internal controller service. Set to "Local" to preserve source IP on providers supporting it. + # Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip + externalTrafficPolicy: "" + # -- Session affinity of the internal controller service. Must be either "None" or "ClientIP" if set. Defaults to "None". + # Ref: https://kubernetes.io/docs/reference/networking/virtual-ips/#session-affinity + sessionAffinity: "" + # -- Specifies the health check node port (numeric port number) for the internal controller service. + # If not specified, the service controller allocates a port from your cluster's node port range. + # Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip + # healthCheckNodePort: 0 + + # -- Represents the dual-stack capabilities of the internal controller service. Possible values are SingleStack, PreferDualStack or RequireDualStack. + # Fields `ipFamilies` and `clusterIP` depend on the value of this field. + # Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services + ipFamilyPolicy: SingleStack + # -- List of IP families (e.g. IPv4, IPv6) assigned to the internal controller service. This field is usually assigned automatically based on cluster configuration and the `ipFamilyPolicy` field. + # Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services + ipFamilies: + - IPv4 + ports: {} + # -- Port the internal HTTP listener is published with. + # Defaults to the value of `controller.service.ports.http`. + # http: 80 + # -- Port the internal HTTPS listener is published with. + # Defaults to the value of `controller.service.ports.https`. + # https: 443 + + targetPorts: {} + # -- Port of the ingress controller the internal HTTP listener is mapped to. + # Defaults to the value of `controller.service.targetPorts.http`. + # http: http + # -- Port of the ingress controller the internal HTTPS listener is mapped to. + # Defaults to the value of `controller.service.targetPorts.https`. + # https: https + + # -- Declare the app protocol of the internal HTTP and HTTPS listeners or not. Supersedes provider-specific annotations for declaring the backend protocol. + # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#application-protocol + appProtocol: true + nodePorts: + # -- Node port allocated for the internal HTTP listener. If left empty, the service controller allocates one from the configured node port range. + http: "" + # -- Node port allocated for the internal HTTPS listener. If left empty, the service controller allocates one from the configured node port range. + https: "" + # -- Node port mapping for internal TCP listeners. If left empty, the service controller allocates them from the configured node port range. + # Example: + # tcp: + # 8080: 30080 + tcp: {} + # -- Node port mapping for internal UDP listeners. If left empty, the service controller allocates them from the configured node port range. + # Example: + # udp: + # 53: 30053 + udp: {} + # shareProcessNamespace enables process namespace sharing within the pod. + # This can be used for example to signal log rotation using `kill -USR1` from a sidecar. + shareProcessNamespace: false + # -- Additional containers to be added to the controller pod. + # See https://github.com/lemonldap-ng-controller/lemonldap-ng-controller as example. + extraContainers: [] + # - name: my-sidecar + # image: nginx:latest + # - name: lemonldap-ng-controller + # image: lemonldapng/lemonldap-ng-controller:0.2.0 + # args: + # - /lemonldap-ng-controller + # - --alsologtostderr + # - --configmap=$(POD_NAMESPACE)/lemonldap-ng-configuration + # env: + # - name: POD_NAME + # valueFrom: + # fieldRef: + # fieldPath: metadata.name + # - name: POD_NAMESPACE + # valueFrom: + # fieldRef: + # fieldPath: metadata.namespace + # volumeMounts: + # - name: copy-portal-skins + # mountPath: /srv/var/lib/lemonldap-ng/portal/skins + + # -- Additional volumeMounts to the controller main container. + extraVolumeMounts: [] + # - name: copy-portal-skins + # mountPath: /var/lib/lemonldap-ng/portal/skins + + # -- Additional volumes to the controller pod. + extraVolumes: [] + # - name: copy-portal-skins + # emptyDir: {} + + # -- Containers, which are run before the app containers are started. + extraInitContainers: [] + # - name: init-myservice + # image: busybox + # command: ['sh', '-c', 'until nslookup myservice; do echo waiting for myservice; sleep 2; done;'] + + # -- Modules, which are mounted into the core nginx image. See values.yaml for a sample to add opentelemetry module + extraModules: [] + # - name: mytestmodule + # image: + # registry: registry.k8s.io + # image: ingress-nginx/mytestmodule + # ## for backwards compatibility consider setting the full image url via the repository value below + # ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail + # ## repository: + # tag: "v1.0.0" + # digest: "" + # distroless: false + # containerSecurityContext: + # runAsNonRoot: true + # runAsUser: + # allowPrivilegeEscalation: false + # seccompProfile: + # type: RuntimeDefault + # capabilities: + # drop: + # - ALL + # readOnlyRootFilesystem: true + # resources: {} + # + # The image must contain a `/usr/local/bin/init_module.sh` executable, which + # will be executed as initContainers, to move its config files within the + # mounted volume. + + opentelemetry: + enabled: false + name: opentelemetry + image: + registry: registry.k8s.io + image: ingress-nginx/opentelemetry-1.25.3 + ## for backwards compatibility consider setting the full image url via the repository value below + ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail + ## repository: + tag: v20240813-b933310d + digest: sha256:f7604ac0547ed64d79b98d92133234e66c2c8aade3c1f4809fed5eec1fb7f922 + distroless: true + containerSecurityContext: + runAsNonRoot: true + # -- The image's default user, inherited from its base image `cgr.dev/chainguard/static`. + runAsUser: 65532 + allowPrivilegeEscalation: false + seccompProfile: + type: RuntimeDefault + capabilities: + drop: + - ALL + readOnlyRootFilesystem: true + resources: {} + admissionWebhooks: + name: admission + annotations: {} + # ignore-check.kube-linter.io/no-read-only-rootfs: "This deployment needs write access to root filesystem". + + ## Additional annotations to the admission webhooks. + ## These annotations will be added to the ValidatingWebhookConfiguration and + ## the Jobs Spec of the admission webhooks. + enabled: true + # -- Additional environment variables to set + extraEnvs: [] + # extraEnvs: + # - name: FOO + # valueFrom: + # secretKeyRef: + # key: FOO + # name: secret-resource + # -- Admission Webhook failure policy to use + failurePolicy: Fail + # timeoutSeconds: 10 + port: 8443 + certificate: "/usr/local/certificates/cert" + key: "/usr/local/certificates/key" + namespaceSelector: {} + objectSelector: {} + # -- Labels to be added to admission webhooks + labels: {} + # -- Use an existing PSP instead of creating one + existingPsp: "" + service: + annotations: {} + # clusterIP: "" + externalIPs: [] + # loadBalancerIP: "" + loadBalancerSourceRanges: [] + servicePort: 443 + type: ClusterIP + createSecretJob: + name: create + # -- Security context for secret creation containers + securityContext: + runAsNonRoot: true + runAsUser: 65532 + allowPrivilegeEscalation: false + seccompProfile: + type: RuntimeDefault + capabilities: + drop: + - ALL + readOnlyRootFilesystem: true + resources: {} + # limits: + # cpu: 10m + # memory: 20Mi + # requests: + # cpu: 10m + # memory: 20Mi + patchWebhookJob: + name: patch + # -- Security context for webhook patch containers + securityContext: + runAsNonRoot: true + runAsUser: 65532 + allowPrivilegeEscalation: false + seccompProfile: + type: RuntimeDefault + capabilities: + drop: + - ALL + readOnlyRootFilesystem: true + resources: {} + patch: + enabled: true + image: + registry: registry.k8s.io + image: ingress-nginx/kube-webhook-certgen + ## for backwards compatibility consider setting the full image url via the repository value below + ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail + ## repository: + tag: v1.4.4 + digest: sha256:a9f03b34a3cbfbb26d103a14046ab2c5130a80c3d69d526ff8063d2b37b9fd3f + pullPolicy: IfNotPresent + # -- Provide a priority class name to the webhook patching job + ## + priorityClassName: "" + podAnnotations: {} + # NetworkPolicy for webhook patch + networkPolicy: + # -- Enable 'networkPolicy' or not + enabled: false + nodeSelector: + kubernetes.io/os: linux + tolerations: [] + # -- Labels to be added to patch job resources + labels: {} + # -- Security context for secret creation & webhook patch pods + securityContext: {} + # -- Admission webhook patch job RBAC + rbac: + # -- Create RBAC or not + create: true + # -- Admission webhook patch job service account + serviceAccount: + # -- Create a service account or not + create: true + # -- Custom service account name + name: "" + # -- Auto-mount service account token or not + automountServiceAccountToken: true + # Use certmanager to generate webhook certs + certManager: + enabled: false + # self-signed root certificate + rootCert: + # default to be 5y + duration: "" + admissionCert: + # default to be 1y + duration: "" + # issuerRef: + # name: "issuer" + # kind: "ClusterIssuer" + metrics: + port: 10254 + portName: metrics + # if this port is changed, change healthz-port: in extraArgs: accordingly + enabled: false + service: + annotations: {} + # prometheus.io/scrape: "true" + # prometheus.io/port: "10254" + # -- Labels to be added to the metrics service resource + labels: {} + # clusterIP: "" + + # -- List of IP addresses at which the stats-exporter service is available + ## Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips + ## + externalIPs: [] + # loadBalancerIP: "" + loadBalancerSourceRanges: [] + servicePort: 10254 + type: ClusterIP + # externalTrafficPolicy: "" + # nodePort: "" + serviceMonitor: + enabled: false + additionalLabels: {} + # -- Annotations to be added to the ServiceMonitor. + annotations: {} + ## The label to use to retrieve the job name from. + ## jobLabel: "app.kubernetes.io/name" + namespace: "" + namespaceSelector: {} + ## Default: scrape .Release.Namespace or namespaceOverride only + ## To scrape all, use the following: + ## namespaceSelector: + ## any: true + scrapeInterval: 30s + # honorLabels: true + targetLabels: [] + relabelings: [] + metricRelabelings: [] + prometheusRule: + enabled: false + additionalLabels: {} + # namespace: "" + rules: [] + # # These are just examples rules, please adapt them to your needs + # - alert: NGINXConfigFailed + # expr: count(nginx_ingress_controller_config_last_reload_successful == 0) > 0 + # for: 1s + # labels: + # severity: critical + # annotations: + # description: bad ingress config - nginx config test failed + # summary: uninstall the latest ingress changes to allow config reloads to resume + # # By default a fake self-signed certificate is generated as default and + # # it is fine if it expires. If `--default-ssl-certificate` flag is used + # # and a valid certificate passed please do not filter for `host` label! + # # (i.e. delete `{host!="_"}` so also the default SSL certificate is + # # checked for expiration) + # - alert: NGINXCertificateExpiry + # expr: (avg(nginx_ingress_controller_ssl_expire_time_seconds{host!="_"}) by (host) - time()) < 604800 + # for: 1s + # labels: + # severity: critical + # annotations: + # description: ssl certificate(s) will expire in less then a week + # summary: renew expiring certificates to avoid downtime + # - alert: NGINXTooMany500s + # expr: 100 * ( sum( nginx_ingress_controller_requests{status=~"5.+"} ) / sum(nginx_ingress_controller_requests) ) > 5 + # for: 1m + # labels: + # severity: warning + # annotations: + # description: Too many 5XXs + # summary: More than 5% of all requests returned 5XX, this requires your attention + # - alert: NGINXTooMany400s + # expr: 100 * ( sum( nginx_ingress_controller_requests{status=~"4.+"} ) / sum(nginx_ingress_controller_requests) ) > 5 + # for: 1m + # labels: + # severity: warning + # annotations: + # description: Too many 4XXs + # summary: More than 5% of all requests returned 4XX, this requires your attention + # -- Improve connection draining when ingress controller pod is deleted using a lifecycle hook: + # With this new hook, we increased the default terminationGracePeriodSeconds from 30 seconds + # to 300, allowing the draining of connections up to five minutes. + # If the active connections end before that, the pod will terminate gracefully at that time. + # To effectively take advantage of this feature, the Configmap feature + # worker-shutdown-timeout new value is 240s instead of 10s. + ## + lifecycle: + preStop: + exec: + command: + - /wait-shutdown + priorityClassName: "" +# -- Rollback limit +## +revisionHistoryLimit: 10 +## Default 404 backend +## +defaultBackend: + ## + enabled: false + name: defaultbackend + image: + registry: registry.k8s.io + image: defaultbackend-amd64 + ## for backwards compatibility consider setting the full image url via the repository value below + ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail + ## repository: + tag: "1.5" + pullPolicy: IfNotPresent + runAsNonRoot: true + # nobody user -> uid 65534 + runAsUser: 65534 + allowPrivilegeEscalation: false + seccompProfile: + type: RuntimeDefault + readOnlyRootFilesystem: true + # -- Use an existing PSP instead of creating one + existingPsp: "" + extraArgs: {} + serviceAccount: + create: true + name: "" + automountServiceAccountToken: true + # -- Additional environment variables to set for defaultBackend pods + extraEnvs: [] + port: 8080 + ## Readiness and liveness probes for default backend + ## Ref: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-probes/ + ## + livenessProbe: + failureThreshold: 3 + initialDelaySeconds: 30 + periodSeconds: 10 + successThreshold: 1 + timeoutSeconds: 5 + readinessProbe: + failureThreshold: 6 + initialDelaySeconds: 0 + periodSeconds: 5 + successThreshold: 1 + timeoutSeconds: 5 + # -- The update strategy to apply to the Deployment or DaemonSet + ## + updateStrategy: {} + # rollingUpdate: + # maxUnavailable: 1 + # type: RollingUpdate + + # -- `minReadySeconds` to avoid killing pods before we are ready + ## + minReadySeconds: 0 + # -- Node tolerations for server scheduling to nodes with taints + ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/ + ## + tolerations: [] + # - key: "key" + # operator: "Equal|Exists" + # value: "value" + # effect: "NoSchedule|PreferNoSchedule|NoExecute(1.6 only)" + + # -- Affinity and anti-affinity rules for server scheduling to nodes + ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#affinity-and-anti-affinity + affinity: {} + # # An example of preferred pod anti-affinity, weight is in the range 1-100 + # podAntiAffinity: + # preferredDuringSchedulingIgnoredDuringExecution: + # - weight: 100 + # podAffinityTerm: + # labelSelector: + # matchExpressions: + # - key: app.kubernetes.io/name + # operator: In + # values: + # - '{{ include "ingress-nginx.name" . }}' + # - key: app.kubernetes.io/instance + # operator: In + # values: + # - '{{ .Release.Name }}' + # - key: app.kubernetes.io/component + # operator: In + # values: + # - default-backend + # topologyKey: kubernetes.io/hostname + + # # An example of required pod anti-affinity + # podAntiAffinity: + # requiredDuringSchedulingIgnoredDuringExecution: + # - labelSelector: + # matchExpressions: + # - key: app.kubernetes.io/name + # operator: In + # values: + # - '{{ include "ingress-nginx.name" . }}' + # - key: app.kubernetes.io/instance + # operator: In + # values: + # - '{{ .Release.Name }}' + # - key: app.kubernetes.io/component + # operator: In + # values: + # - default-backend + # topologyKey: kubernetes.io/hostname + + # -- Topology spread constraints rely on node labels to identify the topology domain(s) that each Node is in. + # Ref.: https://kubernetes.io/docs/concepts/workloads/pods/pod-topology-spread-constraints/ + topologySpreadConstraints: [] + # - labelSelector: + # matchLabels: + # app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + # app.kubernetes.io/instance: '{{ .Release.Name }}' + # app.kubernetes.io/component: default-backend + # topologyKey: topology.kubernetes.io/zone + # maxSkew: 1 + # whenUnsatisfiable: ScheduleAnyway + # - labelSelector: + # matchLabels: + # app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' + # app.kubernetes.io/instance: '{{ .Release.Name }}' + # app.kubernetes.io/component: default-backend + # topologyKey: kubernetes.io/hostname + # maxSkew: 1 + # whenUnsatisfiable: ScheduleAnyway + # -- Security context for default backend pods + podSecurityContext: {} + # -- Security context for default backend containers + containerSecurityContext: {} + # -- Labels to add to the pod container metadata + podLabels: {} + # key: value + + # -- Node labels for default backend pod assignment + ## Ref: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/ + ## + nodeSelector: + kubernetes.io/os: linux + # -- Annotations to be added to default backend pods + ## + podAnnotations: {} + replicaCount: 1 + # -- Minimum available pods set in PodDisruptionBudget. + minAvailable: 1 + resources: {} + # limits: + # cpu: 10m + # memory: 20Mi + # requests: + # cpu: 10m + # memory: 20Mi + + extraVolumeMounts: [] + ## Additional volumeMounts to the default backend container. + # - name: copy-portal-skins + # mountPath: /var/lib/lemonldap-ng/portal/skins + + extraVolumes: [] + ## Additional volumes to the default backend pod. + # - name: copy-portal-skins + # emptyDir: {} + + extraConfigMaps: [] + ## Additional configmaps to the default backend pod. + # - name: my-extra-configmap-1 + # labels: + # type: config-1 + # data: + # extra_file_1.html: | + # + # - name: my-extra-configmap-2 + # labels: + # type: config-2 + # data: + # extra_file_2.html: | + # + + autoscaling: + annotations: {} + enabled: false + minReplicas: 1 + maxReplicas: 2 + targetCPUUtilizationPercentage: 50 + targetMemoryUtilizationPercentage: 50 + # NetworkPolicy for default backend component. + networkPolicy: + # -- Enable 'networkPolicy' or not + enabled: false + service: + annotations: {} + # clusterIP: "" + + # -- List of IP addresses at which the default backend service is available + ## Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips + ## + externalIPs: [] + # loadBalancerIP: "" + loadBalancerSourceRanges: [] + servicePort: 80 + type: ClusterIP + priorityClassName: "" + # -- Labels to be added to the default backend resources + labels: {} +## Enable RBAC as per https://github.com/kubernetes/ingress-nginx/blob/main/docs/deploy/rbac.md and https://github.com/kubernetes/ingress-nginx/issues/266 +rbac: + create: true + scope: false +## If true, create & use Pod Security Policy resources +## https://kubernetes.io/docs/concepts/policy/pod-security-policy/ +podSecurityPolicy: + enabled: false +serviceAccount: + create: true + name: "" + automountServiceAccountToken: true + # -- Annotations for the controller service account + annotations: {} +# -- Optional array of imagePullSecrets containing private registry credentials +## Ref: https://kubernetes.io/docs/tasks/configure-pod-container/pull-image-private-registry/ +imagePullSecrets: [] +# - name: secretName + +# -- TCP service key-value pairs +## Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/exposing-tcp-udp-services.md +## +tcp: {} +# "8080": "default/example-tcp-svc:9000" + +# -- UDP service key-value pairs +## Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/exposing-tcp-udp-services.md +## +udp: {} +# "53": "kube-system/kube-dns:53" + +# -- Prefix for TCP and UDP ports names in ingress controller service +## Some cloud providers, like Yandex Cloud may have a requirements for a port name regex to support cloud load balancer integration +portNamePrefix: "" +# -- (string) A base64-encoded Diffie-Hellman parameter. +# This can be generated with: `openssl dhparam 4096 2> /dev/null | base64` +## Ref: https://github.com/kubernetes/ingress-nginx/tree/main/docs/examples/customization/ssl-dh-param +dhParam: "" From 3beb8dc04d69940733fea01e88a0519ce59bf07d Mon Sep 17 00:00:00 2001 From: shahargl Date: Mon, 21 Oct 2024 15:52:01 +0300 Subject: [PATCH 09/19] feat: wip --- charts/keep/values.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/charts/keep/values.yaml b/charts/keep/values.yaml index 6625ba8..7d6ad1b 100644 --- a/charts/keep/values.yaml +++ b/charts/keep/values.yaml @@ -9,7 +9,7 @@ isGKE: false global: # this section controls the ingress resource and not the ingress-nginx controller - # see the ingress-nginx section below for the controller configuration + # see the ingress-nginx section below for the controller configuration ingress: enabled: true className: "nginx" From bb3206a3e35b788fe0b0e492c5b3b4e0af66fa50 Mon Sep 17 00:00:00 2001 From: shahargl Date: Mon, 21 Oct 2024 15:53:50 +0300 Subject: [PATCH 10/19] feat: wip --- charts/keep/values.yaml | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/charts/keep/values.yaml b/charts/keep/values.yaml index 7d6ad1b..0b8ed7e 100644 --- a/charts/keep/values.yaml +++ b/charts/keep/values.yaml @@ -8,14 +8,17 @@ fullnameOverride: "" isGKE: false global: - # this section controls the ingress resource and not the ingress-nginx controller - # see the ingress-nginx section below for the controller configuration + # this section controls the ingress resource and + # not the ingress-nginx controller + # see the ingress-nginx section below for the + # controller configuration ingress: enabled: true className: "nginx" annotations: {} websocketPrefix: "/websocket" - # can't use /api since its "catched" by the nextjs frontend e.g. /api/auth/signin or /api/config + # can't use /api since its "catched" by the nextjs frontend e.g + # . /api/auth/signin or /api/config backendPrefix: "/apinew" frontendPrefix: "/" hosts: [] From d392e0dac4db47040f16e71e2e8c00716c67f329 Mon Sep 17 00:00:00 2001 From: shahargl Date: Tue, 22 Oct 2024 12:54:45 +0300 Subject: [PATCH 11/19] feat: wip --- charts/keep/Chart.lock | 6 - charts/keep/Chart.yaml | 10 - charts/keep/charts/ingress-nginx-4.11.3.tgz | Bin 58282 -> 0 bytes charts/keep/charts/ingress-nginx/.helmignore | 23 - charts/keep/charts/ingress-nginx/Chart.yaml | 25 - charts/keep/charts/ingress-nginx/OWNERS | 10 - charts/keep/charts/ingress-nginx/README.md | 559 -------- .../charts/ingress-nginx/README.md.gotmpl | 229 ---- .../changelog/helm-chart-2.10.0.md | 9 - .../changelog/helm-chart-2.11.0.md | 10 - .../changelog/helm-chart-2.11.1.md | 9 - .../changelog/helm-chart-2.11.2.md | 9 - .../changelog/helm-chart-2.11.3.md | 9 - .../changelog/helm-chart-2.12.0.md | 10 - .../changelog/helm-chart-2.12.1.md | 9 - .../changelog/helm-chart-2.13.0.md | 10 - .../changelog/helm-chart-2.14.0.md | 9 - .../changelog/helm-chart-2.15.0.md | 9 - .../changelog/helm-chart-2.16.0.md | 9 - .../changelog/helm-chart-2.9.0.md | 9 - .../changelog/helm-chart-2.9.1.md | 9 - .../changelog/helm-chart-3.0.0.md | 9 - .../changelog/helm-chart-3.10.0.md | 9 - .../changelog/helm-chart-3.10.1.md | 9 - .../changelog/helm-chart-3.11.0.md | 9 - .../changelog/helm-chart-3.11.1.md | 9 - .../changelog/helm-chart-3.12.0.md | 9 - .../changelog/helm-chart-3.13.0.md | 9 - .../changelog/helm-chart-3.14.0.md | 9 - .../changelog/helm-chart-3.15.0.md | 9 - .../changelog/helm-chart-3.15.1.md | 9 - .../changelog/helm-chart-3.16.0.md | 9 - .../changelog/helm-chart-3.16.1.md | 9 - .../changelog/helm-chart-3.17.0.md | 9 - .../changelog/helm-chart-3.18.0.md | 10 - .../changelog/helm-chart-3.19.0.md | 9 - .../changelog/helm-chart-3.20.0.md | 9 - .../changelog/helm-chart-3.20.1.md | 10 - .../changelog/helm-chart-3.21.0.md | 12 - .../changelog/helm-chart-3.22.0.md | 10 - .../changelog/helm-chart-3.23.0.md | 9 - .../changelog/helm-chart-3.24.0.md | 9 - .../changelog/helm-chart-3.25.0.md | 9 - .../changelog/helm-chart-3.26.0.md | 9 - .../changelog/helm-chart-3.27.0.md | 9 - .../changelog/helm-chart-3.28.0.md | 9 - .../changelog/helm-chart-3.29.0.md | 9 - .../changelog/helm-chart-3.3.0.md | 12 - .../changelog/helm-chart-3.3.1.md | 12 - .../changelog/helm-chart-3.30.0.md | 9 - .../changelog/helm-chart-3.31.0.md | 9 - .../changelog/helm-chart-3.32.0.md | 9 - .../changelog/helm-chart-3.33.0.md | 9 - .../changelog/helm-chart-3.34.0.md | 9 - .../changelog/helm-chart-3.4.0.md | 9 - .../changelog/helm-chart-3.5.0.md | 9 - .../changelog/helm-chart-3.5.1.md | 9 - .../changelog/helm-chart-3.6.0.md | 9 - .../changelog/helm-chart-3.7.0.md | 9 - .../changelog/helm-chart-3.7.1.md | 9 - .../changelog/helm-chart-3.8.0.md | 13 - .../changelog/helm-chart-3.9.0.md | 9 - .../changelog/helm-chart-4.0.1.md | 9 - .../changelog/helm-chart-4.0.10.md | 9 - .../changelog/helm-chart-4.0.11.md | 9 - .../changelog/helm-chart-4.0.12.md | 9 - .../changelog/helm-chart-4.0.13.md | 9 - .../changelog/helm-chart-4.0.14.md | 9 - .../changelog/helm-chart-4.0.15.md | 43 - .../changelog/helm-chart-4.0.18.md | 40 - .../changelog/helm-chart-4.0.2.md | 9 - .../changelog/helm-chart-4.0.3.md | 9 - .../changelog/helm-chart-4.0.5.md | 9 - .../changelog/helm-chart-4.0.6.md | 12 - .../changelog/helm-chart-4.0.7.md | 10 - .../changelog/helm-chart-4.0.9.md | 9 - .../changelog/helm-chart-4.1.0.md | 21 - .../changelog/helm-chart-4.1.2.md | 11 - .../changelog/helm-chart-4.10.0.md | 9 - .../changelog/helm-chart-4.10.1.md | 11 - .../changelog/helm-chart-4.10.2.md | 18 - .../changelog/helm-chart-4.11.0.md | 18 - .../changelog/helm-chart-4.11.1.md | 9 - .../changelog/helm-chart-4.11.2.md | 9 - .../changelog/helm-chart-4.11.3.md | 9 - .../changelog/helm-chart-4.2.0.md | 47 - .../changelog/helm-chart-4.2.1.md | 10 - .../changelog/helm-chart-4.3.0.md | 14 - .../changelog/helm-chart-4.4.0.md | 12 - .../changelog/helm-chart-4.5.2.md | 13 - .../changelog/helm-chart-4.6.0.md | 24 - .../changelog/helm-chart-4.6.1.md | 11 - .../changelog/helm-chart-4.7.0.md | 14 - .../changelog/helm-chart-4.7.1.md | 12 - .../changelog/helm-chart-4.7.2.md | 9 - .../changelog/helm-chart-4.8.0-beta.0.md | 13 - .../changelog/helm-chart-4.8.0.md | 13 - .../changelog/helm-chart-4.8.1.md | 9 - .../changelog/helm-chart-4.8.2.md | 10 - .../changelog/helm-chart-4.8.3.md | 9 - .../changelog/helm-chart-4.9.0.md | 13 - .../changelog/helm-chart-4.9.1.md | 10 - .../changelog/helm-chart.md.gotmpl | 11 - ...dmission-webhooks-cert-manager-values.yaml | 12 - ...ontroller-configmap-addheaders-values.yaml | 11 - ...troller-configmap-proxyheaders-values.yaml | 11 - .../ci/controller-configmap-values.yaml | 11 - ...roller-daemonset-extra-modules-values.yaml | 30 - .../controller-daemonset-metrics-values.yaml | 13 - ...roller-daemonset-opentelemetry-values.yaml | 13 - ...oller-daemonset-podannotations-values.yaml | 16 - .../ci/controller-daemonset-values.yaml | 10 - ...oller-deployment-extra-modules-values.yaml | 30 - .../controller-deployment-metrics-values.yaml | 13 - ...oller-deployment-opentelemetry-values.yaml | 13 - ...ller-deployment-podannotations-values.yaml | 16 - .../ci/controller-deployment-values.yaml | 10 - .../ci/controller-hpa-values.yaml | 18 - .../ci/controller-ingressclass-values.yaml | 15 - .../controller-service-internal-values.yaml | 13 - .../ci/controller-service-values.yaml | 22 - .../ci/deamonset-psp-values.yaml | 13 - .../ci/deamonset-webhook-and-psp-values.yaml | 13 - .../ci/deployment-psp-values.yaml | 10 - .../ci/deployment-webhook-and-psp-values.yaml | 12 - .../charts/ingress-nginx/templates/NOTES.txt | 73 - .../ingress-nginx/templates/_helpers.tpl | 272 ---- .../ingress-nginx/templates/_params.tpl | 77 -- .../admission-webhooks/cert-manager.yaml | 63 - .../job-patch/clusterrole.yaml | 33 - .../job-patch/clusterrolebinding.yaml | 23 - .../job-patch/job-createSecret.yaml | 79 -- .../job-patch/job-patchWebhook.yaml | 81 -- .../job-patch/networkpolicy.yaml | 26 - .../admission-webhooks/job-patch/psp.yaml | 52 - .../admission-webhooks/job-patch/role.yaml | 24 - .../job-patch/rolebinding.yaml | 24 - .../job-patch/serviceaccount.yaml | 17 - .../validating-webhook.yaml | 54 - .../ingress-nginx/templates/clusterrole.yaml | 102 -- .../templates/clusterrolebinding.yaml | 19 - .../controller-configmap-addheaders.yaml | 14 - .../controller-configmap-proxyheaders.yaml | 14 - .../templates/controller-configmap-tcp.yaml | 17 - .../templates/controller-configmap-udp.yaml | 17 - .../templates/controller-configmap.yaml | 28 - .../templates/controller-daemonset.yaml | 242 ---- .../templates/controller-deployment.yaml | 245 ---- .../templates/controller-hpa.yaml | 47 - .../controller-ingressclass-aliases.yaml | 23 - .../templates/controller-ingressclass.yaml | 26 - .../templates/controller-keda.yaml | 46 - .../templates/controller-networkpolicy.yaml | 45 - .../controller-poddisruptionbudget.yaml | 36 - .../templates/controller-prometheusrule.yaml | 23 - .../templates/controller-psp.yaml | 100 -- .../templates/controller-role.yaml | 104 -- .../templates/controller-rolebinding.yaml | 21 - .../templates/controller-secret.yaml | 15 - .../controller-service-internal.yaml | 105 -- .../templates/controller-service-metrics.yaml | 45 - .../templates/controller-service-webhook.yaml | 40 - .../templates/controller-service.yaml | 105 -- .../templates/controller-serviceaccount.yaml | 17 - .../templates/controller-servicemonitor.yaml | 53 - .../templates/default-backend-deployment.yaml | 119 -- .../default-backend-extra-configmaps.yaml | 23 - .../templates/default-backend-hpa.yaml | 40 - .../default-backend-networkpolicy.yaml | 25 - .../default-backend-poddisruptionbudget.yaml | 25 - .../templates/default-backend-psp.yaml | 50 - .../templates/default-backend-role.yaml | 22 - .../default-backend-rolebinding.yaml | 21 - .../templates/default-backend-service.yaml | 41 - .../default-backend-serviceaccount.yaml | 14 - .../job-patch/clusterrole_test.yaml | 11 - .../job-patch/clusterrolebinding_test.yaml | 11 - .../job-patch/role_test.yaml | 11 - .../job-patch/rolebinding_test.yaml | 11 - .../job-patch/serviceaccount_test.yaml | 47 - .../validating-webhook_test.yaml | 32 - .../controller-configmap-addheaders_test.yaml | 27 - ...ontroller-configmap-proxyheaders_test.yaml | 27 - .../tests/controller-configmap_test.yaml | 31 - .../tests/controller-daemonset_test.yaml | 172 --- .../tests/controller-deployment_test.yaml | 191 --- .../tests/controller-hpa_test.yaml | 31 - .../controller-ingressclass-aliases_test.yaml | 110 -- .../tests/controller-ingressclass_test.yaml | 93 -- .../tests/controller-keda_test.yaml | 31 - .../tests/controller-networkpolicy_test.yaml | 23 - .../controller-poddisruptionbudget_test.yaml | 89 -- .../tests/controller-prometheusrule_test.yaml | 17 - .../controller-service-internal_test.yaml | 25 - .../controller-service-metrics_test.yaml | 23 - .../controller-service-webhook_test.yaml | 32 - .../tests/controller-service_test.yaml | 32 - .../tests/controller-servicemonitor_test.yaml | 29 - .../default-backend-deployment_test.yaml | 169 --- ...default-backend-extra-configmaps_test.yaml | 50 - ...ault-backend-poddisruptionbudget_test.yaml | 48 - .../tests/default-backend-service_test.yaml | 32 - charts/keep/charts/ingress-nginx/values.yaml | 1192 ----------------- 203 files changed, 7680 deletions(-) delete mode 100644 charts/keep/Chart.lock delete mode 100644 charts/keep/charts/ingress-nginx-4.11.3.tgz delete mode 100644 charts/keep/charts/ingress-nginx/.helmignore delete mode 100644 charts/keep/charts/ingress-nginx/Chart.yaml delete mode 100644 charts/keep/charts/ingress-nginx/OWNERS delete mode 100644 charts/keep/charts/ingress-nginx/README.md delete mode 100644 charts/keep/charts/ingress-nginx/README.md.gotmpl delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.10.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.2.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.3.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.13.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.14.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.15.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.16.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.0.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.12.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.13.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.14.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.17.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.18.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.19.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.21.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.22.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.23.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.24.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.25.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.26.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.27.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.28.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.29.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.30.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.31.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.32.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.33.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.34.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.4.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.6.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.8.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-3.9.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.10.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.11.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.12.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.13.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.14.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.15.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.18.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.2.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.3.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.5.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.6.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.7.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.9.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.2.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.2.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.2.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.3.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.3.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.4.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.5.2.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.2.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0-beta.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.2.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.3.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.0.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.1.md delete mode 100644 charts/keep/charts/ingress-nginx/changelog/helm-chart.md.gotmpl delete mode 100644 charts/keep/charts/ingress-nginx/ci/admission-webhooks-cert-manager-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-configmap-addheaders-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-configmap-proxyheaders-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-configmap-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-extra-modules-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-metrics-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-opentelemetry-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-podannotations-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-daemonset-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-extra-modules-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-metrics-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-opentelemetry-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-podannotations-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-deployment-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-hpa-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-ingressclass-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-service-internal-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/controller-service-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/deamonset-psp-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/deamonset-webhook-and-psp-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/deployment-psp-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/ci/deployment-webhook-and-psp-values.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/NOTES.txt delete mode 100644 charts/keep/charts/ingress-nginx/templates/_helpers.tpl delete mode 100644 charts/keep/charts/ingress-nginx/templates/_params.tpl delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/cert-manager.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/networkpolicy.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/psp.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/clusterrole.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/clusterrolebinding.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap-addheaders.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap-proxyheaders.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap-tcp.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap-udp.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-configmap.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-daemonset.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-deployment.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-hpa.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-ingressclass-aliases.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-ingressclass.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-keda.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-networkpolicy.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-prometheusrule.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-psp.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-role.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-rolebinding.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-secret.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-service-internal.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-service-metrics.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-service-webhook.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-service.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/controller-servicemonitor.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-deployment.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-extra-configmaps.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-hpa.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-networkpolicy.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-poddisruptionbudget.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-psp.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-role.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-rolebinding.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-service.yaml delete mode 100644 charts/keep/charts/ingress-nginx/templates/default-backend-serviceaccount.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrole_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrolebinding_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/role_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/rolebinding_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/serviceaccount_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/admission-webhooks/validating-webhook_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-configmap-addheaders_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-configmap-proxyheaders_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-configmap_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-daemonset_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-deployment_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-hpa_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-ingressclass-aliases_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-ingressclass_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-keda_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-networkpolicy_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-poddisruptionbudget_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-prometheusrule_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-service-internal_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-service-metrics_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-service-webhook_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-service_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/controller-servicemonitor_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/default-backend-deployment_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/default-backend-extra-configmaps_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/default-backend-poddisruptionbudget_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/tests/default-backend-service_test.yaml delete mode 100644 charts/keep/charts/ingress-nginx/values.yaml diff --git a/charts/keep/Chart.lock b/charts/keep/Chart.lock deleted file mode 100644 index b041c5e..0000000 --- a/charts/keep/Chart.lock +++ /dev/null @@ -1,6 +0,0 @@ -dependencies: -- name: ingress-nginx - repository: file://./charts/ingress-nginx - version: 4.11.3 -digest: sha256:ff7ed0c079230e383ec15a0250323236ecaaf321816ccbb8af1fc6b230a161ee -generated: "2024-10-21T15:50:15.923046+03:00" diff --git a/charts/keep/Chart.yaml b/charts/keep/Chart.yaml index 4ec00a4..d2b9765 100644 --- a/charts/keep/Chart.yaml +++ b/charts/keep/Chart.yaml @@ -12,16 +12,6 @@ keywords: - alerting - monitoring - monitoring-tool -dependencies: - - name: ingress-nginx - # original from helm repo - # repository: https://kubernetes.github.io/ingress-nginx - # using a local copy of the ingress-nginx chart for now - repository: "file://./charts/ingress-nginx" - version: ~4.11.3 - condition: ingress-nginx.enabled - tags: - - ingress home: https://platform.keephq.dev/ sources: - https://github.com/keephq/helm-charts diff --git a/charts/keep/charts/ingress-nginx-4.11.3.tgz b/charts/keep/charts/ingress-nginx-4.11.3.tgz deleted file mode 100644 index 444186e75b46d0addc23b8531224f4df7a4e6cbc..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 58282 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 O0PWy!r8pKuIR6JWaczG9 diff --git a/charts/keep/charts/ingress-nginx/.helmignore b/charts/keep/charts/ingress-nginx/.helmignore deleted file mode 100644 index 109b408..0000000 --- a/charts/keep/charts/ingress-nginx/.helmignore +++ /dev/null @@ -1,23 +0,0 @@ -# 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 -*~ -# Various IDEs -.project -.idea/ -*.tmproj -.vscode/ -__snapshot__ diff --git a/charts/keep/charts/ingress-nginx/Chart.yaml b/charts/keep/charts/ingress-nginx/Chart.yaml deleted file mode 100644 index 1f01284..0000000 --- a/charts/keep/charts/ingress-nginx/Chart.yaml +++ /dev/null @@ -1,25 +0,0 @@ -annotations: - artifacthub.io/changes: | - - Update Ingress-Nginx version controller-v1.11.3 - artifacthub.io/prerelease: "false" -apiVersion: v2 -appVersion: 1.11.3 -description: Ingress controller for Kubernetes using NGINX as a reverse proxy and - load balancer -home: https://github.com/kubernetes/ingress-nginx -icon: https://upload.wikimedia.org/wikipedia/commons/thumb/c/c5/Nginx_logo.svg/500px-Nginx_logo.svg.png -keywords: -- ingress -- nginx -kubeVersion: '>=1.21.0-0' -maintainers: -- name: cpanato -- name: Gacko -- name: puerco -- name: rikatz -- name: strongjz -- name: tao12345666333 -name: ingress-nginx -sources: -- https://github.com/kubernetes/ingress-nginx -version: 4.11.3 diff --git a/charts/keep/charts/ingress-nginx/OWNERS b/charts/keep/charts/ingress-nginx/OWNERS deleted file mode 100644 index d588ede..0000000 --- a/charts/keep/charts/ingress-nginx/OWNERS +++ /dev/null @@ -1,10 +0,0 @@ -# See the OWNERS docs: https://www.kubernetes.dev/docs/guide/owners - -approvers: -- ingress-nginx-helm-maintainers - -reviewers: -- ingress-nginx-helm-reviewers - -labels: -- area/helm diff --git a/charts/keep/charts/ingress-nginx/README.md b/charts/keep/charts/ingress-nginx/README.md deleted file mode 100644 index f70bd0a..0000000 --- a/charts/keep/charts/ingress-nginx/README.md +++ /dev/null @@ -1,559 +0,0 @@ -# ingress-nginx - -[ingress-nginx](https://github.com/kubernetes/ingress-nginx) Ingress controller for Kubernetes using NGINX as a reverse proxy and load balancer - -![Version: 4.11.3](https://img.shields.io/badge/Version-4.11.3-informational?style=flat-square) ![AppVersion: 1.11.3](https://img.shields.io/badge/AppVersion-1.11.3-informational?style=flat-square) - -To use, add `ingressClassName: nginx` spec field or the `kubernetes.io/ingress.class: nginx` annotation to your Ingress resources. - -This chart bootstraps an ingress-nginx deployment on a [Kubernetes](http://kubernetes.io) cluster using the [Helm](https://helm.sh) package manager. - -## Requirements - -Kubernetes: `>=1.21.0-0` - -## Get Repo Info - -```console -helm repo add ingress-nginx https://kubernetes.github.io/ingress-nginx -helm repo update -``` - -## Install Chart - -**Important:** only helm3 is supported - -```console -helm install [RELEASE_NAME] ingress-nginx/ingress-nginx -``` - -The command deploys ingress-nginx on the Kubernetes cluster in the default configuration. - -_See [configuration](#configuration) below._ - -_See [helm install](https://helm.sh/docs/helm/helm_install/) for command documentation._ - -## Uninstall Chart - -```console -helm uninstall [RELEASE_NAME] -``` - -This removes all the Kubernetes components associated with the chart and deletes the release. - -_See [helm uninstall](https://helm.sh/docs/helm/helm_uninstall/) for command documentation._ - -## Upgrading Chart - -```console -helm upgrade [RELEASE_NAME] [CHART] --install -``` - -_See [helm upgrade](https://helm.sh/docs/helm/helm_upgrade/) for command documentation._ - -### Migrating from stable/nginx-ingress - -There are two main ways to migrate a release from `stable/nginx-ingress` to `ingress-nginx/ingress-nginx` chart: - -1. For Nginx Ingress controllers used for non-critical services, the easiest method is to [uninstall](#uninstall-chart) the old release and [install](#install-chart) the new one -1. For critical services in production that require zero-downtime, you will want to: - 1. [Install](#install-chart) a second Ingress controller - 1. Redirect your DNS traffic from the old controller to the new controller - 1. Log traffic from both controllers during this changeover - 1. [Uninstall](#uninstall-chart) the old controller once traffic has fully drained from it - -Note that there are some different and upgraded configurations between the two charts, described by Rimas Mocevicius from JFrog in the "Upgrading to ingress-nginx Helm chart" section of [Migrating from Helm chart nginx-ingress to ingress-nginx](https://rimusz.net/migrating-to-ingress-nginx). As the `ingress-nginx/ingress-nginx` chart continues to update, you will want to check current differences by running [helm configuration](#configuration) commands on both charts. - -## Configuration - -See [Customizing the Chart Before Installing](https://helm.sh/docs/intro/using_helm/#customizing-the-chart-before-installing). To see all configurable options with detailed comments, visit the chart's [values.yaml](./values.yaml), or run these configuration commands: - -```console -helm show values ingress-nginx/ingress-nginx -``` - -### PodDisruptionBudget - -Note that the PodDisruptionBudget resource will only be defined if the replicaCount is greater than one, -else it would make it impossible to evacuate a node. See [gh issue #7127](https://github.com/helm/charts/issues/7127) for more info. - -### Prometheus Metrics - -The Ingress-Nginx Controller can export Prometheus metrics, by setting `controller.metrics.enabled` to `true`. - -You can add Prometheus annotations to the metrics service using `controller.metrics.service.annotations`. -Alternatively, if you use the Prometheus Operator, you can enable ServiceMonitor creation using `controller.metrics.serviceMonitor.enabled`. And set `controller.metrics.serviceMonitor.additionalLabels.release="prometheus"`. "release=prometheus" should match the label configured in the prometheus servicemonitor ( see `kubectl get servicemonitor prometheus-kube-prom-prometheus -oyaml -n prometheus`) - -### ingress-nginx nginx\_status page/stats server - -Previous versions of this chart had a `controller.stats.*` configuration block, which is now obsolete due to the following changes in Ingress-Nginx Controller: - -- In [0.16.1](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0161), the vts (virtual host traffic status) dashboard was removed -- In [0.23.0](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0230), the status page at port 18080 is now a unix socket webserver only available at localhost. - You can use `curl --unix-socket /tmp/nginx-status-server.sock http://localhost/nginx_status` inside the controller container to access it locally, or use the snippet from [nginx-ingress changelog](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0230) to re-enable the http server - -### ExternalDNS Service Configuration - -Add an [ExternalDNS](https://github.com/kubernetes-sigs/external-dns) annotation to the LoadBalancer service: - -```yaml -controller: - service: - annotations: - external-dns.alpha.kubernetes.io/hostname: kubernetes-example.com. -``` - -### AWS L7 ELB with SSL Termination - -Annotate the controller as shown in the [nginx-ingress l7 patch](https://github.com/kubernetes/ingress-nginx/blob/ab3a789caae65eec4ad6e3b46b19750b481b6bce/deploy/aws/l7/service-l7.yaml): - -```yaml -controller: - service: - targetPorts: - http: http - https: http - annotations: - service.beta.kubernetes.io/aws-load-balancer-ssl-cert: arn:aws:acm:XX-XXXX-X:XXXXXXXXX:certificate/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXX - service.beta.kubernetes.io/aws-load-balancer-backend-protocol: "http" - service.beta.kubernetes.io/aws-load-balancer-ssl-ports: "https" - service.beta.kubernetes.io/aws-load-balancer-connection-idle-timeout: '3600' -``` - -### Additional Internal Load Balancer - -This setup is useful when you need both external and internal load balancers but don't want to have multiple ingress controllers and multiple ingress objects per application. - -By default, the ingress object will point to the external load balancer address, but if correctly configured, you can make use of the internal one if the URL you are looking up resolves to the internal load balancer's URL. - -You'll need to set both the following values: - -`controller.service.internal.enabled` -`controller.service.internal.annotations` - -If one of them is missing the internal load balancer will not be deployed. Example you may have `controller.service.internal.enabled=true` but no annotations set, in this case no action will be taken. - -`controller.service.internal.annotations` varies with the cloud service you're using. - -Example for AWS: - -```yaml -controller: - service: - internal: - enabled: true - annotations: - # Create internal NLB - service.beta.kubernetes.io/aws-load-balancer-scheme: "internal" - # Create internal ELB(Deprecated) - # service.beta.kubernetes.io/aws-load-balancer-internal: "true" - # Any other annotation can be declared here. -``` - -Example for GCE: - -```yaml -controller: - service: - internal: - enabled: true - annotations: - # Create internal LB. More information: https://cloud.google.com/kubernetes-engine/docs/how-to/internal-load-balancing - # For GKE versions 1.17 and later - networking.gke.io/load-balancer-type: "Internal" - # For earlier versions - # cloud.google.com/load-balancer-type: "Internal" - - # Any other annotation can be declared here. -``` - -Example for Azure: - -```yaml -controller: - service: - annotations: - # Create internal LB - service.beta.kubernetes.io/azure-load-balancer-internal: "true" - # Any other annotation can be declared here. -``` - -Example for Oracle Cloud Infrastructure: - -```yaml -controller: - service: - annotations: - # Create internal LB - service.beta.kubernetes.io/oci-load-balancer-internal: "true" - # Any other annotation can be declared here. -``` - -The load balancer annotations of more cloud service providers can be found: [Internal load balancer](https://kubernetes.io/docs/concepts/services-networking/service/#internal-load-balancer). - -An use case for this scenario is having a split-view DNS setup where the public zone CNAME records point to the external balancer URL while the private zone CNAME records point to the internal balancer URL. This way, you only need one ingress kubernetes object. - -Optionally you can set `controller.service.loadBalancerIP` if you need a static IP for the resulting `LoadBalancer`. - -### Ingress Admission Webhooks - -With nginx-ingress-controller version 0.25+, the Ingress-Nginx Controller pod exposes an endpoint that will integrate with the `validatingwebhookconfiguration` Kubernetes feature to prevent bad ingress from being added to the cluster. -**This feature is enabled by default since 0.31.0.** - -With nginx-ingress-controller in 0.25.* work only with kubernetes 1.14+, 0.26 fix [this issue](https://github.com/kubernetes/ingress-nginx/pull/4521) - -#### How the Chart Configures the Hooks -A validating and configuration requires the endpoint to which the request is sent to use TLS. It is possible to set up custom certificates to do this, but in most cases, a self-signed certificate is enough. The setup of this component requires some more complex orchestration when using helm. The steps are created to be idempotent and to allow turning the feature on and off without running into helm quirks. - -1. A pre-install hook provisions a certificate into the same namespace using a format compatible with provisioning using end user certificates. If the certificate already exists, the hook exits. -2. The Ingress-Nginx Controller pod is configured to use a TLS proxy container, which will load that certificate. -3. Validating and Mutating webhook configurations are created in the cluster. -4. A post-install hook reads the CA from the secret created by step 1 and patches the Validating and Mutating webhook configurations. This process will allow a custom CA provisioned by some other process to also be patched into the webhook configurations. The chosen failure policy is also patched into the webhook configurations - -#### Alternatives -It should be possible to use [cert-manager/cert-manager](https://github.com/cert-manager/cert-manager) if a more complete solution is required. - -You can enable automatic self-signed TLS certificate provisioning via cert-manager by setting the `controller.admissionWebhooks.certManager.enabled` value to true. - -Please ensure that cert-manager is correctly installed and configured. - -### Helm Error When Upgrading: spec.clusterIP: Invalid value: "" - -If you are upgrading this chart from a version between 0.31.0 and 1.2.2 then you may get an error like this: - -```console -Error: UPGRADE FAILED: Service "?????-controller" is invalid: spec.clusterIP: Invalid value: "": field is immutable -``` - -Detail of how and why are in [this issue](https://github.com/helm/charts/pull/13646) but to resolve this you can set `xxxx.service.omitClusterIP` to `true` where `xxxx` is the service referenced in the error. - -As of version `1.26.0` of this chart, by simply not providing any clusterIP value, `invalid: spec.clusterIP: Invalid value: "": field is immutable` will no longer occur since `clusterIP: ""` will not be rendered. - -## Values - -| Key | Type | Default | Description | -|-----|------|---------|-------------| -| commonLabels | object | `{}` | | -| controller.addHeaders | object | `{}` | Will add custom headers before sending response traffic to the client according to: https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/#add-headers | -| controller.admissionWebhooks.annotations | object | `{}` | | -| controller.admissionWebhooks.certManager.admissionCert.duration | string | `""` | | -| controller.admissionWebhooks.certManager.enabled | bool | `false` | | -| controller.admissionWebhooks.certManager.rootCert.duration | string | `""` | | -| controller.admissionWebhooks.certificate | string | `"/usr/local/certificates/cert"` | | -| controller.admissionWebhooks.createSecretJob.name | string | `"create"` | | -| controller.admissionWebhooks.createSecretJob.resources | object | `{}` | | -| controller.admissionWebhooks.createSecretJob.securityContext | object | `{"allowPrivilegeEscalation":false,"capabilities":{"drop":["ALL"]},"readOnlyRootFilesystem":true,"runAsNonRoot":true,"runAsUser":65532,"seccompProfile":{"type":"RuntimeDefault"}}` | Security context for secret creation containers | -| controller.admissionWebhooks.enabled | bool | `true` | | -| controller.admissionWebhooks.existingPsp | string | `""` | Use an existing PSP instead of creating one | -| controller.admissionWebhooks.extraEnvs | list | `[]` | Additional environment variables to set | -| controller.admissionWebhooks.failurePolicy | string | `"Fail"` | Admission Webhook failure policy to use | -| controller.admissionWebhooks.key | string | `"/usr/local/certificates/key"` | | -| controller.admissionWebhooks.labels | object | `{}` | Labels to be added to admission webhooks | -| controller.admissionWebhooks.name | string | `"admission"` | | -| controller.admissionWebhooks.namespaceSelector | object | `{}` | | -| controller.admissionWebhooks.objectSelector | object | `{}` | | -| controller.admissionWebhooks.patch.enabled | bool | `true` | | -| controller.admissionWebhooks.patch.image.digest | string | `"sha256:a9f03b34a3cbfbb26d103a14046ab2c5130a80c3d69d526ff8063d2b37b9fd3f"` | | -| controller.admissionWebhooks.patch.image.image | string | `"ingress-nginx/kube-webhook-certgen"` | | -| controller.admissionWebhooks.patch.image.pullPolicy | string | `"IfNotPresent"` | | -| controller.admissionWebhooks.patch.image.registry | string | `"registry.k8s.io"` | | -| controller.admissionWebhooks.patch.image.tag | string | `"v1.4.4"` | | -| controller.admissionWebhooks.patch.labels | object | `{}` | Labels to be added to patch job resources | -| controller.admissionWebhooks.patch.networkPolicy.enabled | bool | `false` | Enable 'networkPolicy' or not | -| controller.admissionWebhooks.patch.nodeSelector."kubernetes.io/os" | string | `"linux"` | | -| controller.admissionWebhooks.patch.podAnnotations | object | `{}` | | -| controller.admissionWebhooks.patch.priorityClassName | string | `""` | Provide a priority class name to the webhook patching job # | -| controller.admissionWebhooks.patch.rbac | object | `{"create":true}` | Admission webhook patch job RBAC | -| controller.admissionWebhooks.patch.rbac.create | bool | `true` | Create RBAC or not | -| controller.admissionWebhooks.patch.securityContext | object | `{}` | Security context for secret creation & webhook patch pods | -| controller.admissionWebhooks.patch.serviceAccount | object | `{"automountServiceAccountToken":true,"create":true,"name":""}` | Admission webhook patch job service account | -| controller.admissionWebhooks.patch.serviceAccount.automountServiceAccountToken | bool | `true` | Auto-mount service account token or not | -| controller.admissionWebhooks.patch.serviceAccount.create | bool | `true` | Create a service account or not | -| controller.admissionWebhooks.patch.serviceAccount.name | string | `""` | Custom service account name | -| controller.admissionWebhooks.patch.tolerations | list | `[]` | | -| controller.admissionWebhooks.patchWebhookJob.name | string | `"patch"` | | -| controller.admissionWebhooks.patchWebhookJob.resources | object | `{}` | | -| controller.admissionWebhooks.patchWebhookJob.securityContext | object | `{"allowPrivilegeEscalation":false,"capabilities":{"drop":["ALL"]},"readOnlyRootFilesystem":true,"runAsNonRoot":true,"runAsUser":65532,"seccompProfile":{"type":"RuntimeDefault"}}` | Security context for webhook patch containers | -| controller.admissionWebhooks.port | int | `8443` | | -| controller.admissionWebhooks.service.annotations | object | `{}` | | -| controller.admissionWebhooks.service.externalIPs | list | `[]` | | -| controller.admissionWebhooks.service.loadBalancerSourceRanges | list | `[]` | | -| controller.admissionWebhooks.service.servicePort | int | `443` | | -| controller.admissionWebhooks.service.type | string | `"ClusterIP"` | | -| controller.affinity | object | `{}` | Affinity and anti-affinity rules for server scheduling to nodes # Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#affinity-and-anti-affinity # | -| controller.allowSnippetAnnotations | bool | `false` | This configuration defines if Ingress Controller should allow users to set their own *-snippet annotations, otherwise this is forbidden / dropped when users add those annotations. Global snippets in ConfigMap are still respected | -| controller.annotations | object | `{}` | Annotations to be added to the controller Deployment or DaemonSet # | -| controller.autoscaling.annotations | object | `{}` | | -| controller.autoscaling.behavior | object | `{}` | | -| controller.autoscaling.enabled | bool | `false` | | -| controller.autoscaling.maxReplicas | int | `11` | | -| controller.autoscaling.minReplicas | int | `1` | | -| controller.autoscaling.targetCPUUtilizationPercentage | int | `50` | | -| controller.autoscaling.targetMemoryUtilizationPercentage | int | `50` | | -| controller.autoscalingTemplate | list | `[]` | | -| controller.config | object | `{}` | Global configuration passed to the ConfigMap consumed by the controller. Values may contain Helm templates. Ref.: https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/ | -| controller.configAnnotations | object | `{}` | Annotations to be added to the controller config configuration configmap. | -| controller.configMapNamespace | string | `""` | Allows customization of the configmap / nginx-configmap namespace; defaults to $(POD_NAMESPACE) | -| controller.containerName | string | `"controller"` | Configures the controller container name | -| controller.containerPort | object | `{"http":80,"https":443}` | Configures the ports that the nginx-controller listens on | -| controller.containerSecurityContext | object | `{}` | Security context for controller containers | -| controller.customTemplate.configMapKey | string | `""` | | -| controller.customTemplate.configMapName | string | `""` | | -| controller.disableLeaderElection | bool | `false` | This configuration disable Nginx Controller Leader Election | -| controller.dnsConfig | object | `{}` | Optionally customize the pod dnsConfig. | -| controller.dnsPolicy | string | `"ClusterFirst"` | Optionally change this to ClusterFirstWithHostNet in case you have 'hostNetwork: true'. By default, while using host network, name resolution uses the host's DNS. If you wish nginx-controller to keep resolving names inside the k8s network, use ClusterFirstWithHostNet. | -| controller.electionID | string | `""` | Election ID to use for status update, by default it uses the controller name combined with a suffix of 'leader' | -| controller.electionTTL | string | `""` | Duration a leader election is valid before it's getting re-elected, e.g. `15s`, `10m` or `1h`. (Default: 30s) | -| controller.enableAnnotationValidations | bool | `false` | | -| controller.enableMimalloc | bool | `true` | Enable mimalloc as a drop-in replacement for malloc. # ref: https://github.com/microsoft/mimalloc # | -| controller.enableTopologyAwareRouting | bool | `false` | This configuration enables Topology Aware Routing feature, used together with service annotation service.kubernetes.io/topology-mode="auto" Defaults to false | -| controller.existingPsp | string | `""` | Use an existing PSP instead of creating one | -| controller.extraArgs | object | `{}` | Additional command line arguments to pass to Ingress-Nginx Controller E.g. to specify the default SSL certificate you can use | -| controller.extraContainers | list | `[]` | Additional containers to be added to the controller pod. See https://github.com/lemonldap-ng-controller/lemonldap-ng-controller as example. | -| controller.extraEnvs | list | `[]` | Additional environment variables to set | -| controller.extraInitContainers | list | `[]` | Containers, which are run before the app containers are started. | -| controller.extraModules | list | `[]` | Modules, which are mounted into the core nginx image. See values.yaml for a sample to add opentelemetry module | -| controller.extraVolumeMounts | list | `[]` | Additional volumeMounts to the controller main container. | -| controller.extraVolumes | list | `[]` | Additional volumes to the controller pod. | -| controller.healthCheckHost | string | `""` | Address to bind the health check endpoint. It is better to set this option to the internal node address if the Ingress-Nginx Controller is running in the `hostNetwork: true` mode. | -| controller.healthCheckPath | string | `"/healthz"` | Path of the health check endpoint. All requests received on the port defined by the healthz-port parameter are forwarded internally to this path. | -| controller.hostAliases | list | `[]` | Optionally customize the pod hostAliases. | -| controller.hostNetwork | bool | `false` | Required for use with CNI based kubernetes installations (such as ones set up by kubeadm), since CNI and hostport don't mix yet. Can be deprecated once https://github.com/kubernetes/kubernetes/issues/23920 is merged | -| controller.hostPort.enabled | bool | `false` | Enable 'hostPort' or not | -| controller.hostPort.ports.http | int | `80` | 'hostPort' http port | -| controller.hostPort.ports.https | int | `443` | 'hostPort' https port | -| controller.hostname | object | `{}` | Optionally customize the pod hostname. | -| controller.image.allowPrivilegeEscalation | bool | `false` | | -| controller.image.chroot | bool | `false` | | -| controller.image.digest | string | `"sha256:d56f135b6462cfc476447cfe564b83a45e8bb7da2774963b00d12161112270b7"` | | -| controller.image.digestChroot | string | `"sha256:22701f0fc0f2dd209ef782f4e281bfe2d8cccd50ededa00aec88e0cdbe7edd14"` | | -| controller.image.image | string | `"ingress-nginx/controller"` | | -| controller.image.pullPolicy | string | `"IfNotPresent"` | | -| controller.image.readOnlyRootFilesystem | bool | `false` | | -| controller.image.registry | string | `"registry.k8s.io"` | | -| controller.image.runAsNonRoot | bool | `true` | | -| controller.image.runAsUser | int | `101` | | -| controller.image.seccompProfile.type | string | `"RuntimeDefault"` | | -| controller.image.tag | string | `"v1.11.3"` | | -| controller.ingressClass | string | `"nginx"` | For backwards compatibility with ingress.class annotation, use ingressClass. Algorithm is as follows, first ingressClassName is considered, if not present, controller looks for ingress.class annotation | -| controller.ingressClassByName | bool | `false` | Process IngressClass per name (additionally as per spec.controller). | -| controller.ingressClassResource | object | `{"aliases":[],"annotations":{},"controllerValue":"k8s.io/ingress-nginx","default":false,"enabled":true,"name":"nginx","parameters":{}}` | This section refers to the creation of the IngressClass resource. IngressClasses are immutable and cannot be changed after creation. We do not support namespaced IngressClasses, yet, so a ClusterRole and a ClusterRoleBinding is required. | -| controller.ingressClassResource.aliases | list | `[]` | Aliases of this IngressClass. Creates copies with identical settings but the respective alias as name. Useful for development environments with only one Ingress Controller but production-like Ingress resources. `default` gets enabled on the original IngressClass only. | -| controller.ingressClassResource.annotations | object | `{}` | Annotations to be added to the IngressClass resource. | -| controller.ingressClassResource.controllerValue | string | `"k8s.io/ingress-nginx"` | Controller of the IngressClass. An Ingress Controller looks for IngressClasses it should reconcile by this value. This value is also being set as the `--controller-class` argument of this Ingress Controller. Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#ingress-class | -| controller.ingressClassResource.default | bool | `false` | If true, Ingresses without `ingressClassName` get assigned to this IngressClass on creation. Ingress creation gets rejected if there are multiple default IngressClasses. Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#default-ingress-class | -| controller.ingressClassResource.enabled | bool | `true` | Create the IngressClass or not | -| controller.ingressClassResource.name | string | `"nginx"` | Name of the IngressClass | -| controller.ingressClassResource.parameters | object | `{}` | A link to a custom resource containing additional configuration for the controller. This is optional if the controller consuming this IngressClass does not require additional parameters. Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#ingress-class | -| controller.keda.apiVersion | string | `"keda.sh/v1alpha1"` | | -| controller.keda.behavior | object | `{}` | | -| controller.keda.cooldownPeriod | int | `300` | | -| controller.keda.enabled | bool | `false` | | -| controller.keda.maxReplicas | int | `11` | | -| controller.keda.minReplicas | int | `1` | | -| controller.keda.pollingInterval | int | `30` | | -| controller.keda.restoreToOriginalReplicaCount | bool | `false` | | -| controller.keda.scaledObject.annotations | object | `{}` | | -| controller.keda.triggers | list | `[]` | | -| controller.kind | string | `"Deployment"` | Use a `DaemonSet` or `Deployment` | -| controller.labels | object | `{}` | Labels to be added to the controller Deployment or DaemonSet and other resources that do not have option to specify labels # | -| controller.lifecycle | object | `{"preStop":{"exec":{"command":["/wait-shutdown"]}}}` | Improve connection draining when ingress controller pod is deleted using a lifecycle hook: With this new hook, we increased the default terminationGracePeriodSeconds from 30 seconds to 300, allowing the draining of connections up to five minutes. If the active connections end before that, the pod will terminate gracefully at that time. To effectively take advantage of this feature, the Configmap feature worker-shutdown-timeout new value is 240s instead of 10s. # | -| controller.livenessProbe.failureThreshold | int | `5` | | -| controller.livenessProbe.httpGet.path | string | `"/healthz"` | | -| controller.livenessProbe.httpGet.port | int | `10254` | | -| controller.livenessProbe.httpGet.scheme | string | `"HTTP"` | | -| controller.livenessProbe.initialDelaySeconds | int | `10` | | -| controller.livenessProbe.periodSeconds | int | `10` | | -| controller.livenessProbe.successThreshold | int | `1` | | -| controller.livenessProbe.timeoutSeconds | int | `1` | | -| controller.maxmindLicenseKey | string | `""` | Maxmind license key to download GeoLite2 Databases. # https://blog.maxmind.com/2019/12/significant-changes-to-accessing-and-using-geolite2-databases/ | -| controller.metrics.enabled | bool | `false` | | -| controller.metrics.port | int | `10254` | | -| controller.metrics.portName | string | `"metrics"` | | -| controller.metrics.prometheusRule.additionalLabels | object | `{}` | | -| controller.metrics.prometheusRule.enabled | bool | `false` | | -| controller.metrics.prometheusRule.rules | list | `[]` | | -| controller.metrics.service.annotations | object | `{}` | | -| controller.metrics.service.externalIPs | list | `[]` | List of IP addresses at which the stats-exporter service is available # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips # | -| controller.metrics.service.labels | object | `{}` | Labels to be added to the metrics service resource | -| controller.metrics.service.loadBalancerSourceRanges | list | `[]` | | -| controller.metrics.service.servicePort | int | `10254` | | -| controller.metrics.service.type | string | `"ClusterIP"` | | -| controller.metrics.serviceMonitor.additionalLabels | object | `{}` | | -| controller.metrics.serviceMonitor.annotations | object | `{}` | Annotations to be added to the ServiceMonitor. | -| controller.metrics.serviceMonitor.enabled | bool | `false` | | -| controller.metrics.serviceMonitor.metricRelabelings | list | `[]` | | -| controller.metrics.serviceMonitor.namespace | string | `""` | | -| controller.metrics.serviceMonitor.namespaceSelector | object | `{}` | | -| controller.metrics.serviceMonitor.relabelings | list | `[]` | | -| controller.metrics.serviceMonitor.scrapeInterval | string | `"30s"` | | -| controller.metrics.serviceMonitor.targetLabels | list | `[]` | | -| controller.minAvailable | int | `1` | Minimum available pods set in PodDisruptionBudget. Define either 'minAvailable' or 'maxUnavailable', never both. | -| controller.minReadySeconds | int | `0` | `minReadySeconds` to avoid killing pods before we are ready # | -| controller.name | string | `"controller"` | | -| controller.networkPolicy.enabled | bool | `false` | Enable 'networkPolicy' or not | -| controller.nodeSelector | object | `{"kubernetes.io/os":"linux"}` | Node labels for controller pod assignment # Ref: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/ # | -| controller.opentelemetry.containerSecurityContext.allowPrivilegeEscalation | bool | `false` | | -| controller.opentelemetry.containerSecurityContext.capabilities.drop[0] | string | `"ALL"` | | -| controller.opentelemetry.containerSecurityContext.readOnlyRootFilesystem | bool | `true` | | -| controller.opentelemetry.containerSecurityContext.runAsNonRoot | bool | `true` | | -| controller.opentelemetry.containerSecurityContext.runAsUser | int | `65532` | The image's default user, inherited from its base image `cgr.dev/chainguard/static`. | -| controller.opentelemetry.containerSecurityContext.seccompProfile.type | string | `"RuntimeDefault"` | | -| controller.opentelemetry.enabled | bool | `false` | | -| controller.opentelemetry.image.digest | string | `"sha256:f7604ac0547ed64d79b98d92133234e66c2c8aade3c1f4809fed5eec1fb7f922"` | | -| controller.opentelemetry.image.distroless | bool | `true` | | -| controller.opentelemetry.image.image | string | `"ingress-nginx/opentelemetry-1.25.3"` | | -| controller.opentelemetry.image.registry | string | `"registry.k8s.io"` | | -| controller.opentelemetry.image.tag | string | `"v20240813-b933310d"` | | -| controller.opentelemetry.name | string | `"opentelemetry"` | | -| controller.opentelemetry.resources | object | `{}` | | -| controller.podAnnotations | object | `{}` | Annotations to be added to controller pods # | -| controller.podLabels | object | `{}` | Labels to add to the pod container metadata | -| controller.podSecurityContext | object | `{}` | Security context for controller pods | -| controller.priorityClassName | string | `""` | | -| controller.proxySetHeaders | object | `{}` | Will add custom headers before sending traffic to backends according to https://github.com/kubernetes/ingress-nginx/tree/main/docs/examples/customization/custom-headers | -| controller.publishService | object | `{"enabled":true,"pathOverride":""}` | Allows customization of the source of the IP address or FQDN to report in the ingress status field. By default, it reads the information provided by the service. If disable, the status field reports the IP address of the node or nodes where an ingress controller pod is running. | -| controller.publishService.enabled | bool | `true` | Enable 'publishService' or not | -| controller.publishService.pathOverride | string | `""` | Allows overriding of the publish service to bind to Must be / | -| controller.readinessProbe.failureThreshold | int | `3` | | -| controller.readinessProbe.httpGet.path | string | `"/healthz"` | | -| controller.readinessProbe.httpGet.port | int | `10254` | | -| controller.readinessProbe.httpGet.scheme | string | `"HTTP"` | | -| controller.readinessProbe.initialDelaySeconds | int | `10` | | -| controller.readinessProbe.periodSeconds | int | `10` | | -| controller.readinessProbe.successThreshold | int | `1` | | -| controller.readinessProbe.timeoutSeconds | int | `1` | | -| controller.replicaCount | int | `1` | | -| controller.reportNodeInternalIp | bool | `false` | Bare-metal considerations via the host network https://kubernetes.github.io/ingress-nginx/deploy/baremetal/#via-the-host-network Ingress status was blank because there is no Service exposing the Ingress-Nginx Controller in a configuration using the host network, the default --publish-service flag used in standard cloud setups does not apply | -| controller.resources.requests.cpu | string | `"100m"` | | -| controller.resources.requests.memory | string | `"90Mi"` | | -| controller.scope.enabled | bool | `false` | Enable 'scope' or not | -| controller.scope.namespace | string | `""` | Namespace to limit the controller to; defaults to $(POD_NAMESPACE) | -| controller.scope.namespaceSelector | string | `""` | When scope.enabled == false, instead of watching all namespaces, we watching namespaces whose labels only match with namespaceSelector. Format like foo=bar. Defaults to empty, means watching all namespaces. | -| controller.service.annotations | object | `{}` | Annotations to be added to the external controller service. See `controller.service.internal.annotations` for annotations to be added to the internal controller service. | -| controller.service.appProtocol | bool | `true` | Declare the app protocol of the external HTTP and HTTPS listeners or not. Supersedes provider-specific annotations for declaring the backend protocol. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#application-protocol | -| controller.service.clusterIP | string | `""` | Pre-defined cluster internal IP address of the external controller service. Take care of collisions with existing services. This value is immutable. Set once, it can not be changed without deleting and re-creating the service. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#choosing-your-own-ip-address | -| controller.service.enableHttp | bool | `true` | Enable the HTTP listener on both controller services or not. | -| controller.service.enableHttps | bool | `true` | Enable the HTTPS listener on both controller services or not. | -| controller.service.enabled | bool | `true` | Enable controller services or not. This does not influence the creation of either the admission webhook or the metrics service. | -| controller.service.external.enabled | bool | `true` | Enable the external controller service or not. Useful for internal-only deployments. | -| controller.service.externalIPs | list | `[]` | List of node IP addresses at which the external controller service is available. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips | -| controller.service.externalTrafficPolicy | string | `""` | External traffic policy of the external controller service. Set to "Local" to preserve source IP on providers supporting it. Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip | -| controller.service.internal.annotations | object | `{}` | Annotations to be added to the internal controller service. Mandatory for the internal controller service to be created. Varies with the cloud service. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#internal-load-balancer | -| controller.service.internal.appProtocol | bool | `true` | Declare the app protocol of the internal HTTP and HTTPS listeners or not. Supersedes provider-specific annotations for declaring the backend protocol. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#application-protocol | -| controller.service.internal.clusterIP | string | `""` | Pre-defined cluster internal IP address of the internal controller service. Take care of collisions with existing services. This value is immutable. Set once, it can not be changed without deleting and re-creating the service. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#choosing-your-own-ip-address | -| controller.service.internal.enabled | bool | `false` | Enable the internal controller service or not. Remember to configure `controller.service.internal.annotations` when enabling this. | -| controller.service.internal.externalIPs | list | `[]` | List of node IP addresses at which the internal controller service is available. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips | -| controller.service.internal.externalTrafficPolicy | string | `""` | External traffic policy of the internal controller service. Set to "Local" to preserve source IP on providers supporting it. Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip | -| controller.service.internal.ipFamilies | list | `["IPv4"]` | List of IP families (e.g. IPv4, IPv6) assigned to the internal controller service. This field is usually assigned automatically based on cluster configuration and the `ipFamilyPolicy` field. Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services | -| controller.service.internal.ipFamilyPolicy | string | `"SingleStack"` | Represents the dual-stack capabilities of the internal controller service. Possible values are SingleStack, PreferDualStack or RequireDualStack. Fields `ipFamilies` and `clusterIP` depend on the value of this field. Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services | -| controller.service.internal.loadBalancerClass | string | `""` | Load balancer class of the internal controller service. Used by cloud providers to select a load balancer implementation other than the cloud provider default. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-class | -| controller.service.internal.loadBalancerIP | string | `""` | Deprecated: Pre-defined IP address of the internal controller service. Used by cloud providers to connect the resulting load balancer service to a pre-existing static IP. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#loadbalancer | -| controller.service.internal.loadBalancerSourceRanges | list | `[]` | Restrict access to the internal controller service. Values must be CIDRs. Allows any source address by default. | -| controller.service.internal.nodePorts.http | string | `""` | Node port allocated for the internal HTTP listener. If left empty, the service controller allocates one from the configured node port range. | -| controller.service.internal.nodePorts.https | string | `""` | Node port allocated for the internal HTTPS listener. If left empty, the service controller allocates one from the configured node port range. | -| controller.service.internal.nodePorts.tcp | object | `{}` | Node port mapping for internal TCP listeners. If left empty, the service controller allocates them from the configured node port range. Example: tcp: 8080: 30080 | -| controller.service.internal.nodePorts.udp | object | `{}` | Node port mapping for internal UDP listeners. If left empty, the service controller allocates them from the configured node port range. Example: udp: 53: 30053 | -| controller.service.internal.ports | object | `{}` | | -| controller.service.internal.sessionAffinity | string | `""` | Session affinity of the internal controller service. Must be either "None" or "ClientIP" if set. Defaults to "None". Ref: https://kubernetes.io/docs/reference/networking/virtual-ips/#session-affinity | -| controller.service.internal.targetPorts | object | `{}` | | -| controller.service.internal.type | string | `""` | Type of the internal controller service. Defaults to the value of `controller.service.type`. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types | -| controller.service.ipFamilies | list | `["IPv4"]` | List of IP families (e.g. IPv4, IPv6) assigned to the external controller service. This field is usually assigned automatically based on cluster configuration and the `ipFamilyPolicy` field. Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services | -| controller.service.ipFamilyPolicy | string | `"SingleStack"` | Represents the dual-stack capabilities of the external controller service. Possible values are SingleStack, PreferDualStack or RequireDualStack. Fields `ipFamilies` and `clusterIP` depend on the value of this field. Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services | -| controller.service.labels | object | `{}` | Labels to be added to both controller services. | -| controller.service.loadBalancerClass | string | `""` | Load balancer class of the external controller service. Used by cloud providers to select a load balancer implementation other than the cloud provider default. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-class | -| controller.service.loadBalancerIP | string | `""` | Deprecated: Pre-defined IP address of the external controller service. Used by cloud providers to connect the resulting load balancer service to a pre-existing static IP. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#loadbalancer | -| controller.service.loadBalancerSourceRanges | list | `[]` | Restrict access to the external controller service. Values must be CIDRs. Allows any source address by default. | -| controller.service.nodePorts.http | string | `""` | Node port allocated for the external HTTP listener. If left empty, the service controller allocates one from the configured node port range. | -| controller.service.nodePorts.https | string | `""` | Node port allocated for the external HTTPS listener. If left empty, the service controller allocates one from the configured node port range. | -| controller.service.nodePorts.tcp | object | `{}` | Node port mapping for external TCP listeners. If left empty, the service controller allocates them from the configured node port range. Example: tcp: 8080: 30080 | -| controller.service.nodePorts.udp | object | `{}` | Node port mapping for external UDP listeners. If left empty, the service controller allocates them from the configured node port range. Example: udp: 53: 30053 | -| controller.service.ports.http | int | `80` | Port the external HTTP listener is published with. | -| controller.service.ports.https | int | `443` | Port the external HTTPS listener is published with. | -| controller.service.sessionAffinity | string | `""` | Session affinity of the external controller service. Must be either "None" or "ClientIP" if set. Defaults to "None". Ref: https://kubernetes.io/docs/reference/networking/virtual-ips/#session-affinity | -| controller.service.targetPorts.http | string | `"http"` | Port of the ingress controller the external HTTP listener is mapped to. | -| controller.service.targetPorts.https | string | `"https"` | Port of the ingress controller the external HTTPS listener is mapped to. | -| controller.service.type | string | `"LoadBalancer"` | Type of the external controller service. Ref: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types | -| controller.shareProcessNamespace | bool | `false` | | -| controller.sysctls | object | `{}` | sysctls for controller pods # Ref: https://kubernetes.io/docs/tasks/administer-cluster/sysctl-cluster/ | -| controller.tcp.annotations | object | `{}` | Annotations to be added to the tcp config configmap | -| controller.tcp.configMapNamespace | string | `""` | Allows customization of the tcp-services-configmap; defaults to $(POD_NAMESPACE) | -| controller.terminationGracePeriodSeconds | int | `300` | `terminationGracePeriodSeconds` to avoid killing pods before we are ready # wait up to five minutes for the drain of connections # | -| controller.tolerations | list | `[]` | Node tolerations for server scheduling to nodes with taints # Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/ # | -| controller.topologySpreadConstraints | list | `[]` | Topology spread constraints rely on node labels to identify the topology domain(s) that each Node is in. # Ref: https://kubernetes.io/docs/concepts/workloads/pods/pod-topology-spread-constraints/ # | -| controller.udp.annotations | object | `{}` | Annotations to be added to the udp config configmap | -| controller.udp.configMapNamespace | string | `""` | Allows customization of the udp-services-configmap; defaults to $(POD_NAMESPACE) | -| controller.updateStrategy | object | `{}` | The update strategy to apply to the Deployment or DaemonSet # | -| controller.watchIngressWithoutClass | bool | `false` | Process Ingress objects without ingressClass annotation/ingressClassName field Overrides value for --watch-ingress-without-class flag of the controller binary Defaults to false | -| defaultBackend.affinity | object | `{}` | Affinity and anti-affinity rules for server scheduling to nodes # Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#affinity-and-anti-affinity | -| defaultBackend.autoscaling.annotations | object | `{}` | | -| defaultBackend.autoscaling.enabled | bool | `false` | | -| defaultBackend.autoscaling.maxReplicas | int | `2` | | -| defaultBackend.autoscaling.minReplicas | int | `1` | | -| defaultBackend.autoscaling.targetCPUUtilizationPercentage | int | `50` | | -| defaultBackend.autoscaling.targetMemoryUtilizationPercentage | int | `50` | | -| defaultBackend.containerSecurityContext | object | `{}` | Security context for default backend containers | -| defaultBackend.enabled | bool | `false` | | -| defaultBackend.existingPsp | string | `""` | Use an existing PSP instead of creating one | -| defaultBackend.extraArgs | object | `{}` | | -| defaultBackend.extraConfigMaps | list | `[]` | | -| defaultBackend.extraEnvs | list | `[]` | Additional environment variables to set for defaultBackend pods | -| defaultBackend.extraVolumeMounts | list | `[]` | | -| defaultBackend.extraVolumes | list | `[]` | | -| defaultBackend.image.allowPrivilegeEscalation | bool | `false` | | -| defaultBackend.image.image | string | `"defaultbackend-amd64"` | | -| defaultBackend.image.pullPolicy | string | `"IfNotPresent"` | | -| defaultBackend.image.readOnlyRootFilesystem | bool | `true` | | -| defaultBackend.image.registry | string | `"registry.k8s.io"` | | -| defaultBackend.image.runAsNonRoot | bool | `true` | | -| defaultBackend.image.runAsUser | int | `65534` | | -| defaultBackend.image.seccompProfile.type | string | `"RuntimeDefault"` | | -| defaultBackend.image.tag | string | `"1.5"` | | -| defaultBackend.labels | object | `{}` | Labels to be added to the default backend resources | -| defaultBackend.livenessProbe.failureThreshold | int | `3` | | -| defaultBackend.livenessProbe.initialDelaySeconds | int | `30` | | -| defaultBackend.livenessProbe.periodSeconds | int | `10` | | -| defaultBackend.livenessProbe.successThreshold | int | `1` | | -| defaultBackend.livenessProbe.timeoutSeconds | int | `5` | | -| defaultBackend.minAvailable | int | `1` | Minimum available pods set in PodDisruptionBudget. | -| defaultBackend.minReadySeconds | int | `0` | `minReadySeconds` to avoid killing pods before we are ready # | -| defaultBackend.name | string | `"defaultbackend"` | | -| defaultBackend.networkPolicy.enabled | bool | `false` | Enable 'networkPolicy' or not | -| defaultBackend.nodeSelector | object | `{"kubernetes.io/os":"linux"}` | Node labels for default backend pod assignment # Ref: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/ # | -| defaultBackend.podAnnotations | object | `{}` | Annotations to be added to default backend pods # | -| defaultBackend.podLabels | object | `{}` | Labels to add to the pod container metadata | -| defaultBackend.podSecurityContext | object | `{}` | Security context for default backend pods | -| defaultBackend.port | int | `8080` | | -| defaultBackend.priorityClassName | string | `""` | | -| defaultBackend.readinessProbe.failureThreshold | int | `6` | | -| defaultBackend.readinessProbe.initialDelaySeconds | int | `0` | | -| defaultBackend.readinessProbe.periodSeconds | int | `5` | | -| defaultBackend.readinessProbe.successThreshold | int | `1` | | -| defaultBackend.readinessProbe.timeoutSeconds | int | `5` | | -| defaultBackend.replicaCount | int | `1` | | -| defaultBackend.resources | object | `{}` | | -| defaultBackend.service.annotations | object | `{}` | | -| defaultBackend.service.externalIPs | list | `[]` | List of IP addresses at which the default backend service is available # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips # | -| defaultBackend.service.loadBalancerSourceRanges | list | `[]` | | -| defaultBackend.service.servicePort | int | `80` | | -| defaultBackend.service.type | string | `"ClusterIP"` | | -| defaultBackend.serviceAccount.automountServiceAccountToken | bool | `true` | | -| defaultBackend.serviceAccount.create | bool | `true` | | -| defaultBackend.serviceAccount.name | string | `""` | | -| defaultBackend.tolerations | list | `[]` | Node tolerations for server scheduling to nodes with taints # Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/ # | -| defaultBackend.topologySpreadConstraints | list | `[]` | Topology spread constraints rely on node labels to identify the topology domain(s) that each Node is in. Ref.: https://kubernetes.io/docs/concepts/workloads/pods/pod-topology-spread-constraints/ | -| defaultBackend.updateStrategy | object | `{}` | The update strategy to apply to the Deployment or DaemonSet # | -| dhParam | string | `""` | A base64-encoded Diffie-Hellman parameter. This can be generated with: `openssl dhparam 4096 2> /dev/null | base64` # Ref: https://github.com/kubernetes/ingress-nginx/tree/main/docs/examples/customization/ssl-dh-param | -| imagePullSecrets | list | `[]` | Optional array of imagePullSecrets containing private registry credentials # Ref: https://kubernetes.io/docs/tasks/configure-pod-container/pull-image-private-registry/ | -| namespaceOverride | string | `""` | Override the deployment namespace; defaults to .Release.Namespace | -| podSecurityPolicy.enabled | bool | `false` | | -| portNamePrefix | string | `""` | Prefix for TCP and UDP ports names in ingress controller service # Some cloud providers, like Yandex Cloud may have a requirements for a port name regex to support cloud load balancer integration | -| rbac.create | bool | `true` | | -| rbac.scope | bool | `false` | | -| revisionHistoryLimit | int | `10` | Rollback limit # | -| serviceAccount.annotations | object | `{}` | Annotations for the controller service account | -| serviceAccount.automountServiceAccountToken | bool | `true` | | -| serviceAccount.create | bool | `true` | | -| serviceAccount.name | string | `""` | | -| tcp | object | `{}` | TCP service key-value pairs # Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/exposing-tcp-udp-services.md # | -| udp | object | `{}` | UDP service key-value pairs # Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/exposing-tcp-udp-services.md # | diff --git a/charts/keep/charts/ingress-nginx/README.md.gotmpl b/charts/keep/charts/ingress-nginx/README.md.gotmpl deleted file mode 100644 index 17b029b..0000000 --- a/charts/keep/charts/ingress-nginx/README.md.gotmpl +++ /dev/null @@ -1,229 +0,0 @@ -{{ template "chart.header" . }} -[ingress-nginx](https://github.com/kubernetes/ingress-nginx) Ingress controller for Kubernetes using NGINX as a reverse proxy and load balancer - -{{ template "chart.versionBadge" . }}{{ template "chart.typeBadge" . }}{{ template "chart.appVersionBadge" . }} - -To use, add `ingressClassName: nginx` spec field or the `kubernetes.io/ingress.class: nginx` annotation to your Ingress resources. - -This chart bootstraps an ingress-nginx deployment on a [Kubernetes](http://kubernetes.io) cluster using the [Helm](https://helm.sh) package manager. - -{{ template "chart.requirementsSection" . }} - -## Get Repo Info - -```console -helm repo add ingress-nginx https://kubernetes.github.io/ingress-nginx -helm repo update -``` - -## Install Chart - -**Important:** only helm3 is supported - -```console -helm install [RELEASE_NAME] ingress-nginx/ingress-nginx -``` - -The command deploys ingress-nginx on the Kubernetes cluster in the default configuration. - -_See [configuration](#configuration) below._ - -_See [helm install](https://helm.sh/docs/helm/helm_install/) for command documentation._ - -## Uninstall Chart - -```console -helm uninstall [RELEASE_NAME] -``` - -This removes all the Kubernetes components associated with the chart and deletes the release. - -_See [helm uninstall](https://helm.sh/docs/helm/helm_uninstall/) for command documentation._ - -## Upgrading Chart - -```console -helm upgrade [RELEASE_NAME] [CHART] --install -``` - -_See [helm upgrade](https://helm.sh/docs/helm/helm_upgrade/) for command documentation._ - -### Migrating from stable/nginx-ingress - -There are two main ways to migrate a release from `stable/nginx-ingress` to `ingress-nginx/ingress-nginx` chart: - -1. For Nginx Ingress controllers used for non-critical services, the easiest method is to [uninstall](#uninstall-chart) the old release and [install](#install-chart) the new one -1. For critical services in production that require zero-downtime, you will want to: - 1. [Install](#install-chart) a second Ingress controller - 1. Redirect your DNS traffic from the old controller to the new controller - 1. Log traffic from both controllers during this changeover - 1. [Uninstall](#uninstall-chart) the old controller once traffic has fully drained from it - -Note that there are some different and upgraded configurations between the two charts, described by Rimas Mocevicius from JFrog in the "Upgrading to ingress-nginx Helm chart" section of [Migrating from Helm chart nginx-ingress to ingress-nginx](https://rimusz.net/migrating-to-ingress-nginx). As the `ingress-nginx/ingress-nginx` chart continues to update, you will want to check current differences by running [helm configuration](#configuration) commands on both charts. - -## Configuration - -See [Customizing the Chart Before Installing](https://helm.sh/docs/intro/using_helm/#customizing-the-chart-before-installing). To see all configurable options with detailed comments, visit the chart's [values.yaml](./values.yaml), or run these configuration commands: - -```console -helm show values ingress-nginx/ingress-nginx -``` - -### PodDisruptionBudget - -Note that the PodDisruptionBudget resource will only be defined if the replicaCount is greater than one, -else it would make it impossible to evacuate a node. See [gh issue #7127](https://github.com/helm/charts/issues/7127) for more info. - -### Prometheus Metrics - -The Ingress-Nginx Controller can export Prometheus metrics, by setting `controller.metrics.enabled` to `true`. - -You can add Prometheus annotations to the metrics service using `controller.metrics.service.annotations`. -Alternatively, if you use the Prometheus Operator, you can enable ServiceMonitor creation using `controller.metrics.serviceMonitor.enabled`. And set `controller.metrics.serviceMonitor.additionalLabels.release="prometheus"`. "release=prometheus" should match the label configured in the prometheus servicemonitor ( see `kubectl get servicemonitor prometheus-kube-prom-prometheus -oyaml -n prometheus`) - -### ingress-nginx nginx\_status page/stats server - -Previous versions of this chart had a `controller.stats.*` configuration block, which is now obsolete due to the following changes in Ingress-Nginx Controller: - -- In [0.16.1](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0161), the vts (virtual host traffic status) dashboard was removed -- In [0.23.0](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0230), the status page at port 18080 is now a unix socket webserver only available at localhost. - You can use `curl --unix-socket /tmp/nginx-status-server.sock http://localhost/nginx_status` inside the controller container to access it locally, or use the snippet from [nginx-ingress changelog](https://github.com/kubernetes/ingress-nginx/blob/main/Changelog.md#0230) to re-enable the http server - -### ExternalDNS Service Configuration - -Add an [ExternalDNS](https://github.com/kubernetes-sigs/external-dns) annotation to the LoadBalancer service: - -```yaml -controller: - service: - annotations: - external-dns.alpha.kubernetes.io/hostname: kubernetes-example.com. -``` - -### AWS L7 ELB with SSL Termination - -Annotate the controller as shown in the [nginx-ingress l7 patch](https://github.com/kubernetes/ingress-nginx/blob/ab3a789caae65eec4ad6e3b46b19750b481b6bce/deploy/aws/l7/service-l7.yaml): - -```yaml -controller: - service: - targetPorts: - http: http - https: http - annotations: - service.beta.kubernetes.io/aws-load-balancer-ssl-cert: arn:aws:acm:XX-XXXX-X:XXXXXXXXX:certificate/XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXX - service.beta.kubernetes.io/aws-load-balancer-backend-protocol: "http" - service.beta.kubernetes.io/aws-load-balancer-ssl-ports: "https" - service.beta.kubernetes.io/aws-load-balancer-connection-idle-timeout: '3600' -``` - -### Additional Internal Load Balancer - -This setup is useful when you need both external and internal load balancers but don't want to have multiple ingress controllers and multiple ingress objects per application. - -By default, the ingress object will point to the external load balancer address, but if correctly configured, you can make use of the internal one if the URL you are looking up resolves to the internal load balancer's URL. - -You'll need to set both the following values: - -`controller.service.internal.enabled` -`controller.service.internal.annotations` - -If one of them is missing the internal load balancer will not be deployed. Example you may have `controller.service.internal.enabled=true` but no annotations set, in this case no action will be taken. - -`controller.service.internal.annotations` varies with the cloud service you're using. - -Example for AWS: - -```yaml -controller: - service: - internal: - enabled: true - annotations: - # Create internal NLB - service.beta.kubernetes.io/aws-load-balancer-scheme: "internal" - # Create internal ELB(Deprecated) - # service.beta.kubernetes.io/aws-load-balancer-internal: "true" - # Any other annotation can be declared here. -``` - -Example for GCE: - -```yaml -controller: - service: - internal: - enabled: true - annotations: - # Create internal LB. More information: https://cloud.google.com/kubernetes-engine/docs/how-to/internal-load-balancing - # For GKE versions 1.17 and later - networking.gke.io/load-balancer-type: "Internal" - # For earlier versions - # cloud.google.com/load-balancer-type: "Internal" - - # Any other annotation can be declared here. -``` - -Example for Azure: - -```yaml -controller: - service: - annotations: - # Create internal LB - service.beta.kubernetes.io/azure-load-balancer-internal: "true" - # Any other annotation can be declared here. -``` - -Example for Oracle Cloud Infrastructure: - -```yaml -controller: - service: - annotations: - # Create internal LB - service.beta.kubernetes.io/oci-load-balancer-internal: "true" - # Any other annotation can be declared here. -``` - -The load balancer annotations of more cloud service providers can be found: [Internal load balancer](https://kubernetes.io/docs/concepts/services-networking/service/#internal-load-balancer). - -An use case for this scenario is having a split-view DNS setup where the public zone CNAME records point to the external balancer URL while the private zone CNAME records point to the internal balancer URL. This way, you only need one ingress kubernetes object. - -Optionally you can set `controller.service.loadBalancerIP` if you need a static IP for the resulting `LoadBalancer`. - -### Ingress Admission Webhooks - -With nginx-ingress-controller version 0.25+, the Ingress-Nginx Controller pod exposes an endpoint that will integrate with the `validatingwebhookconfiguration` Kubernetes feature to prevent bad ingress from being added to the cluster. -**This feature is enabled by default since 0.31.0.** - -With nginx-ingress-controller in 0.25.* work only with kubernetes 1.14+, 0.26 fix [this issue](https://github.com/kubernetes/ingress-nginx/pull/4521) - -#### How the Chart Configures the Hooks -A validating and configuration requires the endpoint to which the request is sent to use TLS. It is possible to set up custom certificates to do this, but in most cases, a self-signed certificate is enough. The setup of this component requires some more complex orchestration when using helm. The steps are created to be idempotent and to allow turning the feature on and off without running into helm quirks. - -1. A pre-install hook provisions a certificate into the same namespace using a format compatible with provisioning using end user certificates. If the certificate already exists, the hook exits. -2. The Ingress-Nginx Controller pod is configured to use a TLS proxy container, which will load that certificate. -3. Validating and Mutating webhook configurations are created in the cluster. -4. A post-install hook reads the CA from the secret created by step 1 and patches the Validating and Mutating webhook configurations. This process will allow a custom CA provisioned by some other process to also be patched into the webhook configurations. The chosen failure policy is also patched into the webhook configurations - -#### Alternatives -It should be possible to use [cert-manager/cert-manager](https://github.com/cert-manager/cert-manager) if a more complete solution is required. - -You can enable automatic self-signed TLS certificate provisioning via cert-manager by setting the `controller.admissionWebhooks.certManager.enabled` value to true. - -Please ensure that cert-manager is correctly installed and configured. - -### Helm Error When Upgrading: spec.clusterIP: Invalid value: "" - -If you are upgrading this chart from a version between 0.31.0 and 1.2.2 then you may get an error like this: - -```console -Error: UPGRADE FAILED: Service "?????-controller" is invalid: spec.clusterIP: Invalid value: "": field is immutable -``` - -Detail of how and why are in [this issue](https://github.com/helm/charts/pull/13646) but to resolve this you can set `xxxx.service.omitClusterIP` to `true` where `xxxx` is the service referenced in the error. - -As of version `1.26.0` of this chart, by simply not providing any clusterIP value, `invalid: spec.clusterIP: Invalid value: "": field is immutable` will no longer occur since `clusterIP: ""` will not be rendered. - -{{ template "chart.valuesSection" . }} diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.10.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.10.0.md deleted file mode 100644 index b42d6c2..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.10.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.10.0 - -* [#5843](https://github.com/kubernetes/ingress-nginx/pull/5843) Update jettech/kube-webhook-certgen image - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.9.1...ingress-nginx-2.10.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.0.md deleted file mode 100644 index e549b38..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.0.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.11.0 - -* [#5879](https://github.com/kubernetes/ingress-nginx/pull/5879) Update helm chart for v0.34.0 -* [#5671](https://github.com/kubernetes/ingress-nginx/pull/5671) Make liveness probe more fault tolerant than readiness probe - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.10.0...ingress-nginx-2.11.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.1.md deleted file mode 100644 index d910d3b..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.11.1 - -* [#5900](https://github.com/kubernetes/ingress-nginx/pull/5900) Release helm chart for v0.34.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.11.0...ingress-nginx-2.11.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.2.md deleted file mode 100644 index 9f78210..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.2.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.11.2 - -* [#5951](https://github.com/kubernetes/ingress-nginx/pull/5951) Bump chart patch version - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.11.1...ingress-nginx-2.11.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.3.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.3.md deleted file mode 100644 index 3447691..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.11.3.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.11.3 - -* [#6038](https://github.com/kubernetes/ingress-nginx/pull/6038) Bump chart version PATCH - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.11.2...ingress-nginx-2.11.3 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.0.md deleted file mode 100644 index 5cb3888..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.0.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.12.0 - -* [#6039](https://github.com/kubernetes/ingress-nginx/pull/6039) Add configurable serviceMonitor metricRelabelling and targetLabels -* [#6044](https://github.com/kubernetes/ingress-nginx/pull/6044) Fix YAML linting - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.11.3...ingress-nginx-2.12.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.1.md deleted file mode 100644 index 94d121d..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.12.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.12.1 - -* [#6075](https://github.com/kubernetes/ingress-nginx/pull/6075) Sync helm chart affinity examples - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.12.0...ingress-nginx-2.12.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.13.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.13.0.md deleted file mode 100644 index 01fe0b1..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.13.0.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.13.0 - -* [#6093](https://github.com/kubernetes/ingress-nginx/pull/6093) Release v0.35.0 -* [#6080](https://github.com/kubernetes/ingress-nginx/pull/6080) Switch images to k8s.gcr.io after Vanity Domain Flip - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.12.1...ingress-nginx-2.13.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.14.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.14.0.md deleted file mode 100644 index 2fb7a5a..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.14.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.14.0 - -* [#6104](https://github.com/kubernetes/ingress-nginx/pull/6104) Misc fixes for nginx-ingress chart for better keel and prometheus-operator integration - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.13.0...ingress-nginx-2.14.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.15.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.15.0.md deleted file mode 100644 index 543a559..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.15.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.15.0 - -* [#6087](https://github.com/kubernetes/ingress-nginx/pull/6087) Adding parameter for externalTrafficPolicy in internal controller service spec - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.14.0...ingress-nginx-2.15.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.16.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.16.0.md deleted file mode 100644 index 996f448..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.16.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.16.0 - -* [#6154](https://github.com/kubernetes/ingress-nginx/pull/6154) add `topologySpreadConstraint` to controller - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.15.0...ingress-nginx-2.16.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.0.md deleted file mode 100644 index 11c5f5f..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.9.0 - -* [#5795](https://github.com/kubernetes/ingress-nginx/pull/5795) Use fully qualified images to avoid cri-o issues - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-TODO...ingress-nginx-2.9.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.1.md deleted file mode 100644 index 7d4314d..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-2.9.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 2.9.1 - -* [#5823](https://github.com/kubernetes/ingress-nginx/pull/5823) Add quoting to sysctls because numeric values need to be presented as strings (#5823) - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.9.0...ingress-nginx-2.9.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.0.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.0.0.md deleted file mode 100644 index a7d50ee..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.0.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.0.0 - -* [#6167](https://github.com/kubernetes/ingress-nginx/pull/6167) Update chart requirements - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-2.16.0...ingress-nginx-3.0.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.0.md deleted file mode 100644 index 3369bed..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.10.0 - -* Fix routing regression introduced in 0.41.0 with PathType Exact - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.9.0...ingress-nginx-3.10.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.1.md deleted file mode 100644 index 6ff682e..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.10.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.10.1 - -* Fix regression introduced in 0.41.0 with external authentication - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.10.0...ingress-nginx-3.10.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.0.md deleted file mode 100644 index 69ba550..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.11.0 - -* Support Keda Autoscaling - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.10.1...ingress-nginx-3.11.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.1.md deleted file mode 100644 index 4e81f4b..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.11.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.11.1 - -* [#6505](https://github.com/kubernetes/ingress-nginx/pull/6505) Reorder HPA resource list to work with GitOps tooling - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.11.0...ingress-nginx-3.11.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.12.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.12.0.md deleted file mode 100644 index 41b9744..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.12.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.12.0 - -* [#6514](https://github.com/kubernetes/ingress-nginx/pull/6514) Remove helm2 support and update docs - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.11.1...ingress-nginx-3.12.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.13.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.13.0.md deleted file mode 100644 index 0855a79..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.13.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.13.0 - -* [#6544](https://github.com/kubernetes/ingress-nginx/pull/6544) Fix default backend HPA name variable - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.12.0...ingress-nginx-3.13.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.14.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.14.0.md deleted file mode 100644 index e07880b..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.14.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.14.0 - -* [#6469](https://github.com/kubernetes/ingress-nginx/pull/6469) Allow custom service names for controller and backend - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.13.0...ingress-nginx-3.14.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.0.md deleted file mode 100644 index 3053a35..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.15.0 - -* [#6586](https://github.com/kubernetes/ingress-nginx/pull/6586) Fix 'maxmindLicenseKey' location in values.yaml - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.14.0...ingress-nginx-3.15.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.1.md deleted file mode 100644 index f11ee0a..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.15.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.15.1 - -* Fix chart-releaser action - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.15.0...ingress-nginx-3.15.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.0.md deleted file mode 100644 index fba30b1..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.16.0 - -* [#6646](https://github.com/kubernetes/ingress-nginx/pull/6646) Added LoadBalancerIP value for internal service - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.15.1...helm-chart-3.16.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.1.md deleted file mode 100644 index 650d1b8..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.16.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.16.1 - -* Fix chart-releaser action - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.16.0...helm-chart-3.16.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.17.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.17.0.md deleted file mode 100644 index 175c7a2..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.17.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.17.0 - -* Update ingress-nginx v0.42.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.16.1...helm-chart-3.17.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.18.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.18.0.md deleted file mode 100644 index 31b815e..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.18.0.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.18.0 - -* [#6688](https://github.com/kubernetes/ingress-nginx/pull/6688) Allow volume-type emptyDir in controller podsecuritypolicy -* [#6691](https://github.com/kubernetes/ingress-nginx/pull/6691) Improve parsing of helm parameters - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.17.0...helm-chart-3.18.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.19.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.19.0.md deleted file mode 100644 index 0970bf0..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.19.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.19.0 - -* Update ingress-nginx v0.43.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.18.0...helm-chart-3.19.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.0.md deleted file mode 100644 index 4b81ae4..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.20.0 - -* [#6730](https://github.com/kubernetes/ingress-nginx/pull/6730) Do not create HPA for defaultBackend if not enabled. - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.19.0...helm-chart-3.20.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.1.md deleted file mode 100644 index 952bf2b..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.20.1.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.20.1 - -* Do not create KEDA in case of DaemonSets. -* Fix KEDA v2 definition - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.20.0...helm-chart-3.20.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.21.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.21.0.md deleted file mode 100644 index 25edbef..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.21.0.md +++ /dev/null @@ -1,12 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.21.0 - -* [#6783](https://github.com/kubernetes/ingress-nginx/pull/6783) Add custom annotations to ScaledObject -* [#6761](https://github.com/kubernetes/ingress-nginx/pull/6761) Adding quotes in the serviceAccount name in Helm values -* [#6767](https://github.com/kubernetes/ingress-nginx/pull/6767) Remove ClusterRole when scope option is enabled -* [#6785](https://github.com/kubernetes/ingress-nginx/pull/6785) Update kube-webhook-certgen image to v1.5.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.20.1...helm-chart-3.21.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.22.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.22.0.md deleted file mode 100644 index 147d664..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.22.0.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.22.0 - -* [#6802](https://github.com/kubernetes/ingress-nginx/pull/6802) Add value for configuring a custom Diffie-Hellman parameters file -* [#6815](https://github.com/kubernetes/ingress-nginx/pull/6815) Allow use of numeric namespaces in helm chart - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.21.0...helm-chart-3.22.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.23.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.23.0.md deleted file mode 100644 index 5dcb50f..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.23.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.23.0 - -* Update ingress-nginx v0.44.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.22.0...helm-chart-3.23.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.24.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.24.0.md deleted file mode 100644 index d7db808..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.24.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.24.0 - -* [#6908](https://github.com/kubernetes/ingress-nginx/pull/6908) Add volumes to default-backend deployment - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.23.0...helm-chart-3.24.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.25.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.25.0.md deleted file mode 100644 index f9679a1..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.25.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.25.0 - -* [#6957](https://github.com/kubernetes/ingress-nginx/pull/6957) Add ability to specify automountServiceAccountToken - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.24.0...helm-chart-3.25.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.26.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.26.0.md deleted file mode 100644 index 0c3a1df..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.26.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.26.0 - -* [#6979](https://github.com/kubernetes/ingress-nginx/pull/6979) Changed servicePort value for metrics - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.25.0...helm-chart-3.26.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.27.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.27.0.md deleted file mode 100644 index 8113d7b..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.27.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.27.0 - -* Update ingress-nginx v0.45.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.26.0...helm-chart-3.27.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.28.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.28.0.md deleted file mode 100644 index eee0ccb..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.28.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.28.0 - -* [#6900](https://github.com/kubernetes/ingress-nginx/pull/6900) Support existing PSPs - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.27.0...helm-chart-3.28.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.29.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.29.0.md deleted file mode 100644 index f0fabdc..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.29.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.29.0 - -* [#6945](https://github.com/kubernetes/ingress-nginx/pull/7020) Add option to specify job label for ServiceMonitor - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.28.0...helm-chart-3.29.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.0.md deleted file mode 100644 index 09fab37..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.0.md +++ /dev/null @@ -1,12 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.3.0 - -* [#6203](https://github.com/kubernetes/ingress-nginx/pull/6203) Refactor parsing of key values -* [#6162](https://github.com/kubernetes/ingress-nginx/pull/6162) Add helm chart options to expose metrics service as NodePort -* [#6180](https://github.com/kubernetes/ingress-nginx/pull/6180) Fix helm chart admissionReviewVersions regression -* [#6169](https://github.com/kubernetes/ingress-nginx/pull/6169) Fix Typo in example prometheus rules - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.0.0...ingress-nginx-3.3.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.1.md deleted file mode 100644 index 81f44fd..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.3.1.md +++ /dev/null @@ -1,12 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.3.1 - -* [#6259](https://github.com/kubernetes/ingress-nginx/pull/6259) Release helm chart -* [#6258](https://github.com/kubernetes/ingress-nginx/pull/6258) Fix chart markdown link -* [#6253](https://github.com/kubernetes/ingress-nginx/pull/6253) Release v0.40.0 -* [#6233](https://github.com/kubernetes/ingress-nginx/pull/6233) Add admission controller e2e test - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.3.0...ingress-nginx-3.3.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.30.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.30.0.md deleted file mode 100644 index 77ad6b4..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.30.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.30.0 - -* [#7092](https://github.com/kubernetes/ingress-nginx/pull/7092) Removes the possibility of using localhost in ExternalNames as endpoints - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.29.0...helm-chart-3.30.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.31.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.31.0.md deleted file mode 100644 index bc07fed..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.31.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.31.0 - -* [7137] https://github.com/kubernetes/ingress-nginx/pull/7137 Add support for custom probes - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.30.0...helm-chart-3.31.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.32.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.32.0.md deleted file mode 100644 index 68f7ed6..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.32.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.32.0 - -* [7117] https://github.com/kubernetes/ingress-nginx/pull/7117 Add annotations for HPA - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.31.0...helm-chart-3.32.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.33.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.33.0.md deleted file mode 100644 index b56c5fc..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.33.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.33.0 - -* [7164] https://github.com/kubernetes/ingress-nginx/pull/7164 Update nginx to v1.20.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.32.0...helm-chart-3.33.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.34.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.34.0.md deleted file mode 100644 index a28cd02..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.34.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.34.0 - -* [7256] https://github.com/kubernetes/ingress-nginx/pull/7256 Add namespace field in the namespace scoped resource templates - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.33.0...helm-chart-3.34.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.4.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.4.0.md deleted file mode 100644 index 3b4ca93..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.4.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.4.0 - -* [#6268](https://github.com/kubernetes/ingress-nginx/pull/6268) Update to 0.40.2 in helm chart #6288 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.3.1...ingress-nginx-3.4.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.0.md deleted file mode 100644 index 44991b3..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.5.0 - -* [#6260](https://github.com/kubernetes/ingress-nginx/pull/6260) Allow Helm Chart to customize admission webhook's annotations, timeoutSeconds, namespaceSelector, objectSelector and cert files locations - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.4.0...ingress-nginx-3.5.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.1.md deleted file mode 100644 index 740f00c..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.5.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.5.1 - -* [#6299](https://github.com/kubernetes/ingress-nginx/pull/6299) Fix helm chart release - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.5.0...ingress-nginx-3.5.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.6.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.6.0.md deleted file mode 100644 index 4af7f11..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.6.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.6.0 - -* [#6305](https://github.com/kubernetes/ingress-nginx/pull/6305) Add default linux nodeSelector - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.5.1...ingress-nginx-3.6.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.0.md deleted file mode 100644 index a6b1299..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.7.0 - -* [#6316](https://github.com/kubernetes/ingress-nginx/pull/6316) Numerals in podAnnotations in quotes [#6315](https://github.com/kubernetes/ingress-nginx/issues/6315) - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.6.0...ingress-nginx-3.7.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.1.md deleted file mode 100644 index 6ba12df..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.7.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.7.1 - -* [#6326](https://github.com/kubernetes/ingress-nginx/pull/6326) Fix liveness and readiness probe path in daemonset chart - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.7.0...ingress-nginx-3.7.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.8.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.8.0.md deleted file mode 100644 index 8df250a..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.8.0.md +++ /dev/null @@ -1,13 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.8.0 - -* [#6395](https://github.com/kubernetes/ingress-nginx/pull/6395) Update jettech/kube-webhook-certgen image -* [#6377](https://github.com/kubernetes/ingress-nginx/pull/6377) Added loadBalancerSourceRanges for internal lbs -* [#6356](https://github.com/kubernetes/ingress-nginx/pull/6356) Add securitycontext settings on defaultbackend -* [#6401](https://github.com/kubernetes/ingress-nginx/pull/6401) Fix controller service annotations -* [#6403](https://github.com/kubernetes/ingress-nginx/pull/6403) Initial helm chart changelog - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.7.1...ingress-nginx-3.8.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.9.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.9.0.md deleted file mode 100644 index e8c9def..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-3.9.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 3.9.0 - -* [#6423](https://github.com/kubernetes/ingress-nginx/pull/6423) Add Default backend HPA autoscaling - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/ingress-nginx-3.8.0...ingress-nginx-3.9.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.1.md deleted file mode 100644 index 7a187b3..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.1 - -* [7535] https://github.com/kubernetes/ingress-nginx/pull/7535 Release v1.0.0 ingress-nginx - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-3.34.0...helm-chart-4.0.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.10.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.10.md deleted file mode 100644 index c5d6516..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.10.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.10 - -* [7964] https://github.com/kubernetes/ingress-nginx/pull/7964 Update controller version to v1.1.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.9...helm-chart-4.0.10 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.11.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.11.md deleted file mode 100644 index 5541823..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.11.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.11 - -* [7873] https://github.com/kubernetes/ingress-nginx/pull/7873 Makes the [appProtocol](https://kubernetes.io/docs/concepts/services-networking/_print/#application-protocol) field optional. - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.10...helm-chart-4.0.11 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.12.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.12.md deleted file mode 100644 index 320f6f5..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.12.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.12 - -* [7978] https://github.com/kubernetes/ingress-nginx/pull/7979 Support custom annotations in admissions Jobs - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.11...helm-chart-4.0.12 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.13.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.13.md deleted file mode 100644 index edd9228..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.13.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.13 - -* [8008] https://github.com/kubernetes/ingress-nginx/pull/8008 Add relabelings in controller-servicemonitor.yaml - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.12...helm-chart-4.0.13 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.14.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.14.md deleted file mode 100644 index e927010..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.14.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.14 - -* [8061] https://github.com/kubernetes/ingress-nginx/pull/8061 Using helm-docs to populate values table in README.md - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.13...helm-chart-4.0.14 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.15.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.15.md deleted file mode 100644 index d3d14a9..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.15.md +++ /dev/null @@ -1,43 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.15 - -* [8120] https://github.com/kubernetes/ingress-nginx/pull/8120 Update go in runner and release v1.1.1 -* [8119] https://github.com/kubernetes/ingress-nginx/pull/8119 Update to go v1.17.6 -* [8118] https://github.com/kubernetes/ingress-nginx/pull/8118 Remove deprecated libraries, update other libs -* [8117] https://github.com/kubernetes/ingress-nginx/pull/8117 Fix codegen errors -* [8115] https://github.com/kubernetes/ingress-nginx/pull/8115 chart/ghaction: set the correct permission to have access to push a release -* [8098] https://github.com/kubernetes/ingress-nginx/pull/8098 generating SHA for CA only certs in backend_ssl.go + comparison of P… -* [8088] https://github.com/kubernetes/ingress-nginx/pull/8088 Fix Edit this page link to use main branch -* [8072] https://github.com/kubernetes/ingress-nginx/pull/8072 Expose GeoIP2 Continent code as variable -* [8061] https://github.com/kubernetes/ingress-nginx/pull/8061 docs(charts): using helm-docs for chart -* [8058] https://github.com/kubernetes/ingress-nginx/pull/8058 Bump github.com/spf13/cobra from 1.2.1 to 1.3.0 -* [8054] https://github.com/kubernetes/ingress-nginx/pull/8054 Bump google.golang.org/grpc from 1.41.0 to 1.43.0 -* [8051] https://github.com/kubernetes/ingress-nginx/pull/8051 align bug report with feature request regarding kind documentation -* [8046] https://github.com/kubernetes/ingress-nginx/pull/8046 Report expired certificates (#8045) -* [8044] https://github.com/kubernetes/ingress-nginx/pull/8044 remove G109 check till gosec resolves issues -* [8042] https://github.com/kubernetes/ingress-nginx/pull/8042 docs_multiple_instances_one_cluster_ticket_7543 -* [8041] https://github.com/kubernetes/ingress-nginx/pull/8041 docs: fix typo'd executable name -* [8035] https://github.com/kubernetes/ingress-nginx/pull/8035 Comment busy owners -* [8029] https://github.com/kubernetes/ingress-nginx/pull/8029 Add stream-snippet as a ConfigMap and Annotation option -* [8023] https://github.com/kubernetes/ingress-nginx/pull/8023 fix nginx compilation flags -* [8021] https://github.com/kubernetes/ingress-nginx/pull/8021 Disable default modsecurity_rules_file if modsecurity-snippet is specified -* [8019] https://github.com/kubernetes/ingress-nginx/pull/8019 Revise main documentation page -* [8018] https://github.com/kubernetes/ingress-nginx/pull/8018 Preserve order of plugin invocation -* [8015] https://github.com/kubernetes/ingress-nginx/pull/8015 Add newline indenting to admission webhook annotations -* [8014] https://github.com/kubernetes/ingress-nginx/pull/8014 Add link to example error page manifest in docs -* [8009] https://github.com/kubernetes/ingress-nginx/pull/8009 Fix spelling in documentation and top-level files -* [8008] https://github.com/kubernetes/ingress-nginx/pull/8008 Add relabelings in controller-servicemonitor.yaml -* [8003] https://github.com/kubernetes/ingress-nginx/pull/8003 Minor improvements (formatting, consistency) in install guide -* [8001] https://github.com/kubernetes/ingress-nginx/pull/8001 fix: go-grpc Dockerfile -* [7999] https://github.com/kubernetes/ingress-nginx/pull/7999 images: use k8s-staging-test-infra/gcb-docker-gcloud -* [7996] https://github.com/kubernetes/ingress-nginx/pull/7996 doc: improvement -* [7983] https://github.com/kubernetes/ingress-nginx/pull/7983 Fix a couple of misspellings in the annotations documentation. -* [7979] https://github.com/kubernetes/ingress-nginx/pull/7979 allow set annotations for admission Jobs -* [7977] https://github.com/kubernetes/ingress-nginx/pull/7977 Add ssl_reject_handshake to default server -* [7975] https://github.com/kubernetes/ingress-nginx/pull/7975 add legacy version update v0.50.0 to main changelog -* [7972] https://github.com/kubernetes/ingress-nginx/pull/7972 updated service upstream definition - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.14...helm-chart-4.0.15 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.18.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.18.md deleted file mode 100644 index 30a8f75..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.18.md +++ /dev/null @@ -1,40 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.18 - -* [8291](https://github.com/kubernetes/ingress-nginx/pull/8291) remove git tag env from cloud build -* [8286](https://github.com/kubernetes/ingress-nginx/pull/8286) Fix OpenTelemetry sidecar image build -* [8277](https://github.com/kubernetes/ingress-nginx/pull/8277) Add OpenSSF Best practices badge -* [8273](https://github.com/kubernetes/ingress-nginx/pull/8273) Issue#8241 -* [8267](https://github.com/kubernetes/ingress-nginx/pull/8267) Add fsGroup value to admission-webhooks/job-patch charts -* [8262](https://github.com/kubernetes/ingress-nginx/pull/8262) Updated confusing error -* [8256](https://github.com/kubernetes/ingress-nginx/pull/8256) fix: deny locations with invalid auth-url annotation -* [8253](https://github.com/kubernetes/ingress-nginx/pull/8253) Add a certificate info metric -* [8236](https://github.com/kubernetes/ingress-nginx/pull/8236) webhook: remove useless code. -* [8227](https://github.com/kubernetes/ingress-nginx/pull/8227) Update libraries in webhook image -* [8225](https://github.com/kubernetes/ingress-nginx/pull/8225) fix inconsistent-label-cardinality for prometheus metrics: nginx_ingress_controller_requests -* [8221](https://github.com/kubernetes/ingress-nginx/pull/8221) Do not validate ingresses with unknown ingress class in admission webhook endpoint -* [8210](https://github.com/kubernetes/ingress-nginx/pull/8210) Bump github.com/prometheus/client_golang from 1.11.0 to 1.12.1 -* [8209](https://github.com/kubernetes/ingress-nginx/pull/8209) Bump google.golang.org/grpc from 1.43.0 to 1.44.0 -* [8204](https://github.com/kubernetes/ingress-nginx/pull/8204) Add Artifact Hub lint -* [8203](https://github.com/kubernetes/ingress-nginx/pull/8203) Fix Indentation of example and link to cert-manager tutorial -* [8201](https://github.com/kubernetes/ingress-nginx/pull/8201) feat(metrics): add path and method labels to requests countera -* [8199](https://github.com/kubernetes/ingress-nginx/pull/8199) use functional options to reduce number of methods creating an EchoDeployment -* [8196](https://github.com/kubernetes/ingress-nginx/pull/8196) docs: fix inconsistent controller annotation -* [8191](https://github.com/kubernetes/ingress-nginx/pull/8191) Using Go install for misspell -* [8186](https://github.com/kubernetes/ingress-nginx/pull/8186) prometheus+grafana using servicemonitor -* [8185](https://github.com/kubernetes/ingress-nginx/pull/8185) Append elements on match, instead of removing for cors-annotations -* [8179](https://github.com/kubernetes/ingress-nginx/pull/8179) Bump github.com/opencontainers/runc from 1.0.3 to 1.1.0 -* [8173](https://github.com/kubernetes/ingress-nginx/pull/8173) Adding annotations to the controller service account -* [8163](https://github.com/kubernetes/ingress-nginx/pull/8163) Update the $req_id placeholder description -* [8162](https://github.com/kubernetes/ingress-nginx/pull/8162) Versioned static manifests -* [8159](https://github.com/kubernetes/ingress-nginx/pull/8159) Adding some geoip variables and default values -* [8155](https://github.com/kubernetes/ingress-nginx/pull/8155) #7271 feat: avoid-pdb-creation-when-default-backend-disabled-and-replicas-gt-1 -* [8151](https://github.com/kubernetes/ingress-nginx/pull/8151) Automatically generate helm docs -* [8143](https://github.com/kubernetes/ingress-nginx/pull/8143) Allow to configure delay before controller exits -* [8136](https://github.com/kubernetes/ingress-nginx/pull/8136) add ingressClass option to helm chart - back compatibility with ingress.class annotations -* [8126](https://github.com/kubernetes/ingress-nginx/pull/8126) Example for JWT - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.15...helm-chart-4.0.18 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.2.md deleted file mode 100644 index 9dbd003..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.2.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.2 - -* [7681] https://github.com/kubernetes/ingress-nginx/pull/7681 Release v1.0.1 of ingress-nginx - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.1...helm-chart-4.0.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.3.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.3.md deleted file mode 100644 index 09b89f6..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.3.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.3 - -* [7707] https://github.com/kubernetes/ingress-nginx/pull/7707 Release v1.0.2 of ingress-nginx - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.2...helm-chart-4.0.3 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.5.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.5.md deleted file mode 100644 index be67704..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.5.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.5 - -* [7740] https://github.com/kubernetes/ingress-nginx/pull/7740 Release v1.0.3 of ingress-nginx - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.3...helm-chart-4.0.5 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.6.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.6.md deleted file mode 100644 index 25276e2..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.6.md +++ /dev/null @@ -1,12 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.6 - -* [7804] https://github.com/kubernetes/ingress-nginx/pull/7804 Release v1.0.4 of ingress-nginx -* [7651] https://github.com/kubernetes/ingress-nginx/pull/7651 Support ipFamilyPolicy and ipFamilies fields in Helm Chart -* [7798] https://github.com/kubernetes/ingress-nginx/pull/7798 Exoscale: use HTTP Healthcheck mode -* [7793] https://github.com/kubernetes/ingress-nginx/pull/7793 Update kube-webhook-certgen to v1.1.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.5...helm-chart-4.0.6 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.7.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.7.md deleted file mode 100644 index 50fd922..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.7.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.7 - -* [7923] https://github.com/kubernetes/ingress-nginx/pull/7923 Release v1.0.5 of ingress-nginx -* [7806] https://github.com/kubernetes/ingress-nginx/pull/7806 Choice option for internal/external loadbalancer type service - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.6...helm-chart-4.0.7 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.9.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.9.md deleted file mode 100644 index f2f725c..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.0.9.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.0.9 - -* [6992] https://github.com/kubernetes/ingress-nginx/pull/6992 Add ability to specify labels for all resources - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.7...helm-chart-4.0.9 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.0.md deleted file mode 100644 index 24aaf49..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.0.md +++ /dev/null @@ -1,21 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.1.0 - -* [8481](https://github.com/kubernetes/ingress-nginx/pull/8481) Fix log creation in chroot script -* [8479](https://github.com/kubernetes/ingress-nginx/pull/8479) changed nginx base img tag to img built with alpine3.14.6 -* [8478](https://github.com/kubernetes/ingress-nginx/pull/8478) update base images and protobuf gomod -* [8468](https://github.com/kubernetes/ingress-nginx/pull/8468) Fallback to ngx.var.scheme for redirectScheme with use-forward-headers when X-Forwarded-Proto is empty -* [8456](https://github.com/kubernetes/ingress-nginx/pull/8456) Implement object deep inspector -* [8455](https://github.com/kubernetes/ingress-nginx/pull/8455) Update dependencies -* [8454](https://github.com/kubernetes/ingress-nginx/pull/8454) Update index.md -* [8447](https://github.com/kubernetes/ingress-nginx/pull/8447) typo fixing -* [8446](https://github.com/kubernetes/ingress-nginx/pull/8446) Fix suggested annotation-value-word-blocklist -* [8444](https://github.com/kubernetes/ingress-nginx/pull/8444) replace deprecated topology key in example with current one -* [8443](https://github.com/kubernetes/ingress-nginx/pull/8443) Add dependency review enforcement -* [8434](https://github.com/kubernetes/ingress-nginx/pull/8434) added new auth-tls-match-cn annotation -* [8426](https://github.com/kubernetes/ingress-nginx/pull/8426) Bump github.com/prometheus/common from 0.32.1 to 0.33.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.0.18...helm-chart-4.1.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.2.md deleted file mode 100644 index 2061855..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.1.2.md +++ /dev/null @@ -1,11 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.1.2 - -* [8587](https://github.com/kubernetes/ingress-nginx/pull/8587) Add CAP_SYS_CHROOT to DS/PSP when needed -* [8458](https://github.com/kubernetes/ingress-nginx/pull/8458) Add portNamePrefix Helm chart parameter -* [8522](https://github.com/kubernetes/ingress-nginx/pull/8522) Add documentation for controller.service.loadBalancerIP in Helm chart - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.1.0...helm-chart-4.1.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.0.md deleted file mode 100644 index a1f1847..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.0.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.10.0 - -* - "Update Ingress-Nginx version controller-v1.10.0" - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.9.1...helm-chart-4.10.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.1.md deleted file mode 100644 index 3a28de0..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.1.md +++ /dev/null @@ -1,11 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.10.1 - -* - "update post submit helm ci and clean up (#11221)" -* - "refactor helm ci tests part I (#11188)" -* - "Update Ingress-Nginx version controller-v1.10.1" - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.10.0...helm-chart-4.10.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.2.md deleted file mode 100644 index 399bd98..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.10.2.md +++ /dev/null @@ -1,18 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.10.2 - -* Chores: Align security contacts & chart maintainers to actual owners. (#11480) -* Fix helm install on cloud provider admonition block (#11412) -* edited helm-install tips (#11411) -* added info for aws helm install (#11410) -* add workflow to helm release and update ct for branch (#11317) -* Merge pull request #11277 from strongjz/chart-1.10.1 (#11314) -* release helm chart from release branch (#11278) -* update post submit helm ci and clean up (#11221) -* refactor helm ci tests part I (#11188) -* Update Ingress-Nginx version controller-v1.10.2 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.10.1...helm-chart-4.10.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.0.md deleted file mode 100644 index 64108c0..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.0.md +++ /dev/null @@ -1,18 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.11.0 - -* Chores: Align security contacts & chart maintainers to actual owners. (#11465) -* Merge pull request #11277 from strongjz/chart-1.10.1 (#11415) -* Fix helm install on cloud provider admonition block (#11394) -* edited helm-install tips (#11393) -* added info for aws helm install (#11390) -* add workflow to helm release and update ct for branch (#11378) -* release helm chart from release branch (#11276) -* update post submit helm ci and clean up (#11220) -* refactor helm ci tests part I (#11178) -* Update Ingress-Nginx version controller-v1.11.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.10.2...helm-chart-4.11.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.1.md deleted file mode 100644 index 281513e..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.11.1 - -* Update Ingress-Nginx version controller-v1.11.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.11.0...helm-chart-4.11.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.2.md deleted file mode 100644 index c7645a5..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.2.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.11.2 - -* Update Ingress-Nginx version controller-v1.11.2 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.11.1...helm-chart-4.11.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.3.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.3.md deleted file mode 100644 index 18ec6ba..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.11.3.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.11.3 - -* Update Ingress-Nginx version controller-v1.11.3 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.11.2...helm-chart-4.11.3 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.0.md deleted file mode 100644 index 2074a09..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.0.md +++ /dev/null @@ -1,47 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.2.0 - -* Support for Kubernetes v1.19.0 was removed -* [8810](https://github.com/kubernetes/ingress-nginx/pull/8810) Prepare for v1.3.0 -* [8808](https://github.com/kubernetes/ingress-nginx/pull/8808) revert arch var name -* [8805](https://github.com/kubernetes/ingress-nginx/pull/8805) Bump k8s.io/klog/v2 from 2.60.1 to 2.70.1 -* [8803](https://github.com/kubernetes/ingress-nginx/pull/8803) Update to nginx base with alpine v3.16 -* [8802](https://github.com/kubernetes/ingress-nginx/pull/8802) chore: start v1.3.0 release process -* [8798](https://github.com/kubernetes/ingress-nginx/pull/8798) Add v1.24.0 to test matrix -* [8796](https://github.com/kubernetes/ingress-nginx/pull/8796) fix: add MAC_OS variable for static-check -* [8793](https://github.com/kubernetes/ingress-nginx/pull/8793) changed to alpine-v3.16 -* [8781](https://github.com/kubernetes/ingress-nginx/pull/8781) Bump github.com/stretchr/testify from 1.7.5 to 1.8.0 -* [8778](https://github.com/kubernetes/ingress-nginx/pull/8778) chore: remove stable.txt from release process -* [8775](https://github.com/kubernetes/ingress-nginx/pull/8775) Remove stable -* [8773](https://github.com/kubernetes/ingress-nginx/pull/8773) Bump github/codeql-action from 2.1.14 to 2.1.15 -* [8772](https://github.com/kubernetes/ingress-nginx/pull/8772) Bump ossf/scorecard-action from 1.1.1 to 1.1.2 -* [8771](https://github.com/kubernetes/ingress-nginx/pull/8771) fix bullet md format -* [8770](https://github.com/kubernetes/ingress-nginx/pull/8770) Add condition for monitoring.coreos.com/v1 API -* [8769](https://github.com/kubernetes/ingress-nginx/pull/8769) Fix typos and add links to developer guide -* [8767](https://github.com/kubernetes/ingress-nginx/pull/8767) change v1.2.0 to v1.2.1 in deploy doc URLs -* [8765](https://github.com/kubernetes/ingress-nginx/pull/8765) Bump github/codeql-action from 1.0.26 to 2.1.14 -* [8752](https://github.com/kubernetes/ingress-nginx/pull/8752) Bump github.com/spf13/cobra from 1.4.0 to 1.5.0 -* [8751](https://github.com/kubernetes/ingress-nginx/pull/8751) Bump github.com/stretchr/testify from 1.7.2 to 1.7.5 -* [8750](https://github.com/kubernetes/ingress-nginx/pull/8750) added announcement -* [8740](https://github.com/kubernetes/ingress-nginx/pull/8740) change sha e2etestrunner and echoserver -* [8738](https://github.com/kubernetes/ingress-nginx/pull/8738) Update docs to make it easier for noobs to follow step by step -* [8737](https://github.com/kubernetes/ingress-nginx/pull/8737) updated baseimage sha -* [8736](https://github.com/kubernetes/ingress-nginx/pull/8736) set ld-musl-path -* [8733](https://github.com/kubernetes/ingress-nginx/pull/8733) feat: migrate leaderelection lock to leases -* [8726](https://github.com/kubernetes/ingress-nginx/pull/8726) prometheus metric: upstream_latency_seconds -* [8720](https://github.com/kubernetes/ingress-nginx/pull/8720) Ci pin deps -* [8719](https://github.com/kubernetes/ingress-nginx/pull/8719) Working OpenTelemetry sidecar (base nginx image) -* [8714](https://github.com/kubernetes/ingress-nginx/pull/8714) Create Openssf scorecard -* [8708](https://github.com/kubernetes/ingress-nginx/pull/8708) Bump github.com/prometheus/common from 0.34.0 to 0.35.0 -* [8703](https://github.com/kubernetes/ingress-nginx/pull/8703) Bump actions/dependency-review-action from 1 to 2 -* [8701](https://github.com/kubernetes/ingress-nginx/pull/8701) Fix several typos -* [8699](https://github.com/kubernetes/ingress-nginx/pull/8699) fix the gosec test and a make target for it -* [8698](https://github.com/kubernetes/ingress-nginx/pull/8698) Bump actions/upload-artifact from 2.3.1 to 3.1.0 -* [8697](https://github.com/kubernetes/ingress-nginx/pull/8697) Bump actions/setup-go from 2.2.0 to 3.2.0 -* [8695](https://github.com/kubernetes/ingress-nginx/pull/8695) Bump actions/download-artifact from 2 to 3 -* [8694](https://github.com/kubernetes/ingress-nginx/pull/8694) Bump crazy-max/ghaction-docker-buildx from 1.6.2 to 3.3.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.1.2...helm-chart-4.2.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.1.md deleted file mode 100644 index 7965bb1..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.2.1.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.2.1 - -* The sha of kube-webhook-certgen image & the opentelemetry image, in values file, was changed to new images built on alpine-v3.16.1 -* [8896](https://github.com/kubernetes/ingress-nginx/pull/8896) updated to new images built today - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.2.0...helm-chart-4.2.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.3.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.3.0.md deleted file mode 100644 index f9dca22..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.3.0.md +++ /dev/null @@ -1,14 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.3.0 - -* Support for Kubernetes v.1.25.0 was added and support for endpoint slices -* Support for Kubernetes v1.20.0 and v1.21.0 was removed -* [8890](https://github.com/kubernetes/ingress-nginx/pull/8890) migrate to endpointslices -* [9059](https://github.com/kubernetes/ingress-nginx/pull/9059) kubewebhookcertgen sha change after go1191 -* [9046](https://github.com/kubernetes/ingress-nginx/pull/9046) Parameterize metrics port name -* [9104](https://github.com/kubernetes/ingress-nginx/pull/9104) Fix yaml formatting error with multiple annotations - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.2.1...helm-chart-4.3.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.4.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.4.0.md deleted file mode 100644 index 20f9e23..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.4.0.md +++ /dev/null @@ -1,12 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.4.0 - -* Adding support for disabling liveness and readiness probes to the Helm chart by @njegosrailic in https://github.com/kubernetes/ingress-nginx/pull/9238 -* add:(admission-webhooks) ability to set securityContext by @ybelMekk in https://github.com/kubernetes/ingress-nginx/pull/9186 -* #7652 - Updated Helm chart to use the fullname for the electionID if not specified. by @FutureMatt in https://github.com/kubernetes/ingress-nginx/pull/9133 -* Rename controller-wehbooks-networkpolicy.yaml. by @Gacko in https://github.com/kubernetes/ingress-nginx/pull/9123 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.3.0...helm-chart-4.4.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.5.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.5.2.md deleted file mode 100644 index b6d8a3b..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.5.2.md +++ /dev/null @@ -1,13 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.5.2 - -* add lint on chart before release (#9570) -* ci: remove setup-helm step (#9404) -* feat(helm): Optionally use cert-manager instead admission patch (#9279) -* run helm release on main only and when the chart/value changes only (#9290) -* Update Ingress-Nginx version controller-v1.6.4 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.4.3...helm-chart-4.5.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.0.md deleted file mode 100644 index 469aaba..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.0.md +++ /dev/null @@ -1,24 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.5.3 - -* docs(helm): fix value key in readme for enabling certManager (#9640) -* Upgrade alpine 3.17.2 -* Upgrade golang 1.20 -* Drop testing/support for Kubernetes 1.23 -* docs(helm): fix value key in readme for enabling certManager (#9640) -* Update Ingress-Nginx version controller-v1.7.0 -* feat: OpenTelemetry module integration (#9062) -* canary-weight-total annotation ignored in rule backends (#9729) -* fix controller psp's volume config (#9740) -* Fix several Helm YAML issues with extraModules and extraInitContainers (#9709) -* Chart: Drop `controller.headers`, rework DH param secret. (#9659) -* Deployment/DaemonSet: Label pods using `ingress-nginx.labels`. (#9732) -* HPA: autoscaling/v2beta1 deprecated, bump apiVersion to v2 for defaultBackend (#9731) -* Fix incorrect annotation name in upstream hashing configuration (#9617) - -* Update Ingress-Nginx version controller-v1.7.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.5.2...helm-chart-4.6.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.1.md deleted file mode 100644 index 57d99b8..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.6.1.md +++ /dev/null @@ -1,11 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.6.1 - -* [helm] Support custom port configuration for internal service (#9846) -* Adding resource type to default HPA configuration to resolve issues with Terraform helm chart usage (#9803) -* Update Ingress-Nginx version controller-v1.7.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.6.0...helm-chart-4.6.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.0.md deleted file mode 100644 index 9d54070..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.0.md +++ /dev/null @@ -1,14 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.7.0 - -* helm: Fix opentelemetry module installation for daemonset (#9792) -* Update charts/* to keep project name display aligned (#9931) -* HPA: Use capabilities & align manifests. (#9521) -* PodDisruptionBudget spec logic update (#9904) -* add option for annotations in PodDisruptionBudget (#9843) -* Update Ingress-Nginx version controller-v1.8.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.6.1...helm-chart-4.7.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.1.md deleted file mode 100644 index 4d69a71..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.1.md +++ /dev/null @@ -1,12 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.7.1 - -* Added a doc line to the missing helm value service.internal.loadBalancerIP (#9406) -* feat(helm): Add loadBalancerClass (#9562) -* added helmshowvalues example (#10019) -* Update Ingress-Nginx version controller-v1.8.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.7.0...helm-chart-4.7.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.2.md deleted file mode 100644 index 57b17b9..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.7.2.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.7.2 - -* Update Ingress-Nginx version controller-v1.8.2 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.7.1...helm-chart-4.7.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0-beta.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0-beta.0.md deleted file mode 100644 index 9072a75..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0-beta.0.md +++ /dev/null @@ -1,13 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.8.0-beta.0 - -* ci(helm): fix Helm Chart release action 422 error (#10237) -* helm: Use .Release.Namespace as default for ServiceMonitor namespace (#10249) -* [helm] configure allow to configure hostAliases (#10180) -* [helm] pass service annotations through helm tpl engine (#10084) -* Update Ingress-Nginx version controller-v1.9.0-beta.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.7.2...helm-chart-4.8.0-beta.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0.md deleted file mode 100644 index af8f124..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.0.md +++ /dev/null @@ -1,13 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.8.0 - -* ci(helm): fix Helm Chart release action 422 error (#10237) -* helm: Use .Release.Namespace as default for ServiceMonitor namespace (#10249) -* [helm] configure allow to configure hostAliases (#10180) -* [helm] pass service annotations through helm tpl engine (#10084) -* Update Ingress-Nginx version controller-v1.9.0 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.7.2...helm-chart-4.8.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.1.md deleted file mode 100644 index 53a4493..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.1.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.8.1 - -* Update Ingress-Nginx version controller-v1.9.1 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.8.0...helm-chart-4.8.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.2.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.2.md deleted file mode 100644 index 9957c1a..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.2.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.8.2 - -* update nginx base, httpbun, e2e, helm webhook cert gen (#10506) -* Update Ingress-Nginx version controller-v1.9.3 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.8.1...helm-chart-4.8.2 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.3.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.3.md deleted file mode 100644 index b8d4d56..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.8.3.md +++ /dev/null @@ -1,9 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.8.3 - -* Update Ingress-Nginx version controller-v1.9.4 - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.8.2...helm-chart-4.8.3 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.0.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.0.md deleted file mode 100644 index 5c77298..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.0.md +++ /dev/null @@ -1,13 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.9.0 - -* - "Add controller.metrics.serviceMonitor.annotations in Helm chart" -* - "fix(labels): use complete labels variable on default-backend deployment" -* - "chart: allow setting allocateLoadBalancerNodePorts (#10693)" -* - "[release-1.9] feat(helm): add documentation about metric args (#10695)" -* - "Update Ingress-Nginx version controller-v1.9.5" - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.8.3...helm-chart-4.9.0 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.1.md b/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.1.md deleted file mode 100644 index c6120e7..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart-4.9.1.md +++ /dev/null @@ -1,10 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### 4.9.1 - -* - "update web hook cert gen to latest release v20231226-1a7112e06" -* - "Update Ingress-Nginx version controller-v1.9.6" - -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-4.9.0...helm-chart-4.9.1 diff --git a/charts/keep/charts/ingress-nginx/changelog/helm-chart.md.gotmpl b/charts/keep/charts/ingress-nginx/changelog/helm-chart.md.gotmpl deleted file mode 100644 index ef5add5..0000000 --- a/charts/keep/charts/ingress-nginx/changelog/helm-chart.md.gotmpl +++ /dev/null @@ -1,11 +0,0 @@ -# Changelog - -This file documents all notable changes to [ingress-nginx](https://github.com/kubernetes/ingress-nginx) Helm Chart. The release numbering uses [semantic versioning](http://semver.org). - -### {{ .NewHelmChartVersion }} -{{ with .HelmUpdates }} -{{- range . }} -* {{ . }} -{{- end }} -{{ end }} -**Full Changelog**: https://github.com/kubernetes/ingress-nginx/compare/helm-chart-{{ .PreviousHelmChartVersion }}...helm-chart-{{ .NewHelmChartVersion }} diff --git a/charts/keep/charts/ingress-nginx/ci/admission-webhooks-cert-manager-values.yaml b/charts/keep/charts/ingress-nginx/ci/admission-webhooks-cert-manager-values.yaml deleted file mode 100644 index 7eafd0c..0000000 --- a/charts/keep/charts/ingress-nginx/ci/admission-webhooks-cert-manager-values.yaml +++ /dev/null @@ -1,12 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - admissionWebhooks: - certManager: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-configmap-addheaders-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-configmap-addheaders-values.yaml deleted file mode 100644 index 460a610..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-configmap-addheaders-values.yaml +++ /dev/null @@ -1,11 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - addHeaders: - X-Frame-Options: deny diff --git a/charts/keep/charts/ingress-nginx/ci/controller-configmap-proxyheaders-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-configmap-proxyheaders-values.yaml deleted file mode 100644 index e23a13c..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-configmap-proxyheaders-values.yaml +++ /dev/null @@ -1,11 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - proxySetHeaders: - X-Forwarded-Proto: https diff --git a/charts/keep/charts/ingress-nginx/ci/controller-configmap-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-configmap-values.yaml deleted file mode 100644 index a702989..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-configmap-values.yaml +++ /dev/null @@ -1,11 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - config: - use-proxy-protocol: "true" diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-extra-modules-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-extra-modules-values.yaml deleted file mode 100644 index edf12e7..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-extra-modules-values.yaml +++ /dev/null @@ -1,30 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: DaemonSet - - extraModules: - - name: opentelemetry - image: - registry: registry.k8s.io - image: ingress-nginx/opentelemetry-1.25.3 - tag: v20240813-b933310d - digest: sha256:f7604ac0547ed64d79b98d92133234e66c2c8aade3c1f4809fed5eec1fb7f922 - distroless: true - containerSecurityContext: - runAsNonRoot: true - runAsUser: 65532 - runAsGroup: 65532 - allowPrivilegeEscalation: false - seccompProfile: - type: RuntimeDefault - capabilities: - drop: - - ALL - readOnlyRootFilesystem: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-metrics-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-metrics-values.yaml deleted file mode 100644 index 7a98580..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-metrics-values.yaml +++ /dev/null @@ -1,13 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: DaemonSet - - metrics: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-opentelemetry-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-opentelemetry-values.yaml deleted file mode 100644 index 179ab2a..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-opentelemetry-values.yaml +++ /dev/null @@ -1,13 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: DaemonSet - - opentelemetry: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-podannotations-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-podannotations-values.yaml deleted file mode 100644 index 405992e..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-podannotations-values.yaml +++ /dev/null @@ -1,16 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: DaemonSet - - podAnnotations: - prometheus.io/scrape: "true" - prometheus.io/port: "10254" - prometheus.io/scheme: http - prometheus.io/path: /metrics diff --git a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-daemonset-values.yaml deleted file mode 100644 index d34025c..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-daemonset-values.yaml +++ /dev/null @@ -1,10 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: DaemonSet diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-extra-modules-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-extra-modules-values.yaml deleted file mode 100644 index d4083cc..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-deployment-extra-modules-values.yaml +++ /dev/null @@ -1,30 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: Deployment - - extraModules: - - name: opentelemetry - image: - registry: registry.k8s.io - image: ingress-nginx/opentelemetry-1.25.3 - tag: v20240813-b933310d - digest: sha256:f7604ac0547ed64d79b98d92133234e66c2c8aade3c1f4809fed5eec1fb7f922 - distroless: true - containerSecurityContext: - runAsNonRoot: true - runAsUser: 65532 - runAsGroup: 65532 - allowPrivilegeEscalation: false - seccompProfile: - type: RuntimeDefault - capabilities: - drop: - - ALL - readOnlyRootFilesystem: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-metrics-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-metrics-values.yaml deleted file mode 100644 index 9c95d34..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-deployment-metrics-values.yaml +++ /dev/null @@ -1,13 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: Deployment - - metrics: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-opentelemetry-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-opentelemetry-values.yaml deleted file mode 100644 index 9443dde..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-deployment-opentelemetry-values.yaml +++ /dev/null @@ -1,13 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: Deployment - - opentelemetry: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-podannotations-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-podannotations-values.yaml deleted file mode 100644 index cf1f261..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-deployment-podannotations-values.yaml +++ /dev/null @@ -1,16 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: Deployment - - podAnnotations: - prometheus.io/scrape: "true" - prometheus.io/port: "10254" - prometheus.io/scheme: http - prometheus.io/path: /metrics diff --git a/charts/keep/charts/ingress-nginx/ci/controller-deployment-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-deployment-values.yaml deleted file mode 100644 index 1b092dc..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-deployment-values.yaml +++ /dev/null @@ -1,10 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - kind: Deployment diff --git a/charts/keep/charts/ingress-nginx/ci/controller-hpa-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-hpa-values.yaml deleted file mode 100644 index 54a0d2f..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-hpa-values.yaml +++ /dev/null @@ -1,18 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - autoscaling: - enabled: true - behavior: - scaleDown: - stabilizationWindowSeconds: 300 - policies: - - type: Pods - value: 1 - periodSeconds: 180 diff --git a/charts/keep/charts/ingress-nginx/ci/controller-ingressclass-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-ingressclass-values.yaml deleted file mode 100644 index c06429f..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-ingressclass-values.yaml +++ /dev/null @@ -1,15 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - ingressClassResource: - name: custom-nginx - default: true - controllerValue: k8s.io/custom-nginx - - watchIngressWithoutClass: true diff --git a/charts/keep/charts/ingress-nginx/ci/controller-service-internal-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-service-internal-values.yaml deleted file mode 100644 index 11108fb..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-service-internal-values.yaml +++ /dev/null @@ -1,13 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: ClusterIP - - internal: - enabled: true - annotations: - service.beta.kubernetes.io/aws-load-balancer-internal: "true" diff --git a/charts/keep/charts/ingress-nginx/ci/controller-service-values.yaml b/charts/keep/charts/ingress-nginx/ci/controller-service-values.yaml deleted file mode 100644 index 9039368..0000000 --- a/charts/keep/charts/ingress-nginx/ci/controller-service-values.yaml +++ /dev/null @@ -1,22 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - - service: - type: NodePort - - nodePorts: - tcp: - 9000: 30090 - udp: - 9001: 30091 - -portNamePrefix: port - -tcp: - 9000: default/test:8080 - -udp: - 9001: default/test:8080 diff --git a/charts/keep/charts/ingress-nginx/ci/deamonset-psp-values.yaml b/charts/keep/charts/ingress-nginx/ci/deamonset-psp-values.yaml deleted file mode 100644 index 8026a63..0000000 --- a/charts/keep/charts/ingress-nginx/ci/deamonset-psp-values.yaml +++ /dev/null @@ -1,13 +0,0 @@ -controller: - kind: DaemonSet - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - admissionWebhooks: - enabled: false - service: - type: ClusterIP - -podSecurityPolicy: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/deamonset-webhook-and-psp-values.yaml b/charts/keep/charts/ingress-nginx/ci/deamonset-webhook-and-psp-values.yaml deleted file mode 100644 index fccdb13..0000000 --- a/charts/keep/charts/ingress-nginx/ci/deamonset-webhook-and-psp-values.yaml +++ /dev/null @@ -1,13 +0,0 @@ -controller: - kind: DaemonSet - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - admissionWebhooks: - enabled: true - service: - type: ClusterIP - -podSecurityPolicy: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/deployment-psp-values.yaml b/charts/keep/charts/ingress-nginx/ci/deployment-psp-values.yaml deleted file mode 100644 index 2f332a7..0000000 --- a/charts/keep/charts/ingress-nginx/ci/deployment-psp-values.yaml +++ /dev/null @@ -1,10 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - service: - type: ClusterIP - -podSecurityPolicy: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/ci/deployment-webhook-and-psp-values.yaml b/charts/keep/charts/ingress-nginx/ci/deployment-webhook-and-psp-values.yaml deleted file mode 100644 index 6195bb3..0000000 --- a/charts/keep/charts/ingress-nginx/ci/deployment-webhook-and-psp-values.yaml +++ /dev/null @@ -1,12 +0,0 @@ -controller: - image: - repository: ingress-controller/controller - tag: 1.0.0-dev - digest: null - admissionWebhooks: - enabled: true - service: - type: ClusterIP - -podSecurityPolicy: - enabled: true diff --git a/charts/keep/charts/ingress-nginx/templates/NOTES.txt b/charts/keep/charts/ingress-nginx/templates/NOTES.txt deleted file mode 100644 index f492300..0000000 --- a/charts/keep/charts/ingress-nginx/templates/NOTES.txt +++ /dev/null @@ -1,73 +0,0 @@ -The ingress-nginx controller has been installed. - -{{- if contains "NodePort" .Values.controller.service.type }} -Get the application URL by running these commands: - -{{- if (not (empty .Values.controller.service.nodePorts.http)) }} - export HTTP_NODE_PORT={{ .Values.controller.service.nodePorts.http }} -{{- else }} - export HTTP_NODE_PORT=$(kubectl get service --namespace {{ include "ingress-nginx.namespace" . }} {{ include "ingress-nginx.controller.fullname" . }} --output jsonpath="{.spec.ports[0].nodePort}") -{{- end }} -{{- if (not (empty .Values.controller.service.nodePorts.https)) }} - export HTTPS_NODE_PORT={{ .Values.controller.service.nodePorts.https }} -{{- else }} - export HTTPS_NODE_PORT=$(kubectl get service --namespace {{ include "ingress-nginx.namespace" . }} {{ include "ingress-nginx.controller.fullname" . }} --output jsonpath="{.spec.ports[1].nodePort}") -{{- end }} - export NODE_IP="$(kubectl get nodes --output jsonpath="{.items[0].status.addresses[1].address}")" - - echo "Visit http://${NODE_IP}:${HTTP_NODE_PORT} to access your application via HTTP." - echo "Visit https://${NODE_IP}:${HTTPS_NODE_PORT} to access your application via HTTPS." -{{- else if contains "LoadBalancer" .Values.controller.service.type }} -It may take a few minutes for the load balancer IP to be available. -You can watch the status by running 'kubectl get service --namespace {{ include "ingress-nginx.namespace" . }} {{ include "ingress-nginx.controller.fullname" . }} --output wide --watch' -{{- else if contains "ClusterIP" .Values.controller.service.type }} -Get the application URL by running these commands: - export POD_NAME="$(kubectl get pods --namespace {{ include "ingress-nginx.namespace" . }} --selector app.kubernetes.io/name={{ include "ingress-nginx.name" . }},app.kubernetes.io/instance={{ .Release.Name }},app.kubernetes.io/component=controller --output jsonpath="{.items[0].metadata.name}")" - kubectl port-forward --namespace {{ include "ingress-nginx.namespace" . }} "${POD_NAME}" 8080:80 - echo "Visit http://127.0.0.1:8080 to access your application." -{{- end }} - -An example Ingress that makes use of the controller: - -{{- $isV1 := semverCompare ">=1" .Chart.AppVersion}} - apiVersion: networking.k8s.io/v1 - kind: Ingress - metadata: - name: example - namespace: foo - {{- if eq $isV1 false }} - annotations: - kubernetes.io/ingress.class: {{ .Values.controller.ingressClass }} - {{- end }} - spec: - {{- if $isV1 }} - ingressClassName: {{ .Values.controller.ingressClassResource.name }} - {{- end }} - rules: - - host: www.example.com - http: - paths: - - pathType: Prefix - backend: - service: - name: exampleService - port: - number: 80 - path: / - # This section is only required if TLS is to be enabled for the Ingress - tls: - - hosts: - - www.example.com - secretName: example-tls - -If TLS is enabled for the Ingress, a Secret containing the certificate and key must also be provided: - - apiVersion: v1 - kind: Secret - metadata: - name: example-tls - namespace: foo - data: - tls.crt: - tls.key: - type: kubernetes.io/tls diff --git a/charts/keep/charts/ingress-nginx/templates/_helpers.tpl b/charts/keep/charts/ingress-nginx/templates/_helpers.tpl deleted file mode 100644 index 24cfd14..0000000 --- a/charts/keep/charts/ingress-nginx/templates/_helpers.tpl +++ /dev/null @@ -1,272 +0,0 @@ -{{/* vim: set filetype=mustache: */}} -{{/* -Expand the name of the chart. -*/}} -{{- define "ingress-nginx.name" -}} -{{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" -}} -{{- end -}} - -{{/* -Create chart name and version as used by the chart label. -*/}} -{{- define "ingress-nginx.chart" -}} -{{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | 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). -*/}} -{{- define "ingress-nginx.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 -}} - -{{/* -Expand the namespace of the release. -Allows overriding it for multi-namespace deployments in combined charts. -*/}} -{{- define "ingress-nginx.namespace" -}} -{{- default .Release.Namespace .Values.namespaceOverride | trunc 63 | trimSuffix "-" -}} -{{- end -}} - -{{/* -Controller container security context. -*/}} -{{- define "ingress-nginx.controller.containerSecurityContext" -}} -{{- if .Values.controller.containerSecurityContext -}} -{{- toYaml .Values.controller.containerSecurityContext -}} -{{- else -}} -runAsNonRoot: {{ .Values.controller.image.runAsNonRoot }} -runAsUser: {{ .Values.controller.image.runAsUser }} -allowPrivilegeEscalation: {{ or .Values.controller.image.allowPrivilegeEscalation .Values.controller.image.chroot }} -{{- if .Values.controller.image.seccompProfile }} -seccompProfile: {{ toYaml .Values.controller.image.seccompProfile | nindent 2 }} -{{- end }} -capabilities: - drop: - - ALL - add: - - NET_BIND_SERVICE - {{- if .Values.controller.image.chroot }} - {{- if .Values.controller.image.seccompProfile }} - - SYS_ADMIN - {{- end }} - - SYS_CHROOT - {{- end }} -readOnlyRootFilesystem: {{ .Values.controller.image.readOnlyRootFilesystem }} -{{- end -}} -{{- end -}} - -{{/* -Get specific image -*/}} -{{- define "ingress-nginx.image" -}} -{{- if .chroot -}} -{{- printf "%s-chroot" .image -}} -{{- else -}} -{{- printf "%s" .image -}} -{{- end }} -{{- end -}} - -{{/* -Get specific image digest -*/}} -{{- define "ingress-nginx.imageDigest" -}} -{{- if .chroot -}} -{{- if .digestChroot -}} -{{- printf "@%s" .digestChroot -}} -{{- end }} -{{- else -}} -{{ if .digest -}} -{{- printf "@%s" .digest -}} -{{- end -}} -{{- end -}} -{{- end -}} - -{{/* -Create a default fully qualified controller name. -We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). -*/}} -{{- define "ingress-nginx.controller.fullname" -}} -{{- printf "%s-%s" (include "ingress-nginx.fullname" .) .Values.controller.name | trunc 63 | trimSuffix "-" -}} -{{- end -}} - -{{/* -Construct a unique electionID. -Users can provide an override for an explicit electionID if they want via `.Values.controller.electionID` -*/}} -{{- define "ingress-nginx.controller.electionID" -}} -{{- $defElectionID := printf "%s-leader" (include "ingress-nginx.fullname" .) -}} -{{- $electionID := default $defElectionID .Values.controller.electionID -}} -{{- print $electionID -}} -{{- end -}} - -{{/* -Construct the path for the publish-service. - -By convention this will simply use the / to match the name of the -service generated. - -Users can provide an override for an explicit service they want bound via `.Values.controller.publishService.pathOverride` -*/}} -{{- define "ingress-nginx.controller.publishServicePath" -}} -{{- $defServiceName := printf "%s/%s" "$(POD_NAMESPACE)" (include "ingress-nginx.controller.fullname" .) -}} -{{- $servicePath := default $defServiceName .Values.controller.publishService.pathOverride }} -{{- print $servicePath | trimSuffix "-" -}} -{{- end -}} - -{{/* -Common labels -*/}} -{{- define "ingress-nginx.labels" -}} -helm.sh/chart: {{ include "ingress-nginx.chart" . }} -{{ include "ingress-nginx.selectorLabels" . }} -{{- if .Chart.AppVersion }} -app.kubernetes.io/version: {{ .Chart.AppVersion | quote }} -{{- end }} -app.kubernetes.io/part-of: {{ template "ingress-nginx.name" . }} -app.kubernetes.io/managed-by: {{ .Release.Service }} -{{- if .Values.commonLabels}} -{{ toYaml .Values.commonLabels }} -{{- end }} -{{- end -}} - -{{/* -Selector labels -*/}} -{{- define "ingress-nginx.selectorLabels" -}} -app.kubernetes.io/name: {{ include "ingress-nginx.name" . }} -app.kubernetes.io/instance: {{ .Release.Name }} -{{- end -}} - -{{/* -Create the name of the controller service account to use -*/}} -{{- define "ingress-nginx.serviceAccountName" -}} -{{- if .Values.serviceAccount.create -}} - {{ default (include "ingress-nginx.fullname" .) .Values.serviceAccount.name }} -{{- else -}} - {{ default "default" .Values.serviceAccount.name }} -{{- end -}} -{{- end -}} - -{{/* -Create a default fully qualified admission webhook name. -We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). -*/}} -{{- define "ingress-nginx.admissionWebhooks.fullname" -}} -{{- printf "%s-%s" (include "ingress-nginx.fullname" .) .Values.controller.admissionWebhooks.name | trunc 63 | trimSuffix "-" -}} -{{- end -}} - -{{/* -Create the name of the admission webhook patch job service account to use -*/}} -{{- define "ingress-nginx.admissionWebhooks.patch.serviceAccountName" -}} -{{- if .Values.controller.admissionWebhooks.patch.serviceAccount.create -}} - {{ default (include "ingress-nginx.admissionWebhooks.fullname" .) .Values.controller.admissionWebhooks.patch.serviceAccount.name }} -{{- else -}} - {{ default "default" .Values.controller.admissionWebhooks.patch.serviceAccount.name }} -{{- end -}} -{{- end -}} - -{{/* -Create a default fully qualified admission webhook secret creation job name. -We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). -*/}} -{{- define "ingress-nginx.admissionWebhooks.createSecretJob.fullname" -}} -{{- printf "%s-%s" (include "ingress-nginx.admissionWebhooks.fullname" .) .Values.controller.admissionWebhooks.createSecretJob.name | trunc 63 | trimSuffix "-" -}} -{{- end -}} - -{{/* -Create a default fully qualified admission webhook patch job name. -We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). -*/}} -{{- define "ingress-nginx.admissionWebhooks.patchWebhookJob.fullname" -}} -{{- printf "%s-%s" (include "ingress-nginx.admissionWebhooks.fullname" .) .Values.controller.admissionWebhooks.patchWebhookJob.name | trunc 63 | trimSuffix "-" -}} -{{- end -}} - -{{/* -Create a default fully qualified default backend name. -We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). -*/}} -{{- define "ingress-nginx.defaultBackend.fullname" -}} -{{- printf "%s-%s" (include "ingress-nginx.fullname" .) .Values.defaultBackend.name | trunc 63 | trimSuffix "-" -}} -{{- end -}} - -{{/* -Create the name of the default backend service account to use -*/}} -{{- define "ingress-nginx.defaultBackend.serviceAccountName" -}} -{{- if .Values.defaultBackend.serviceAccount.create -}} - {{ default (printf "%s-backend" (include "ingress-nginx.fullname" .)) .Values.defaultBackend.serviceAccount.name }} -{{- else -}} - {{ default "default-backend" .Values.defaultBackend.serviceAccount.name }} -{{- end -}} -{{- end -}} - -{{/* -Default backend container security context. -*/}} -{{- define "ingress-nginx.defaultBackend.containerSecurityContext" -}} -{{- if .Values.defaultBackend.containerSecurityContext -}} -{{- toYaml .Values.defaultBackend.containerSecurityContext -}} -{{- else -}} -runAsNonRoot: {{ .Values.defaultBackend.image.runAsNonRoot }} -runAsUser: {{ .Values.defaultBackend.image.runAsUser }} -allowPrivilegeEscalation: {{ .Values.defaultBackend.image.allowPrivilegeEscalation }} -{{- if .Values.defaultBackend.image.seccompProfile }} -seccompProfile: {{ toYaml .Values.defaultBackend.image.seccompProfile | nindent 2 }} -{{- end }} -capabilities: - drop: - - ALL -readOnlyRootFilesystem: {{ .Values.defaultBackend.image.readOnlyRootFilesystem }} -{{- end -}} -{{- end -}} - -{{/* -Return the appropriate apiGroup for PodSecurityPolicy. -*/}} -{{- define "podSecurityPolicy.apiGroup" -}} -{{- if semverCompare ">=1.14-0" .Capabilities.KubeVersion.GitVersion -}} -{{- print "policy" -}} -{{- else -}} -{{- print "extensions" -}} -{{- end -}} -{{- end -}} - -{{/* -Extra modules. -*/}} -{{- define "extraModules" -}} -- name: {{ .name }} - {{- with .image }} - image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ .image }}{{ end }}:{{ .tag }}{{ if .digest }}@{{ .digest }}{{ end }} - command: - {{- if .distroless }} - - /init_module - {{- else }} - - sh - - -c - - /usr/local/bin/init_module.sh - {{- end }} - {{- end }} - {{- if .containerSecurityContext }} - securityContext: {{ toYaml .containerSecurityContext | nindent 4 }} - {{- end }} - {{- if .resources }} - resources: {{ toYaml .resources | nindent 4 }} - {{- end }} - volumeMounts: - - name: modules - mountPath: /modules_mount -{{- end -}} diff --git a/charts/keep/charts/ingress-nginx/templates/_params.tpl b/charts/keep/charts/ingress-nginx/templates/_params.tpl deleted file mode 100644 index 48569a8..0000000 --- a/charts/keep/charts/ingress-nginx/templates/_params.tpl +++ /dev/null @@ -1,77 +0,0 @@ -{{- define "ingress-nginx.params" -}} -- /nginx-ingress-controller -{{- if .Values.controller.enableAnnotationValidations }} -- --enable-annotation-validation=true -{{- end }} -{{- if .Values.defaultBackend.enabled }} -- --default-backend-service=$(POD_NAMESPACE)/{{ include "ingress-nginx.defaultBackend.fullname" . }} -{{- end }} -{{- if and .Values.controller.publishService.enabled .Values.controller.service.enabled }} -{{- if .Values.controller.service.external.enabled }} -- --publish-service={{ template "ingress-nginx.controller.publishServicePath" . }} -{{- else if .Values.controller.service.internal.enabled }} -- --publish-service={{ template "ingress-nginx.controller.publishServicePath" . }}-internal -{{- end }} -{{- end }} -- --election-id={{ include "ingress-nginx.controller.electionID" . }} -- --controller-class={{ .Values.controller.ingressClassResource.controllerValue }} -{{- if .Values.controller.ingressClass }} -- --ingress-class={{ .Values.controller.ingressClass }} -{{- end }} -- --configmap={{ default "$(POD_NAMESPACE)" .Values.controller.configMapNamespace }}/{{ include "ingress-nginx.controller.fullname" . }} -{{- if .Values.tcp }} -- --tcp-services-configmap={{ default "$(POD_NAMESPACE)" .Values.controller.tcp.configMapNamespace }}/{{ include "ingress-nginx.fullname" . }}-tcp -{{- end }} -{{- if .Values.udp }} -- --udp-services-configmap={{ default "$(POD_NAMESPACE)" .Values.controller.udp.configMapNamespace }}/{{ include "ingress-nginx.fullname" . }}-udp -{{- end }} -{{- if .Values.controller.scope.enabled }} -- --watch-namespace={{ default "$(POD_NAMESPACE)" .Values.controller.scope.namespace }} -{{- end }} -{{- if and (not .Values.controller.scope.enabled) .Values.controller.scope.namespaceSelector }} -- --watch-namespace-selector={{ .Values.controller.scope.namespaceSelector }} -{{- end }} -{{- if and .Values.controller.reportNodeInternalIp .Values.controller.hostNetwork }} -- --report-node-internal-ip-address={{ .Values.controller.reportNodeInternalIp }} -{{- end }} -{{- if .Values.controller.admissionWebhooks.enabled }} -- --validating-webhook=:{{ .Values.controller.admissionWebhooks.port }} -- --validating-webhook-certificate={{ .Values.controller.admissionWebhooks.certificate }} -- --validating-webhook-key={{ .Values.controller.admissionWebhooks.key }} -{{- end }} -{{- if .Values.controller.maxmindLicenseKey }} -- --maxmind-license-key={{ .Values.controller.maxmindLicenseKey }} -{{- end }} -{{- if .Values.controller.healthCheckHost }} -- --healthz-host={{ .Values.controller.healthCheckHost }} -{{- end }} -{{- if not (eq .Values.controller.healthCheckPath "/healthz") }} -- --health-check-path={{ .Values.controller.healthCheckPath }} -{{- end }} -{{- if .Values.controller.ingressClassByName }} -- --ingress-class-by-name=true -{{- end }} -{{- if .Values.controller.watchIngressWithoutClass }} -- --watch-ingress-without-class=true -{{- end }} -{{- if not .Values.controller.metrics.enabled }} -- --enable-metrics={{ .Values.controller.metrics.enabled }} -{{- end }} -{{- if .Values.controller.enableTopologyAwareRouting }} -- --enable-topology-aware-routing=true -{{- end }} -{{- if .Values.controller.disableLeaderElection }} -- --disable-leader-election=true -{{- end }} -{{- if .Values.controller.electionTTL }} -- --election-ttl={{ .Values.controller.electionTTL }} -{{- end }} -{{- range $key, $value := .Values.controller.extraArgs }} -{{- /* Accept keys without values or with false as value */}} -{{- if eq ($value | quote | len) 2 }} -- --{{ $key }} -{{- else }} -- --{{ $key }}={{ $value }} -{{- end }} -{{- end }} -{{- end -}} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/cert-manager.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/cert-manager.yaml deleted file mode 100644 index db2946c..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/cert-manager.yaml +++ /dev/null @@ -1,63 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.certManager.enabled -}} -{{- if not .Values.controller.admissionWebhooks.certManager.issuerRef -}} -# Create a selfsigned Issuer, in order to create a root CA certificate for -# signing webhook serving certificates -apiVersion: cert-manager.io/v1 -kind: Issuer -metadata: - name: {{ include "ingress-nginx.fullname" . }}-self-signed-issuer - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - selfSigned: {} ---- -# Generate a CA Certificate used to sign certificates for the webhook -apiVersion: cert-manager.io/v1 -kind: Certificate -metadata: - name: {{ include "ingress-nginx.fullname" . }}-root-cert - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - secretName: {{ include "ingress-nginx.fullname" . }}-root-cert - duration: {{ .Values.controller.admissionWebhooks.certManager.rootCert.duration | default "43800h0m0s" | quote }} - issuerRef: - name: {{ include "ingress-nginx.fullname" . }}-self-signed-issuer - commonName: "ca.webhook.ingress-nginx" - isCA: true - subject: - organizations: - - ingress-nginx ---- -# Create an Issuer that uses the above generated CA certificate to issue certs -apiVersion: cert-manager.io/v1 -kind: Issuer -metadata: - name: {{ include "ingress-nginx.fullname" . }}-root-issuer - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - ca: - secretName: {{ include "ingress-nginx.fullname" . }}-root-cert -{{- end }} ---- -# generate a server certificate for the apiservices to use -apiVersion: cert-manager.io/v1 -kind: Certificate -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - secretName: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - duration: {{ .Values.controller.admissionWebhooks.certManager.admissionCert.duration | default "8760h0m0s" | quote }} - issuerRef: - {{- if .Values.controller.admissionWebhooks.certManager.issuerRef }} - {{- toYaml .Values.controller.admissionWebhooks.certManager.issuerRef | nindent 4 }} - {{- else }} - name: {{ include "ingress-nginx.fullname" . }}-root-issuer - {{- end }} - dnsNames: - - {{ include "ingress-nginx.controller.fullname" . }}-admission - - {{ include "ingress-nginx.controller.fullname" . }}-admission.{{ include "ingress-nginx.namespace" . }} - - {{ include "ingress-nginx.controller.fullname" . }}-admission.{{ include "ingress-nginx.namespace" . }}.svc - subject: - organizations: - - ingress-nginx-admission -{{- end -}} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml deleted file mode 100644 index a218482..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrole.yaml +++ /dev/null @@ -1,33 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.rbac.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: ClusterRole -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -rules: - - apiGroups: - - admissionregistration.k8s.io - resources: - - validatingwebhookconfigurations - verbs: - - get - - update -{{- if .Values.podSecurityPolicy.enabled }} - - apiGroups: [{{ template "podSecurityPolicy.apiGroup" . }}] - resources: ['podsecuritypolicies'] - verbs: ['use'] - {{- with .Values.controller.admissionWebhooks.existingPsp }} - resourceNames: [{{ . }}] - {{- else }} - resourceNames: [{{ include "ingress-nginx.admissionWebhooks.fullname" . }}] - {{- end }} -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml deleted file mode 100644 index b893884..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/clusterrolebinding.yaml +++ /dev/null @@ -1,23 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.rbac.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: ClusterRoleBinding -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -roleRef: - apiGroup: rbac.authorization.k8s.io - kind: ClusterRole - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} -subjects: - - kind: ServiceAccount - name: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml deleted file mode 100644 index 1766164..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-createSecret.yaml +++ /dev/null @@ -1,79 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled (not .Values.controller.admissionWebhooks.certManager.enabled) -}} -apiVersion: batch/v1 -kind: Job -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.createSecretJob.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - annotations: - "helm.sh/hook": pre-install,pre-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - {{- with .Values.controller.admissionWebhooks.annotations }} - {{- toYaml . | nindent 4 }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -spec: -{{- if .Capabilities.APIVersions.Has "batch/v1alpha1" }} - # Alpha feature since k8s 1.12 - ttlSecondsAfterFinished: 0 -{{- end }} - template: - metadata: - name: {{ include "ingress-nginx.admissionWebhooks.createSecretJob.fullname" . }} - {{- if .Values.controller.admissionWebhooks.patch.podAnnotations }} - annotations: {{ toYaml .Values.controller.admissionWebhooks.patch.podAnnotations | nindent 8 }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 8 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 8 }} - {{- end }} - spec: - {{- if .Values.controller.admissionWebhooks.patch.priorityClassName }} - priorityClassName: {{ .Values.controller.admissionWebhooks.patch.priorityClassName }} - {{- end }} - {{- if .Values.imagePullSecrets }} - imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} - {{- end }} - containers: - - name: create - {{- with .Values.controller.admissionWebhooks.patch.image }} - image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ .image }}{{ end }}:{{ .tag }}{{ if .digest }}@{{ .digest }}{{ end }} - {{- end }} - imagePullPolicy: {{ .Values.controller.admissionWebhooks.patch.image.pullPolicy }} - args: - - create - - --host={{ include "ingress-nginx.controller.fullname" . }}-admission,{{ include "ingress-nginx.controller.fullname" . }}-admission.$(POD_NAMESPACE).svc - - --namespace=$(POD_NAMESPACE) - - --secret-name={{ include "ingress-nginx.admissionWebhooks.fullname" . }} - env: - - name: POD_NAMESPACE - valueFrom: - fieldRef: - fieldPath: metadata.namespace - {{- if .Values.controller.admissionWebhooks.extraEnvs }} - {{- toYaml .Values.controller.admissionWebhooks.extraEnvs | nindent 12 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.createSecretJob.securityContext }} - securityContext: {{ toYaml .Values.controller.admissionWebhooks.createSecretJob.securityContext | nindent 12 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.createSecretJob.resources }} - resources: {{ toYaml .Values.controller.admissionWebhooks.createSecretJob.resources | nindent 12 }} - {{- end }} - restartPolicy: OnFailure - serviceAccountName: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} - {{- if .Values.controller.admissionWebhooks.patch.nodeSelector }} - nodeSelector: {{ toYaml .Values.controller.admissionWebhooks.patch.nodeSelector | nindent 8 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.patch.tolerations }} - tolerations: {{ toYaml .Values.controller.admissionWebhooks.patch.tolerations | nindent 8 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.patch.securityContext }} - securityContext: {{ toYaml .Values.controller.admissionWebhooks.patch.securityContext | nindent 8 }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml deleted file mode 100644 index f7d44a2..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/job-patchWebhook.yaml +++ /dev/null @@ -1,81 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled (not .Values.controller.admissionWebhooks.certManager.enabled) -}} -apiVersion: batch/v1 -kind: Job -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.patchWebhookJob.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - annotations: - "helm.sh/hook": post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - {{- with .Values.controller.admissionWebhooks.annotations }} - {{- toYaml . | nindent 4 }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -spec: -{{- if .Capabilities.APIVersions.Has "batch/v1alpha1" }} - # Alpha feature since k8s 1.12 - ttlSecondsAfterFinished: 0 -{{- end }} - template: - metadata: - name: {{ include "ingress-nginx.admissionWebhooks.patchWebhookJob.fullname" . }} - {{- if .Values.controller.admissionWebhooks.patch.podAnnotations }} - annotations: {{ toYaml .Values.controller.admissionWebhooks.patch.podAnnotations | nindent 8 }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 8 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 8 }} - {{- end }} - spec: - {{- if .Values.controller.admissionWebhooks.patch.priorityClassName }} - priorityClassName: {{ .Values.controller.admissionWebhooks.patch.priorityClassName }} - {{- end }} - {{- if .Values.imagePullSecrets }} - imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} - {{- end }} - containers: - - name: patch - {{- with .Values.controller.admissionWebhooks.patch.image }} - image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ .image }}{{ end }}:{{ .tag }}{{ if .digest }}@{{ .digest }}{{ end }} - {{- end }} - imagePullPolicy: {{ .Values.controller.admissionWebhooks.patch.image.pullPolicy }} - args: - - patch - - --webhook-name={{ include "ingress-nginx.admissionWebhooks.fullname" . }} - - --namespace=$(POD_NAMESPACE) - - --patch-mutating=false - - --secret-name={{ include "ingress-nginx.admissionWebhooks.fullname" . }} - - --patch-failure-policy={{ .Values.controller.admissionWebhooks.failurePolicy }} - env: - - name: POD_NAMESPACE - valueFrom: - fieldRef: - fieldPath: metadata.namespace - {{- if .Values.controller.admissionWebhooks.extraEnvs }} - {{- toYaml .Values.controller.admissionWebhooks.extraEnvs | nindent 12 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.patchWebhookJob.securityContext }} - securityContext: {{ toYaml .Values.controller.admissionWebhooks.patchWebhookJob.securityContext | nindent 12 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.patchWebhookJob.resources }} - resources: {{ toYaml .Values.controller.admissionWebhooks.patchWebhookJob.resources | nindent 12 }} - {{- end }} - restartPolicy: OnFailure - serviceAccountName: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} - {{- if .Values.controller.admissionWebhooks.patch.nodeSelector }} - nodeSelector: {{ toYaml .Values.controller.admissionWebhooks.patch.nodeSelector | nindent 8 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.patch.tolerations }} - tolerations: {{ toYaml .Values.controller.admissionWebhooks.patch.tolerations | nindent 8 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.patch.securityContext }} - securityContext: {{ toYaml .Values.controller.admissionWebhooks.patch.securityContext | nindent 8 }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/networkpolicy.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/networkpolicy.yaml deleted file mode 100644 index a8f38df..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/networkpolicy.yaml +++ /dev/null @@ -1,26 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.networkPolicy.enabled (not .Values.controller.admissionWebhooks.certManager.enabled) -}} -apiVersion: networking.k8s.io/v1 -kind: NetworkPolicy -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -spec: - podSelector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: admission-webhook - policyTypes: - - Ingress - - Egress - egress: - - {} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/psp.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/psp.yaml deleted file mode 100644 index 8e5dc72..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/psp.yaml +++ /dev/null @@ -1,52 +0,0 @@ -{{- if (semverCompare "<1.25.0-0" .Capabilities.KubeVersion.Version) }} -{{- if and .Values.podSecurityPolicy.enabled .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled (empty .Values.controller.admissionWebhooks.existingPsp) -}} -apiVersion: policy/v1beta1 -kind: PodSecurityPolicy -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - seccomp.security.alpha.kubernetes.io/allowedProfileNames: "*" - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -spec: - privileged: false - hostPID: false - hostIPC: false - hostNetwork: false - volumes: - - configMap - - downwardAPI - - emptyDir - - secret - - projected - fsGroup: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - readOnlyRootFilesystem: true - runAsUser: - rule: MustRunAsNonRoot - runAsGroup: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - supplementalGroups: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - allowPrivilegeEscalation: false - requiredDropCapabilities: - - ALL - seLinux: - rule: RunAsAny -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml deleted file mode 100644 index c4b23aa..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/role.yaml +++ /dev/null @@ -1,24 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.rbac.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: Role -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -rules: - - apiGroups: - - "" - resources: - - secrets - verbs: - - get - - create -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml deleted file mode 100644 index 425e8d8..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/rolebinding.yaml +++ /dev/null @@ -1,24 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.rbac.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: RoleBinding -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -roleRef: - apiGroup: rbac.authorization.k8s.io - kind: Role - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} -subjects: - - kind: ServiceAccount - name: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml deleted file mode 100644 index 52f94dc..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/job-patch/serviceaccount.yaml +++ /dev/null @@ -1,17 +0,0 @@ -{{- if and .Values.controller.admissionWebhooks.enabled .Values.controller.admissionWebhooks.patch.enabled .Values.controller.admissionWebhooks.patch.serviceAccount.create (not .Values.controller.admissionWebhooks.certManager.enabled) -}} -apiVersion: v1 -kind: ServiceAccount -metadata: - name: {{ include "ingress-nginx.admissionWebhooks.patch.serviceAccountName" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - annotations: - "helm.sh/hook": pre-install,pre-upgrade,post-install,post-upgrade - "helm.sh/hook-delete-policy": before-hook-creation,hook-succeeded - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.patch.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -automountServiceAccountToken: {{ .Values.controller.admissionWebhooks.patch.serviceAccount.automountServiceAccountToken }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml b/charts/keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml deleted file mode 100644 index 0949cea..0000000 --- a/charts/keep/charts/ingress-nginx/templates/admission-webhooks/validating-webhook.yaml +++ /dev/null @@ -1,54 +0,0 @@ -{{- if .Values.controller.admissionWebhooks.enabled -}} -# before changing this value, check the required kubernetes version -# https://kubernetes.io/docs/reference/access-authn-authz/extensible-admission-controllers/#prerequisites -apiVersion: admissionregistration.k8s.io/v1 -kind: ValidatingWebhookConfiguration -metadata: - annotations: - {{- if .Values.controller.admissionWebhooks.certManager.enabled }} - certmanager.k8s.io/inject-ca-from: {{ printf "%s/%s" (include "ingress-nginx.namespace" .) (include "ingress-nginx.admissionWebhooks.fullname" .) | quote }} - cert-manager.io/inject-ca-from: {{ printf "%s/%s" (include "ingress-nginx.namespace" .) (include "ingress-nginx.admissionWebhooks.fullname" .) | quote }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.annotations }} - {{- toYaml .Values.controller.admissionWebhooks.annotations | nindent 4 }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: admission-webhook - {{- with .Values.controller.admissionWebhooks.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} -webhooks: - - name: validate.nginx.ingress.kubernetes.io - matchPolicy: Equivalent - rules: - - apiGroups: - - networking.k8s.io - apiVersions: - - v1 - operations: - - CREATE - - UPDATE - resources: - - ingresses - failurePolicy: {{ .Values.controller.admissionWebhooks.failurePolicy | default "Fail" }} - sideEffects: None - admissionReviewVersions: - - v1 - clientConfig: - service: - name: {{ include "ingress-nginx.controller.fullname" . }}-admission - namespace: {{ include "ingress-nginx.namespace" . }} - port: {{ .Values.controller.admissionWebhooks.service.servicePort }} - path: /networking/v1/ingresses - {{- if .Values.controller.admissionWebhooks.timeoutSeconds }} - timeoutSeconds: {{ .Values.controller.admissionWebhooks.timeoutSeconds }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.namespaceSelector }} - namespaceSelector: {{ toYaml .Values.controller.admissionWebhooks.namespaceSelector | nindent 6 }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.objectSelector }} - objectSelector: {{ toYaml .Values.controller.admissionWebhooks.objectSelector | nindent 6 }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/clusterrole.yaml b/charts/keep/charts/ingress-nginx/templates/clusterrole.yaml deleted file mode 100644 index 51bc500..0000000 --- a/charts/keep/charts/ingress-nginx/templates/clusterrole.yaml +++ /dev/null @@ -1,102 +0,0 @@ -{{- if .Values.rbac.create }} - -{{- if and .Values.rbac.scope (not .Values.controller.scope.enabled) -}} - {{ required "Invalid configuration: 'rbac.scope' should be equal to 'controller.scope.enabled' (true/false)." (index (dict) ".") }} -{{- end }} - -{{- if not .Values.rbac.scope -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: ClusterRole -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.fullname" . }} -rules: - - apiGroups: - - "" - resources: - - configmaps - - endpoints - - nodes - - pods - - secrets -{{- if not .Values.controller.scope.enabled }} - - namespaces -{{- end}} - verbs: - - list - - watch - - apiGroups: - - coordination.k8s.io - resources: - - leases - verbs: - - list - - watch -{{- if and .Values.controller.scope.enabled .Values.controller.scope.namespace }} - - apiGroups: - - "" - resources: - - namespaces - resourceNames: - - "{{ .Values.controller.scope.namespace }}" - verbs: - - get -{{- end }} - - apiGroups: - - "" - resources: - - nodes - verbs: - - get - - apiGroups: - - "" - resources: - - services - verbs: - - get - - list - - watch - - apiGroups: - - networking.k8s.io - resources: - - ingresses - verbs: - - get - - list - - watch - - apiGroups: - - "" - resources: - - events - verbs: - - create - - patch - - apiGroups: - - networking.k8s.io - resources: - - ingresses/status - verbs: - - update - - apiGroups: - - networking.k8s.io - resources: - - ingressclasses - verbs: - - get - - list - - watch - - apiGroups: - - discovery.k8s.io - resources: - - endpointslices - verbs: - - list - - watch - - get -{{- end }} - -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/clusterrolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/clusterrolebinding.yaml deleted file mode 100644 index 8f91aac..0000000 --- a/charts/keep/charts/ingress-nginx/templates/clusterrolebinding.yaml +++ /dev/null @@ -1,19 +0,0 @@ -{{- if and .Values.rbac.create (not .Values.rbac.scope) -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: ClusterRoleBinding -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.fullname" . }} -roleRef: - apiGroup: rbac.authorization.k8s.io - kind: ClusterRole - name: {{ include "ingress-nginx.fullname" . }} -subjects: - - kind: ServiceAccount - name: {{ template "ingress-nginx.serviceAccountName" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap-addheaders.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap-addheaders.yaml deleted file mode 100644 index 4e4bd13..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-configmap-addheaders.yaml +++ /dev/null @@ -1,14 +0,0 @@ -{{- if .Values.controller.addHeaders -}} -apiVersion: v1 -kind: ConfigMap -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.fullname" . }}-custom-add-headers - namespace: {{ include "ingress-nginx.namespace" . }} -data: {{ toYaml .Values.controller.addHeaders | nindent 2 }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap-proxyheaders.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap-proxyheaders.yaml deleted file mode 100644 index 0a22600..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-configmap-proxyheaders.yaml +++ /dev/null @@ -1,14 +0,0 @@ -{{- if .Values.controller.proxySetHeaders -}} -apiVersion: v1 -kind: ConfigMap -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.fullname" . }}-custom-proxy-headers - namespace: {{ include "ingress-nginx.namespace" . }} -data: {{ toYaml .Values.controller.proxySetHeaders | nindent 2 }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap-tcp.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap-tcp.yaml deleted file mode 100644 index 131a9ad..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-configmap-tcp.yaml +++ /dev/null @@ -1,17 +0,0 @@ -{{- if .Values.tcp -}} -apiVersion: v1 -kind: ConfigMap -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -{{- if .Values.controller.tcp.annotations }} - annotations: {{ toYaml .Values.controller.tcp.annotations | nindent 4 }} -{{- end }} - name: {{ include "ingress-nginx.fullname" . }}-tcp - namespace: {{ include "ingress-nginx.namespace" . }} -data: {{ tpl (toYaml .Values.tcp) . | nindent 2 }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap-udp.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap-udp.yaml deleted file mode 100644 index 7137da9..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-configmap-udp.yaml +++ /dev/null @@ -1,17 +0,0 @@ -{{- if .Values.udp -}} -apiVersion: v1 -kind: ConfigMap -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -{{- if .Values.controller.udp.annotations }} - annotations: {{ toYaml .Values.controller.udp.annotations | nindent 4 }} -{{- end }} - name: {{ include "ingress-nginx.fullname" . }}-udp - namespace: {{ include "ingress-nginx.namespace" . }} -data: {{ tpl (toYaml .Values.udp) . | nindent 2 }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-configmap.yaml b/charts/keep/charts/ingress-nginx/templates/controller-configmap.yaml deleted file mode 100644 index 22080d1..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-configmap.yaml +++ /dev/null @@ -1,28 +0,0 @@ -apiVersion: v1 -kind: ConfigMap -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -{{- if .Values.controller.configAnnotations }} - annotations: {{ toYaml .Values.controller.configAnnotations | nindent 4 }} -{{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -data: - allow-snippet-annotations: "{{ .Values.controller.allowSnippetAnnotations }}" -{{- if .Values.controller.addHeaders }} - add-headers: {{ include "ingress-nginx.namespace" . }}/{{ include "ingress-nginx.fullname" . }}-custom-add-headers -{{- end }} -{{- if .Values.controller.proxySetHeaders }} - proxy-set-headers: {{ include "ingress-nginx.namespace" . }}/{{ include "ingress-nginx.fullname" . }}-custom-proxy-headers -{{- end }} -{{- if .Values.dhParam }} - ssl-dh-param: {{ include "ingress-nginx.namespace" . }}/{{ include "ingress-nginx.controller.fullname" . }} -{{- end }} -{{- range $key, $value := .Values.controller.config }} - {{- $key | nindent 2 }}: {{ tpl (toString $value) $ | quote }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-daemonset.yaml b/charts/keep/charts/ingress-nginx/templates/controller-daemonset.yaml deleted file mode 100644 index fcc633d..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-daemonset.yaml +++ /dev/null @@ -1,242 +0,0 @@ -{{- if eq .Values.controller.kind "DaemonSet" -}} -apiVersion: apps/v1 -kind: DaemonSet -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - {{- if .Values.controller.annotations }} - annotations: {{ toYaml .Values.controller.annotations | nindent 4 }} - {{- end }} -spec: - selector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: controller - revisionHistoryLimit: {{ .Values.revisionHistoryLimit }} - {{- if .Values.controller.updateStrategy }} - updateStrategy: {{ toYaml .Values.controller.updateStrategy | nindent 4 }} - {{- end }} - minReadySeconds: {{ .Values.controller.minReadySeconds }} - template: - metadata: - {{- if .Values.controller.podAnnotations }} - annotations: - {{- range $key, $value := .Values.controller.podAnnotations }} - {{ $key }}: {{ $value | quote }} - {{- end }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 8 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 8 }} - {{- end }} - {{- if .Values.controller.podLabels }} - {{- toYaml .Values.controller.podLabels | nindent 8 }} - {{- end }} - spec: - {{- if .Values.controller.dnsConfig }} - dnsConfig: {{ toYaml .Values.controller.dnsConfig | nindent 8 }} - {{- end }} - {{- if .Values.controller.hostAliases }} - hostAliases: {{ tpl (toYaml .Values.controller.hostAliases) $ | nindent 8 }} - {{- end }} - {{- if .Values.controller.hostname }} - hostname: {{ toYaml .Values.controller.hostname | nindent 8 }} - {{- end }} - dnsPolicy: {{ .Values.controller.dnsPolicy }} - {{- if .Values.imagePullSecrets }} - imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} - {{- end }} - {{- if .Values.controller.priorityClassName }} - priorityClassName: {{ .Values.controller.priorityClassName | quote }} - {{- end }} - {{- if or .Values.controller.podSecurityContext .Values.controller.sysctls }} - securityContext: - {{- if .Values.controller.podSecurityContext }} - {{- toYaml .Values.controller.podSecurityContext | nindent 8 }} - {{- end }} - {{- if .Values.controller.sysctls }} - sysctls: - {{- range $sysctl, $value := .Values.controller.sysctls }} - - name: {{ $sysctl | quote }} - value: {{ $value | quote }} - {{- end }} - {{- end }} - {{- end }} - {{- if .Values.controller.shareProcessNamespace }} - shareProcessNamespace: {{ .Values.controller.shareProcessNamespace }} - {{- end }} - containers: - - name: {{ .Values.controller.containerName }} - {{- with .Values.controller.image }} - image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ include "ingress-nginx.image" . }}{{ end }}:{{ .tag }}{{ include "ingress-nginx.imageDigest" . }} - {{- end }} - imagePullPolicy: {{ .Values.controller.image.pullPolicy }} - {{- if .Values.controller.lifecycle }} - lifecycle: {{ toYaml .Values.controller.lifecycle | nindent 12 }} - {{- end }} - args: {{ include "ingress-nginx.params" . | nindent 12 }} - securityContext: {{ include "ingress-nginx.controller.containerSecurityContext" . | nindent 12 }} - env: - - name: POD_NAME - valueFrom: - fieldRef: - fieldPath: metadata.name - - name: POD_NAMESPACE - valueFrom: - fieldRef: - fieldPath: metadata.namespace - {{- if .Values.controller.enableMimalloc }} - - name: LD_PRELOAD - value: /usr/local/lib/libmimalloc.so - {{- end }} - {{- if .Values.controller.extraEnvs }} - {{- toYaml .Values.controller.extraEnvs | nindent 12 }} - {{- end }} - {{- if .Values.controller.startupProbe }} - startupProbe: {{ toYaml .Values.controller.startupProbe | nindent 12 }} - {{- end }} - {{- if .Values.controller.livenessProbe }} - livenessProbe: {{ toYaml .Values.controller.livenessProbe | nindent 12 }} - {{- end }} - {{- if .Values.controller.readinessProbe }} - readinessProbe: {{ toYaml .Values.controller.readinessProbe | nindent 12 }} - {{- end }} - ports: - {{- range $key, $value := .Values.controller.containerPort }} - - name: {{ $key }} - containerPort: {{ $value }} - protocol: TCP - {{- if $.Values.controller.hostPort.enabled }} - hostPort: {{ index $.Values.controller.hostPort.ports $key | default $value }} - {{- end }} - {{- end }} - {{- if .Values.controller.metrics.enabled }} - - name: {{ .Values.controller.metrics.portName }} - containerPort: {{ .Values.controller.metrics.port }} - protocol: TCP - {{- end }} - {{- if .Values.controller.admissionWebhooks.enabled }} - - name: webhook - containerPort: {{ .Values.controller.admissionWebhooks.port }} - protocol: TCP - {{- end }} - {{- range $key, $value := .Values.tcp }} - - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp - containerPort: {{ $key }} - protocol: TCP - {{- if $.Values.controller.hostPort.enabled }} - hostPort: {{ $key }} - {{- end }} - {{- end }} - {{- range $key, $value := .Values.udp }} - - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp - containerPort: {{ $key }} - protocol: UDP - {{- if $.Values.controller.hostPort.enabled }} - hostPort: {{ $key }} - {{- end }} - {{- end }} - {{- if (or .Values.controller.customTemplate.configMapName .Values.controller.extraVolumeMounts .Values.controller.admissionWebhooks.enabled .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} - volumeMounts: - {{- if (or .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} - - name: modules - {{- if .Values.controller.image.chroot }} - mountPath: /chroot/modules_mount - {{- else }} - mountPath: /modules_mount - {{- end }} - {{- end }} - {{- if .Values.controller.customTemplate.configMapName }} - - mountPath: /etc/nginx/template - name: nginx-template-volume - readOnly: true - {{- end }} - {{- if .Values.controller.admissionWebhooks.enabled }} - - name: webhook-cert - mountPath: /usr/local/certificates/ - readOnly: true - {{- end }} - {{- if .Values.controller.extraVolumeMounts }} - {{- toYaml .Values.controller.extraVolumeMounts | nindent 12 }} - {{- end }} - {{- end }} - {{- if .Values.controller.resources }} - resources: {{ toYaml .Values.controller.resources | nindent 12 }} - {{- end }} - {{- if .Values.controller.extraContainers }} - {{- toYaml .Values.controller.extraContainers | nindent 8 }} - {{- end }} - {{- if (or .Values.controller.extraInitContainers .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} - initContainers: - {{- if .Values.controller.extraInitContainers }} - {{- toYaml .Values.controller.extraInitContainers | nindent 8 }} - {{- end }} - {{- if .Values.controller.extraModules }} - {{- range .Values.controller.extraModules }} - {{- $containerSecurityContext := .containerSecurityContext | default $.Values.controller.containerSecurityContext }} - {{- include "extraModules" (dict "name" .name "image" .image "containerSecurityContext" $containerSecurityContext "resources" .resources) | nindent 8 }} - {{- end }} - {{- end }} - {{- if .Values.controller.opentelemetry.enabled }} - {{- with .Values.controller.opentelemetry }} - {{- $containerSecurityContext := .containerSecurityContext | default $.Values.controller.containerSecurityContext }} - {{- include "extraModules" (dict "name" .name "image" .image "containerSecurityContext" $containerSecurityContext "resources" .resources) | nindent 8 }} - {{- end }} - {{- end }} - {{- end }} - {{- if .Values.controller.hostNetwork }} - hostNetwork: {{ .Values.controller.hostNetwork }} - {{- end }} - {{- if .Values.controller.nodeSelector }} - nodeSelector: {{ toYaml .Values.controller.nodeSelector | nindent 8 }} - {{- end }} - {{- if .Values.controller.tolerations }} - tolerations: {{ toYaml .Values.controller.tolerations | nindent 8 }} - {{- end }} - {{- if .Values.controller.affinity }} - affinity: {{ tpl (toYaml .Values.controller.affinity) $ | nindent 8 }} - {{- end }} - {{- if .Values.controller.topologySpreadConstraints }} - topologySpreadConstraints: {{ tpl (toYaml .Values.controller.topologySpreadConstraints) $ | nindent 8 }} - {{- end }} - serviceAccountName: {{ template "ingress-nginx.serviceAccountName" . }} - terminationGracePeriodSeconds: {{ .Values.controller.terminationGracePeriodSeconds }} - {{- if (or .Values.controller.customTemplate.configMapName .Values.controller.extraVolumeMounts .Values.controller.admissionWebhooks.enabled .Values.controller.extraVolumes .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} - volumes: - {{- if (or .Values.controller.extraModules .Values.controller.opentelemetry.enabled)}} - - name: modules - emptyDir: {} - {{- end }} - {{- if .Values.controller.customTemplate.configMapName }} - - name: nginx-template-volume - configMap: - name: {{ .Values.controller.customTemplate.configMapName }} - items: - - key: {{ .Values.controller.customTemplate.configMapKey }} - path: nginx.tmpl - {{- end }} - {{- if .Values.controller.admissionWebhooks.enabled }} - - name: webhook-cert - secret: - secretName: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - {{- if .Values.controller.admissionWebhooks.certManager.enabled }} - items: - - key: tls.crt - path: cert - - key: tls.key - path: key - {{- end }} - {{- end }} - {{- if .Values.controller.extraVolumes }} - {{ toYaml .Values.controller.extraVolumes | nindent 8 }} - {{- end }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-deployment.yaml b/charts/keep/charts/ingress-nginx/templates/controller-deployment.yaml deleted file mode 100644 index 5211acd..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-deployment.yaml +++ /dev/null @@ -1,245 +0,0 @@ -{{- if eq .Values.controller.kind "Deployment" -}} -apiVersion: apps/v1 -kind: Deployment -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - {{- if .Values.controller.annotations }} - annotations: {{ toYaml .Values.controller.annotations | nindent 4 }} - {{- end }} -spec: - selector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: controller - {{- if eq .Values.controller.autoscaling.enabled .Values.controller.keda.enabled }} - replicas: {{ .Values.controller.replicaCount }} - {{- end }} - revisionHistoryLimit: {{ .Values.revisionHistoryLimit }} - {{- if .Values.controller.updateStrategy }} - strategy: {{ toYaml .Values.controller.updateStrategy | nindent 4 }} - {{- end }} - minReadySeconds: {{ .Values.controller.minReadySeconds }} - template: - metadata: - {{- if .Values.controller.podAnnotations }} - annotations: - {{- range $key, $value := .Values.controller.podAnnotations }} - {{ $key }}: {{ $value | quote }} - {{- end }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 8 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 8 }} - {{- end }} - {{- if .Values.controller.podLabels }} - {{- toYaml .Values.controller.podLabels | nindent 8 }} - {{- end }} - spec: - {{- if .Values.controller.dnsConfig }} - dnsConfig: {{ toYaml .Values.controller.dnsConfig | nindent 8 }} - {{- end }} - {{- if .Values.controller.hostAliases }} - hostAliases: {{ tpl (toYaml .Values.controller.hostAliases) $ | nindent 8 }} - {{- end }} - {{- if .Values.controller.hostname }} - hostname: {{ toYaml .Values.controller.hostname | nindent 8 }} - {{- end }} - dnsPolicy: {{ .Values.controller.dnsPolicy }} - {{- if .Values.imagePullSecrets }} - imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} - {{- end }} - {{- if .Values.controller.priorityClassName }} - priorityClassName: {{ .Values.controller.priorityClassName | quote }} - {{- end }} - {{- if or .Values.controller.podSecurityContext .Values.controller.sysctls }} - securityContext: - {{- if .Values.controller.podSecurityContext }} - {{- toYaml .Values.controller.podSecurityContext | nindent 8 }} - {{- end }} - {{- if .Values.controller.sysctls }} - sysctls: - {{- range $sysctl, $value := .Values.controller.sysctls }} - - name: {{ $sysctl | quote }} - value: {{ $value | quote }} - {{- end }} - {{- end }} - {{- end }} - {{- if .Values.controller.shareProcessNamespace }} - shareProcessNamespace: {{ .Values.controller.shareProcessNamespace }} - {{- end }} - containers: - - name: {{ .Values.controller.containerName }} - {{- with .Values.controller.image }} - image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ include "ingress-nginx.image" . }}{{ end }}:{{ .tag }}{{ include "ingress-nginx.imageDigest" . }} - {{- end }} - imagePullPolicy: {{ .Values.controller.image.pullPolicy }} - {{- if .Values.controller.lifecycle }} - lifecycle: {{ toYaml .Values.controller.lifecycle | nindent 12 }} - {{- end }} - args: {{ include "ingress-nginx.params" . | nindent 12 }} - securityContext: {{ include "ingress-nginx.controller.containerSecurityContext" . | nindent 12 }} - env: - - name: POD_NAME - valueFrom: - fieldRef: - fieldPath: metadata.name - - name: POD_NAMESPACE - valueFrom: - fieldRef: - fieldPath: metadata.namespace - {{- if .Values.controller.enableMimalloc }} - - name: LD_PRELOAD - value: /usr/local/lib/libmimalloc.so - {{- end }} - {{- if .Values.controller.extraEnvs }} - {{- toYaml .Values.controller.extraEnvs | nindent 12 }} - {{- end }} - {{- if .Values.controller.startupProbe }} - startupProbe: {{ toYaml .Values.controller.startupProbe | nindent 12 }} - {{- end }} - {{- if .Values.controller.livenessProbe }} - livenessProbe: {{ toYaml .Values.controller.livenessProbe | nindent 12 }} - {{- end }} - {{- if .Values.controller.readinessProbe }} - readinessProbe: {{ toYaml .Values.controller.readinessProbe | nindent 12 }} - {{- end }} - ports: - {{- range $key, $value := .Values.controller.containerPort }} - - name: {{ $key }} - containerPort: {{ $value }} - protocol: TCP - {{- if $.Values.controller.hostPort.enabled }} - hostPort: {{ index $.Values.controller.hostPort.ports $key | default $value }} - {{- end }} - {{- end }} - {{- if .Values.controller.metrics.enabled }} - - name: {{ .Values.controller.metrics.portName }} - containerPort: {{ .Values.controller.metrics.port }} - protocol: TCP - {{- end }} - {{- if .Values.controller.admissionWebhooks.enabled }} - - name: webhook - containerPort: {{ .Values.controller.admissionWebhooks.port }} - protocol: TCP - {{- end }} - {{- range $key, $value := .Values.tcp }} - - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp - containerPort: {{ $key }} - protocol: TCP - {{- if $.Values.controller.hostPort.enabled }} - hostPort: {{ $key }} - {{- end }} - {{- end }} - {{- range $key, $value := .Values.udp }} - - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp - containerPort: {{ $key }} - protocol: UDP - {{- if $.Values.controller.hostPort.enabled }} - hostPort: {{ $key }} - {{- end }} - {{- end }} - {{- if (or .Values.controller.customTemplate.configMapName .Values.controller.extraVolumeMounts .Values.controller.admissionWebhooks.enabled .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} - volumeMounts: - {{- if (or .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} - - name: modules - {{- if .Values.controller.image.chroot }} - mountPath: /chroot/modules_mount - {{- else }} - mountPath: /modules_mount - {{- end }} - {{- end }} - {{- if .Values.controller.customTemplate.configMapName }} - - mountPath: /etc/nginx/template - name: nginx-template-volume - readOnly: true - {{- end }} - {{- if .Values.controller.admissionWebhooks.enabled }} - - name: webhook-cert - mountPath: /usr/local/certificates/ - readOnly: true - {{- end }} - {{- if .Values.controller.extraVolumeMounts }} - {{- toYaml .Values.controller.extraVolumeMounts | nindent 12 }} - {{- end }} - {{- end }} - {{- if .Values.controller.resources }} - resources: {{ toYaml .Values.controller.resources | nindent 12 }} - {{- end }} - {{- if .Values.controller.extraContainers }} - {{- toYaml .Values.controller.extraContainers | nindent 8 }} - {{- end }} - {{- if (or .Values.controller.extraInitContainers .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} - initContainers: - {{- if .Values.controller.extraInitContainers }} - {{- toYaml .Values.controller.extraInitContainers | nindent 8 }} - {{- end }} - {{- if .Values.controller.extraModules }} - {{- range .Values.controller.extraModules }} - {{- $containerSecurityContext := .containerSecurityContext | default $.Values.controller.containerSecurityContext }} - {{- include "extraModules" (dict "name" .name "image" .image "containerSecurityContext" $containerSecurityContext "resources" .resources) | nindent 8 }} - {{- end }} - {{- end }} - {{- if .Values.controller.opentelemetry.enabled }} - {{- with .Values.controller.opentelemetry }} - {{- $containerSecurityContext := .containerSecurityContext | default $.Values.controller.containerSecurityContext }} - {{- include "extraModules" (dict "name" .name "image" .image "containerSecurityContext" $containerSecurityContext "resources" .resources) | nindent 8 }} - {{- end }} - {{- end }} - {{- end }} - {{- if .Values.controller.hostNetwork }} - hostNetwork: {{ .Values.controller.hostNetwork }} - {{- end }} - {{- if .Values.controller.nodeSelector }} - nodeSelector: {{ toYaml .Values.controller.nodeSelector | nindent 8 }} - {{- end }} - {{- if .Values.controller.tolerations }} - tolerations: {{ toYaml .Values.controller.tolerations | nindent 8 }} - {{- end }} - {{- if .Values.controller.affinity }} - affinity: {{ tpl (toYaml .Values.controller.affinity) $ | nindent 8 }} - {{- end }} - {{- if .Values.controller.topologySpreadConstraints }} - topologySpreadConstraints: {{ tpl (toYaml .Values.controller.topologySpreadConstraints) $ | nindent 8 }} - {{- end }} - serviceAccountName: {{ template "ingress-nginx.serviceAccountName" . }} - terminationGracePeriodSeconds: {{ .Values.controller.terminationGracePeriodSeconds }} - {{- if (or .Values.controller.customTemplate.configMapName .Values.controller.extraVolumeMounts .Values.controller.admissionWebhooks.enabled .Values.controller.extraVolumes .Values.controller.extraModules .Values.controller.opentelemetry.enabled) }} - volumes: - {{- if (or .Values.controller.extraModules .Values.controller.opentelemetry.enabled)}} - - name: modules - emptyDir: {} - {{- end }} - {{- if .Values.controller.customTemplate.configMapName }} - - name: nginx-template-volume - configMap: - name: {{ .Values.controller.customTemplate.configMapName }} - items: - - key: {{ .Values.controller.customTemplate.configMapKey }} - path: nginx.tmpl - {{- end }} - {{- if .Values.controller.admissionWebhooks.enabled }} - - name: webhook-cert - secret: - secretName: {{ include "ingress-nginx.admissionWebhooks.fullname" . }} - {{- if .Values.controller.admissionWebhooks.certManager.enabled }} - items: - - key: tls.crt - path: cert - - key: tls.key - path: key - {{- end }} - {{- end }} - {{- if .Values.controller.extraVolumes }} - {{ toYaml .Values.controller.extraVolumes | nindent 8 }} - {{- end }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-hpa.yaml b/charts/keep/charts/ingress-nginx/templates/controller-hpa.yaml deleted file mode 100644 index ec9ad73..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-hpa.yaml +++ /dev/null @@ -1,47 +0,0 @@ -{{- if and (eq .Values.controller.kind "Deployment") .Values.controller.autoscaling.enabled (not .Values.controller.keda.enabled) -}} -apiVersion: {{ ternary "autoscaling/v2" "autoscaling/v2beta2" (.Capabilities.APIVersions.Has "autoscaling/v2") }} -kind: HorizontalPodAutoscaler -metadata: - {{- with .Values.controller.autoscaling.annotations }} - annotations: {{ toYaml . | nindent 4 }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - scaleTargetRef: - apiVersion: apps/v1 - kind: Deployment - name: {{ include "ingress-nginx.controller.fullname" . }} - minReplicas: {{ .Values.controller.autoscaling.minReplicas }} - maxReplicas: {{ .Values.controller.autoscaling.maxReplicas }} - metrics: - {{- with .Values.controller.autoscaling.targetMemoryUtilizationPercentage }} - - type: Resource - resource: - name: memory - target: - type: Utilization - averageUtilization: {{ . }} - {{- end }} - {{- with .Values.controller.autoscaling.targetCPUUtilizationPercentage }} - - type: Resource - resource: - name: cpu - target: - type: Utilization - averageUtilization: {{ . }} - {{- end }} - {{- with .Values.controller.autoscalingTemplate }} - {{- toYaml . | nindent 2 }} - {{- end }} - {{- with .Values.controller.autoscaling.behavior }} - behavior: - {{- toYaml . | nindent 4 }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-ingressclass-aliases.yaml b/charts/keep/charts/ingress-nginx/templates/controller-ingressclass-aliases.yaml deleted file mode 100644 index ffe2231..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-ingressclass-aliases.yaml +++ /dev/null @@ -1,23 +0,0 @@ -{{- if .Values.controller.ingressClassResource.enabled -}} -{{- range .Values.controller.ingressClassResource.aliases }} ---- -apiVersion: networking.k8s.io/v1 -kind: IngressClass -metadata: - labels: - {{- include "ingress-nginx.labels" $ | nindent 4 }} - app.kubernetes.io/component: controller - {{- with $.Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ . }} - {{- if $.Values.controller.ingressClassResource.annotations }} - annotations: {{ toYaml $.Values.controller.ingressClassResource.annotations | nindent 4 }} - {{- end }} -spec: - controller: {{ $.Values.controller.ingressClassResource.controllerValue }} - {{- with $.Values.controller.ingressClassResource.parameters }} - parameters: {{ toYaml . | nindent 4 }} - {{- end }} -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-ingressclass.yaml b/charts/keep/charts/ingress-nginx/templates/controller-ingressclass.yaml deleted file mode 100644 index 98479a5..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-ingressclass.yaml +++ /dev/null @@ -1,26 +0,0 @@ -{{- if .Values.controller.ingressClassResource.enabled -}} -apiVersion: networking.k8s.io/v1 -kind: IngressClass -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ .Values.controller.ingressClassResource.name }} - {{- if or .Values.controller.ingressClassResource.default .Values.controller.ingressClassResource.annotations }} - annotations: - {{- if .Values.controller.ingressClassResource.default }} - ingressclass.kubernetes.io/is-default-class: "true" - {{- end }} - {{- if .Values.controller.ingressClassResource.annotations }} - {{- toYaml .Values.controller.ingressClassResource.annotations | nindent 4 }} - {{- end }} - {{- end }} -spec: - controller: {{ .Values.controller.ingressClassResource.controllerValue }} - {{- with .Values.controller.ingressClassResource.parameters }} - parameters: {{ toYaml . | nindent 4 }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-keda.yaml b/charts/keep/charts/ingress-nginx/templates/controller-keda.yaml deleted file mode 100644 index 24d30fa..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-keda.yaml +++ /dev/null @@ -1,46 +0,0 @@ -{{- if and (eq .Values.controller.kind "Deployment") .Values.controller.keda.enabled (not .Values.controller.autoscaling.enabled) -}} -apiVersion: {{ .Values.controller.keda.apiVersion }} -kind: ScaledObject -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - {{- if .Values.controller.keda.scaledObject.annotations }} - annotations: {{ toYaml .Values.controller.keda.scaledObject.annotations | nindent 4 }} - {{- end }} -spec: - scaleTargetRef: -{{- if eq .Values.controller.keda.apiVersion "keda.k8s.io/v1alpha1" }} - deploymentName: {{ include "ingress-nginx.controller.fullname" . }} -{{- else if eq .Values.controller.keda.apiVersion "keda.sh/v1alpha1" }} - name: {{ include "ingress-nginx.controller.fullname" . }} -{{- end }} - pollingInterval: {{ .Values.controller.keda.pollingInterval }} - cooldownPeriod: {{ .Values.controller.keda.cooldownPeriod }} - minReplicaCount: {{ .Values.controller.keda.minReplicas }} - maxReplicaCount: {{ .Values.controller.keda.maxReplicas }} -{{- with .Values.controller.keda.fallback }} - fallback: - failureThreshold: {{ .failureThreshold | default 3 }} - replicas: {{ .replicas | default $.Values.controller.keda.maxReplicas }} -{{- end }} - triggers: -{{- with .Values.controller.keda.triggers }} -{{ toYaml . | indent 2 }} -{{ end }} - advanced: - restoreToOriginalReplicaCount: {{ .Values.controller.keda.restoreToOriginalReplicaCount }} -{{- if .Values.controller.keda.behavior }} - horizontalPodAutoscalerConfig: - behavior: -{{ with .Values.controller.keda.behavior -}} -{{ toYaml . | indent 8 }} -{{ end }} - -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-networkpolicy.yaml b/charts/keep/charts/ingress-nginx/templates/controller-networkpolicy.yaml deleted file mode 100644 index e68f991..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-networkpolicy.yaml +++ /dev/null @@ -1,45 +0,0 @@ -{{- if .Values.controller.networkPolicy.enabled }} -apiVersion: networking.k8s.io/v1 -kind: NetworkPolicy -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - podSelector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: controller - policyTypes: - - Ingress - - Egress - ingress: - - ports: - {{- range $key, $value := .Values.controller.containerPort }} - - protocol: TCP - port: {{ $value }} - {{- end }} - {{- if .Values.controller.metrics.enabled }} - - protocol: TCP - port: {{ .Values.controller.metrics.port }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.enabled }} - - protocol: TCP - port: {{ .Values.controller.admissionWebhooks.port }} - {{- end }} - {{- range $key, $value := .Values.tcp }} - - protocol: TCP - port: {{ $key }} - {{- end }} - {{- range $key, $value := .Values.udp }} - - protocol: UDP - port: {{ $key }} - {{- end }} - egress: - - {} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml b/charts/keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml deleted file mode 100644 index 8e0181f..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-poddisruptionbudget.yaml +++ /dev/null @@ -1,36 +0,0 @@ -# PDB is not supported for DaemonSets. -# https://github.com/kubernetes/kubernetes/issues/108124 -{{- if eq .Values.controller.kind "Deployment" }} -{{- $replicas := .Values.controller.replicaCount }} -{{- if and .Values.controller.autoscaling.enabled (not .Values.controller.keda.enabled) }} -{{- $replicas = .Values.controller.autoscaling.minReplicas }} -{{- else if and .Values.controller.keda.enabled (not .Values.controller.autoscaling.enabled) }} -{{- $replicas = .Values.controller.keda.minReplicas }} -{{- end }} -{{- if gt ($replicas | int) 1 }} -apiVersion: {{ ternary "policy/v1" "policy/v1beta1" (semverCompare ">=1.21.0-0" .Capabilities.KubeVersion.Version) }} -kind: PodDisruptionBudget -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - {{- if .Values.controller.annotations }} - annotations: {{ toYaml .Values.controller.annotations | nindent 4 }} - {{- end }} -spec: - selector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: controller - {{- if and .Values.controller.minAvailable (not (hasKey .Values.controller "maxUnavailable")) }} - minAvailable: {{ .Values.controller.minAvailable }} - {{- else if .Values.controller.maxUnavailable }} - maxUnavailable: {{ .Values.controller.maxUnavailable }} - {{- end }} -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-prometheusrule.yaml b/charts/keep/charts/ingress-nginx/templates/controller-prometheusrule.yaml deleted file mode 100644 index 41684c3..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-prometheusrule.yaml +++ /dev/null @@ -1,23 +0,0 @@ -{{- if and .Values.controller.metrics.enabled .Values.controller.metrics.prometheusRule.enabled -}} -apiVersion: monitoring.coreos.com/v1 -kind: PrometheusRule -metadata: - name: {{ include "ingress-nginx.controller.fullname" . }} -{{- if .Values.controller.metrics.prometheusRule.namespace }} - namespace: {{ .Values.controller.metrics.prometheusRule.namespace }} -{{- else }} - namespace: {{ include "ingress-nginx.namespace" . }} -{{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- if .Values.controller.metrics.prometheusRule.additionalLabels }} - {{- toYaml .Values.controller.metrics.prometheusRule.additionalLabels | nindent 4 }} - {{- end }} -spec: -{{- if .Values.controller.metrics.prometheusRule.rules }} - groups: - - name: {{ template "ingress-nginx.name" . }} - rules: {{- toYaml .Values.controller.metrics.prometheusRule.rules | nindent 4 }} -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-psp.yaml b/charts/keep/charts/ingress-nginx/templates/controller-psp.yaml deleted file mode 100644 index aad1d27..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-psp.yaml +++ /dev/null @@ -1,100 +0,0 @@ -{{- if (semverCompare "<1.25.0-0" .Capabilities.KubeVersion.Version) }} -{{- if and .Values.podSecurityPolicy.enabled (empty .Values.controller.existingPsp) -}} -apiVersion: policy/v1beta1 -kind: PodSecurityPolicy -metadata: - name: {{ include "ingress-nginx.fullname" . }} - annotations: - seccomp.security.alpha.kubernetes.io/allowedProfileNames: "*" - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -spec: - privileged: false - hostPID: false - hostIPC: false - hostNetwork: {{ .Values.controller.hostNetwork }} -{{- if or .Values.controller.hostNetwork .Values.controller.hostPort.enabled }} - hostPorts: - {{- if .Values.controller.hostNetwork }} - {{- range $key, $value := .Values.controller.containerPort }} - # controller.containerPort.{{ $key }} - - min: {{ $value }} - max: {{ $value }} - {{- end }} - {{- else if .Values.controller.hostPort.enabled }} - {{- range $key, $value := .Values.controller.hostPort.ports }} - # controller.hostPort.ports.{{ $key }} - - min: {{ $value }} - max: {{ $value }} - {{- end }} - {{- end }} - {{- if .Values.controller.metrics.enabled }} - # controller.metrics.port - - min: {{ .Values.controller.metrics.port }} - max: {{ .Values.controller.metrics.port }} - {{- end }} - {{- if .Values.controller.admissionWebhooks.enabled }} - # controller.admissionWebhooks.port - - min: {{ .Values.controller.admissionWebhooks.port }} - max: {{ .Values.controller.admissionWebhooks.port }} - {{- end }} - {{- range $key, $value := .Values.tcp }} - # tcp.{{ $key }} - - min: {{ $key }} - max: {{ $key }} - {{- end }} - {{- range $key, $value := .Values.udp }} - # udp.{{ $key }} - - min: {{ $key }} - max: {{ $key }} - {{- end }} -{{- end }} - volumes: - - configMap - - downwardAPI - - emptyDir - - secret - - projected - fsGroup: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - readOnlyRootFilesystem: false - runAsUser: - rule: MustRunAsNonRoot - runAsGroup: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - supplementalGroups: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - allowPrivilegeEscalation: {{ or .Values.controller.image.allowPrivilegeEscalation .Values.controller.image.chroot }} - requiredDropCapabilities: - - ALL - allowedCapabilities: - - NET_BIND_SERVICE - {{- if .Values.controller.image.chroot }} - {{- if .Values.controller.image.seccompProfile }} - - SYS_ADMIN - {{- end }} - - SYS_CHROOT - {{- end }} - seLinux: - rule: RunAsAny -{{- if .Values.controller.sysctls }} - allowedUnsafeSysctls: - {{- range $sysctl, $value := .Values.controller.sysctls }} - - {{ $sysctl }} - {{- end }} -{{- end }} -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-role.yaml b/charts/keep/charts/ingress-nginx/templates/controller-role.yaml deleted file mode 100644 index a94b399..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-role.yaml +++ /dev/null @@ -1,104 +0,0 @@ -{{- if .Values.rbac.create -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: Role -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -rules: - - apiGroups: - - "" - resources: - - namespaces - verbs: - - get - - apiGroups: - - "" - resources: - - configmaps - - pods - - secrets - - endpoints - verbs: - - get - - list - - watch - - apiGroups: - - "" - resources: - - services - verbs: - - get - - list - - watch - - apiGroups: - - networking.k8s.io - resources: - - ingresses - verbs: - - get - - list - - watch - # Omit Ingress status permissions if `--update-status` is disabled. - {{- if ne (index .Values.controller.extraArgs "update-status") "false" }} - - apiGroups: - - networking.k8s.io - resources: - - ingresses/status - verbs: - - update - {{- end }} - - apiGroups: - - networking.k8s.io - resources: - - ingressclasses - verbs: - - get - - list - - watch - - apiGroups: - - coordination.k8s.io - resources: - - leases - resourceNames: - - {{ include "ingress-nginx.controller.electionID" . }} - verbs: - - get - - update - - apiGroups: - - coordination.k8s.io - resources: - - leases - verbs: - - create - - apiGroups: - - "" - resources: - - events - verbs: - - create - - patch - - apiGroups: - - discovery.k8s.io - resources: - - endpointslices - verbs: - - list - - watch - - get -{{- if .Values.podSecurityPolicy.enabled }} - - apiGroups: [{{ template "podSecurityPolicy.apiGroup" . }}] - resources: ['podsecuritypolicies'] - verbs: ['use'] - {{- with .Values.controller.existingPsp }} - resourceNames: [{{ . }}] - {{- else }} - resourceNames: [{{ include "ingress-nginx.fullname" . }}] - {{- end }} -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-rolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/controller-rolebinding.yaml deleted file mode 100644 index 153430a..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-rolebinding.yaml +++ /dev/null @@ -1,21 +0,0 @@ -{{- if .Values.rbac.create -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: RoleBinding -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -roleRef: - apiGroup: rbac.authorization.k8s.io - kind: Role - name: {{ include "ingress-nginx.fullname" . }} -subjects: - - kind: ServiceAccount - name: {{ template "ingress-nginx.serviceAccountName" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-secret.yaml b/charts/keep/charts/ingress-nginx/templates/controller-secret.yaml deleted file mode 100644 index f20f534..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-secret.yaml +++ /dev/null @@ -1,15 +0,0 @@ -{{- if .Values.dhParam -}} -apiVersion: v1 -kind: Secret -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -data: - dhparam.pem: {{ .Values.dhParam }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-service-internal.yaml b/charts/keep/charts/ingress-nginx/templates/controller-service-internal.yaml deleted file mode 100644 index 6d0b47c..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-service-internal.yaml +++ /dev/null @@ -1,105 +0,0 @@ -{{- if and .Values.controller.service.enabled .Values.controller.service.internal.enabled .Values.controller.service.internal.annotations -}} -apiVersion: v1 -kind: Service -metadata: - annotations: - {{- range $key, $value := .Values.controller.service.internal.annotations }} - {{ $key }}: {{ tpl ($value | toString) $ | quote }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- if .Values.controller.service.labels }} - {{- toYaml .Values.controller.service.labels | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }}-internal - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - type: {{ .Values.controller.service.internal.type | default .Values.controller.service.type }} -{{- if .Values.controller.service.internal.clusterIP }} - clusterIP: {{ .Values.controller.service.internal.clusterIP }} -{{- end }} -{{- if .Values.controller.service.internal.externalIPs }} - externalIPs: {{ toYaml .Values.controller.service.internal.externalIPs | nindent 4 }} -{{- end }} -{{- if .Values.controller.service.internal.loadBalancerIP }} - loadBalancerIP: {{ .Values.controller.service.internal.loadBalancerIP }} -{{- end }} -{{- if .Values.controller.service.internal.loadBalancerSourceRanges }} - loadBalancerSourceRanges: {{ toYaml .Values.controller.service.internal.loadBalancerSourceRanges | nindent 4 }} -{{- end }} -{{- if .Values.controller.service.internal.loadBalancerClass }} - loadBalancerClass: {{ .Values.controller.service.internal.loadBalancerClass }} -{{- end }} -{{- if hasKey .Values.controller.service.internal "allocateLoadBalancerNodePorts" }} - allocateLoadBalancerNodePorts: {{ .Values.controller.service.internal.allocateLoadBalancerNodePorts }} -{{- end }} -{{- if .Values.controller.service.internal.externalTrafficPolicy }} - externalTrafficPolicy: {{ .Values.controller.service.internal.externalTrafficPolicy }} -{{- end }} -{{- if .Values.controller.service.internal.sessionAffinity }} - sessionAffinity: {{ .Values.controller.service.internal.sessionAffinity }} -{{- end }} -{{- if .Values.controller.service.internal.healthCheckNodePort }} - healthCheckNodePort: {{ .Values.controller.service.internal.healthCheckNodePort }} -{{- end }} -{{- if semverCompare ">=1.21.0-0" .Capabilities.KubeVersion.Version -}} -{{- if .Values.controller.service.internal.ipFamilyPolicy }} - ipFamilyPolicy: {{ .Values.controller.service.internal.ipFamilyPolicy }} -{{- end }} -{{- if .Values.controller.service.internal.ipFamilies }} - ipFamilies: {{ toYaml .Values.controller.service.internal.ipFamilies | nindent 4 }} -{{- end }} -{{- end }} - ports: - {{- $setNodePorts := (or (eq .Values.controller.service.type "NodePort") (eq .Values.controller.service.type "LoadBalancer")) }} - {{- if .Values.controller.service.enableHttp }} - - name: http - port: {{ .Values.controller.service.internal.ports.http | default .Values.controller.service.ports.http }} - protocol: TCP - targetPort: {{ .Values.controller.service.internal.targetPorts.http | default .Values.controller.service.targetPorts.http }} - {{- if and (semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version) (.Values.controller.service.internal.appProtocol) }} - appProtocol: http - {{- end }} - {{- if (and $setNodePorts (not (empty .Values.controller.service.internal.nodePorts.http))) }} - nodePort: {{ .Values.controller.service.internal.nodePorts.http }} - {{- end }} - {{- end }} - {{- if .Values.controller.service.enableHttps }} - - name: https - port: {{ .Values.controller.service.internal.ports.https | default .Values.controller.service.ports.https }} - protocol: TCP - targetPort: {{ .Values.controller.service.internal.targetPorts.https | default .Values.controller.service.targetPorts.https }} - {{- if and (semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version) (.Values.controller.service.internal.appProtocol) }} - appProtocol: https - {{- end }} - {{- if (and $setNodePorts (not (empty .Values.controller.service.internal.nodePorts.https))) }} - nodePort: {{ .Values.controller.service.internal.nodePorts.https }} - {{- end }} - {{- end }} - {{- range $key, $value := .Values.tcp }} - - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp - port: {{ $key }} - protocol: TCP - targetPort: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp - {{- if $.Values.controller.service.internal.nodePorts.tcp }} - {{- if index $.Values.controller.service.internal.nodePorts.tcp $key }} - nodePort: {{ index $.Values.controller.service.internal.nodePorts.tcp $key }} - {{- end }} - {{- end }} - {{- end }} - {{- range $key, $value := .Values.udp }} - - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp - port: {{ $key }} - protocol: UDP - targetPort: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp - {{- if $.Values.controller.service.internal.nodePorts.udp }} - {{- if index $.Values.controller.service.internal.nodePorts.udp $key }} - nodePort: {{ index $.Values.controller.service.internal.nodePorts.udp $key }} - {{- end }} - {{- end }} - {{- end }} - selector: - {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} - app.kubernetes.io/component: controller -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-service-metrics.yaml b/charts/keep/charts/ingress-nginx/templates/controller-service-metrics.yaml deleted file mode 100644 index 7c15329..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-service-metrics.yaml +++ /dev/null @@ -1,45 +0,0 @@ -{{- if .Values.controller.metrics.enabled -}} -apiVersion: v1 -kind: Service -metadata: -{{- if .Values.controller.metrics.service.annotations }} - annotations: {{ toYaml .Values.controller.metrics.service.annotations | nindent 4 }} -{{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- if .Values.controller.metrics.service.labels }} - {{- toYaml .Values.controller.metrics.service.labels | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }}-metrics - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - type: {{ .Values.controller.metrics.service.type }} -{{- if .Values.controller.metrics.service.clusterIP }} - clusterIP: {{ .Values.controller.metrics.service.clusterIP }} -{{- end }} -{{- if .Values.controller.metrics.service.externalIPs }} - externalIPs: {{ toYaml .Values.controller.metrics.service.externalIPs | nindent 4 }} -{{- end }} -{{- if .Values.controller.metrics.service.loadBalancerIP }} - loadBalancerIP: {{ .Values.controller.metrics.service.loadBalancerIP }} -{{- end }} -{{- if .Values.controller.metrics.service.loadBalancerSourceRanges }} - loadBalancerSourceRanges: {{ toYaml .Values.controller.metrics.service.loadBalancerSourceRanges | nindent 4 }} -{{- end }} -{{- if .Values.controller.metrics.service.externalTrafficPolicy }} - externalTrafficPolicy: {{ .Values.controller.metrics.service.externalTrafficPolicy }} -{{- end }} - ports: - - name: {{ .Values.controller.metrics.portName }} - port: {{ .Values.controller.metrics.service.servicePort }} - protocol: TCP - targetPort: {{ .Values.controller.metrics.portName }} - {{- $setNodePorts := (or (eq .Values.controller.metrics.service.type "NodePort") (eq .Values.controller.metrics.service.type "LoadBalancer")) }} - {{- if (and $setNodePorts (not (empty .Values.controller.metrics.service.nodePort))) }} - nodePort: {{ .Values.controller.metrics.service.nodePort }} - {{- end }} - selector: - {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} - app.kubernetes.io/component: controller -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-service-webhook.yaml b/charts/keep/charts/ingress-nginx/templates/controller-service-webhook.yaml deleted file mode 100644 index 67aac0d..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-service-webhook.yaml +++ /dev/null @@ -1,40 +0,0 @@ -{{- if .Values.controller.admissionWebhooks.enabled -}} -apiVersion: v1 -kind: Service -metadata: -{{- if .Values.controller.admissionWebhooks.service.annotations }} - annotations: {{ toYaml .Values.controller.admissionWebhooks.service.annotations | nindent 4 }} -{{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }}-admission - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - type: {{ .Values.controller.admissionWebhooks.service.type }} -{{- if .Values.controller.admissionWebhooks.service.clusterIP }} - clusterIP: {{ .Values.controller.admissionWebhooks.service.clusterIP }} -{{- end }} -{{- if .Values.controller.admissionWebhooks.service.externalIPs }} - externalIPs: {{ toYaml .Values.controller.admissionWebhooks.service.externalIPs | nindent 4 }} -{{- end }} -{{- if .Values.controller.admissionWebhooks.service.loadBalancerIP }} - loadBalancerIP: {{ .Values.controller.admissionWebhooks.service.loadBalancerIP }} -{{- end }} -{{- if .Values.controller.admissionWebhooks.service.loadBalancerSourceRanges }} - loadBalancerSourceRanges: {{ toYaml .Values.controller.admissionWebhooks.service.loadBalancerSourceRanges | nindent 4 }} -{{- end }} - ports: - - name: https-webhook - port: {{ .Values.controller.admissionWebhooks.service.servicePort }} - targetPort: webhook - {{- if semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version }} - appProtocol: https - {{- end }} - selector: - {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} - app.kubernetes.io/component: controller -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-service.yaml b/charts/keep/charts/ingress-nginx/templates/controller-service.yaml deleted file mode 100644 index cb78a70..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-service.yaml +++ /dev/null @@ -1,105 +0,0 @@ -{{- if and .Values.controller.service.enabled .Values.controller.service.external.enabled -}} -apiVersion: v1 -kind: Service -metadata: - annotations: - {{- range $key, $value := .Values.controller.service.annotations }} - {{ $key }}: {{ tpl ($value | toString) $ | quote }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- if .Values.controller.service.labels }} - {{- toYaml .Values.controller.service.labels | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.controller.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - type: {{ .Values.controller.service.type }} -{{- if .Values.controller.service.clusterIP }} - clusterIP: {{ .Values.controller.service.clusterIP }} -{{- end }} -{{- if .Values.controller.service.externalIPs }} - externalIPs: {{ toYaml .Values.controller.service.externalIPs | nindent 4 }} -{{- end }} -{{- if .Values.controller.service.loadBalancerIP }} - loadBalancerIP: {{ .Values.controller.service.loadBalancerIP }} -{{- end }} -{{- if .Values.controller.service.loadBalancerSourceRanges }} - loadBalancerSourceRanges: {{ toYaml .Values.controller.service.loadBalancerSourceRanges | nindent 4 }} -{{- end }} -{{- if .Values.controller.service.loadBalancerClass }} - loadBalancerClass: {{ .Values.controller.service.loadBalancerClass }} -{{- end }} -{{- if hasKey .Values.controller.service "allocateLoadBalancerNodePorts" }} - allocateLoadBalancerNodePorts: {{ .Values.controller.service.allocateLoadBalancerNodePorts }} -{{- end }} -{{- if .Values.controller.service.externalTrafficPolicy }} - externalTrafficPolicy: {{ .Values.controller.service.externalTrafficPolicy }} -{{- end }} -{{- if .Values.controller.service.sessionAffinity }} - sessionAffinity: {{ .Values.controller.service.sessionAffinity }} -{{- end }} -{{- if .Values.controller.service.healthCheckNodePort }} - healthCheckNodePort: {{ .Values.controller.service.healthCheckNodePort }} -{{- end }} -{{- if semverCompare ">=1.21.0-0" .Capabilities.KubeVersion.Version -}} -{{- if .Values.controller.service.ipFamilyPolicy }} - ipFamilyPolicy: {{ .Values.controller.service.ipFamilyPolicy }} -{{- end }} -{{- if .Values.controller.service.ipFamilies }} - ipFamilies: {{ toYaml .Values.controller.service.ipFamilies | nindent 4 }} -{{- end }} -{{- end }} - ports: - {{- $setNodePorts := (or (eq .Values.controller.service.type "NodePort") (eq .Values.controller.service.type "LoadBalancer")) }} - {{- if .Values.controller.service.enableHttp }} - - name: http - port: {{ .Values.controller.service.ports.http }} - protocol: TCP - targetPort: {{ .Values.controller.service.targetPorts.http }} - {{- if and (semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version) (.Values.controller.service.appProtocol) }} - appProtocol: http - {{- end }} - {{- if (and $setNodePorts (not (empty .Values.controller.service.nodePorts.http))) }} - nodePort: {{ .Values.controller.service.nodePorts.http }} - {{- end }} - {{- end }} - {{- if .Values.controller.service.enableHttps }} - - name: https - port: {{ .Values.controller.service.ports.https }} - protocol: TCP - targetPort: {{ .Values.controller.service.targetPorts.https }} - {{- if and (semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version) (.Values.controller.service.appProtocol) }} - appProtocol: https - {{- end }} - {{- if (and $setNodePorts (not (empty .Values.controller.service.nodePorts.https))) }} - nodePort: {{ .Values.controller.service.nodePorts.https }} - {{- end }} - {{- end }} - {{- range $key, $value := .Values.tcp }} - - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp - port: {{ $key }} - protocol: TCP - targetPort: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-tcp - {{- if $.Values.controller.service.nodePorts.tcp }} - {{- if index $.Values.controller.service.nodePorts.tcp $key }} - nodePort: {{ index $.Values.controller.service.nodePorts.tcp $key }} - {{- end }} - {{- end }} - {{- end }} - {{- range $key, $value := .Values.udp }} - - name: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp - port: {{ $key }} - protocol: UDP - targetPort: {{ if $.Values.portNamePrefix }}{{ $.Values.portNamePrefix }}-{{ end }}{{ $key }}-udp - {{- if $.Values.controller.service.nodePorts.udp }} - {{- if index $.Values.controller.service.nodePorts.udp $key }} - nodePort: {{ index $.Values.controller.service.nodePorts.udp $key }} - {{- end }} - {{- end }} - {{- end }} - selector: - {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} - app.kubernetes.io/component: controller -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml b/charts/keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml deleted file mode 100644 index df83de3..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-serviceaccount.yaml +++ /dev/null @@ -1,17 +0,0 @@ -{{- if or .Values.serviceAccount.create -}} -apiVersion: v1 -kind: ServiceAccount -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- with .Values.controller.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ template "ingress-nginx.serviceAccountName" . }} - namespace: {{ include "ingress-nginx.namespace" . }} - {{- if .Values.serviceAccount.annotations }} - annotations: {{ toYaml .Values.serviceAccount.annotations | nindent 4 }} - {{- end }} -automountServiceAccountToken: {{ .Values.serviceAccount.automountServiceAccountToken }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/controller-servicemonitor.yaml b/charts/keep/charts/ingress-nginx/templates/controller-servicemonitor.yaml deleted file mode 100644 index 62301da..0000000 --- a/charts/keep/charts/ingress-nginx/templates/controller-servicemonitor.yaml +++ /dev/null @@ -1,53 +0,0 @@ -{{- if and .Values.controller.metrics.enabled .Values.controller.metrics.serviceMonitor.enabled -}} -apiVersion: monitoring.coreos.com/v1 -kind: ServiceMonitor -metadata: - name: {{ include "ingress-nginx.controller.fullname" . }} -{{- if .Values.controller.metrics.serviceMonitor.namespace }} - namespace: {{ .Values.controller.metrics.serviceMonitor.namespace }} -{{- else }} - namespace: {{ include "ingress-nginx.namespace" . }} -{{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: controller - {{- if .Values.controller.metrics.serviceMonitor.additionalLabels }} - {{- toYaml .Values.controller.metrics.serviceMonitor.additionalLabels | nindent 4 }} - {{- end }} - {{- if .Values.controller.metrics.serviceMonitor.annotations }} - annotations: {{ toYaml .Values.controller.metrics.serviceMonitor.annotations | nindent 4 }} - {{- end }} -spec: - endpoints: - - port: {{ .Values.controller.metrics.portName }} - interval: {{ .Values.controller.metrics.serviceMonitor.scrapeInterval }} - {{- if .Values.controller.metrics.serviceMonitor.honorLabels }} - honorLabels: true - {{- end }} - {{- if .Values.controller.metrics.serviceMonitor.relabelings }} - relabelings: {{ toYaml .Values.controller.metrics.serviceMonitor.relabelings | nindent 8 }} - {{- end }} - {{- if .Values.controller.metrics.serviceMonitor.metricRelabelings }} - metricRelabelings: {{ toYaml .Values.controller.metrics.serviceMonitor.metricRelabelings | nindent 8 }} - {{- end }} -{{- if .Values.controller.metrics.serviceMonitor.jobLabel }} - jobLabel: {{ .Values.controller.metrics.serviceMonitor.jobLabel | quote }} -{{- end }} -{{- if .Values.controller.metrics.serviceMonitor.namespaceSelector }} - namespaceSelector: {{ toYaml .Values.controller.metrics.serviceMonitor.namespaceSelector | nindent 4 }} -{{- else }} - namespaceSelector: - matchNames: - - {{ include "ingress-nginx.namespace" . }} -{{- end }} -{{- if .Values.controller.metrics.serviceMonitor.targetLabels }} - targetLabels: - {{- range .Values.controller.metrics.serviceMonitor.targetLabels }} - - {{ . }} - {{- end }} -{{- end }} - selector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: controller -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-deployment.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-deployment.yaml deleted file mode 100644 index 6755e23..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-deployment.yaml +++ /dev/null @@ -1,119 +0,0 @@ -{{- if .Values.defaultBackend.enabled -}} -apiVersion: apps/v1 -kind: Deployment -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.defaultBackend.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - selector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: default-backend -{{- if not .Values.defaultBackend.autoscaling.enabled }} - replicas: {{ .Values.defaultBackend.replicaCount }} -{{- end }} - revisionHistoryLimit: {{ .Values.revisionHistoryLimit }} - {{- if .Values.defaultBackend.updateStrategy }} - strategy: - {{ toYaml .Values.defaultBackend.updateStrategy | nindent 4 }} - {{- end }} - minReadySeconds: {{ .Values.defaultBackend.minReadySeconds }} - template: - metadata: - {{- if .Values.defaultBackend.podAnnotations }} - annotations: {{ toYaml .Values.defaultBackend.podAnnotations | nindent 8 }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 8 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 8 }} - {{- end }} - {{- if .Values.defaultBackend.podLabels }} - {{- toYaml .Values.defaultBackend.podLabels | nindent 8 }} - {{- end }} - spec: - {{- if .Values.imagePullSecrets }} - imagePullSecrets: {{ toYaml .Values.imagePullSecrets | nindent 8 }} - {{- end }} - {{- if .Values.defaultBackend.priorityClassName }} - priorityClassName: {{ .Values.defaultBackend.priorityClassName }} - {{- end }} - {{- if .Values.defaultBackend.podSecurityContext }} - securityContext: {{ toYaml .Values.defaultBackend.podSecurityContext | nindent 8 }} - {{- end }} - containers: - - name: {{ template "ingress-nginx.name" . }}-default-backend - {{- with .Values.defaultBackend.image }} - image: {{ if .repository }}{{ .repository }}{{ else }}{{ .registry }}/{{ .image }}{{ end }}:{{ .tag }}{{ if .digest }}@{{ .digest }}{{ end }} - {{- end }} - imagePullPolicy: {{ .Values.defaultBackend.image.pullPolicy }} - {{- if .Values.defaultBackend.extraArgs }} - args: - {{- range $key, $value := .Values.defaultBackend.extraArgs }} - {{- /* Accept keys without values or with false as value */}} - {{- if eq ($value | quote | len) 2 }} - - --{{ $key }} - {{- else }} - - --{{ $key }}={{ $value }} - {{- end }} - {{- end }} - {{- end }} - securityContext: {{ include "ingress-nginx.defaultBackend.containerSecurityContext" . | nindent 12 }} - {{- if .Values.defaultBackend.extraEnvs }} - env: {{ toYaml .Values.defaultBackend.extraEnvs | nindent 12 }} - {{- end }} - livenessProbe: - httpGet: - path: /healthz - port: {{ .Values.defaultBackend.port }} - scheme: HTTP - initialDelaySeconds: {{ .Values.defaultBackend.livenessProbe.initialDelaySeconds }} - periodSeconds: {{ .Values.defaultBackend.livenessProbe.periodSeconds }} - timeoutSeconds: {{ .Values.defaultBackend.livenessProbe.timeoutSeconds }} - successThreshold: {{ .Values.defaultBackend.livenessProbe.successThreshold }} - failureThreshold: {{ .Values.defaultBackend.livenessProbe.failureThreshold }} - readinessProbe: - httpGet: - path: /healthz - port: {{ .Values.defaultBackend.port }} - scheme: HTTP - initialDelaySeconds: {{ .Values.defaultBackend.readinessProbe.initialDelaySeconds }} - periodSeconds: {{ .Values.defaultBackend.readinessProbe.periodSeconds }} - timeoutSeconds: {{ .Values.defaultBackend.readinessProbe.timeoutSeconds }} - successThreshold: {{ .Values.defaultBackend.readinessProbe.successThreshold }} - failureThreshold: {{ .Values.defaultBackend.readinessProbe.failureThreshold }} - ports: - - name: http - containerPort: {{ .Values.defaultBackend.port }} - protocol: TCP - {{- if .Values.defaultBackend.extraVolumeMounts }} - volumeMounts: {{- toYaml .Values.defaultBackend.extraVolumeMounts | nindent 12 }} - {{- end }} - {{- if .Values.defaultBackend.resources }} - resources: {{ toYaml .Values.defaultBackend.resources | nindent 12 }} - {{- end }} - {{- if .Values.defaultBackend.nodeSelector }} - nodeSelector: {{ toYaml .Values.defaultBackend.nodeSelector | nindent 8 }} - {{- end }} - serviceAccountName: {{ include "ingress-nginx.defaultBackend.serviceAccountName" . }} - {{- if .Values.defaultBackend.tolerations }} - tolerations: {{ toYaml .Values.defaultBackend.tolerations | nindent 8 }} - {{- end }} - {{- if .Values.defaultBackend.affinity }} - affinity: {{ tpl (toYaml .Values.defaultBackend.affinity) $ | nindent 8 }} - {{- end }} - {{- if .Values.defaultBackend.topologySpreadConstraints }} - topologySpreadConstraints: {{ tpl (toYaml .Values.defaultBackend.topologySpreadConstraints) $ | nindent 8 }} - {{- end }} - terminationGracePeriodSeconds: 60 - {{- if .Values.defaultBackend.extraVolumes }} - volumes: {{ toYaml .Values.defaultBackend.extraVolumes | nindent 8 }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-extra-configmaps.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-extra-configmaps.yaml deleted file mode 100644 index 9af56cf..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-extra-configmaps.yaml +++ /dev/null @@ -1,23 +0,0 @@ -{{- if .Values.defaultBackend.enabled }} -{{- range .Values.defaultBackend.extraConfigMaps }} ---- -apiVersion: v1 -kind: ConfigMap -metadata: - labels: - {{- include "ingress-nginx.labels" $ | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with $.Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - {{- with .labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ .name }} - namespace: {{ include "ingress-nginx.namespace" $ }} -data: - {{- with .data }} - {{- toYaml . | nindent 2 }} - {{- end }} -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-hpa.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-hpa.yaml deleted file mode 100644 index 49bcdcf..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-hpa.yaml +++ /dev/null @@ -1,40 +0,0 @@ -{{- if and .Values.defaultBackend.enabled .Values.defaultBackend.autoscaling.enabled }} -apiVersion: {{ ternary "autoscaling/v2" "autoscaling/v2beta2" (.Capabilities.APIVersions.Has "autoscaling/v2") }} -kind: HorizontalPodAutoscaler -metadata: - {{- with .Values.defaultBackend.autoscaling.annotations }} - annotations: {{ toYaml . | nindent 4 }} - {{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.defaultBackend.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - scaleTargetRef: - apiVersion: apps/v1 - kind: Deployment - name: {{ include "ingress-nginx.defaultBackend.fullname" . }} - minReplicas: {{ .Values.defaultBackend.autoscaling.minReplicas }} - maxReplicas: {{ .Values.defaultBackend.autoscaling.maxReplicas }} - metrics: - {{- with .Values.defaultBackend.autoscaling.targetMemoryUtilizationPercentage }} - - type: Resource - resource: - name: memory - target: - type: Utilization - averageUtilization: {{ . }} - {{- end }} - {{- with .Values.defaultBackend.autoscaling.targetCPUUtilizationPercentage }} - - type: Resource - resource: - name: cpu - target: - type: Utilization - averageUtilization: {{ . }} - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-networkpolicy.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-networkpolicy.yaml deleted file mode 100644 index 90b3c2b..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-networkpolicy.yaml +++ /dev/null @@ -1,25 +0,0 @@ -{{- if and .Values.defaultBackend.enabled .Values.defaultBackend.networkPolicy.enabled }} -apiVersion: networking.k8s.io/v1 -kind: NetworkPolicy -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.defaultBackend.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - podSelector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: default-backend - policyTypes: - - Ingress - - Egress - ingress: - - ports: - - protocol: TCP - port: {{ .Values.defaultBackend.port }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-poddisruptionbudget.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-poddisruptionbudget.yaml deleted file mode 100644 index c8363fd..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-poddisruptionbudget.yaml +++ /dev/null @@ -1,25 +0,0 @@ -{{- if .Values.defaultBackend.enabled -}} -{{- $replicas := .Values.defaultBackend.replicaCount }} -{{- if .Values.defaultBackend.autoscaling.enabled }} -{{- $replicas = .Values.defaultBackend.autoscaling.minReplicas }} -{{- end }} -{{- if gt ($replicas | int) 1 }} -apiVersion: {{ ternary "policy/v1" "policy/v1beta1" (semverCompare ">=1.21.0-0" .Capabilities.KubeVersion.Version) }} -kind: PodDisruptionBudget -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.defaultBackend.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - selector: - matchLabels: - {{- include "ingress-nginx.selectorLabels" . | nindent 6 }} - app.kubernetes.io/component: default-backend - minAvailable: {{ .Values.defaultBackend.minAvailable }} -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-psp.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-psp.yaml deleted file mode 100644 index 4241091..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-psp.yaml +++ /dev/null @@ -1,50 +0,0 @@ -{{- if (semverCompare "<1.25.0-0" .Capabilities.KubeVersion.Version) }} -{{- if and .Values.podSecurityPolicy.enabled .Values.defaultBackend.enabled (empty .Values.defaultBackend.existingPsp) -}} -apiVersion: policy/v1beta1 -kind: PodSecurityPolicy -metadata: - name: {{ include "ingress-nginx.fullname" . }}-backend - annotations: - seccomp.security.alpha.kubernetes.io/allowedProfileNames: "*" - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} -spec: - privileged: false - hostPID: false - hostIPC: false - hostNetwork: false - volumes: - - configMap - - downwardAPI - - emptyDir - - secret - - projected - fsGroup: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - readOnlyRootFilesystem: true - runAsUser: - rule: MustRunAsNonRoot - runAsGroup: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - supplementalGroups: - rule: MustRunAs - ranges: - - min: 1 - max: 65535 - allowPrivilegeEscalation: false - requiredDropCapabilities: - - ALL - seLinux: - rule: RunAsAny -{{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-role.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-role.yaml deleted file mode 100644 index dd7868a..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-role.yaml +++ /dev/null @@ -1,22 +0,0 @@ -{{- if and .Values.rbac.create .Values.podSecurityPolicy.enabled .Values.defaultBackend.enabled -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: Role -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.fullname" . }}-backend - namespace: {{ include "ingress-nginx.namespace" . }} -rules: - - apiGroups: [{{ template "podSecurityPolicy.apiGroup" . }}] - resources: ['podsecuritypolicies'] - verbs: ['use'] - {{- with .Values.defaultBackend.existingPsp }} - resourceNames: [{{ . }}] - {{- else }} - resourceNames: [{{ include "ingress-nginx.fullname" . }}-backend] - {{- end }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-rolebinding.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-rolebinding.yaml deleted file mode 100644 index 3203b6f..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-rolebinding.yaml +++ /dev/null @@ -1,21 +0,0 @@ -{{- if and .Values.rbac.create .Values.podSecurityPolicy.enabled .Values.defaultBackend.enabled -}} -apiVersion: rbac.authorization.k8s.io/v1 -kind: RoleBinding -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.fullname" . }}-backend - namespace: {{ include "ingress-nginx.namespace" . }} -roleRef: - apiGroup: rbac.authorization.k8s.io - kind: Role - name: {{ include "ingress-nginx.fullname" . }}-backend -subjects: - - kind: ServiceAccount - name: {{ template "ingress-nginx.defaultBackend.serviceAccountName" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-service.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-service.yaml deleted file mode 100644 index 65b6b83..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-service.yaml +++ /dev/null @@ -1,41 +0,0 @@ -{{- if .Values.defaultBackend.enabled -}} -apiVersion: v1 -kind: Service -metadata: -{{- if .Values.defaultBackend.service.annotations }} - annotations: {{ toYaml .Values.defaultBackend.service.annotations | nindent 4 }} -{{- end }} - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.defaultBackend.fullname" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -spec: - type: {{ .Values.defaultBackend.service.type }} -{{- if .Values.defaultBackend.service.clusterIP }} - clusterIP: {{ .Values.defaultBackend.service.clusterIP }} -{{- end }} -{{- if .Values.defaultBackend.service.externalIPs }} - externalIPs: {{ toYaml .Values.defaultBackend.service.externalIPs | nindent 4 }} -{{- end }} -{{- if .Values.defaultBackend.service.loadBalancerIP }} - loadBalancerIP: {{ .Values.defaultBackend.service.loadBalancerIP }} -{{- end }} -{{- if .Values.defaultBackend.service.loadBalancerSourceRanges }} - loadBalancerSourceRanges: {{ toYaml .Values.defaultBackend.service.loadBalancerSourceRanges | nindent 4 }} -{{- end }} - ports: - - name: http - port: {{ .Values.defaultBackend.service.servicePort }} - protocol: TCP - targetPort: http - {{- if semverCompare ">=1.20.0-0" .Capabilities.KubeVersion.Version }} - appProtocol: http - {{- end }} - selector: - {{- include "ingress-nginx.selectorLabels" . | nindent 4 }} - app.kubernetes.io/component: default-backend -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/templates/default-backend-serviceaccount.yaml b/charts/keep/charts/ingress-nginx/templates/default-backend-serviceaccount.yaml deleted file mode 100644 index 6fd2d62..0000000 --- a/charts/keep/charts/ingress-nginx/templates/default-backend-serviceaccount.yaml +++ /dev/null @@ -1,14 +0,0 @@ -{{- if and .Values.defaultBackend.enabled .Values.defaultBackend.serviceAccount.create -}} -apiVersion: v1 -kind: ServiceAccount -metadata: - labels: - {{- include "ingress-nginx.labels" . | nindent 4 }} - app.kubernetes.io/component: default-backend - {{- with .Values.defaultBackend.labels }} - {{- toYaml . | nindent 4 }} - {{- end }} - name: {{ include "ingress-nginx.defaultBackend.serviceAccountName" . }} - namespace: {{ include "ingress-nginx.namespace" . }} -automountServiceAccountToken: {{ .Values.defaultBackend.serviceAccount.automountServiceAccountToken }} -{{- end }} diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrole_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrole_test.yaml deleted file mode 100644 index d7a8b88..0000000 --- a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrole_test.yaml +++ /dev/null @@ -1,11 +0,0 @@ -suite: Admission Webhooks > Patch Job > ClusterRole -templates: - - admission-webhooks/job-patch/clusterrole.yaml - -tests: - - it: should not create a ClusterRole if `controller.admissionWebhooks.patch.rbac.create` is false - set: - controller.admissionWebhooks.patch.rbac.create: false - asserts: - - hasDocuments: - count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrolebinding_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrolebinding_test.yaml deleted file mode 100644 index d7c3266..0000000 --- a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/clusterrolebinding_test.yaml +++ /dev/null @@ -1,11 +0,0 @@ -suite: Admission Webhooks > Patch Job > ClusterRoleBinding -templates: - - admission-webhooks/job-patch/clusterrolebinding.yaml - -tests: - - it: should not create a ClusterRoleBinding if `controller.admissionWebhooks.patch.rbac.create` is false - set: - controller.admissionWebhooks.patch.rbac.create: false - asserts: - - hasDocuments: - count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/role_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/role_test.yaml deleted file mode 100644 index a236f3d..0000000 --- a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/role_test.yaml +++ /dev/null @@ -1,11 +0,0 @@ -suite: Admission Webhooks > Patch Job > Role -templates: - - admission-webhooks/job-patch/role.yaml - -tests: - - it: should not create a Role if `controller.admissionWebhooks.patch.rbac.create` is false - set: - controller.admissionWebhooks.patch.rbac.create: false - asserts: - - hasDocuments: - count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/rolebinding_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/rolebinding_test.yaml deleted file mode 100644 index 74abaa1..0000000 --- a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/rolebinding_test.yaml +++ /dev/null @@ -1,11 +0,0 @@ -suite: Admission Webhooks > Patch Job > RoleBinding -templates: - - admission-webhooks/job-patch/rolebinding.yaml - -tests: - - it: should not create a RoleBinding if `controller.admissionWebhooks.patch.rbac.create` is false - set: - controller.admissionWebhooks.patch.rbac.create: false - asserts: - - hasDocuments: - count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/serviceaccount_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/serviceaccount_test.yaml deleted file mode 100644 index 7c30d1e..0000000 --- a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/job-patch/serviceaccount_test.yaml +++ /dev/null @@ -1,47 +0,0 @@ -suite: Admission Webhooks > Patch Job > ServiceAccount -templates: - - admission-webhooks/job-patch/serviceaccount.yaml - -tests: - - it: should not create a ServiceAccount if `controller.admissionWebhooks.patch.serviceAccount.create` is false - set: - controller.admissionWebhooks.patch.serviceAccount.create: false - asserts: - - hasDocuments: - count: 0 - - - it: should create a ServiceAccount if `controller.admissionWebhooks.patch.serviceAccount.create` is true - set: - controller.admissionWebhooks.patch.serviceAccount.create: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ServiceAccount - - equal: - path: metadata.name - value: ingress-nginx-admission - - - it: should create a ServiceAccount with specified name if `controller.admissionWebhooks.patch.serviceAccount.name` is set - set: - controller.admissionWebhooks.patch.serviceAccount.name: ingress-nginx-admission-test-sa - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ServiceAccount - - equal: - path: metadata.name - value: ingress-nginx-admission-test-sa - - - it: should create a ServiceAccount with token auto-mounting disabled if `controller.admissionWebhooks.patch.serviceAccount.automountServiceAccountToken` is false - set: - controller.admissionWebhooks.patch.serviceAccount.automountServiceAccountToken: false - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ServiceAccount - - equal: - path: automountServiceAccountToken - value: false diff --git a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/validating-webhook_test.yaml b/charts/keep/charts/ingress-nginx/tests/admission-webhooks/validating-webhook_test.yaml deleted file mode 100644 index b9d6d78..0000000 --- a/charts/keep/charts/ingress-nginx/tests/admission-webhooks/validating-webhook_test.yaml +++ /dev/null @@ -1,32 +0,0 @@ -suite: Admission Webhooks > ValidatingWebhookConfiguration -templates: - - admission-webhooks/validating-webhook.yaml - -tests: - - it: should not create a ValidatingWebhookConfiguration if `controller.admissionWebhooks.enabled` is false - set: - controller.admissionWebhooks.enabled: false - asserts: - - hasDocuments: - count: 0 - - - it: should create a ValidatingWebhookConfiguration if `controller.admissionWebhooks.enabled` is true - set: - controller.admissionWebhooks.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ValidatingWebhookConfiguration - - equal: - path: metadata.name - value: RELEASE-NAME-admission - - - it: should create a ValidatingWebhookConfiguration with a custom port if `controller.admissionWebhooks.service.servicePort` is set - set: - controller.admissionWebhooks.enabled: true - controller.admissionWebhooks.service.servicePort: 9443 - asserts: - - equal: - path: webhooks[0].clientConfig.service.port - value: 9443 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-configmap-addheaders_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-configmap-addheaders_test.yaml deleted file mode 100644 index e831d50..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-configmap-addheaders_test.yaml +++ /dev/null @@ -1,27 +0,0 @@ -suite: Controller > ConfigMap > Add Headers -templates: - - controller-configmap-addheaders.yaml - -tests: - - it: should not create a ConfigMap if `controller.addHeaders` is not set - set: - controller.addHeaders: null - asserts: - - hasDocuments: - count: 0 - - - it: should create a ConfigMap if `controller.addHeaders` is set - set: - controller.addHeaders: - X-Another-Custom-Header: Value - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ConfigMap - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-custom-add-headers - - equal: - path: data.X-Another-Custom-Header - value: Value diff --git a/charts/keep/charts/ingress-nginx/tests/controller-configmap-proxyheaders_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-configmap-proxyheaders_test.yaml deleted file mode 100644 index 0634a37..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-configmap-proxyheaders_test.yaml +++ /dev/null @@ -1,27 +0,0 @@ -suite: Controller > ConfigMap > Proxy Headers -templates: - - controller-configmap-proxyheaders.yaml - -tests: - - it: should not create a ConfigMap if `controller.proxySetHeaders` is not set - set: - controller.proxySetHeaders: null - asserts: - - hasDocuments: - count: 0 - - - it: should create a ConfigMap if `controller.proxySetHeaders` is set - set: - controller.proxySetHeaders: - X-Custom-Header: Value - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ConfigMap - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-custom-proxy-headers - - equal: - path: data.X-Custom-Header - value: Value diff --git a/charts/keep/charts/ingress-nginx/tests/controller-configmap_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-configmap_test.yaml deleted file mode 100644 index 168b657..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-configmap_test.yaml +++ /dev/null @@ -1,31 +0,0 @@ -suite: Controller > ConfigMap -templates: - - controller-configmap.yaml - -tests: - - it: should create a ConfigMap - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ConfigMap - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should create a ConfigMap with templated values if `controller.config` contains templates - set: - controller.config: - template: "test.{{ .Release.Namespace }}.svc.kubernetes.local" - integer: 12345 - boolean: true - asserts: - - equal: - path: data.template - value: test.NAMESPACE.svc.kubernetes.local - - equal: - path: data.integer - value: "12345" - - equal: - path: data.boolean - value: "true" diff --git a/charts/keep/charts/ingress-nginx/tests/controller-daemonset_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-daemonset_test.yaml deleted file mode 100644 index 81d067b..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-daemonset_test.yaml +++ /dev/null @@ -1,172 +0,0 @@ -suite: Controller > DaemonSet -templates: - - controller-daemonset.yaml - -tests: - - it: should create a DaemonSet if `controller.kind` is "DaemonSet" - set: - controller.kind: DaemonSet - asserts: - - hasDocuments: - count: 1 - - isKind: - of: DaemonSet - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should create a DaemonSet with argument `--enable-metrics=false` if `controller.metrics.enabled` is false - set: - controller.kind: DaemonSet - controller.metrics.enabled: false - asserts: - - contains: - path: spec.template.spec.containers[0].args - content: --enable-metrics=false - - - it: should create a DaemonSet without argument `--enable-metrics=false` if `controller.metrics.enabled` is true - set: - controller.kind: DaemonSet - controller.metrics.enabled: true - asserts: - - notContains: - path: spec.template.spec.containers[0].args - content: --enable-metrics=false - - - it: should create a DaemonSet with argument `--controller-class=k8s.io/ingress-nginx-internal` if `controller.ingressClassResource.controllerValue` is "k8s.io/ingress-nginx-internal" - set: - controller.kind: DaemonSet - controller.ingressClassResource.controllerValue: k8s.io/ingress-nginx-internal - asserts: - - contains: - path: spec.template.spec.containers[0].args - content: --controller-class=k8s.io/ingress-nginx-internal - - - it: should create a DaemonSet with resource limits if `controller.resources.limits` is set - set: - controller.kind: DaemonSet - controller.resources.limits.cpu: 500m - controller.resources.limits.memory: 512Mi - asserts: - - equal: - path: spec.template.spec.containers[0].resources.limits.cpu - value: 500m - - equal: - path: spec.template.spec.containers[0].resources.limits.memory - value: 512Mi - - - it: should create a DaemonSet with topology spread constraints if `controller.topologySpreadConstraints` is set - set: - controller.kind: DaemonSet - controller.topologySpreadConstraints: - - labelSelector: - matchLabels: - app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - app.kubernetes.io/instance: '{{ .Release.Name }}' - app.kubernetes.io/component: controller - topologyKey: topology.kubernetes.io/zone - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - labelSelector: - matchLabels: - app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - app.kubernetes.io/instance: '{{ .Release.Name }}' - app.kubernetes.io/component: controller - topologyKey: kubernetes.io/hostname - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - asserts: - - equal: - path: spec.template.spec.topologySpreadConstraints - value: - - labelSelector: - matchLabels: - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: RELEASE-NAME - app.kubernetes.io/component: controller - topologyKey: topology.kubernetes.io/zone - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - labelSelector: - matchLabels: - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: RELEASE-NAME - app.kubernetes.io/component: controller - topologyKey: kubernetes.io/hostname - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - - it: should create a DaemonSet with affinity if `controller.affinity` is set - set: - controller.kind: DaemonSet - controller.affinity: - podAntiAffinity: - requiredDuringSchedulingIgnoredDuringExecution: - - labelSelector: - matchExpressions: - - key: app.kubernetes.io/name - operator: In - values: - - '{{ include "ingress-nginx.name" . }}' - - key: app.kubernetes.io/instance - operator: In - values: - - '{{ .Release.Name }}' - - key: app.kubernetes.io/component - operator: In - values: - - controller - topologyKey: kubernetes.io/hostname - asserts: - - equal: - path: spec.template.spec.affinity - value: - podAntiAffinity: - requiredDuringSchedulingIgnoredDuringExecution: - - labelSelector: - matchExpressions: - - key: app.kubernetes.io/name - operator: In - values: - - ingress-nginx - - key: app.kubernetes.io/instance - operator: In - values: - - RELEASE-NAME - - key: app.kubernetes.io/component - operator: In - values: - - controller - topologyKey: kubernetes.io/hostname - - - it: should create a DaemonSet with a custom registry if `controller.image.registry` is set - set: - controller.kind: DaemonSet - controller.image.registry: custom.registry.io - controller.image.tag: v1.0.0-dev - controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: custom.registry.io/ingress-nginx/controller:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - - - it: should create a DaemonSet with a custom image if `controller.image.image` is set - set: - controller.kind: DaemonSet - controller.image.image: custom-repo/custom-image - controller.image.tag: v1.0.0-dev - controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: registry.k8s.io/custom-repo/custom-image:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - - - it: should create a DaemonSet with a custom tag if `controller.image.tag` is set - set: - controller.kind: DaemonSet - controller.image.tag: custom-tag - controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: registry.k8s.io/ingress-nginx/controller:custom-tag@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd diff --git a/charts/keep/charts/ingress-nginx/tests/controller-deployment_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-deployment_test.yaml deleted file mode 100644 index 382aecd..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-deployment_test.yaml +++ /dev/null @@ -1,191 +0,0 @@ -suite: Controller > Deployment -templates: - - controller-deployment.yaml - -tests: - - it: should create a Deployment - asserts: - - hasDocuments: - count: 1 - - isKind: - of: Deployment - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should create a Deployment with 3 replicas if `controller.replicaCount` is 3 - set: - controller.replicaCount: 3 - asserts: - - equal: - path: spec.replicas - value: 3 - - - it: should create a Deployment without replicas if `controller.autoscaling.enabled` is true - set: - controller.autoscaling.enabled: true - asserts: - - notExists: - path: spec.replicas - - - it: should create a Deployment without replicas if `controller.keda.enabled` is true - set: - controller.keda.enabled: true - asserts: - - notExists: - path: spec.replicas - - - it: should create a Deployment with replicas if `controller.autoscaling.enabled` is true and `controller.keda.enabled` is true - set: - controller.autoscaling.enabled: true - controller.keda.enabled: true - asserts: - - exists: - path: spec.replicas - - - it: should create a Deployment with argument `--enable-metrics=false` if `controller.metrics.enabled` is false - set: - controller.metrics.enabled: false - asserts: - - contains: - path: spec.template.spec.containers[0].args - content: --enable-metrics=false - - - it: should create a Deployment without argument `--enable-metrics=false` if `controller.metrics.enabled` is true - set: - controller.metrics.enabled: true - asserts: - - notContains: - path: spec.template.spec.containers[0].args - content: --enable-metrics=false - - - it: should create a Deployment with argument `--controller-class=k8s.io/ingress-nginx-internal` if `controller.ingressClassResource.controllerValue` is "k8s.io/ingress-nginx-internal" - set: - controller.ingressClassResource.controllerValue: k8s.io/ingress-nginx-internal - asserts: - - contains: - path: spec.template.spec.containers[0].args - content: --controller-class=k8s.io/ingress-nginx-internal - - - it: should create a Deployment with resource limits if `controller.resources.limits` is set - set: - controller.resources.limits.cpu: 500m - controller.resources.limits.memory: 512Mi - asserts: - - equal: - path: spec.template.spec.containers[0].resources.limits.cpu - value: 500m - - equal: - path: spec.template.spec.containers[0].resources.limits.memory - value: 512Mi - - - it: should create a Deployment with topology spread constraints if `controller.topologySpreadConstraints` is set - set: - controller.topologySpreadConstraints: - - labelSelector: - matchLabels: - app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - app.kubernetes.io/instance: '{{ .Release.Name }}' - app.kubernetes.io/component: controller - topologyKey: topology.kubernetes.io/zone - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - labelSelector: - matchLabels: - app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - app.kubernetes.io/instance: '{{ .Release.Name }}' - app.kubernetes.io/component: controller - topologyKey: kubernetes.io/hostname - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - asserts: - - equal: - path: spec.template.spec.topologySpreadConstraints - value: - - labelSelector: - matchLabels: - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: RELEASE-NAME - app.kubernetes.io/component: controller - topologyKey: topology.kubernetes.io/zone - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - labelSelector: - matchLabels: - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: RELEASE-NAME - app.kubernetes.io/component: controller - topologyKey: kubernetes.io/hostname - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - - it: should create a Deployment with affinity if `controller.affinity` is set - set: - controller.affinity: - podAntiAffinity: - requiredDuringSchedulingIgnoredDuringExecution: - - labelSelector: - matchExpressions: - - key: app.kubernetes.io/name - operator: In - values: - - '{{ include "ingress-nginx.name" . }}' - - key: app.kubernetes.io/instance - operator: In - values: - - '{{ .Release.Name }}' - - key: app.kubernetes.io/component - operator: In - values: - - controller - topologyKey: kubernetes.io/hostname - asserts: - - equal: - path: spec.template.spec.affinity - value: - podAntiAffinity: - requiredDuringSchedulingIgnoredDuringExecution: - - labelSelector: - matchExpressions: - - key: app.kubernetes.io/name - operator: In - values: - - ingress-nginx - - key: app.kubernetes.io/instance - operator: In - values: - - RELEASE-NAME - - key: app.kubernetes.io/component - operator: In - values: - - controller - topologyKey: kubernetes.io/hostname - - - it: should create a Deployment with a custom registry if `controller.image.registry` is set - set: - controller.image.registry: custom.registry.io - controller.image.tag: v1.0.0-dev - controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: custom.registry.io/ingress-nginx/controller:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - - - it: should create a Deployment with a custom image if `controller.image.image` is set - set: - controller.image.image: custom-repo/custom-image - controller.image.tag: v1.0.0-dev - controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: registry.k8s.io/custom-repo/custom-image:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - - - it: should create a Deployment with a custom tag if `controller.image.tag` is set - set: - controller.image.tag: custom-tag - controller.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: registry.k8s.io/ingress-nginx/controller:custom-tag@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd diff --git a/charts/keep/charts/ingress-nginx/tests/controller-hpa_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-hpa_test.yaml deleted file mode 100644 index 869d3a6..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-hpa_test.yaml +++ /dev/null @@ -1,31 +0,0 @@ -suite: Controller > HPA -templates: - - controller-hpa.yaml - -tests: - - it: should create an HPA if `controller.autoscaling.enabled` is true - set: - controller.autoscaling.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: HorizontalPodAutoscaler - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should not create an HPA if `controller.autoscaling.enabled` is true and `controller.keda.enabled` is true - set: - controller.autoscaling.enabled: true - controller.keda.enabled: true - asserts: - - hasDocuments: - count: 0 - - - it: should not create an HPA if `controller.kind` is "DaemonSet" - set: - controller.kind: DaemonSet - asserts: - - hasDocuments: - count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-ingressclass-aliases_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-ingressclass-aliases_test.yaml deleted file mode 100644 index 9a4a576..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-ingressclass-aliases_test.yaml +++ /dev/null @@ -1,110 +0,0 @@ -suite: Controller > IngressClass > Aliases -templates: - - controller-ingressclass-aliases.yaml - -tests: - - it: should not create IngressClass aliases - asserts: - - hasDocuments: - count: 0 - - - it: should create an IngressClass alias with name "nginx-alias" if `controller.ingressClassResource.aliases` is set - set: - controller.ingressClassResource.aliases: - - nginx-alias - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx-alias - - - it: should create an IngressClass alias without annotation `ingressclass.kubernetes.io/is-default-class` if `controller.ingressClassResource.default` is true - set: - controller.ingressClassResource.aliases: - - nginx-alias - controller.ingressClassResource.default: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx-alias - - notExists: - path: metadata.annotations["ingressclass.kubernetes.io/is-default-class"] - - - it: should create an IngressClass alias with annotations if `controller.ingressClassResource.annotations` is set - set: - controller.ingressClassResource.aliases: - - nginx-alias - controller.ingressClassResource.annotations: - my-fancy-annotation: has-a-value - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx-alias - - equal: - path: metadata.annotations.my-fancy-annotation - value: has-a-value - - - it: should create an IngressClass alias with controller "k8s.io/ingress-nginx-internal" if `controller.ingressClassResource.controllerValue` is "k8s.io/ingress-nginx-internal" - set: - controller.ingressClassResource.aliases: - - nginx-alias - controller.ingressClassResource.controllerValue: k8s.io/ingress-nginx-internal - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx-alias - - equal: - path: spec.controller - value: k8s.io/ingress-nginx-internal - - - it: should create an IngressClass alias with parameters if `controller.ingressClassResource.parameters` is set - set: - controller.ingressClassResource.aliases: - - nginx-alias - controller.ingressClassResource.parameters: - apiGroup: k8s.example.com - kind: IngressParameters - name: external-lb - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx-alias - - equal: - path: spec.parameters - value: - apiGroup: k8s.example.com - kind: IngressParameters - name: external-lb - - - it: should create two IngressClass aliases if `controller.ingressClassResource.aliases` has two elements - set: - controller.ingressClassResource.aliases: - - nginx-alias-1 - - nginx-alias-2 - asserts: - - hasDocuments: - count: 2 - - isKind: - of: IngressClass - - matchRegex: - path: metadata.name - pattern: nginx-alias-(1|2) diff --git a/charts/keep/charts/ingress-nginx/tests/controller-ingressclass_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-ingressclass_test.yaml deleted file mode 100644 index b3384af..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-ingressclass_test.yaml +++ /dev/null @@ -1,93 +0,0 @@ -suite: Controller > IngressClass -templates: - - controller-ingressclass.yaml - -tests: - - it: should create an IngressClass - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx - - - it: should create an IngressClass with name "nginx-internal" if `controller.ingressClassResource.name` is "nginx-internal" - set: - controller.ingressClassResource.name: nginx-internal - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx-internal - - - it: "should create an IngressClass with annotation `ingressclass.kubernetes.io/is-default-class: \"true\"` if `controller.ingressClassResource.default` is true" - set: - controller.ingressClassResource.default: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx - - equal: - path: metadata.annotations["ingressclass.kubernetes.io/is-default-class"] - value: "true" - - - it: should create an IngressClass with annotations if `controller.ingressClassResource.annotations` is set - set: - controller.ingressClassResource.annotations: - my-fancy-annotation: has-a-value - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx - - equal: - path: metadata.annotations.my-fancy-annotation - value: has-a-value - - - it: should create an IngressClass with controller "k8s.io/ingress-nginx-internal" if `controller.ingressClassResource.controllerValue` is "k8s.io/ingress-nginx-internal" - set: - controller.ingressClassResource.controllerValue: k8s.io/ingress-nginx-internal - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx - - equal: - path: spec.controller - value: k8s.io/ingress-nginx-internal - - - it: should create an IngressClass with parameters if `controller.ingressClassResource.parameters` is set - set: - controller.ingressClassResource.parameters: - apiGroup: k8s.example.com - kind: IngressParameters - name: external-lb - asserts: - - hasDocuments: - count: 1 - - isKind: - of: IngressClass - - equal: - path: metadata.name - value: nginx - - equal: - path: spec.parameters - value: - apiGroup: k8s.example.com - kind: IngressParameters - name: external-lb diff --git a/charts/keep/charts/ingress-nginx/tests/controller-keda_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-keda_test.yaml deleted file mode 100644 index 8002834..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-keda_test.yaml +++ /dev/null @@ -1,31 +0,0 @@ -suite: Controller > KEDA -templates: - - controller-keda.yaml - -tests: - - it: should create a ScaledObject if `controller.keda.enabled` is true - set: - controller.keda.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ScaledObject - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should not create a ScaledObject if `controller.keda.enabled` is true and `controller.autoscaling.enabled` is true - set: - controller.keda.enabled: true - controller.autoscaling.enabled: true - asserts: - - hasDocuments: - count: 0 - - - it: should not create a ScaledObject if `controller.kind` is "DaemonSet" - set: - controller.kind: DaemonSet - asserts: - - hasDocuments: - count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-networkpolicy_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-networkpolicy_test.yaml deleted file mode 100644 index 5de12e9..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-networkpolicy_test.yaml +++ /dev/null @@ -1,23 +0,0 @@ -suite: Controller > NetworkPolicy -templates: - - controller-networkpolicy.yaml - -tests: - - it: should not create a NetworkPolicy if `controller.networkPolicy.enabled` is false - set: - controller.networkPolicy.enabled: false - asserts: - - hasDocuments: - count: 0 - - - it: should create a NetworkPolicy if `controller.networkPolicy.enabled` is true - set: - controller.networkPolicy.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: NetworkPolicy - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller diff --git a/charts/keep/charts/ingress-nginx/tests/controller-poddisruptionbudget_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-poddisruptionbudget_test.yaml deleted file mode 100644 index f215f35..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-poddisruptionbudget_test.yaml +++ /dev/null @@ -1,89 +0,0 @@ -suite: Controller > PodDisruptionBudget -templates: - - controller-poddisruptionbudget.yaml - -tests: - - it: should create a PodDisruptionBudget if `controller.replicaCount` is greater than 1 - set: - controller.replicaCount: 2 - asserts: - - hasDocuments: - count: 1 - - isKind: - of: PodDisruptionBudget - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should not create a PodDisruptionBudget if `controller.replicaCount` is less than or equal 1 - set: - controller.replicaCount: 1 - asserts: - - hasDocuments: - count: 0 - - - it: should create a PodDisruptionBudget if `controller.autoscaling.enabled` is true and `controller.autoscaling.minReplicas` is greater than 1 - set: - controller.autoscaling.enabled: true - controller.autoscaling.minReplicas: 2 - asserts: - - hasDocuments: - count: 1 - - isKind: - of: PodDisruptionBudget - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should not create a PodDisruptionBudget if `controller.autoscaling.enabled` is true and `controller.autoscaling.minReplicas` is less than or equal 1 - set: - controller.autoscaling.enabled: true - controller.autoscaling.minReplicas: 1 - asserts: - - hasDocuments: - count: 0 - - - it: should create a PodDisruptionBudget if `controller.keda.enabled` is true and `controller.keda.minReplicas` is greater than 1 - set: - controller.keda.enabled: true - controller.keda.minReplicas: 2 - asserts: - - hasDocuments: - count: 1 - - isKind: - of: PodDisruptionBudget - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should not create a PodDisruptionBudget if `controller.keda.enabled` is true and `controller.keda.minReplicas` is less than or equal 1 - set: - controller.keda.enabled: true - controller.keda.minReplicas: 1 - asserts: - - hasDocuments: - count: 0 - - - it: should not create a PodDisruptionBudget if `controller.autoscaling.enabled` is true and `controller.keda.enabled` is true - set: - controller.autoscaling.enabled: true - controller.keda.enabled: true - asserts: - - hasDocuments: - count: 0 - - - it: should create a PodDisruptionBudget without `minAvailable` and with `maxUnavailable` if `controller.minAvailable` and `controller.maxUnavailable` are set - set: - controller.replicaCount: 2 - controller.minAvailable: 1 - controller.maxUnavailable: 1 - asserts: - - hasDocuments: - count: 1 - - isKind: - of: PodDisruptionBudget - - notExists: - path: spec.minAvailable - - equal: - path: spec.maxUnavailable - value: 1 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-prometheusrule_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-prometheusrule_test.yaml deleted file mode 100644 index d60a983..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-prometheusrule_test.yaml +++ /dev/null @@ -1,17 +0,0 @@ -suite: Controller > PrometheusRule -templates: - - controller-prometheusrule.yaml - -tests: - - it: should create a PrometheusRule if `controller.metrics.prometheusRule.enabled` is true - set: - controller.metrics.enabled: true - controller.metrics.prometheusRule.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: PrometheusRule - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller diff --git a/charts/keep/charts/ingress-nginx/tests/controller-service-internal_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-service-internal_test.yaml deleted file mode 100644 index 5465e1a..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-service-internal_test.yaml +++ /dev/null @@ -1,25 +0,0 @@ -suite: Controller > Service > Internal -templates: - - controller-service-internal.yaml - -tests: - - it: should not create an internal Service if `controller.service.internal.enabled` is false - set: - controller.service.internal.enabled: false - asserts: - - hasDocuments: - count: 0 - - - it: should create an internal Service if `controller.service.internal.enabled` is true and `controller.service.internal.annotations` are set - set: - controller.service.internal.enabled: true - controller.service.internal.annotations: - test.annotation: "true" - asserts: - - hasDocuments: - count: 1 - - isKind: - of: Service - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller-internal diff --git a/charts/keep/charts/ingress-nginx/tests/controller-service-metrics_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-service-metrics_test.yaml deleted file mode 100644 index afdb940..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-service-metrics_test.yaml +++ /dev/null @@ -1,23 +0,0 @@ -suite: Controller > Service > Metrics -templates: - - controller-service-metrics.yaml - -tests: - - it: should not create a metrics Service if `controller.metrics.enabled` is false - set: - controller.metrics.enabled: false - asserts: - - hasDocuments: - count: 0 - - - it: should create a metrics Service if `controller.metrics.enabled` is true - set: - controller.metrics.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: Service - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller-metrics diff --git a/charts/keep/charts/ingress-nginx/tests/controller-service-webhook_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-service-webhook_test.yaml deleted file mode 100644 index 1c759ed..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-service-webhook_test.yaml +++ /dev/null @@ -1,32 +0,0 @@ -suite: Controller > Service > Webhook -templates: - - controller-service-webhook.yaml - -tests: - - it: should not create a webhook Service if `controller.admissionWebhooks.enabled` is false - set: - controller.admissionWebhooks.enabled: false - asserts: - - hasDocuments: - count: 0 - - - it: should create a webhook Service if `controller.admissionWebhooks.enabled` is true - set: - controller.admissionWebhooks.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: Service - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller-admission - - - it: should create a webhook Service with a custom port if `controller.admissionWebhooks.service.servicePort` is set - set: - controller.admissionWebhooks.enabled: true - controller.admissionWebhooks.service.servicePort: 9443 - asserts: - - equal: - path: spec.ports[0].port - value: 9443 diff --git a/charts/keep/charts/ingress-nginx/tests/controller-service_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-service_test.yaml deleted file mode 100644 index 10574f2..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-service_test.yaml +++ /dev/null @@ -1,32 +0,0 @@ -suite: Controller > Service -templates: - - controller-service.yaml - -tests: - - it: should not create a Service if `controller.service.external.enabled` is false - set: - controller.service.external.enabled: false - asserts: - - hasDocuments: - count: 0 - - - it: should create a Service if `controller.service.external.enabled` is true - set: - controller.service.external.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: Service - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should create a Service of type "NodePort" if `controller.service.external.enabled` is true and `controller.service.type` is "NodePort" - set: - controller.service.external.enabled: true - controller.service.type: NodePort - asserts: - - equal: - path: spec.type - value: NodePort diff --git a/charts/keep/charts/ingress-nginx/tests/controller-servicemonitor_test.yaml b/charts/keep/charts/ingress-nginx/tests/controller-servicemonitor_test.yaml deleted file mode 100644 index 310097c..0000000 --- a/charts/keep/charts/ingress-nginx/tests/controller-servicemonitor_test.yaml +++ /dev/null @@ -1,29 +0,0 @@ -suite: Controller > ServiceMonitor -templates: - - controller-servicemonitor.yaml - -tests: - - it: should create a ServiceMonitor if `controller.metrics.serviceMonitor.enabled` is true - set: - controller.metrics.enabled: true - controller.metrics.serviceMonitor.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ServiceMonitor - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-controller - - - it: should create a ServiceMonitor with annotations if `controller.metrics.serviceMonitor.annotations` is set - set: - controller.metrics.enabled: true - controller.metrics.serviceMonitor.enabled: true - controller.metrics.serviceMonitor.annotations: - my-little-annotation: test-value - asserts: - - equal: - path: metadata.annotations - value: - my-little-annotation: test-value diff --git a/charts/keep/charts/ingress-nginx/tests/default-backend-deployment_test.yaml b/charts/keep/charts/ingress-nginx/tests/default-backend-deployment_test.yaml deleted file mode 100644 index 4ba4b03..0000000 --- a/charts/keep/charts/ingress-nginx/tests/default-backend-deployment_test.yaml +++ /dev/null @@ -1,169 +0,0 @@ -suite: Default Backend > Deployment -templates: - - default-backend-deployment.yaml - -tests: - - it: should not create a Deployment if `defaultBackend.enabled` is false - set: - defaultBackend.enabled: false - asserts: - - hasDocuments: - count: 0 - - - it: should create a Deployment if `defaultBackend.enabled` is true - set: - defaultBackend.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: Deployment - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-defaultbackend - - - it: should create a Deployment with 3 replicas if `defaultBackend.replicaCount` is 3 - set: - defaultBackend.enabled: true - defaultBackend.replicaCount: 3 - asserts: - - equal: - path: spec.replicas - value: 3 - - - it: should create a Deployment without replicas if `defaultBackend.autoscaling.enabled` is true - set: - defaultBackend.enabled: true - defaultBackend.autoscaling.enabled: true - asserts: - - notExists: - path: spec.replicas - - - it: should create a Deployment with resource limits if `defaultBackend.resources.limits` is set - set: - defaultBackend.enabled: true - defaultBackend.resources.limits.cpu: 500m - defaultBackend.resources.limits.memory: 512Mi - asserts: - - equal: - path: spec.template.spec.containers[0].resources.limits.cpu - value: 500m - - equal: - path: spec.template.spec.containers[0].resources.limits.memory - value: 512Mi - - - it: should create a Deployment with topology spread constraints if `defaultBackend.topologySpreadConstraints` is set - set: - defaultBackend.enabled: true - defaultBackend.topologySpreadConstraints: - - labelSelector: - matchLabels: - app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - app.kubernetes.io/instance: '{{ .Release.Name }}' - app.kubernetes.io/component: default-backend - topologyKey: topology.kubernetes.io/zone - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - labelSelector: - matchLabels: - app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - app.kubernetes.io/instance: '{{ .Release.Name }}' - app.kubernetes.io/component: default-backend - topologyKey: kubernetes.io/hostname - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - asserts: - - equal: - path: spec.template.spec.topologySpreadConstraints - value: - - labelSelector: - matchLabels: - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: RELEASE-NAME - app.kubernetes.io/component: default-backend - topologyKey: topology.kubernetes.io/zone - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - labelSelector: - matchLabels: - app.kubernetes.io/name: ingress-nginx - app.kubernetes.io/instance: RELEASE-NAME - app.kubernetes.io/component: default-backend - topologyKey: kubernetes.io/hostname - maxSkew: 1 - whenUnsatisfiable: ScheduleAnyway - - - it: should create a Deployment with affinity if `defaultBackend.affinity` is set - set: - defaultBackend.enabled: true - defaultBackend.affinity: - podAntiAffinity: - requiredDuringSchedulingIgnoredDuringExecution: - - labelSelector: - matchExpressions: - - key: app.kubernetes.io/name - operator: In - values: - - '{{ include "ingress-nginx.name" . }}' - - key: app.kubernetes.io/instance - operator: In - values: - - '{{ .Release.Name }}' - - key: app.kubernetes.io/component - operator: In - values: - - default-backend - topologyKey: kubernetes.io/hostname - asserts: - - equal: - path: spec.template.spec.affinity - value: - podAntiAffinity: - requiredDuringSchedulingIgnoredDuringExecution: - - labelSelector: - matchExpressions: - - key: app.kubernetes.io/name - operator: In - values: - - ingress-nginx - - key: app.kubernetes.io/instance - operator: In - values: - - RELEASE-NAME - - key: app.kubernetes.io/component - operator: In - values: - - default-backend - topologyKey: kubernetes.io/hostname - - - it: should create a Deployment with a custom registry if `defaultBackend.image.registry` is set - set: - defaultBackend.enabled: true - defaultBackend.image.registry: custom.registry.io - defaultBackend.image.tag: v1.0.0-dev - defaultBackend.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: custom.registry.io/defaultbackend-amd64:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - - - it: should create a Deployment with a custom image if `defaultBackend.image.image` is set - set: - defaultBackend.enabled: true - defaultBackend.image.image: custom-repo/custom-image - defaultBackend.image.tag: v1.0.0-dev - defaultBackend.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: registry.k8s.io/custom-repo/custom-image:v1.0.0-dev@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - - - it: should create a Deployment with a custom tag if `defaultBackend.image.tag` is set - set: - defaultBackend.enabled: true - defaultBackend.image.tag: custom-tag - defaultBackend.image.digest: sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd - asserts: - - equal: - path: spec.template.spec.containers[0].image - value: registry.k8s.io/defaultbackend-amd64:custom-tag@sha256:faa2d18687f734994b6bd9e309e7a73852a81c30e1b8f63165fcd4f0a087e3cd diff --git a/charts/keep/charts/ingress-nginx/tests/default-backend-extra-configmaps_test.yaml b/charts/keep/charts/ingress-nginx/tests/default-backend-extra-configmaps_test.yaml deleted file mode 100644 index aa600e7..0000000 --- a/charts/keep/charts/ingress-nginx/tests/default-backend-extra-configmaps_test.yaml +++ /dev/null @@ -1,50 +0,0 @@ -suite: Default Backend > Extra ConfigMaps -templates: - - default-backend-extra-configmaps.yaml - -tests: - - it: should not create a ConfigMap if `defaultBackend.extraConfigMaps` is empty - set: - defaultBackend.enabled: true - defaultBackend.extraConfigMaps: [] - asserts: - - hasDocuments: - count: 0 - - - it: should create one ConfigMap if `defaultBackend.extraConfigMaps` has one element - set: - defaultBackend.enabled: true - defaultBackend.extraConfigMaps: - - name: my-configmap-1 - data: - key1: value1 - asserts: - - hasDocuments: - count: 1 - - isKind: - of: ConfigMap - - equal: - path: metadata.name - value: my-configmap-1 - - equal: - path: data.key1 - value: value1 - - - it: should create two ConfigMaps if `defaultBackend.extraConfigMaps` has two elements - set: - defaultBackend.enabled: true - defaultBackend.extraConfigMaps: - - name: my-configmap-1 - data: - key1: value1 - - name: my-configmap-2 - data: - key2: value2 - asserts: - - hasDocuments: - count: 2 - - isKind: - of: ConfigMap - - matchRegex: - path: metadata.name - pattern: my-configmap-(1|2) diff --git a/charts/keep/charts/ingress-nginx/tests/default-backend-poddisruptionbudget_test.yaml b/charts/keep/charts/ingress-nginx/tests/default-backend-poddisruptionbudget_test.yaml deleted file mode 100644 index 0958018..0000000 --- a/charts/keep/charts/ingress-nginx/tests/default-backend-poddisruptionbudget_test.yaml +++ /dev/null @@ -1,48 +0,0 @@ -suite: Default Backend > PodDisruptionBudget -templates: - - default-backend-poddisruptionbudget.yaml - -tests: - - it: should create a PodDisruptionBudget if `defaultBackend.replicaCount` is greater than 1 - set: - defaultBackend.enabled: true - defaultBackend.replicaCount: 2 - asserts: - - hasDocuments: - count: 1 - - isKind: - of: PodDisruptionBudget - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-defaultbackend - - - it: should not create a PodDisruptionBudget if `defaultBackend.replicaCount` is less than or equal 1 - set: - defaultBackend.enabled: true - defaultBackend.replicaCount: 1 - asserts: - - hasDocuments: - count: 0 - - - it: should create a PodDisruptionBudget if `defaultBackend.autoscaling.enabled` is true and `defaultBackend.autoscaling.minReplicas` is greater than 1 - set: - defaultBackend.enabled: true - defaultBackend.autoscaling.enabled: true - defaultBackend.autoscaling.minReplicas: 2 - asserts: - - hasDocuments: - count: 1 - - isKind: - of: PodDisruptionBudget - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-defaultbackend - - - it: should not create a PodDisruptionBudget if `defaultBackend.autoscaling.enabled` is true and `defaultBackend.autoscaling.minReplicas` is less than or equal 1 - set: - defaultBackend.enabled: true - defaultBackend.autoscaling.enabled: true - defaultBackend.autoscaling.minReplicas: 1 - asserts: - - hasDocuments: - count: 0 diff --git a/charts/keep/charts/ingress-nginx/tests/default-backend-service_test.yaml b/charts/keep/charts/ingress-nginx/tests/default-backend-service_test.yaml deleted file mode 100644 index f16904f..0000000 --- a/charts/keep/charts/ingress-nginx/tests/default-backend-service_test.yaml +++ /dev/null @@ -1,32 +0,0 @@ -suite: Default Backend > Service -templates: - - default-backend-service.yaml - -tests: - - it: should not create a Service if `defaultBackend.enabled` is false - set: - defaultBackend.enabled: false - asserts: - - hasDocuments: - count: 0 - - - it: should create a Service if `defaultBackend.enabled` is true - set: - defaultBackend.enabled: true - asserts: - - hasDocuments: - count: 1 - - isKind: - of: Service - - equal: - path: metadata.name - value: RELEASE-NAME-ingress-nginx-defaultbackend - - - it: should create a Service with port 80 if `defaultBackend.service.port` is 80 - set: - defaultBackend.enabled: true - defaultBackend.service.port: 80 - asserts: - - equal: - path: spec.ports[0].port - value: 80 diff --git a/charts/keep/charts/ingress-nginx/values.yaml b/charts/keep/charts/ingress-nginx/values.yaml deleted file mode 100644 index f42a682..0000000 --- a/charts/keep/charts/ingress-nginx/values.yaml +++ /dev/null @@ -1,1192 +0,0 @@ -## nginx configuration -## Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/nginx-configuration/index.md -## - -## Overrides for generated resource names -# See templates/_helpers.tpl -# nameOverride: -# fullnameOverride: - -# -- Override the deployment namespace; defaults to .Release.Namespace -namespaceOverride: "" -## Labels to apply to all resources -## -commonLabels: {} -# scmhash: abc123 -# myLabel: aakkmd - -controller: - name: controller - enableAnnotationValidations: false - image: - ## Keep false as default for now! - chroot: false - registry: registry.k8s.io - image: ingress-nginx/controller - ## for backwards compatibility consider setting the full image url via the repository value below - ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail - ## repository: - tag: "v1.11.3" - digest: sha256:d56f135b6462cfc476447cfe564b83a45e8bb7da2774963b00d12161112270b7 - digestChroot: sha256:22701f0fc0f2dd209ef782f4e281bfe2d8cccd50ededa00aec88e0cdbe7edd14 - pullPolicy: IfNotPresent - runAsNonRoot: true - # www-data -> uid 101 - runAsUser: 101 - allowPrivilegeEscalation: false - seccompProfile: - type: RuntimeDefault - readOnlyRootFilesystem: false - # -- Use an existing PSP instead of creating one - existingPsp: "" - # -- Configures the controller container name - containerName: controller - # -- Configures the ports that the nginx-controller listens on - containerPort: - http: 80 - https: 443 - # -- Global configuration passed to the ConfigMap consumed by the controller. Values may contain Helm templates. - # Ref.: https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/ - config: {} - # -- Annotations to be added to the controller config configuration configmap. - configAnnotations: {} - # -- Will add custom headers before sending traffic to backends according to https://github.com/kubernetes/ingress-nginx/tree/main/docs/examples/customization/custom-headers - proxySetHeaders: {} - # -- Will add custom headers before sending response traffic to the client according to: https://kubernetes.github.io/ingress-nginx/user-guide/nginx-configuration/configmap/#add-headers - addHeaders: {} - # -- Optionally customize the pod dnsConfig. - dnsConfig: {} - # -- Optionally customize the pod hostAliases. - hostAliases: [] - # - ip: 127.0.0.1 - # hostnames: - # - foo.local - # - bar.local - # - ip: 10.1.2.3 - # hostnames: - # - foo.remote - # - bar.remote - # -- Optionally customize the pod hostname. - hostname: {} - # -- Optionally change this to ClusterFirstWithHostNet in case you have 'hostNetwork: true'. - # By default, while using host network, name resolution uses the host's DNS. If you wish nginx-controller - # to keep resolving names inside the k8s network, use ClusterFirstWithHostNet. - dnsPolicy: ClusterFirst - # -- Bare-metal considerations via the host network https://kubernetes.github.io/ingress-nginx/deploy/baremetal/#via-the-host-network - # Ingress status was blank because there is no Service exposing the Ingress-Nginx Controller in a configuration using the host network, the default --publish-service flag used in standard cloud setups does not apply - reportNodeInternalIp: false - # -- Process Ingress objects without ingressClass annotation/ingressClassName field - # Overrides value for --watch-ingress-without-class flag of the controller binary - # Defaults to false - watchIngressWithoutClass: false - # -- Process IngressClass per name (additionally as per spec.controller). - ingressClassByName: false - # -- This configuration enables Topology Aware Routing feature, used together with service annotation service.kubernetes.io/topology-mode="auto" - # Defaults to false - enableTopologyAwareRouting: false - # -- This configuration disable Nginx Controller Leader Election - disableLeaderElection: false - # -- Duration a leader election is valid before it's getting re-elected, e.g. `15s`, `10m` or `1h`. (Default: 30s) - electionTTL: "" - # -- This configuration defines if Ingress Controller should allow users to set - # their own *-snippet annotations, otherwise this is forbidden / dropped - # when users add those annotations. - # Global snippets in ConfigMap are still respected - allowSnippetAnnotations: false - # -- Required for use with CNI based kubernetes installations (such as ones set up by kubeadm), - # since CNI and hostport don't mix yet. Can be deprecated once https://github.com/kubernetes/kubernetes/issues/23920 - # is merged - hostNetwork: false - ## Use host ports 80 and 443 - ## Disabled by default - hostPort: - # -- Enable 'hostPort' or not - enabled: false - ports: - # -- 'hostPort' http port - http: 80 - # -- 'hostPort' https port - https: 443 - # NetworkPolicy for controller component. - networkPolicy: - # -- Enable 'networkPolicy' or not - enabled: false - # -- Election ID to use for status update, by default it uses the controller name combined with a suffix of 'leader' - electionID: "" - # -- This section refers to the creation of the IngressClass resource. - # IngressClasses are immutable and cannot be changed after creation. - # We do not support namespaced IngressClasses, yet, so a ClusterRole and a ClusterRoleBinding is required. - ingressClassResource: - # -- Name of the IngressClass - name: nginx - # -- Create the IngressClass or not - enabled: true - # -- If true, Ingresses without `ingressClassName` get assigned to this IngressClass on creation. - # Ingress creation gets rejected if there are multiple default IngressClasses. - # Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#default-ingress-class - default: false - # -- Annotations to be added to the IngressClass resource. - annotations: {} - # -- Controller of the IngressClass. An Ingress Controller looks for IngressClasses it should reconcile by this value. - # This value is also being set as the `--controller-class` argument of this Ingress Controller. - # Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#ingress-class - controllerValue: k8s.io/ingress-nginx - # -- Aliases of this IngressClass. Creates copies with identical settings but the respective alias as name. - # Useful for development environments with only one Ingress Controller but production-like Ingress resources. - # `default` gets enabled on the original IngressClass only. - aliases: [] - # aliases: - # - nginx-alias-1 - # - nginx-alias-2 - # -- A link to a custom resource containing additional configuration for the controller. - # This is optional if the controller consuming this IngressClass does not require additional parameters. - # Ref: https://kubernetes.io/docs/concepts/services-networking/ingress/#ingress-class - parameters: {} - # parameters: - # apiGroup: k8s.example.com - # kind: IngressParameters - # name: external-lb - # -- For backwards compatibility with ingress.class annotation, use ingressClass. - # Algorithm is as follows, first ingressClassName is considered, if not present, controller looks for ingress.class annotation - ingressClass: nginx - # -- Labels to add to the pod container metadata - podLabels: {} - # key: value - - # -- Security context for controller pods - podSecurityContext: {} - # -- sysctls for controller pods - ## Ref: https://kubernetes.io/docs/tasks/administer-cluster/sysctl-cluster/ - sysctls: {} - # sysctls: - # "net.core.somaxconn": "8192" - # -- Security context for controller containers - containerSecurityContext: {} - # -- Allows customization of the source of the IP address or FQDN to report - # in the ingress status field. By default, it reads the information provided - # by the service. If disable, the status field reports the IP address of the - # node or nodes where an ingress controller pod is running. - publishService: - # -- Enable 'publishService' or not - enabled: true - # -- Allows overriding of the publish service to bind to - # Must be / - pathOverride: "" - # Limit the scope of the controller to a specific namespace - scope: - # -- Enable 'scope' or not - enabled: false - # -- Namespace to limit the controller to; defaults to $(POD_NAMESPACE) - namespace: "" - # -- When scope.enabled == false, instead of watching all namespaces, we watching namespaces whose labels - # only match with namespaceSelector. Format like foo=bar. Defaults to empty, means watching all namespaces. - namespaceSelector: "" - # -- Allows customization of the configmap / nginx-configmap namespace; defaults to $(POD_NAMESPACE) - configMapNamespace: "" - tcp: - # -- Allows customization of the tcp-services-configmap; defaults to $(POD_NAMESPACE) - configMapNamespace: "" - # -- Annotations to be added to the tcp config configmap - annotations: {} - udp: - # -- Allows customization of the udp-services-configmap; defaults to $(POD_NAMESPACE) - configMapNamespace: "" - # -- Annotations to be added to the udp config configmap - annotations: {} - # -- Maxmind license key to download GeoLite2 Databases. - ## https://blog.maxmind.com/2019/12/significant-changes-to-accessing-and-using-geolite2-databases/ - maxmindLicenseKey: "" - # -- Additional command line arguments to pass to Ingress-Nginx Controller - # E.g. to specify the default SSL certificate you can use - extraArgs: {} - ## extraArgs: - ## default-ssl-certificate: "/" - ## time-buckets: "0.005,0.01,0.025,0.05,0.1,0.25,0.5,1,2.5,5,10" - ## length-buckets: "10,20,30,40,50,60,70,80,90,100" - ## size-buckets: "10,100,1000,10000,100000,1e+06,1e+07" - - # -- Additional environment variables to set - extraEnvs: [] - # extraEnvs: - # - name: FOO - # valueFrom: - # secretKeyRef: - # key: FOO - # name: secret-resource - - # -- Use a `DaemonSet` or `Deployment` - kind: Deployment - # -- Annotations to be added to the controller Deployment or DaemonSet - ## - annotations: {} - # keel.sh/pollSchedule: "@every 60m" - - # -- Labels to be added to the controller Deployment or DaemonSet and other resources that do not have option to specify labels - ## - labels: {} - # keel.sh/policy: patch - # keel.sh/trigger: poll - - # -- The update strategy to apply to the Deployment or DaemonSet - ## - updateStrategy: {} - # rollingUpdate: - # maxUnavailable: 1 - # type: RollingUpdate - - # -- `minReadySeconds` to avoid killing pods before we are ready - ## - minReadySeconds: 0 - # -- Node tolerations for server scheduling to nodes with taints - ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/ - ## - tolerations: [] - # - key: "key" - # operator: "Equal|Exists" - # value: "value" - # effect: "NoSchedule|PreferNoSchedule|NoExecute(1.6 only)" - - # -- Affinity and anti-affinity rules for server scheduling to nodes - ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#affinity-and-anti-affinity - ## - affinity: {} - # # An example of preferred pod anti-affinity, weight is in the range 1-100 - # podAntiAffinity: - # preferredDuringSchedulingIgnoredDuringExecution: - # - weight: 100 - # podAffinityTerm: - # labelSelector: - # matchExpressions: - # - key: app.kubernetes.io/name - # operator: In - # values: - # - '{{ include "ingress-nginx.name" . }}' - # - key: app.kubernetes.io/instance - # operator: In - # values: - # - '{{ .Release.Name }}' - # - key: app.kubernetes.io/component - # operator: In - # values: - # - controller - # topologyKey: kubernetes.io/hostname - - # # An example of required pod anti-affinity - # podAntiAffinity: - # requiredDuringSchedulingIgnoredDuringExecution: - # - labelSelector: - # matchExpressions: - # - key: app.kubernetes.io/name - # operator: In - # values: - # - '{{ include "ingress-nginx.name" . }}' - # - key: app.kubernetes.io/instance - # operator: In - # values: - # - '{{ .Release.Name }}' - # - key: app.kubernetes.io/component - # operator: In - # values: - # - controller - # topologyKey: kubernetes.io/hostname - - # -- Topology spread constraints rely on node labels to identify the topology domain(s) that each Node is in. - ## Ref: https://kubernetes.io/docs/concepts/workloads/pods/pod-topology-spread-constraints/ - ## - topologySpreadConstraints: [] - # - labelSelector: - # matchLabels: - # app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - # app.kubernetes.io/instance: '{{ .Release.Name }}' - # app.kubernetes.io/component: controller - # topologyKey: topology.kubernetes.io/zone - # maxSkew: 1 - # whenUnsatisfiable: ScheduleAnyway - # - labelSelector: - # matchLabels: - # app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - # app.kubernetes.io/instance: '{{ .Release.Name }}' - # app.kubernetes.io/component: controller - # topologyKey: kubernetes.io/hostname - # maxSkew: 1 - # whenUnsatisfiable: ScheduleAnyway - - # -- `terminationGracePeriodSeconds` to avoid killing pods before we are ready - ## wait up to five minutes for the drain of connections - ## - terminationGracePeriodSeconds: 300 - # -- Node labels for controller pod assignment - ## Ref: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/ - ## - nodeSelector: - kubernetes.io/os: linux - ## Liveness and readiness probe values - ## Ref: https://kubernetes.io/docs/concepts/workloads/pods/pod-lifecycle/#container-probes - ## - ## startupProbe: - ## httpGet: - ## # should match container.healthCheckPath - ## path: "/healthz" - ## port: 10254 - ## scheme: HTTP - ## initialDelaySeconds: 5 - ## periodSeconds: 5 - ## timeoutSeconds: 2 - ## successThreshold: 1 - ## failureThreshold: 5 - livenessProbe: - httpGet: - # should match container.healthCheckPath - path: "/healthz" - port: 10254 - scheme: HTTP - initialDelaySeconds: 10 - periodSeconds: 10 - timeoutSeconds: 1 - successThreshold: 1 - failureThreshold: 5 - readinessProbe: - httpGet: - # should match container.healthCheckPath - path: "/healthz" - port: 10254 - scheme: HTTP - initialDelaySeconds: 10 - periodSeconds: 10 - timeoutSeconds: 1 - successThreshold: 1 - failureThreshold: 3 - # -- Path of the health check endpoint. All requests received on the port defined by - # the healthz-port parameter are forwarded internally to this path. - healthCheckPath: "/healthz" - # -- Address to bind the health check endpoint. - # It is better to set this option to the internal node address - # if the Ingress-Nginx Controller is running in the `hostNetwork: true` mode. - healthCheckHost: "" - # -- Annotations to be added to controller pods - ## - podAnnotations: {} - replicaCount: 1 - # -- Minimum available pods set in PodDisruptionBudget. - # Define either 'minAvailable' or 'maxUnavailable', never both. - minAvailable: 1 - # -- Maximum unavailable pods set in PodDisruptionBudget. If set, 'minAvailable' is ignored. - # maxUnavailable: 1 - - ## Define requests resources to avoid probe issues due to CPU utilization in busy nodes - ## ref: https://github.com/kubernetes/ingress-nginx/issues/4735#issuecomment-551204903 - ## Ideally, there should be no limits. - ## https://engineering.indeedblog.com/blog/2019/12/cpu-throttling-regression-fix/ - resources: - ## limits: - ## cpu: 100m - ## memory: 90Mi - requests: - cpu: 100m - memory: 90Mi - # Mutually exclusive with keda autoscaling - autoscaling: - enabled: false - annotations: {} - minReplicas: 1 - maxReplicas: 11 - targetCPUUtilizationPercentage: 50 - targetMemoryUtilizationPercentage: 50 - behavior: {} - # scaleDown: - # stabilizationWindowSeconds: 300 - # policies: - # - type: Pods - # value: 1 - # periodSeconds: 180 - # scaleUp: - # stabilizationWindowSeconds: 300 - # policies: - # - type: Pods - # value: 2 - # periodSeconds: 60 - autoscalingTemplate: [] - # Custom or additional autoscaling metrics - # ref: https://kubernetes.io/docs/tasks/run-application/horizontal-pod-autoscale/#support-for-custom-metrics - # - type: Pods - # pods: - # metric: - # name: nginx_ingress_controller_nginx_process_requests_total - # target: - # type: AverageValue - # averageValue: 10000m - - # Mutually exclusive with hpa autoscaling - keda: - apiVersion: "keda.sh/v1alpha1" - ## apiVersion changes with keda 1.x vs 2.x - ## 2.x = keda.sh/v1alpha1 - ## 1.x = keda.k8s.io/v1alpha1 - enabled: false - minReplicas: 1 - maxReplicas: 11 - pollingInterval: 30 - cooldownPeriod: 300 - # fallback: - # failureThreshold: 3 - # replicas: 11 - restoreToOriginalReplicaCount: false - scaledObject: - annotations: {} - # Custom annotations for ScaledObject resource - # annotations: - # key: value - triggers: [] - # - type: prometheus - # metadata: - # serverAddress: http://:9090 - # metricName: http_requests_total - # threshold: '100' - # query: sum(rate(http_requests_total{deployment="my-deployment"}[2m])) - - behavior: {} - # scaleDown: - # stabilizationWindowSeconds: 300 - # policies: - # - type: Pods - # value: 1 - # periodSeconds: 180 - # scaleUp: - # stabilizationWindowSeconds: 300 - # policies: - # - type: Pods - # value: 2 - # periodSeconds: 60 - # -- Enable mimalloc as a drop-in replacement for malloc. - ## ref: https://github.com/microsoft/mimalloc - ## - enableMimalloc: true - ## Override NGINX template - customTemplate: - configMapName: "" - configMapKey: "" - service: - # -- Enable controller services or not. This does not influence the creation of either the admission webhook or the metrics service. - enabled: true - external: - # -- Enable the external controller service or not. Useful for internal-only deployments. - enabled: true - # -- Annotations to be added to the external controller service. See `controller.service.internal.annotations` for annotations to be added to the internal controller service. - annotations: {} - # -- Labels to be added to both controller services. - labels: {} - # -- Type of the external controller service. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types - type: LoadBalancer - # -- Pre-defined cluster internal IP address of the external controller service. Take care of collisions with existing services. - # This value is immutable. Set once, it can not be changed without deleting and re-creating the service. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#choosing-your-own-ip-address - clusterIP: "" - # -- List of node IP addresses at which the external controller service is available. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips - externalIPs: [] - # -- Deprecated: Pre-defined IP address of the external controller service. Used by cloud providers to connect the resulting load balancer service to a pre-existing static IP. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#loadbalancer - loadBalancerIP: "" - # -- Restrict access to the external controller service. Values must be CIDRs. Allows any source address by default. - loadBalancerSourceRanges: [] - # -- Load balancer class of the external controller service. Used by cloud providers to select a load balancer implementation other than the cloud provider default. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-class - loadBalancerClass: "" - # -- Enable node port allocation for the external controller service or not. Applies to type `LoadBalancer` only. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-nodeport-allocation - # allocateLoadBalancerNodePorts: true - - # -- External traffic policy of the external controller service. Set to "Local" to preserve source IP on providers supporting it. - # Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip - externalTrafficPolicy: "" - # -- Session affinity of the external controller service. Must be either "None" or "ClientIP" if set. Defaults to "None". - # Ref: https://kubernetes.io/docs/reference/networking/virtual-ips/#session-affinity - sessionAffinity: "" - # -- Specifies the health check node port (numeric port number) for the external controller service. - # If not specified, the service controller allocates a port from your cluster's node port range. - # Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip - # healthCheckNodePort: 0 - - # -- Represents the dual-stack capabilities of the external controller service. Possible values are SingleStack, PreferDualStack or RequireDualStack. - # Fields `ipFamilies` and `clusterIP` depend on the value of this field. - # Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services - ipFamilyPolicy: SingleStack - # -- List of IP families (e.g. IPv4, IPv6) assigned to the external controller service. This field is usually assigned automatically based on cluster configuration and the `ipFamilyPolicy` field. - # Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services - ipFamilies: - - IPv4 - # -- Enable the HTTP listener on both controller services or not. - enableHttp: true - # -- Enable the HTTPS listener on both controller services or not. - enableHttps: true - ports: - # -- Port the external HTTP listener is published with. - http: 80 - # -- Port the external HTTPS listener is published with. - https: 443 - targetPorts: - # -- Port of the ingress controller the external HTTP listener is mapped to. - http: http - # -- Port of the ingress controller the external HTTPS listener is mapped to. - https: https - # -- Declare the app protocol of the external HTTP and HTTPS listeners or not. Supersedes provider-specific annotations for declaring the backend protocol. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#application-protocol - appProtocol: true - nodePorts: - # -- Node port allocated for the external HTTP listener. If left empty, the service controller allocates one from the configured node port range. - http: "" - # -- Node port allocated for the external HTTPS listener. If left empty, the service controller allocates one from the configured node port range. - https: "" - # -- Node port mapping for external TCP listeners. If left empty, the service controller allocates them from the configured node port range. - # Example: - # tcp: - # 8080: 30080 - tcp: {} - # -- Node port mapping for external UDP listeners. If left empty, the service controller allocates them from the configured node port range. - # Example: - # udp: - # 53: 30053 - udp: {} - internal: - # -- Enable the internal controller service or not. Remember to configure `controller.service.internal.annotations` when enabling this. - enabled: false - # -- Annotations to be added to the internal controller service. Mandatory for the internal controller service to be created. Varies with the cloud service. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#internal-load-balancer - annotations: {} - # -- Type of the internal controller service. - # Defaults to the value of `controller.service.type`. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#publishing-services-service-types - type: "" - # -- Pre-defined cluster internal IP address of the internal controller service. Take care of collisions with existing services. - # This value is immutable. Set once, it can not be changed without deleting and re-creating the service. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#choosing-your-own-ip-address - clusterIP: "" - # -- List of node IP addresses at which the internal controller service is available. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips - externalIPs: [] - # -- Deprecated: Pre-defined IP address of the internal controller service. Used by cloud providers to connect the resulting load balancer service to a pre-existing static IP. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#loadbalancer - loadBalancerIP: "" - # -- Restrict access to the internal controller service. Values must be CIDRs. Allows any source address by default. - loadBalancerSourceRanges: [] - # -- Load balancer class of the internal controller service. Used by cloud providers to select a load balancer implementation other than the cloud provider default. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-class - loadBalancerClass: "" - # -- Enable node port allocation for the internal controller service or not. Applies to type `LoadBalancer` only. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#load-balancer-nodeport-allocation - # allocateLoadBalancerNodePorts: true - - # -- External traffic policy of the internal controller service. Set to "Local" to preserve source IP on providers supporting it. - # Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip - externalTrafficPolicy: "" - # -- Session affinity of the internal controller service. Must be either "None" or "ClientIP" if set. Defaults to "None". - # Ref: https://kubernetes.io/docs/reference/networking/virtual-ips/#session-affinity - sessionAffinity: "" - # -- Specifies the health check node port (numeric port number) for the internal controller service. - # If not specified, the service controller allocates a port from your cluster's node port range. - # Ref: https://kubernetes.io/docs/tasks/access-application-cluster/create-external-load-balancer/#preserving-the-client-source-ip - # healthCheckNodePort: 0 - - # -- Represents the dual-stack capabilities of the internal controller service. Possible values are SingleStack, PreferDualStack or RequireDualStack. - # Fields `ipFamilies` and `clusterIP` depend on the value of this field. - # Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services - ipFamilyPolicy: SingleStack - # -- List of IP families (e.g. IPv4, IPv6) assigned to the internal controller service. This field is usually assigned automatically based on cluster configuration and the `ipFamilyPolicy` field. - # Ref: https://kubernetes.io/docs/concepts/services-networking/dual-stack/#services - ipFamilies: - - IPv4 - ports: {} - # -- Port the internal HTTP listener is published with. - # Defaults to the value of `controller.service.ports.http`. - # http: 80 - # -- Port the internal HTTPS listener is published with. - # Defaults to the value of `controller.service.ports.https`. - # https: 443 - - targetPorts: {} - # -- Port of the ingress controller the internal HTTP listener is mapped to. - # Defaults to the value of `controller.service.targetPorts.http`. - # http: http - # -- Port of the ingress controller the internal HTTPS listener is mapped to. - # Defaults to the value of `controller.service.targetPorts.https`. - # https: https - - # -- Declare the app protocol of the internal HTTP and HTTPS listeners or not. Supersedes provider-specific annotations for declaring the backend protocol. - # Ref: https://kubernetes.io/docs/concepts/services-networking/service/#application-protocol - appProtocol: true - nodePorts: - # -- Node port allocated for the internal HTTP listener. If left empty, the service controller allocates one from the configured node port range. - http: "" - # -- Node port allocated for the internal HTTPS listener. If left empty, the service controller allocates one from the configured node port range. - https: "" - # -- Node port mapping for internal TCP listeners. If left empty, the service controller allocates them from the configured node port range. - # Example: - # tcp: - # 8080: 30080 - tcp: {} - # -- Node port mapping for internal UDP listeners. If left empty, the service controller allocates them from the configured node port range. - # Example: - # udp: - # 53: 30053 - udp: {} - # shareProcessNamespace enables process namespace sharing within the pod. - # This can be used for example to signal log rotation using `kill -USR1` from a sidecar. - shareProcessNamespace: false - # -- Additional containers to be added to the controller pod. - # See https://github.com/lemonldap-ng-controller/lemonldap-ng-controller as example. - extraContainers: [] - # - name: my-sidecar - # image: nginx:latest - # - name: lemonldap-ng-controller - # image: lemonldapng/lemonldap-ng-controller:0.2.0 - # args: - # - /lemonldap-ng-controller - # - --alsologtostderr - # - --configmap=$(POD_NAMESPACE)/lemonldap-ng-configuration - # env: - # - name: POD_NAME - # valueFrom: - # fieldRef: - # fieldPath: metadata.name - # - name: POD_NAMESPACE - # valueFrom: - # fieldRef: - # fieldPath: metadata.namespace - # volumeMounts: - # - name: copy-portal-skins - # mountPath: /srv/var/lib/lemonldap-ng/portal/skins - - # -- Additional volumeMounts to the controller main container. - extraVolumeMounts: [] - # - name: copy-portal-skins - # mountPath: /var/lib/lemonldap-ng/portal/skins - - # -- Additional volumes to the controller pod. - extraVolumes: [] - # - name: copy-portal-skins - # emptyDir: {} - - # -- Containers, which are run before the app containers are started. - extraInitContainers: [] - # - name: init-myservice - # image: busybox - # command: ['sh', '-c', 'until nslookup myservice; do echo waiting for myservice; sleep 2; done;'] - - # -- Modules, which are mounted into the core nginx image. See values.yaml for a sample to add opentelemetry module - extraModules: [] - # - name: mytestmodule - # image: - # registry: registry.k8s.io - # image: ingress-nginx/mytestmodule - # ## for backwards compatibility consider setting the full image url via the repository value below - # ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail - # ## repository: - # tag: "v1.0.0" - # digest: "" - # distroless: false - # containerSecurityContext: - # runAsNonRoot: true - # runAsUser: - # allowPrivilegeEscalation: false - # seccompProfile: - # type: RuntimeDefault - # capabilities: - # drop: - # - ALL - # readOnlyRootFilesystem: true - # resources: {} - # - # The image must contain a `/usr/local/bin/init_module.sh` executable, which - # will be executed as initContainers, to move its config files within the - # mounted volume. - - opentelemetry: - enabled: false - name: opentelemetry - image: - registry: registry.k8s.io - image: ingress-nginx/opentelemetry-1.25.3 - ## for backwards compatibility consider setting the full image url via the repository value below - ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail - ## repository: - tag: v20240813-b933310d - digest: sha256:f7604ac0547ed64d79b98d92133234e66c2c8aade3c1f4809fed5eec1fb7f922 - distroless: true - containerSecurityContext: - runAsNonRoot: true - # -- The image's default user, inherited from its base image `cgr.dev/chainguard/static`. - runAsUser: 65532 - allowPrivilegeEscalation: false - seccompProfile: - type: RuntimeDefault - capabilities: - drop: - - ALL - readOnlyRootFilesystem: true - resources: {} - admissionWebhooks: - name: admission - annotations: {} - # ignore-check.kube-linter.io/no-read-only-rootfs: "This deployment needs write access to root filesystem". - - ## Additional annotations to the admission webhooks. - ## These annotations will be added to the ValidatingWebhookConfiguration and - ## the Jobs Spec of the admission webhooks. - enabled: true - # -- Additional environment variables to set - extraEnvs: [] - # extraEnvs: - # - name: FOO - # valueFrom: - # secretKeyRef: - # key: FOO - # name: secret-resource - # -- Admission Webhook failure policy to use - failurePolicy: Fail - # timeoutSeconds: 10 - port: 8443 - certificate: "/usr/local/certificates/cert" - key: "/usr/local/certificates/key" - namespaceSelector: {} - objectSelector: {} - # -- Labels to be added to admission webhooks - labels: {} - # -- Use an existing PSP instead of creating one - existingPsp: "" - service: - annotations: {} - # clusterIP: "" - externalIPs: [] - # loadBalancerIP: "" - loadBalancerSourceRanges: [] - servicePort: 443 - type: ClusterIP - createSecretJob: - name: create - # -- Security context for secret creation containers - securityContext: - runAsNonRoot: true - runAsUser: 65532 - allowPrivilegeEscalation: false - seccompProfile: - type: RuntimeDefault - capabilities: - drop: - - ALL - readOnlyRootFilesystem: true - resources: {} - # limits: - # cpu: 10m - # memory: 20Mi - # requests: - # cpu: 10m - # memory: 20Mi - patchWebhookJob: - name: patch - # -- Security context for webhook patch containers - securityContext: - runAsNonRoot: true - runAsUser: 65532 - allowPrivilegeEscalation: false - seccompProfile: - type: RuntimeDefault - capabilities: - drop: - - ALL - readOnlyRootFilesystem: true - resources: {} - patch: - enabled: true - image: - registry: registry.k8s.io - image: ingress-nginx/kube-webhook-certgen - ## for backwards compatibility consider setting the full image url via the repository value below - ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail - ## repository: - tag: v1.4.4 - digest: sha256:a9f03b34a3cbfbb26d103a14046ab2c5130a80c3d69d526ff8063d2b37b9fd3f - pullPolicy: IfNotPresent - # -- Provide a priority class name to the webhook patching job - ## - priorityClassName: "" - podAnnotations: {} - # NetworkPolicy for webhook patch - networkPolicy: - # -- Enable 'networkPolicy' or not - enabled: false - nodeSelector: - kubernetes.io/os: linux - tolerations: [] - # -- Labels to be added to patch job resources - labels: {} - # -- Security context for secret creation & webhook patch pods - securityContext: {} - # -- Admission webhook patch job RBAC - rbac: - # -- Create RBAC or not - create: true - # -- Admission webhook patch job service account - serviceAccount: - # -- Create a service account or not - create: true - # -- Custom service account name - name: "" - # -- Auto-mount service account token or not - automountServiceAccountToken: true - # Use certmanager to generate webhook certs - certManager: - enabled: false - # self-signed root certificate - rootCert: - # default to be 5y - duration: "" - admissionCert: - # default to be 1y - duration: "" - # issuerRef: - # name: "issuer" - # kind: "ClusterIssuer" - metrics: - port: 10254 - portName: metrics - # if this port is changed, change healthz-port: in extraArgs: accordingly - enabled: false - service: - annotations: {} - # prometheus.io/scrape: "true" - # prometheus.io/port: "10254" - # -- Labels to be added to the metrics service resource - labels: {} - # clusterIP: "" - - # -- List of IP addresses at which the stats-exporter service is available - ## Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips - ## - externalIPs: [] - # loadBalancerIP: "" - loadBalancerSourceRanges: [] - servicePort: 10254 - type: ClusterIP - # externalTrafficPolicy: "" - # nodePort: "" - serviceMonitor: - enabled: false - additionalLabels: {} - # -- Annotations to be added to the ServiceMonitor. - annotations: {} - ## The label to use to retrieve the job name from. - ## jobLabel: "app.kubernetes.io/name" - namespace: "" - namespaceSelector: {} - ## Default: scrape .Release.Namespace or namespaceOverride only - ## To scrape all, use the following: - ## namespaceSelector: - ## any: true - scrapeInterval: 30s - # honorLabels: true - targetLabels: [] - relabelings: [] - metricRelabelings: [] - prometheusRule: - enabled: false - additionalLabels: {} - # namespace: "" - rules: [] - # # These are just examples rules, please adapt them to your needs - # - alert: NGINXConfigFailed - # expr: count(nginx_ingress_controller_config_last_reload_successful == 0) > 0 - # for: 1s - # labels: - # severity: critical - # annotations: - # description: bad ingress config - nginx config test failed - # summary: uninstall the latest ingress changes to allow config reloads to resume - # # By default a fake self-signed certificate is generated as default and - # # it is fine if it expires. If `--default-ssl-certificate` flag is used - # # and a valid certificate passed please do not filter for `host` label! - # # (i.e. delete `{host!="_"}` so also the default SSL certificate is - # # checked for expiration) - # - alert: NGINXCertificateExpiry - # expr: (avg(nginx_ingress_controller_ssl_expire_time_seconds{host!="_"}) by (host) - time()) < 604800 - # for: 1s - # labels: - # severity: critical - # annotations: - # description: ssl certificate(s) will expire in less then a week - # summary: renew expiring certificates to avoid downtime - # - alert: NGINXTooMany500s - # expr: 100 * ( sum( nginx_ingress_controller_requests{status=~"5.+"} ) / sum(nginx_ingress_controller_requests) ) > 5 - # for: 1m - # labels: - # severity: warning - # annotations: - # description: Too many 5XXs - # summary: More than 5% of all requests returned 5XX, this requires your attention - # - alert: NGINXTooMany400s - # expr: 100 * ( sum( nginx_ingress_controller_requests{status=~"4.+"} ) / sum(nginx_ingress_controller_requests) ) > 5 - # for: 1m - # labels: - # severity: warning - # annotations: - # description: Too many 4XXs - # summary: More than 5% of all requests returned 4XX, this requires your attention - # -- Improve connection draining when ingress controller pod is deleted using a lifecycle hook: - # With this new hook, we increased the default terminationGracePeriodSeconds from 30 seconds - # to 300, allowing the draining of connections up to five minutes. - # If the active connections end before that, the pod will terminate gracefully at that time. - # To effectively take advantage of this feature, the Configmap feature - # worker-shutdown-timeout new value is 240s instead of 10s. - ## - lifecycle: - preStop: - exec: - command: - - /wait-shutdown - priorityClassName: "" -# -- Rollback limit -## -revisionHistoryLimit: 10 -## Default 404 backend -## -defaultBackend: - ## - enabled: false - name: defaultbackend - image: - registry: registry.k8s.io - image: defaultbackend-amd64 - ## for backwards compatibility consider setting the full image url via the repository value below - ## use *either* current default registry/image or repository format or installing chart by providing the values.yaml will fail - ## repository: - tag: "1.5" - pullPolicy: IfNotPresent - runAsNonRoot: true - # nobody user -> uid 65534 - runAsUser: 65534 - allowPrivilegeEscalation: false - seccompProfile: - type: RuntimeDefault - readOnlyRootFilesystem: true - # -- Use an existing PSP instead of creating one - existingPsp: "" - extraArgs: {} - serviceAccount: - create: true - name: "" - automountServiceAccountToken: true - # -- Additional environment variables to set for defaultBackend pods - extraEnvs: [] - port: 8080 - ## Readiness and liveness probes for default backend - ## Ref: https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-probes/ - ## - livenessProbe: - failureThreshold: 3 - initialDelaySeconds: 30 - periodSeconds: 10 - successThreshold: 1 - timeoutSeconds: 5 - readinessProbe: - failureThreshold: 6 - initialDelaySeconds: 0 - periodSeconds: 5 - successThreshold: 1 - timeoutSeconds: 5 - # -- The update strategy to apply to the Deployment or DaemonSet - ## - updateStrategy: {} - # rollingUpdate: - # maxUnavailable: 1 - # type: RollingUpdate - - # -- `minReadySeconds` to avoid killing pods before we are ready - ## - minReadySeconds: 0 - # -- Node tolerations for server scheduling to nodes with taints - ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/ - ## - tolerations: [] - # - key: "key" - # operator: "Equal|Exists" - # value: "value" - # effect: "NoSchedule|PreferNoSchedule|NoExecute(1.6 only)" - - # -- Affinity and anti-affinity rules for server scheduling to nodes - ## Ref: https://kubernetes.io/docs/concepts/configuration/assign-pod-node/#affinity-and-anti-affinity - affinity: {} - # # An example of preferred pod anti-affinity, weight is in the range 1-100 - # podAntiAffinity: - # preferredDuringSchedulingIgnoredDuringExecution: - # - weight: 100 - # podAffinityTerm: - # labelSelector: - # matchExpressions: - # - key: app.kubernetes.io/name - # operator: In - # values: - # - '{{ include "ingress-nginx.name" . }}' - # - key: app.kubernetes.io/instance - # operator: In - # values: - # - '{{ .Release.Name }}' - # - key: app.kubernetes.io/component - # operator: In - # values: - # - default-backend - # topologyKey: kubernetes.io/hostname - - # # An example of required pod anti-affinity - # podAntiAffinity: - # requiredDuringSchedulingIgnoredDuringExecution: - # - labelSelector: - # matchExpressions: - # - key: app.kubernetes.io/name - # operator: In - # values: - # - '{{ include "ingress-nginx.name" . }}' - # - key: app.kubernetes.io/instance - # operator: In - # values: - # - '{{ .Release.Name }}' - # - key: app.kubernetes.io/component - # operator: In - # values: - # - default-backend - # topologyKey: kubernetes.io/hostname - - # -- Topology spread constraints rely on node labels to identify the topology domain(s) that each Node is in. - # Ref.: https://kubernetes.io/docs/concepts/workloads/pods/pod-topology-spread-constraints/ - topologySpreadConstraints: [] - # - labelSelector: - # matchLabels: - # app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - # app.kubernetes.io/instance: '{{ .Release.Name }}' - # app.kubernetes.io/component: default-backend - # topologyKey: topology.kubernetes.io/zone - # maxSkew: 1 - # whenUnsatisfiable: ScheduleAnyway - # - labelSelector: - # matchLabels: - # app.kubernetes.io/name: '{{ include "ingress-nginx.name" . }}' - # app.kubernetes.io/instance: '{{ .Release.Name }}' - # app.kubernetes.io/component: default-backend - # topologyKey: kubernetes.io/hostname - # maxSkew: 1 - # whenUnsatisfiable: ScheduleAnyway - # -- Security context for default backend pods - podSecurityContext: {} - # -- Security context for default backend containers - containerSecurityContext: {} - # -- Labels to add to the pod container metadata - podLabels: {} - # key: value - - # -- Node labels for default backend pod assignment - ## Ref: https://kubernetes.io/docs/concepts/scheduling-eviction/assign-pod-node/ - ## - nodeSelector: - kubernetes.io/os: linux - # -- Annotations to be added to default backend pods - ## - podAnnotations: {} - replicaCount: 1 - # -- Minimum available pods set in PodDisruptionBudget. - minAvailable: 1 - resources: {} - # limits: - # cpu: 10m - # memory: 20Mi - # requests: - # cpu: 10m - # memory: 20Mi - - extraVolumeMounts: [] - ## Additional volumeMounts to the default backend container. - # - name: copy-portal-skins - # mountPath: /var/lib/lemonldap-ng/portal/skins - - extraVolumes: [] - ## Additional volumes to the default backend pod. - # - name: copy-portal-skins - # emptyDir: {} - - extraConfigMaps: [] - ## Additional configmaps to the default backend pod. - # - name: my-extra-configmap-1 - # labels: - # type: config-1 - # data: - # extra_file_1.html: | - # - # - name: my-extra-configmap-2 - # labels: - # type: config-2 - # data: - # extra_file_2.html: | - # - - autoscaling: - annotations: {} - enabled: false - minReplicas: 1 - maxReplicas: 2 - targetCPUUtilizationPercentage: 50 - targetMemoryUtilizationPercentage: 50 - # NetworkPolicy for default backend component. - networkPolicy: - # -- Enable 'networkPolicy' or not - enabled: false - service: - annotations: {} - # clusterIP: "" - - # -- List of IP addresses at which the default backend service is available - ## Ref: https://kubernetes.io/docs/concepts/services-networking/service/#external-ips - ## - externalIPs: [] - # loadBalancerIP: "" - loadBalancerSourceRanges: [] - servicePort: 80 - type: ClusterIP - priorityClassName: "" - # -- Labels to be added to the default backend resources - labels: {} -## Enable RBAC as per https://github.com/kubernetes/ingress-nginx/blob/main/docs/deploy/rbac.md and https://github.com/kubernetes/ingress-nginx/issues/266 -rbac: - create: true - scope: false -## If true, create & use Pod Security Policy resources -## https://kubernetes.io/docs/concepts/policy/pod-security-policy/ -podSecurityPolicy: - enabled: false -serviceAccount: - create: true - name: "" - automountServiceAccountToken: true - # -- Annotations for the controller service account - annotations: {} -# -- Optional array of imagePullSecrets containing private registry credentials -## Ref: https://kubernetes.io/docs/tasks/configure-pod-container/pull-image-private-registry/ -imagePullSecrets: [] -# - name: secretName - -# -- TCP service key-value pairs -## Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/exposing-tcp-udp-services.md -## -tcp: {} -# "8080": "default/example-tcp-svc:9000" - -# -- UDP service key-value pairs -## Ref: https://github.com/kubernetes/ingress-nginx/blob/main/docs/user-guide/exposing-tcp-udp-services.md -## -udp: {} -# "53": "kube-system/kube-dns:53" - -# -- Prefix for TCP and UDP ports names in ingress controller service -## Some cloud providers, like Yandex Cloud may have a requirements for a port name regex to support cloud load balancer integration -portNamePrefix: "" -# -- (string) A base64-encoded Diffie-Hellman parameter. -# This can be generated with: `openssl dhparam 4096 2> /dev/null | base64` -## Ref: https://github.com/kubernetes/ingress-nginx/tree/main/docs/examples/customization/ssl-dh-param -dhParam: "" From b6f2f97a7af82d591f3ec4b9b00ba1d645f99026 Mon Sep 17 00:00:00 2001 From: shahargl Date: Tue, 22 Oct 2024 14:22:03 +0300 Subject: [PATCH 12/19] feat: wip --- charts/keep/README.md | 129 +++++++++++++---------- charts/keep/templates/nginx-ingress.yaml | 4 +- 2 files changed, 74 insertions(+), 59 deletions(-) diff --git a/charts/keep/README.md b/charts/keep/README.md index 7b603ee..b40d957 100644 --- a/charts/keep/README.md +++ b/charts/keep/README.md @@ -1,6 +1,6 @@ # keep -![Version: 0.1.18](https://img.shields.io/badge/Version-0.1.18-informational?style=flat-square) ![Type: application](https://img.shields.io/badge/Type-application-informational?style=flat-square) ![AppVersion: 0.25.3](https://img.shields.io/badge/AppVersion-0.25.3-informational?style=flat-square) +![Version: 0.1.25](https://img.shields.io/badge/Version-0.1.25-informational?style=flat-square) ![Type: application](https://img.shields.io/badge/Type-application-informational?style=flat-square) ![AppVersion: 0.26.1](https://img.shields.io/badge/AppVersion-0.26.1-informational?style=flat-square) Keep Helm Chart @@ -27,6 +27,13 @@ Keep Helm Chart | backend.autoscaling.minReplicas | int | `1` | | | backend.autoscaling.targetCPUUtilizationPercentage | int | `80` | | | backend.autoscaling.targetMemoryUtilizationPercentage | int | `80` | | +| backend.backendConfig.healthCheck.checkIntervalSec | int | `30` | | +| backend.backendConfig.healthCheck.healthyThreshold | int | `1` | | +| backend.backendConfig.healthCheck.path | string | `"/docs"` | | +| backend.backendConfig.healthCheck.port | int | `8080` | | +| backend.backendConfig.healthCheck.timeoutSec | int | `10` | | +| backend.backendConfig.healthCheck.type | string | `"HTTP"` | | +| backend.backendConfig.healthCheck.unhealthyThreshold | int | `3` | | | backend.databaseConnectionStringFromSecret.enabled | bool | `false` | | | backend.databaseConnectionStringFromSecret.secretKey | string | `""` | | | backend.databaseConnectionStringFromSecret.secretName | string | `""` | | @@ -37,18 +44,16 @@ Keep Helm Chart | backend.env[1].value | string | `"k8s"` | | | backend.env[2].name | string | `"PORT"` | | | backend.env[2].value | string | `"8080"` | | -| backend.env[3].name | string | `"SECRET_MANAGER_DIRECTORY"` | | -| backend.env[3].value | string | `"/state"` | | -| backend.env[4].name | string | `"PUSHER_APP_ID"` | | -| backend.env[4].value | int | `1` | | -| backend.env[5].name | string | `"PUSHER_APP_KEY"` | | -| backend.env[5].value | string | `"keepappkey"` | | -| backend.env[6].name | string | `"PUSHER_APP_SECRET"` | | -| backend.env[6].value | string | `"keepappsecret"` | | -| backend.env[7].name | string | `"PUSHER_HOST"` | | -| backend.env[7].value | string | `"keep-websocket"` | | -| backend.env[8].name | string | `"PUSHER_PORT"` | | -| backend.env[8].value | int | `6001` | | +| backend.env[3].name | string | `"PUSHER_APP_ID"` | | +| backend.env[3].value | int | `1` | | +| backend.env[4].name | string | `"PUSHER_APP_KEY"` | | +| backend.env[4].value | string | `"keepappkey"` | | +| backend.env[5].name | string | `"PUSHER_APP_SECRET"` | | +| backend.env[5].value | string | `"keepappsecret"` | | +| backend.env[6].name | string | `"PUSHER_HOST"` | | +| backend.env[6].value | string | `"keep-websocket"` | | +| backend.env[7].name | string | `"PUSHER_PORT"` | | +| backend.env[7].value | int | `6001` | | | backend.extraInitContainers | list | `[]` | | | backend.extraVolumeMounts | list | `[]` | | | backend.extraVolumes | list | `[]` | | @@ -59,15 +64,7 @@ Keep Helm Chart | backend.healthCheck.probes.readinessProbe.tcpSocket.port | int | `8080` | | | backend.image.pullPolicy | string | `"Always"` | | | backend.image.repository | string | `"us-central1-docker.pkg.dev/keephq/keep/keep-api"` | | -| backend.image.tag | string | `"{{ .Chart.AppVersion }}"` | | | backend.imagePullSecrets | list | `[]` | | -| backend.ingress.annotations | object | `{}` | | -| backend.ingress.className | string | `""` | | -| backend.ingress.enabled | bool | `true` | | -| backend.ingress.hosts[0].host | string | `"chart-example-backend.local"` | | -| backend.ingress.hosts[0].paths[0].path | string | `"/"` | | -| backend.ingress.hosts[0].paths[0].pathType | string | `"ImplementationSpecific"` | | -| backend.ingress.tls | list | `[]` | | | backend.nodeSelector | object | `{}` | | | backend.openAiApi.enabled | bool | `false` | | | backend.openAiApi.openAiApiKey | string | `""` | | @@ -126,31 +123,28 @@ Keep Helm Chart | frontend.autoscaling.minReplicas | int | `1` | | | frontend.autoscaling.targetCPUUtilizationPercentage | int | `80` | | | frontend.autoscaling.targetMemoryUtilizationPercentage | int | `80` | | +| frontend.backendConfig.healthCheck.checkIntervalSec | int | `30` | | +| frontend.backendConfig.healthCheck.healthyThreshold | int | `1` | | +| frontend.backendConfig.healthCheck.path | string | `"/signin"` | | +| frontend.backendConfig.healthCheck.port | int | `3000` | | +| frontend.backendConfig.healthCheck.timeoutSec | int | `10` | | +| frontend.backendConfig.healthCheck.type | string | `"HTTP"` | | +| frontend.backendConfig.healthCheck.unhealthyThreshold | int | `3` | | | frontend.enabled | bool | `true` | | | frontend.env[0].name | string | `"NEXTAUTH_SECRET"` | | | frontend.env[0].value | string | `"secret"` | | -| frontend.env[10].name | string | `"PUSHER_PORT"` | | -| frontend.env[10].value | int | `6001` | | -| frontend.env[11].name | string | `"PUSHER_APP_KEY"` | | -| frontend.env[11].value | string | `"keepappkey"` | | | frontend.env[1].name | string | `"NEXTAUTH_URL"` | | | frontend.env[1].value | string | `"http://localhost:3000"` | | -| frontend.env[2].name | string | `"API_URL"` | | -| frontend.env[2].value | string | `"http://keep-backend:8080"` | | -| frontend.env[3].name | string | `"NEXT_PUBLIC_API_URL"` | | -| frontend.env[3].value | string | `""` | | -| frontend.env[4].name | string | `"NEXT_PUBLIC_POSTHOG_KEY"` | | -| frontend.env[4].value | string | `"phc_muk9qE3TfZsX3SZ9XxX52kCGJBclrjhkP9JxAQcm1PZ"` | | -| frontend.env[5].name | string | `"NEXT_PUBLIC_POSTHOG_HOST"` | | -| frontend.env[5].value | string | `"https://app.posthog.com"` | | -| frontend.env[6].name | string | `"ENV"` | | -| frontend.env[6].value | string | `"development"` | | -| frontend.env[7].name | string | `"NODE_ENV"` | | -| frontend.env[7].value | string | `"development"` | | -| frontend.env[8].name | string | `"HOSTNAME"` | | -| frontend.env[8].value | string | `"0.0.0.0"` | | -| frontend.env[9].name | string | `"PUSHER_HOST"` | | -| frontend.env[9].value | string | `"keep-websocket.default.svc.cluster.local"` | | +| frontend.env[2].name | string | `"VERCEL"` | | +| frontend.env[2].value | int | `1` | | +| frontend.env[3].name | string | `"ENV"` | | +| frontend.env[3].value | string | `"development"` | | +| frontend.env[4].name | string | `"NODE_ENV"` | | +| frontend.env[4].value | string | `"development"` | | +| frontend.env[5].name | string | `"HOSTNAME"` | | +| frontend.env[5].value | string | `"0.0.0.0"` | | +| frontend.env[6].name | string | `"PUSHER_APP_KEY"` | | +| frontend.env[6].value | string | `"keepappkey"` | | | frontend.healthCheck.enabled | bool | `false` | | | frontend.healthCheck.probes.livenessProbe.httpGet.path | string | `"/"` | | | frontend.healthCheck.probes.livenessProbe.httpGet.port | string | `"http"` | | @@ -158,15 +152,8 @@ Keep Helm Chart | frontend.healthCheck.probes.readinessProbe.httpGet.port | string | `"http"` | | | frontend.image.pullPolicy | string | `"Always"` | | | frontend.image.repository | string | `"us-central1-docker.pkg.dev/keephq/keep/keep-ui"` | | -| frontend.image.tag | string | `"{{ .Chart.AppVersion }}"` | | +| frontend.image.tag | string | `"feature_websocket-improve"` | | | frontend.imagePullSecrets | list | `[]` | | -| frontend.ingress.annotations | object | `{}` | | -| frontend.ingress.className | string | `""` | | -| frontend.ingress.enabled | bool | `true` | | -| frontend.ingress.hosts[0].host | string | `"chart-example.local"` | | -| frontend.ingress.hosts[0].paths[0].path | string | `"/"` | | -| frontend.ingress.hosts[0].paths[0].pathType | string | `"ImplementationSpecific"` | | -| frontend.ingress.tls | list | `[]` | | | frontend.nodeSelector | object | `{}` | | | frontend.podAnnotations | object | `{}` | | | frontend.podSecurityContext | object | `{}` | | @@ -185,6 +172,26 @@ Keep Helm Chart | frontend.serviceAccount.name | string | `""` | | | frontend.tolerations | list | `[]` | | | fullnameOverride | string | `""` | | +| global.ingress.annotations | object | `{}` | | +| global.ingress.backendPrefix | string | `"/apinew"` | | +| global.ingress.className | string | `"nginx"` | | +| global.ingress.enabled | bool | `true` | | +| global.ingress.frontendPrefix | string | `"/"` | | +| global.ingress.hosts | list | `[]` | | +| global.ingress.tls | list | `[]` | | +| global.ingress.websocketPrefix | string | `"/websocket"` | | +| ingress-nginx.controller.admissionWebhooks.certManager.enabled | bool | `false` | | +| ingress-nginx.controller.admissionWebhooks.failurePolicy | string | `"Ignore"` | | +| ingress-nginx.controller.admissionWebhooks.patch.enabled | bool | `true` | | +| ingress-nginx.controller.admissionWebhooks.patch.image.pullPolicy | string | `"IfNotPresent"` | | +| ingress-nginx.controller.allowSnippetAnnotations | bool | `true` | | +| ingress-nginx.controller.service.annotations | object | `{}` | | +| ingress-nginx.controller.service.enabled | bool | `true` | | +| ingress-nginx.controller.service.ports.http | int | `80` | | +| ingress-nginx.controller.service.ports.https | int | `443` | | +| ingress-nginx.controller.service.type | string | `"LoadBalancer"` | | +| ingress-nginx.enabled | bool | `true` | | +| isGKE | bool | `false` | | | nameOverride | string | `""` | | | namespace | string | `"default"` | | | serviceAccount.annotations | object | `{}` | | @@ -197,14 +204,18 @@ Keep Helm Chart | websocket.autoscaling.targetCPUUtilizationPercentage | int | `80` | | | websocket.autoscaling.targetMemoryUtilizationPercentage | int | `80` | | | websocket.enabled | bool | `true` | | -| websocket.env[0].name | string | `"SOKETI_USER_AUTHENTICATION_TIMEOUT"` | | -| websocket.env[0].value | int | `3000` | | -| websocket.env[1].name | string | `"SOKETI_DEFAULT_APP_ID"` | | -| websocket.env[1].value | int | `1` | | -| websocket.env[2].name | string | `"SOKETI_DEFAULT_APP_KEY"` | | -| websocket.env[2].value | string | `"keepappkey"` | | -| websocket.env[3].name | string | `"SOKETI_DEFAULT_APP_SECRET"` | | -| websocket.env[3].value | string | `"keepappsecret"` | | +| websocket.env[0].name | string | `"SOKETI_HOST"` | | +| websocket.env[0].value | string | `"0.0.0.0"` | | +| websocket.env[1].name | string | `"SOKETI_DEBUG"` | | +| websocket.env[1].value | string | `"1"` | | +| websocket.env[2].name | string | `"SOKETI_USER_AUTHENTICATION_TIMEOUT"` | | +| websocket.env[2].value | int | `3000` | | +| websocket.env[3].name | string | `"SOKETI_DEFAULT_APP_ID"` | | +| websocket.env[3].value | int | `1` | | +| websocket.env[4].name | string | `"SOKETI_DEFAULT_APP_KEY"` | | +| websocket.env[4].value | string | `"keepappkey"` | | +| websocket.env[5].name | string | `"SOKETI_DEFAULT_APP_SECRET"` | | +| websocket.env[5].value | string | `"keepappsecret"` | | | websocket.healthCheck.enabled | bool | `false` | | | websocket.healthCheck.probes.livenessProbe.httpGet.path | string | `"/"` | | | websocket.healthCheck.probes.livenessProbe.httpGet.port | string | `"http"` | | @@ -219,6 +230,10 @@ Keep Helm Chart | websocket.podSecurityContext | object | `{}` | | | websocket.replicaCount | int | `1` | | | websocket.resources | object | `{}` | | +| websocket.route.enabled | bool | `false` | | +| websocket.route.host | string | `"chart-example.local"` | | +| websocket.route.tls | list | `[]` | | +| websocket.route.wildcardPolicy | string | `"None"` | | | websocket.securityContext | object | `{}` | | | websocket.service.port | int | `6001` | | | websocket.service.type | string | `"ClusterIP"` | | diff --git a/charts/keep/templates/nginx-ingress.yaml b/charts/keep/templates/nginx-ingress.yaml index b6d2fc7..61061d0 100644 --- a/charts/keep/templates/nginx-ingress.yaml +++ b/charts/keep/templates/nginx-ingress.yaml @@ -23,7 +23,7 @@ metadata: {{- if $.Values.websocket.enabled }} location ^~ {{ .Values.global.ingress.websocketPrefix }} { rewrite ^{{ .Values.global.ingress.websocketPrefix }}(/|$)(.*) /$2 break; - proxy_pass http://{{ $fullName }}-websocket:{{ $.Values.websocket.service.port }}; + proxy_pass http://{{ $fullName }}-websocket.{{ .Release.Namespace }}.svc.cluster.local:{{ $.Values.websocket.service.port }}; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; @@ -113,4 +113,4 @@ spec: port: number: {{ $.Values.frontend.service.port }} {{- end }} -{{- end }} +{{- end }} \ No newline at end of file From 8f7c1ab8e7839f08adeeb10f7be4b3063c0ba14c Mon Sep 17 00:00:00 2001 From: shahargl Date: Tue, 22 Oct 2024 21:00:55 +0300 Subject: [PATCH 13/19] feat: wip --- README.md | 115 +++++++++++++++--- charts/keep/templates/_helpers.tpl | 67 +++++----- charts/keep/templates/delete-secret-job.yaml | 4 +- charts/keep/templates/frontend.yaml | 19 +-- .../role-binding-secret-manager.yaml | 4 +- .../keep/templates/role-secret-manager.yaml | 2 +- charts/keep/values.yaml | 8 +- 7 files changed, 154 insertions(+), 65 deletions(-) diff --git a/README.md b/README.md index ead6350..c2512e5 100644 --- a/README.md +++ b/README.md @@ -1,37 +1,114 @@ # Keep Helm Chart The Keep Helm Chart provides a convenient way to deploy and manage Keep on Kubernetes using Helm, a package manager for Kubernetes applications. +# Prerequisites + +## Ingress Controller (Recommended) +The recommended way to deploy Keep is with ingress-nginx that serves as a single ingress for all services (backend, frontend, and websocket server). + +1. Install ingress-nginx: +```bash +helm upgrade --install ingress-nginx ingress-nginx \ + --repo https://kubernetes.github.io/ingress-nginx \ + --namespace ingress-nginx --create-namespace +``` + +2. Enable snippet annotations: +The ingress controller must have snippet annotations enabled. You can enable it during installation: +```bash +helm upgrade --install ingress-nginx ingress-nginx \ + --repo https://kubernetes.github.io/ingress-nginx \ + --namespace ingress-nginx --create-namespace \ + --set controller.config.allow-snippet-annotations=true +``` + +To verify if snippet annotations are enabled: +```bash +# Check the configmap +kubectl get configmap -n ingress-nginx ingress-nginx-controller -o yaml | grep allow-snippet-annotations + +# Or check the controller logs +kubectl logs -n ingress-nginx -l app.kubernetes.io/component=controller | grep "allow-snippet-annotations" +``` + # Installation -The easiest way to install Keep with Helm is with the following command: +## Option 1: With ingress-nginx (Recommended) ```bash -# add the Helm repository +# Add the Helm repository helm repo add keephq https://keephq.github.io/helm-charts -# pull the latest version of the chart -helm pull keephq/keep -# install the chart + +# Install Keep with ingress enabled (default nginx) +helm install keep keephq/keep -n keep --create-namespace +``` + +## Option 2: Without ingress-nginx (Not recommended) +Keep can be deployed without ingress-nginx, but this will create three separate ingresses (one for each service): +```bash +# Add the Helm repository +helm repo add keephq https://keephq.github.io/helm-charts + +# Install Keep without ingress helm install keep keephq/keep ``` +# Post-Installation + +## With ingress-nginx +Your Keep installation will be available at the ingress host you configured. Check your ingress status: +```bash +kubectl get ingress +``` + +## Without ingress-nginx +You'll need to set up port forwarding to access the services: +```bash +# Expose the UI locally +kubectl port-forward svc/keep-frontend 3000:3000 & + +# Expose the Backend locally +kubectl port-forward svc/keep-backend 8080:8080 & + +# Export websocket server (optional) +kubectl port-forward svc/keep-websocket 6001:6001 & +``` + # Uninstallation -`helm uninstall keep` +```bash +helm uninstall keep +``` # Configuration To view supported configuration, see [this](charts/keep/README.md). -# Openshift -Keep's Helm Chart also supports installation on Openshift. -Simply set up the keys under frontend(/backend).route: -- route.host: your desired hostname +# Platform-Specific Instructions -# Local Kubernetes -For local kubernetes without external IP (such as NodePort or LoadBalancer), you'll need to run port forwarding: +## Openshift +Keep's Helm Chart supports installation on Openshift. +Configure the route settings under frontend(/backend).route: +```yaml +frontend: + route: + host: your-desired-hostname +``` -## Port forward -```bash +## Local Kubernetes +For local Kubernetes clusters without external IP (such as when using NodePort or LoadBalancer): -# expose the UI locally -kubectl port-forward svc/keep-frontend 3000:3000 & \ -# export websocket server (optional) -kubectl port-forward svc/keep-websocket 6001:6001 & -``` +1. If using ingress-nginx, ensure your ingress controller is properly configured for local development +2. If not using ingress-nginx, use the port forwarding method described in the "Without ingress-nginx" section + +# Troubleshooting + +## Common Issues +1. Ingress not working + - Verify ingress-nginx is properly installed + - Check if snippet annotations are enabled + - Verify ingress configuration with `kubectl describe ingress` + +2. WebSocket connection issues + - Ensure the websocket service is running + - Check ingress configuration for proper WebSocket headers + - Verify connectivity using `curl` or browser developer tools + +For more detailed configuration options and troubleshooting, refer to the [documentation](charts/keep/README.md). \ No newline at end of file diff --git a/charts/keep/templates/_helpers.tpl b/charts/keep/templates/_helpers.tpl index d7c2687..78a9b54 100644 --- a/charts/keep/templates/_helpers.tpl +++ b/charts/keep/templates/_helpers.tpl @@ -66,9 +66,9 @@ Helper function to find an environment variable in the list */}} {{- define "keep.findEnvVar" -}} {{- $name := index . 0 -}} -{{- $values := index . 1 -}} -{{- if and $values.frontend $values.frontend.env -}} - {{- range $values.frontend.env -}} +{{- $root := index . 1 -}} +{{- if and $root.Values.frontend $root.Values.frontend.env -}} + {{- range $root.Values.frontend.env -}} {{- if eq .name $name -}} {{- .value -}} {{- end -}} @@ -112,41 +112,52 @@ Helper function for PUSHER_HOST {{/* Helper function for API_URL for the frontend */}} -{{- define "keep.apiUrl" -}} -{{- $apiUrl := include "keep.findEnvVar" (list "API_URL" .) -}} -{{- if $apiUrl -}} - {{- $apiUrl -}} +{{- define "keep.apiUrlClient" -}} +{{- $apiUrlClient := include "keep.findEnvVar" (list "API_URL_CLIENT" .) -}} +{{- if $apiUrlClient -}} + {{- $apiUrlClient -}} {{- else -}} {{- include "keep.backendPrefix" . -}} {{- end -}} {{- end -}} +{{/* +Expand the namespace of the release. +*/}} +{{- define "keep.namespace" -}} +{{- default .Release.Namespace .Values.namespaceOverride | trunc 63 | trimSuffix "-" -}} +{{- end -}} + {{/* -Determine if ingress-nginx should be installed +Helper function for getting the full URL (with protocol and host) */}} -{{- define "keep.shouldInstallIngressNginx" -}} -{{- if .Release.IsInstall -}} - {{- if .Values.preInstallJob.enabled -}} - {{- $jobName := printf "%s-nginx-ingress-check" .Release.Name -}} - {{- $job := (lookup "batch/v1" "Job" .Release.Namespace $jobName) -}} - {{- if $job -}} - {{- if $job.status -}} - {{- if eq (int $job.status.succeeded) 0 -}} - {{- printf "false" -}} - {{- else -}} - {{- printf "true" -}} - {{- end -}} - {{- else -}} - {{- printf "true" -}} - {{- end -}} - {{- else -}} - {{- printf "true" -}} - {{- end -}} +{{- define "keep.fullUrl" -}} +{{- if and .Values.global.ingress.enabled .Values.global.ingress.hosts -}} + {{- if .Values.global.ingress.tls -}} + {{- $host := index .Values.global.ingress.hosts 0 -}} + {{- printf "https://%s" $host.host -}} {{- else -}} - {{- printf "true" -}} + {{- $host := index .Values.global.ingress.hosts 0 -}} + {{- printf "http://%s" $host.host -}} {{- end -}} {{- else -}} - {{- printf "false" -}} + {{- print "http://localhost:3000" -}} +{{- end -}} +{{- end -}} + +{{/* +Helper function for NEXTAUTH_URL +*/}} +{{- define "keep.nextAuthUrl" -}} +{{- $nextAuthUrl := include "keep.findEnvVar" (list "NEXTAUTH_URL" .) -}} +{{- if $nextAuthUrl -}} + {{- $nextAuthUrl -}} +{{- else -}} + {{- if .Values.global.ingress.enabled -}} + {{- include "keep.fullUrl" . -}} + {{- else -}} + {{- print "http://localhost:3000" -}} + {{- end -}} {{- end -}} {{- end -}} \ No newline at end of file diff --git a/charts/keep/templates/delete-secret-job.yaml b/charts/keep/templates/delete-secret-job.yaml index e1fd325..9de20b7 100644 --- a/charts/keep/templates/delete-secret-job.yaml +++ b/charts/keep/templates/delete-secret-job.yaml @@ -16,9 +16,9 @@ spec: - /bin/sh - -c - > - secrets=$(kubectl get secrets -n {{ .Values.Namespace }} -o name | grep '^secret/keep-'); + secrets=$(kubectl get secrets -n {{ include "keep.namespace" . }} -o name | grep '^secret/keep-'); if [ -n "$secrets" ]; then - echo "$secrets" | xargs kubectl delete -n {{ .Values.Namespace }}; + echo "$secrets" | xargs kubectl delete -n {{ include "keep.namespace" . }}; else echo "No matching secrets found to delete."; fi diff --git a/charts/keep/templates/frontend.yaml b/charts/keep/templates/frontend.yaml index 3f599ce..00fa9df 100644 --- a/charts/keep/templates/frontend.yaml +++ b/charts/keep/templates/frontend.yaml @@ -42,19 +42,20 @@ spec: containerPort: {{ .Values.frontend.service.port }} protocol: TCP env: - {{- $pusherHost := include "keep.pusherHost" . -}} - {{- $apiUrl := include "keep.apiUrl" . -}} + - name: PUSHER_HOST + value: {{ include "keep.pusherHost" . | quote }} + - name: API_URL_CLIENT + value: {{ include "keep.apiUrlClient" . | quote }} + - name: NEXTAUTH_URL + value: {{ include "keep.nextAuthUrl" . | quote }} {{- range .Values.frontend.env }} + {{- if and + (ne .name "PUSHER_HOST") + (ne .name "API_URL_CLIENT") + (ne .name "NEXTAUTH_URL") }} - name: {{ .name }} value: {{ .value | quote }} {{- end }} - {{- if and $pusherHost (not (include "keep.findEnvVar" (list "PUSHER_HOST" .))) }} - - name: PUSHER_HOST - value: {{ $pusherHost | quote }} - {{- end }} - {{- if and $apiUrl (not (include "keep.findEnvVar" (list "API_URL" .))) }} - - name: API_URL - value: {{ $apiUrl | quote }} {{- end }} volumeMounts: - name: state-volume diff --git a/charts/keep/templates/role-binding-secret-manager.yaml b/charts/keep/templates/role-binding-secret-manager.yaml index 3c9b8bc..313e975 100644 --- a/charts/keep/templates/role-binding-secret-manager.yaml +++ b/charts/keep/templates/role-binding-secret-manager.yaml @@ -2,11 +2,11 @@ apiVersion: rbac.authorization.k8s.io/v1 kind: RoleBinding metadata: name: secret-manager-rolebinding - namespace: {{ .Values.namespace | default .Release.Namespace | default "default" }} + namespace: {{ include "keep.namespace" . }} subjects: - kind: ServiceAccount name: {{ include "keep.serviceAccountName" . }} - namespace: {{ .Values.namespace | default .Release.Namespace | default "default" }} + namespace: {{ include "keep.namespace" . }} roleRef: kind: Role name: secret-manager-role diff --git a/charts/keep/templates/role-secret-manager.yaml b/charts/keep/templates/role-secret-manager.yaml index 57b842f..917ae57 100644 --- a/charts/keep/templates/role-secret-manager.yaml +++ b/charts/keep/templates/role-secret-manager.yaml @@ -2,7 +2,7 @@ apiVersion: rbac.authorization.k8s.io/v1 kind: Role metadata: name: secret-manager-role - namespace: {{ .Values.namespace | default .Release.Namespace | default "default" }} + namespace: {{ include "keep.namespace" . }} rules: - apiGroups: [""] resources: ["secrets"] diff --git a/charts/keep/values.yaml b/charts/keep/values.yaml index 0b8ed7e..680ebaf 100644 --- a/charts/keep/values.yaml +++ b/charts/keep/values.yaml @@ -1,4 +1,4 @@ -namespace: default +namespace: keep serviceAccount: create: true annotations: {} @@ -138,8 +138,8 @@ frontend: env: - name: NEXTAUTH_SECRET value: secret - - name: NEXTAUTH_URL - value: http://localhost:3000 + - name: API_URL_CLIENT + value: http://keep-backend:8080 # Shahar: took me whole day to figure out that I need to set this to 1 # https://github.com/nextauthjs/next-auth/issues/600 - name: VERCEL @@ -156,7 +156,7 @@ frontend: image: repository: us-central1-docker.pkg.dev/keephq/keep/keep-ui pullPolicy: Always - tag: "feature_websocket-improve" + tag: feat_debug-k8s imagePullSecrets: [] serviceAccount: create: true From bfa7ebe75e35e3faf5e4a1f8d84a048e5ed086b1 Mon Sep 17 00:00:00 2001 From: shahargl Date: Wed, 23 Oct 2024 10:42:41 +0300 Subject: [PATCH 14/19] feat: wip --- charts/keep/templates/_helpers.tpl | 14 ++++++++++++++ charts/keep/templates/backend.yaml | 2 ++ charts/keep/values.yaml | 10 ++++++++-- 3 files changed, 24 insertions(+), 2 deletions(-) diff --git a/charts/keep/templates/_helpers.tpl b/charts/keep/templates/_helpers.tpl index 78a9b54..b108951 100644 --- a/charts/keep/templates/_helpers.tpl +++ b/charts/keep/templates/_helpers.tpl @@ -160,4 +160,18 @@ Helper function for NEXTAUTH_URL {{- print "http://localhost:3000" -}} {{- end -}} {{- end -}} +{{- end -}} + + +{{/* +Helper function for KEEP_API_URL that handles both relative and absolute URLs +*/}} +{{- define "keep.apiUrl" -}} +{{- $apiUrlClient := include "keep.apiUrlClient" . -}} +{{- /* Check if the URL starts with http:// or https:// */ -}} +{{- if or (hasPrefix "http://" $apiUrlClient) (hasPrefix "https://" $apiUrlClient) -}} + {{- $apiUrlClient -}} +{{- else -}} + {{- include "keep.fullUrl" . -}}{{- $apiUrlClient -}} +{{- end -}} {{- end -}} \ No newline at end of file diff --git a/charts/keep/templates/backend.yaml b/charts/keep/templates/backend.yaml index b528f8b..8b03192 100644 --- a/charts/keep/templates/backend.yaml +++ b/charts/keep/templates/backend.yaml @@ -48,6 +48,8 @@ spec: containerPort: {{ .Values.backend.service.port }} protocol: TCP env: + - name: KEEP_API_URL + value: {{ include "keep.apiUrl" . | quote }} {{- range .Values.backend.env }} - name: {{ .name }} {{- if .secretKeyRef }} diff --git a/charts/keep/values.yaml b/charts/keep/values.yaml index 680ebaf..3e79a3c 100644 --- a/charts/keep/values.yaml +++ b/charts/keep/values.yaml @@ -22,7 +22,15 @@ global: backendPrefix: "/apinew" frontendPrefix: "/" hosts: [] + # uncomment when you want to use a custom domain + # hosts: + # - host: keep.example.com tls: [] + # uncomment when you want to use a custom domain with TLS + # tls: + # - hosts: + # - keep.example.com + # secretName: keep-tls # this section controls the ingress-nginx **controller** # and not the ingress resource itself @@ -138,8 +146,6 @@ frontend: env: - name: NEXTAUTH_SECRET value: secret - - name: API_URL_CLIENT - value: http://keep-backend:8080 # Shahar: took me whole day to figure out that I need to set this to 1 # https://github.com/nextauthjs/next-auth/issues/600 - name: VERCEL From 133dd7167e9cf1193c4f601a020ef1ebddd0c528 Mon Sep 17 00:00:00 2001 From: shahargl Date: Wed, 23 Oct 2024 11:04:24 +0300 Subject: [PATCH 15/19] feat: wip --- charts/keep/values.yaml | 1 - 1 file changed, 1 deletion(-) diff --git a/charts/keep/values.yaml b/charts/keep/values.yaml index 3e79a3c..6b3a32e 100644 --- a/charts/keep/values.yaml +++ b/charts/keep/values.yaml @@ -162,7 +162,6 @@ frontend: image: repository: us-central1-docker.pkg.dev/keephq/keep/keep-ui pullPolicy: Always - tag: feat_debug-k8s imagePullSecrets: [] serviceAccount: create: true From d8bf80b907299e29a92ca050400eba4b5d8336fe Mon Sep 17 00:00:00 2001 From: shahargl Date: Wed, 23 Oct 2024 11:05:22 +0300 Subject: [PATCH 16/19] feat: update keep version --- charts/keep/Chart.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/charts/keep/Chart.yaml b/charts/keep/Chart.yaml index d2b9765..a0ccb01 100644 --- a/charts/keep/Chart.yaml +++ b/charts/keep/Chart.yaml @@ -4,7 +4,7 @@ version: 0.1.25 description: Keep Helm Chart type: application icon: https://platform.keephq.dev/_next/image?url=%2Fkeep.png&w=48&q=75 -appVersion: 0.26.1 +appVersion: 0.27.0 deprecated: false annotations: app: keep From 6aa971d0b3487f4ab3d67fa224a20768435bb31d Mon Sep 17 00:00:00 2001 From: shahargl Date: Wed, 23 Oct 2024 11:17:21 +0300 Subject: [PATCH 17/19] feat: update keep version --- charts/keep/values.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/charts/keep/values.yaml b/charts/keep/values.yaml index 6b3a32e..75a0854 100644 --- a/charts/keep/values.yaml +++ b/charts/keep/values.yaml @@ -19,7 +19,7 @@ global: websocketPrefix: "/websocket" # can't use /api since its "catched" by the nextjs frontend e.g # . /api/auth/signin or /api/config - backendPrefix: "/apinew" + backendPrefix: "/v2" frontendPrefix: "/" hosts: [] # uncomment when you want to use a custom domain From 88665ce8a8f5eda190e3de667e0957160c465d30 Mon Sep 17 00:00:00 2001 From: shahargl Date: Wed, 23 Oct 2024 11:19:24 +0300 Subject: [PATCH 18/19] feat: update keep version --- charts/keep/README.md | 27 ++++++++++++--------------- 1 file changed, 12 insertions(+), 15 deletions(-) diff --git a/charts/keep/README.md b/charts/keep/README.md index b40d957..5e1bb17 100644 --- a/charts/keep/README.md +++ b/charts/keep/README.md @@ -1,6 +1,6 @@ # keep -![Version: 0.1.25](https://img.shields.io/badge/Version-0.1.25-informational?style=flat-square) ![Type: application](https://img.shields.io/badge/Type-application-informational?style=flat-square) ![AppVersion: 0.26.1](https://img.shields.io/badge/AppVersion-0.26.1-informational?style=flat-square) +![Version: 0.1.25](https://img.shields.io/badge/Version-0.1.25-informational?style=flat-square) ![Type: application](https://img.shields.io/badge/Type-application-informational?style=flat-square) ![AppVersion: 0.27.0](https://img.shields.io/badge/AppVersion-0.27.0-informational?style=flat-square) Keep Helm Chart @@ -133,18 +133,16 @@ Keep Helm Chart | frontend.enabled | bool | `true` | | | frontend.env[0].name | string | `"NEXTAUTH_SECRET"` | | | frontend.env[0].value | string | `"secret"` | | -| frontend.env[1].name | string | `"NEXTAUTH_URL"` | | -| frontend.env[1].value | string | `"http://localhost:3000"` | | -| frontend.env[2].name | string | `"VERCEL"` | | -| frontend.env[2].value | int | `1` | | -| frontend.env[3].name | string | `"ENV"` | | +| frontend.env[1].name | string | `"VERCEL"` | | +| frontend.env[1].value | int | `1` | | +| frontend.env[2].name | string | `"ENV"` | | +| frontend.env[2].value | string | `"development"` | | +| frontend.env[3].name | string | `"NODE_ENV"` | | | frontend.env[3].value | string | `"development"` | | -| frontend.env[4].name | string | `"NODE_ENV"` | | -| frontend.env[4].value | string | `"development"` | | -| frontend.env[5].name | string | `"HOSTNAME"` | | -| frontend.env[5].value | string | `"0.0.0.0"` | | -| frontend.env[6].name | string | `"PUSHER_APP_KEY"` | | -| frontend.env[6].value | string | `"keepappkey"` | | +| frontend.env[4].name | string | `"HOSTNAME"` | | +| frontend.env[4].value | string | `"0.0.0.0"` | | +| frontend.env[5].name | string | `"PUSHER_APP_KEY"` | | +| frontend.env[5].value | string | `"keepappkey"` | | | frontend.healthCheck.enabled | bool | `false` | | | frontend.healthCheck.probes.livenessProbe.httpGet.path | string | `"/"` | | | frontend.healthCheck.probes.livenessProbe.httpGet.port | string | `"http"` | | @@ -152,7 +150,6 @@ Keep Helm Chart | frontend.healthCheck.probes.readinessProbe.httpGet.port | string | `"http"` | | | frontend.image.pullPolicy | string | `"Always"` | | | frontend.image.repository | string | `"us-central1-docker.pkg.dev/keephq/keep/keep-ui"` | | -| frontend.image.tag | string | `"feature_websocket-improve"` | | | frontend.imagePullSecrets | list | `[]` | | | frontend.nodeSelector | object | `{}` | | | frontend.podAnnotations | object | `{}` | | @@ -173,7 +170,7 @@ Keep Helm Chart | frontend.tolerations | list | `[]` | | | fullnameOverride | string | `""` | | | global.ingress.annotations | object | `{}` | | -| global.ingress.backendPrefix | string | `"/apinew"` | | +| global.ingress.backendPrefix | string | `"/v2"` | | | global.ingress.className | string | `"nginx"` | | | global.ingress.enabled | bool | `true` | | | global.ingress.frontendPrefix | string | `"/"` | | @@ -193,7 +190,7 @@ Keep Helm Chart | ingress-nginx.enabled | bool | `true` | | | isGKE | bool | `false` | | | nameOverride | string | `""` | | -| namespace | string | `"default"` | | +| namespace | string | `"keep"` | | | serviceAccount.annotations | object | `{}` | | | serviceAccount.create | bool | `true` | | | serviceAccount.name | string | `""` | | From bf4e6b0413a1a9f0d1d7b2931c9a9e79f5d2258e Mon Sep 17 00:00:00 2001 From: shahargl Date: Wed, 23 Oct 2024 11:26:45 +0300 Subject: [PATCH 19/19] feat: update keep version --- charts/keep/templates/nginx-ingress.yaml | 2 ++ charts/keep/values.yaml | 24 ------------------------ 2 files changed, 2 insertions(+), 24 deletions(-) diff --git a/charts/keep/templates/nginx-ingress.yaml b/charts/keep/templates/nginx-ingress.yaml index 61061d0..6d3c18c 100644 --- a/charts/keep/templates/nginx-ingress.yaml +++ b/charts/keep/templates/nginx-ingress.yaml @@ -7,6 +7,7 @@ metadata: labels: {{- include "keep.labels" . | nindent 4 }} annotations: + {{- if eq .Values.global.ingress.className "nginx" }} kubernetes.io/ingress.class: "nginx" nginx.ingress.kubernetes.io/proxy-read-timeout: "3600" nginx.ingress.kubernetes.io/proxy-send-timeout: "3600" @@ -37,6 +38,7 @@ metadata: {{- end }} nginx.ingress.kubernetes.io/rewrite-target: /$1 nginx.ingress.kubernetes.io/use-regex: "true" + {{- end }} {{- with .Values.global.ingress.annotations }} {{- toYaml . | nindent 4 }} {{- end }} diff --git a/charts/keep/values.yaml b/charts/keep/values.yaml index 75a0854..71874cc 100644 --- a/charts/keep/values.yaml +++ b/charts/keep/values.yaml @@ -32,30 +32,6 @@ global: # - keep.example.com # secretName: keep-tls -# this section controls the ingress-nginx **controller** -# and not the ingress resource itself -ingress-nginx: - # install the ingress-nginx controller dependency repo - enabled: true - controller: - service: - enabled: true - type: LoadBalancer - annotations: {} - ports: - http: 80 - https: 443 - admissionWebhooks: - failurePolicy: Ignore - patch: - enabled: true - image: - pullPolicy: IfNotPresent - certManager: - enabled: false - allowSnippetAnnotations: true - - backend: # if true, the backend will be enabled enabled: true