From 9b43bdabc089ef13c2bdb549126c72439d583205 Mon Sep 17 00:00:00 2001 From: Christian Struck Date: Thu, 28 Mar 2024 17:53:24 +0100 Subject: [PATCH] feat(openfga): add servicemonitor to OpenFGA chart (#122) --- charts/openfga/Chart.yaml | 2 +- charts/openfga/templates/_helpers.tpl | 10 +++- charts/openfga/templates/servicemonitor.yaml | 52 ++++++++++++++++ charts/openfga/values.schema.json | 62 +++++++++++++++++++- charts/openfga/values.yaml | 50 ++++++++++++++++ 5 files changed, 173 insertions(+), 3 deletions(-) create mode 100644 charts/openfga/templates/servicemonitor.yaml diff --git a/charts/openfga/Chart.yaml b/charts/openfga/Chart.yaml index 963156f..9d0084d 100644 --- a/charts/openfga/Chart.yaml +++ b/charts/openfga/Chart.yaml @@ -3,7 +3,7 @@ name: openfga description: A Kubernetes Helm chart for the OpenFGA project. type: application -version: 0.1.41 +version: 0.2.0 appVersion: "v1.5.1" home: "https://openfga.github.io/helm-charts" diff --git a/charts/openfga/templates/_helpers.tpl b/charts/openfga/templates/_helpers.tpl index 6652760..6abf573 100644 --- a/charts/openfga/templates/_helpers.tpl +++ b/charts/openfga/templates/_helpers.tpl @@ -23,6 +23,14 @@ If release name contains chart name it will be used as a full name. {{- end }} {{- end }} +{{/* +Expand the namespace of the release. +Allows overriding it for multi-namespace deployments in combined charts. +*/}} +{{- define "openfga.namespace" -}} +{{- default .Release.Namespace .Values.namespaceOverride | trunc 63 | trimSuffix "-" -}} +{{- end -}} + {{/* Create chart name and version as used by the chart label. */}} @@ -68,4 +76,4 @@ Return true if a secret object should be created {{- if not (or .Values.global.postgresql.auth.existingSecret .Values.auth.existingSecret) -}} {{- true -}} {{- end -}} -{{- end -}} \ No newline at end of file +{{- end -}} diff --git a/charts/openfga/templates/servicemonitor.yaml b/charts/openfga/templates/servicemonitor.yaml new file mode 100644 index 0000000..578417d --- /dev/null +++ b/charts/openfga/templates/servicemonitor.yaml @@ -0,0 +1,52 @@ +{{- if and .Values.telemetry.metrics.enabled .Values.telemetry.metrics.serviceMonitor.enabled -}} +apiVersion: monitoring.coreos.com/v1 +kind: ServiceMonitor +metadata: + name: {{ include "openfga.fullname" . }} +{{- if .Values.telemetry.metrics.serviceMonitor.namespace }} + namespace: {{ .Values.telemetry.metrics.serviceMonitor.namespace }} +{{- else }} + namespace: {{ include "openfga.namespace" . }} +{{- end }} + labels: + {{- include "openfga.labels" . | nindent 4 }} + {{- if .Values.telemetry.metrics.serviceMonitor.additionalLabels }} + {{- toYaml .Values.telemetry.metrics.serviceMonitor.additionalLabels | nindent 4 }} + {{- end }} + {{- if .Values.telemetry.metrics.serviceMonitor.annotations }} + annotations: {{ toYaml .Values.telemetry.metrics.serviceMonitor.annotations | nindent 4 }} + {{- end }} +spec: + endpoints: + - port: metrics + interval: {{ .Values.telemetry.metrics.serviceMonitor.scrapeInterval }} + scrapeTimeout: {{ .Values.telemetry.metrics.serviceMonitor.scrapeTimeout }} + {{- if .Values.telemetry.metrics.serviceMonitor.honorLabels }} + honorLabels: true + {{- end }} + {{- if .Values.telemetry.metrics.serviceMonitor.relabelings }} + relabelings: {{ toYaml .Values.telemetry.metrics.serviceMonitor.relabelings | nindent 8 }} + {{- end }} + {{- if .Values.telemetry.metrics.serviceMonitor.metricRelabelings }} + metricRelabelings: {{ toYaml .Values.telemetry.metrics.serviceMonitor.metricRelabelings | nindent 8 }} + {{- end }} +{{- if .Values.telemetry.metrics.serviceMonitor.jobLabel }} + jobLabel: {{ .Values.telemetry.metrics.serviceMonitor.jobLabel | quote }} +{{- end }} +{{- if .Values.telemetry.metrics.serviceMonitor.namespaceSelector }} + namespaceSelector: {{ toYaml .Values.telemetry.metrics.serviceMonitor.namespaceSelector | nindent 4 }} +{{- else }} + namespaceSelector: + matchNames: + - {{ include "openfga.namespace" . }} +{{- end }} +{{- if .Values.telemetry.metrics.serviceMonitor.targetLabels }} + targetLabels: + {{- range .Values.telemetry.metrics.serviceMonitor.targetLabels }} + - {{ . }} + {{- end }} +{{- end }} + selector: + matchLabels: + {{- include "openfga.selectorLabels" . | nindent 6 }} +{{- end }} diff --git a/charts/openfga/values.schema.json b/charts/openfga/values.schema.json index 32430e9..77994bd 100644 --- a/charts/openfga/values.schema.json +++ b/charts/openfga/values.schema.json @@ -176,6 +176,66 @@ "description": "enable/disable prometheus metrics on the '/metrics' endpoint", "default": true }, + "serviceMonitor": { + "type": "object", + "properties": { + "enabled": { + "type": "boolean", + "description": "enable/disable installation of serviceMonitor custom resource", + "default": false + }, + "additionalLabels": { + "type": "object", + "description": "additional labels to be added to the serivceMonitor resource", + "default": {} + }, + "annotations": { + "type": "object", + "description": "annotations to be added to the serviceMonitor resource", + "default": {} + }, + "jobLabel": { + "type": "string", + "description": "the label to use to retrieve the job name from", + "default": "app.kubernetes.io/name" + }, + "namespace": { + "type": "string", + "description": "namespace where the serviceMonitor resource should be installed to", + "default": "" + }, + "namespaceSelector": { + "type": "object", + "description": "which namespaces should be scraped", + "default": {} + }, + "scrapeInterval": { + "type": "string", + "description": "prometheus scrape interval", + "default": "30s" + }, + "scrapeTimeout": { + "type": "string", + "description": "prometheus scrape timeout", + "default": "10s" + }, + "targetLabels": { + "type": "array", + "description": "additional target labels to scrape", + "default": [] + }, + "relabelings": { + "type": "array", + "description": "add job relabelings", + "default": [] + }, + "metricRelabelings": { + "type": "array", + "description": "add metric relabelings", + "default": [] + } + } + }, "addr": { "type": "string", "description": "the host:port address to serve the prometheus metrics server on", @@ -887,4 +947,4 @@ "common": {} }, "additionalProperties": false -} \ No newline at end of file +} diff --git a/charts/openfga/values.yaml b/charts/openfga/values.yaml index 8168386..cb56305 100644 --- a/charts/openfga/values.yaml +++ b/charts/openfga/values.yaml @@ -123,6 +123,56 @@ telemetry: ## enabled: true + serviceMonitor: + ## @param telemetry.metrics.serviceMonitor.enabled enable/disable installation of serviceMonitor custom resource + ## + enabled: false + + ## @param telemetry.metrics.serviceMonitor.additionalLabels additional labels to be added to the serivceMonitor resource + ## + additionalLabels: {} + + ## @param telemetry.metrics.serviceMonitor.annotations annotations to be added to the serviceMonitor resource + ## + annotations: {} + + ## @param telemetry.metrics.serviceMonitor.jobLabel the label to use to retrieve the job name from + ## + jobLabel: "app.kubernetes.io/name" + + ## @param telemetry.metrics.serviceMonitor.namespace namespace where the serviceMonitor resource should be installed to + ## + namespace: "" + + ## @param telemetry.metrics.serviceMonitor.namespaceSelector which namespaces should be scraped + ## + ## Default: scrape .Release.Namespace or namespaceOverride only + ## To scrape all, use the following: + ## namespaceSelector: + ## any: true + ## + namespaceSelector: {} + + ## @param telemetry.metrics.serviceMonitor.scrapeInterval prometheus scrape interval + ## + scrapeInterval: 30s + + ## @param telemetry.metrics.serviceMonitor.scrapeTimeout prometheus scrape timeout + ## + scrapeTimeout: 10s + + ## @param telemetry.metrics.serviceMonitor.targetLabels additional target labels to scrape + ## + targetLabels: [] + + ## @param telemetry.metrics.serviceMonitor.relabelings add job relabelings + ## + relabelings: [] + + ## @param telemetry.metrics.serviceMonitor.metricRelabelings add metric relabelings + ## + metricRelabelings: [] + ## @param telemetry.metrics.addr the host:port address to serve the Metrics server on addr: 0.0.0.0:2112