Skip to content

Commit

Permalink
feat(keda): Allow using own Cert-manager Issuer/ClusterIssuer for iss…
Browse files Browse the repository at this point in the history
…uing KEDA TLS certificates (#530)

* feat(keda): ✨ Allow providing own cert-manager issuer in TLS certificate

Signed-off-by: Dmytro Kovalenko <[email protected]>

* docs(keda): 📝 Generate Helm docs

Signed-off-by: Dmytro Kovalenko <[email protected]>

* fix(keda): 🐛 Inject CA from cert-manager Certificate when providing own Issuer

Signed-off-by: Dmytro Kovalenko <[email protected]>

* refactor(keda): ♻️ Refactor values format

Signed-off-by: Dmytro Kovalenko <[email protected]>

* revert(keda): ⏪ Revert unnecessary auto-formatting

Signed-off-by: Dmytro Kovalenko <[email protected]>

* chore: Improve the CI on PRs to be more efficient (#540)

Signed-off-by: Jorge Turrado <[email protected]>
Signed-off-by: Jorge Turrado <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* fix(http-add-on): Refactor the chart for next version (#523)

Signed-off-by: Dmytro Kovalenko <[email protected]>

* feat(add-on): Supporting streamInterval configuration (#541)

Signed-off-by: Dmytro Kovalenko <[email protected]>

* chore(add-on): Ship Release 0.6.0 (#543)

Signed-off-by: Dmytro Kovalenko <[email protected]>

* chore: update versions in README.md (#546)

Signed-off-by: Dmytro Kovalenko <[email protected]>

* feat: update crd to allow vault secret to handle write operation (#548)

Signed-off-by: Loïs Postula <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* Fix the svc name of webhook to avoid breaking istio (#551)

Signed-off-by: Dmytro Kovalenko <[email protected]>

* Show only logs with a severity level of ERROR or higher in the stderr (#506)

Signed-off-by: Adarsh-verma-14 <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* Support profiling for keda components (#549)

Signed-off-by: yuval weber <[email protected]>
Signed-off-by: unknown <[email protected]>
Co-authored-by: Tom Kerkhove <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* Fix TriggerAuthentication - added configuration for validation webhook (#553)

Signed-off-by: Dmytro Kovalenko <[email protected]>

* fix: Declare missing port in KEDA operator (#552)

Signed-off-by: Dmytro Kovalenko <[email protected]>

* Allow image registry override for all keda components (#557)

Signed-off-by: Dmytro Kovalenko <[email protected]>

* docs: Clarify that contributors do not have to ship Helm chart (#573)

Signed-off-by: Dmytro Kovalenko <[email protected]>

* add  disable-compression arg for both operator and metrics-server (#554)

Signed-off-by: Adarsh-verma-14 <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* feat: Introduce CloudEventSources CRD and adding ClusterName parameter (#572)

* Add CloudEventSources Crd and ClustetName Parameter

Signed-off-by: SpiritZhou <[email protected]>

* Update

Signed-off-by: SpiritZhou <[email protected]>

* Update

Signed-off-by: SpiritZhou <[email protected]>

* Update keda/values.yaml

Co-authored-by: Tom Kerkhove <[email protected]>
Signed-off-by: SpiritZhou <[email protected]>

* Fix

Signed-off-by: SpiritZhou <[email protected]>

* Update

Signed-off-by: SpiritZhou <[email protected]>

* Revert unnecessary update

Signed-off-by: SpiritZhou <[email protected]>

---------

Signed-off-by: SpiritZhou <[email protected]>
Co-authored-by: Tom Kerkhove <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* store 2.12.1 package at `main` (#577)

Signed-off-by: Zbynek Roubalik <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* fix: restore http-add-on chart 0.6.0 indexing (#579)

Signed-off-by: Dmytro Kovalenko <[email protected]>

* fix(add-on): Use 'main' tag for KEDA installation during CI (#582)

Signed-off-by: Dmytro Kovalenko <[email protected]>

* set securityContext for http-add-on chart (#561)

Co-authored-by: Tom Kerkhove <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* Fix http-add-on operator resources (#567)

Signed-off-by: Dmytro Kovalenko <[email protected]>

* Fix http-add-on verbosity configuration (#568)

Signed-off-by: Dmytro Kovalenko <[email protected]>

* chore: Adjust RBAC with code (#585)

* chore: Adjust RBAC with code

Signed-off-by: Jorge Turrado <[email protected]>

* fix typo

Signed-off-by: Jorge Turrado <[email protected]>

---------

Signed-off-by: Jorge Turrado <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* fix: Don't recreate CA with 8 months until it expires (#586)

Signed-off-by: Jorge Turrado Ferrero <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* feat(ClusterRole): Add RBAC rule to allow access to `LimitRange` (#588)

Signed-off-by: Dmytro Kovalenko <[email protected]>

* remove not required insecureSkipTLSVerify (#564)

Signed-off-by: Frank Kloeker <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* Update templates/webhooks deployment (#590)

Align deployment for extraVolumes and extraVolumesMount for fix problem Error: YAML parse error on keda/templates/webhooks/deployment.yaml: error converting YAML to JSON: yaml: line 96: did not find expected key

Signed-off-by: ferndem <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* Fix Prometheus metrics handling for the operator. (#555)

The current state of the Helm chart is slightly confusing, because:
- There's no easy way to really disable prometheus metrics --
  `--enable-prometheus-metrics` defaults to true anthe current code
  either emits `--enable-prometheus-metrics=true` or nothing at all
  (making it `true` once again).
- The `http` container port is actually a `metrics` port (by convention
  from .e.g. webhook), but is present regardless of whether Prometheus
  metrics are enabled or not. To make it less confusing, this PR
  proposes renaming it.

Signed-off-by: Milan Plzik <[email protected]>
Signed-off-by: Jorge Turrado Ferrero <[email protected]>
Co-authored-by: Jorge Turrado Ferrero <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* Fix Remove app.kubernetes.io/instance label in crd (#556)

Signed-off-by: choisungwook <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* Support crd-specific annotations (#584)

* support crd-specific annotations

Signed-off-by: Adam Walford <[email protected]>

* update readme

Signed-off-by: Adam Walford <[email protected]>

* update docs using helm-docs

Signed-off-by: Adam Walford <[email protected]>

---------

Signed-off-by: Adam Walford <[email protected]>
Co-authored-by: Adam Walford <[email protected]>
Co-authored-by: Tom Kerkhove <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* Add ciliumnetworkpolicies (#558)

Signed-off-by: Dmytro Kovalenko <[email protected]>

* Add tlsConfig for ServiceMonitor (#591)

Co-authored-by: guicholeo <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* Release 2.13.0 (#593)

Signed-off-by: Dmytro Kovalenko <[email protected]>

* fix: Ship v2.13.1 with missing RoleBinding (#595)

Signed-off-by: Jorge Turrado <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* chore(add-on): Apply HTTP Add-on changes on Helm chart (#598)

Signed-off-by: Dmytro Kovalenko <[email protected]>

* chore(add-on): Release v0.7.0 (#599)

Signed-off-by: Jorge Turrado <[email protected]>
Signed-off-by: Dmytro Kovalenko <[email protected]>

* refactor: Unify cert-manager annotations

Signed-off-by: Dmytro Kovalenko <[email protected]>

---------

Signed-off-by: Dmytro Kovalenko <[email protected]>
Signed-off-by: Jorge Turrado <[email protected]>
Signed-off-by: Jorge Turrado <[email protected]>
Signed-off-by: Loïs Postula <[email protected]>
Signed-off-by: Adarsh-verma-14 <[email protected]>
Signed-off-by: yuval weber <[email protected]>
Signed-off-by: unknown <[email protected]>
Signed-off-by: SpiritZhou <[email protected]>
Signed-off-by: Zbynek Roubalik <[email protected]>
Signed-off-by: Jorge Turrado Ferrero <[email protected]>
Signed-off-by: Frank Kloeker <[email protected]>
Signed-off-by: ferndem <[email protected]>
Signed-off-by: Milan Plzik <[email protected]>
Signed-off-by: choisungwook <[email protected]>
Signed-off-by: Adam Walford <[email protected]>
Co-authored-by: Dmytro Kovalenko <[email protected]>
Co-authored-by: Jorge Turrado Ferrero <[email protected]>
Co-authored-by: Loïs Postula <[email protected]>
Co-authored-by: Roy Gao <[email protected]>
Co-authored-by: Adarsh Verma <[email protected]>
Co-authored-by: yuval weber <[email protected]>
Co-authored-by: Tom Kerkhove <[email protected]>
Co-authored-by: Radek Fojtik <[email protected]>
Co-authored-by: Quentin Bisson <[email protected]>
Co-authored-by: SpiritZhou <[email protected]>
Co-authored-by: Zbynek Roubalik <[email protected]>
Co-authored-by: Frank Kloeker <[email protected]>
Co-authored-by: Andrew <[email protected]>
Co-authored-by: Bhargav Ravuri <[email protected]>
Co-authored-by: ferndem <[email protected]>
Co-authored-by: Milan Plžík <[email protected]>
Co-authored-by: choisungwook <[email protected]>
Co-authored-by: Adam Walford <[email protected]>
Co-authored-by: Adam Walford <[email protected]>
Co-authored-by: guicholeo <[email protected]>
Co-authored-by: Jan Wozniak <[email protected]>
  • Loading branch information
22 people committed Jan 30, 2024
1 parent 6493bd1 commit 4cf42b3
Show file tree
Hide file tree
Showing 8 changed files with 46 additions and 13 deletions.
7 changes: 7 additions & 0 deletions keda/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -64,8 +64,15 @@ their default values.
| `asciiArt` | bool | `true` | Capability to turn on/off ASCII art in Helm installation notes |
| `certificates.autoGenerated` | bool | `true` | Enables the self generation for KEDA TLS certificates inside KEDA operator |
| `certificates.certManager.caSecretName` | string | `"kedaorg-ca"` | Secret name where the CA is stored (generatedby cert-manager or user given) |
| `certificates.certManager.duration` | string | `"8760h0m0s"` | Certificate duration |
| `certificates.certManager.enabled` | bool | `false` | Enables Cert-manager for certificate management |
| `certificates.certManager.generateCA` | bool | `true` | Generates a self-signed CA with Cert-manager. If generateCA is false, the secret with the CA has to be annotated with `cert-manager.io/allow-direct-injection: "true"` |
| `certificates.certManager.issuer` | object | `{"generate":true,"group":"cert-manager.io","kind":"ClusterIssuer","name":"foo-org-ca"}` | Reference to custom Issuer. If issuer.generate is false, then issuer.group, issuer.kind and issuer.name are required |
| `certificates.certManager.issuer.generate` | bool | `true` | Generates an Issuer resource with Cert-manager |
| `certificates.certManager.issuer.group` | string | `"cert-manager.io"` | Custom Issuer group. Required when generate: false |
| `certificates.certManager.issuer.kind` | string | `"ClusterIssuer"` | Custom Issuer kind. Required when generate: false |
| `certificates.certManager.issuer.name` | string | `"foo-org-ca"` | Custom Issuer name. Required when generate: false |
| `certificates.certManager.renewBefore` | string | `"5840h0m0s"` | Certificate renewal time before expiration |
| `certificates.certManager.secretTemplate` | object | `{}` | Add labels/annotations to secrets created by Certificate resources [docs](https://cert-manager.io/docs/usage/certificate/#creating-certificate-resources) |
| `certificates.mountPath` | string | `"/certs"` | Path where KEDA TLS certificates are mounted |
| `certificates.secretName` | string | `"kedaorg-certs"` | Secret name to be mounted with KEDA TLS certificates |
Expand Down
4 changes: 2 additions & 2 deletions keda/templates/cert-manager/keda-issuer.yaml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
{{- if .Values.certificates.certManager.enabled }}
{{- if and .Values.certificates.certManager.enabled .Values.certificates.certManager.issuer.generate }}
apiVersion: cert-manager.io/v1
kind: Issuer
metadata:
Expand All @@ -11,4 +11,4 @@ metadata:
spec:
ca:
secretName: {{ .Values.certificates.certManager.caSecretName }}
{{- end }}
{{- end }}
16 changes: 14 additions & 2 deletions keda/templates/cert-manager/keda-tls-certificate.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -25,10 +25,22 @@ spec:
privateKey:
algorithm: RSA
size: 2048
duration: 8760h0m0s # 1 year
renewBefore: 5840h0m0s # 8 months
duration: {{ .Values.certificates.certManager.duration }}
renewBefore: {{ .Values.certificates.certManager.renewBefore }}
issuerRef:
{{- if .Values.certificates.certManager.issuer.generate }}
name: {{ .Values.operator.name }}-issuer
kind: Issuer
group: cert-manager.io
{{- else }}
{{- if .Values.certificates.certManager.issuer.name }}
name: {{ .Values.certificates.certManager.issuer.name }}
{{- end }}
{{- if .Values.certificates.certManager.issuer.kind }}
kind: {{ .Values.certificates.certManager.issuer.kind }}
{{- end }}
{{- if .Values.certificates.certManager.issuer.group }}
group: {{ .Values.certificates.certManager.issuer.group }}
{{- end }}
{{- end }}
{{- end }}
2 changes: 1 addition & 1 deletion keda/templates/cert-manager/self-ca.yaml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
{{- if and .Values.certificates.certManager.enabled .Values.certificates.certManager.generateCA }}
{{- if and .Values.certificates.certManager.enabled .Values.certificates.certManager.generateCA .Values.certificates.certManager.issuer.generate }}
apiVersion: cert-manager.io/v1
kind: Certificate
metadata:
Expand Down
4 changes: 2 additions & 2 deletions keda/templates/cert-manager/self-issuer.yaml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
{{- if and .Values.certificates.certManager.enabled .Values.certificates.certManager.generateCA }}
{{- if and .Values.certificates.certManager.enabled .Values.certificates.certManager.generateCA .Values.certificates.certManager.issuer.generate }}
apiVersion: cert-manager.io/v1
kind: Issuer
metadata:
Expand All @@ -10,4 +10,4 @@ metadata:
namespace: {{ .Release.Namespace }}
spec:
selfSigned: {}
{{- end }}
{{- end }}
6 changes: 3 additions & 3 deletions keda/templates/metrics-server/apiservice.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -4,10 +4,10 @@ metadata:
{{- if or .Values.certificates.certManager.enabled .Values.additionalAnnotations }}
annotations:
{{- if .Values.certificates.certManager.enabled }}
{{- if .Values.certificates.certManager.generateCA }}
cert-manager.io/inject-ca-from: {{ .Release.Namespace }}/{{ .Values.operator.name }}-ca
{{- else }}
{{- if and (not .Values.certificates.certManager.generateCA) .Values.certificates.certManager.issuer.generate }}
cert-manager.io/inject-ca-from-secret: {{ .Release.Namespace }}/{{ .Values.certificates.certManager.caSecretName }}
{{- else }}
cert-manager.io/inject-ca-from: {{ .Release.Namespace }}/{{ .Values.operator.name }}-tls-certificates
{{- end }}
{{- end }}
{{- if .Values.additionalAnnotations }}
Expand Down
6 changes: 3 additions & 3 deletions keda/templates/webhooks/validatingconfiguration.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,10 @@ metadata:
{{- if or .Values.certificates.certManager.enabled .Values.additionalAnnotations }}
annotations:
{{- if .Values.certificates.certManager.enabled }}
{{- if .Values.certificates.certManager.generateCA }}
cert-manager.io/inject-ca-from: {{ .Release.Namespace }}/{{ .Values.operator.name }}-ca
{{- else }}
{{- if and (not .Values.certificates.certManager.generateCA) .Values.certificates.certManager.issuer.generate }}
cert-manager.io/inject-ca-from-secret: {{ .Release.Namespace }}/{{ .Values.certificates.certManager.caSecretName }}
{{- else }}
cert-manager.io/inject-ca-from: {{ .Release.Namespace }}/{{ .Values.operator.name }}-tls-certificates
{{- end }}
{{- end }}
{{- if .Values.additionalAnnotations }}
Expand Down
14 changes: 14 additions & 0 deletions keda/values.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -738,6 +738,10 @@ certificates:
certManager:
# -- Enables Cert-manager for certificate management
enabled: false
# -- Certificate duration
duration: 8760h0m0s # 1 year
# -- Certificate renewal time before expiration
renewBefore: 5840h0m0s # 8 months
# -- Generates a self-signed CA with Cert-manager.
# If generateCA is false, the secret with the CA
# has to be annotated with `cert-manager.io/allow-direct-injection: "true"`
Expand All @@ -752,6 +756,16 @@ certificates:
# my-secret-annotation-2: "bar"
# labels:
# my-secret-label: foo
# -- Reference to custom Issuer.
issuer:
# -- Generates an Issuer resource with Cert-manager
generate: true
# -- Custom Issuer name. Required when generate: false
name: foo-org-ca
# -- Custom Issuer kind. Required when generate: false
kind: ClusterIssuer
# -- Custom Issuer group. Required when generate: false
group: cert-manager.io

permissions:
metricServer:
Expand Down

0 comments on commit 4cf42b3

Please sign in to comment.