{{- if and (.Values.global.prometheus.enabled) (.Values.prometheus.server.enabled) (.Values.prometheus.server.ingress.enabled) }} {{- $serviceName := include "prometheus.server.fullname" . }} {{- $servicePort := .Values.prometheus.server.service.servicePort -}} {{- $extraPaths := .Values.prometheus.server.ingress.extraPaths -}} {{- $pathType := .Values.prometheus.server.ingress.pathType -}} apiVersion: networking.k8s.io/v1 kind: Ingress metadata: {{- if .Values.prometheus.server.ingress.annotations }} annotations: {{ toYaml .Values.prometheus.server.ingress.annotations | indent 4 }} {{- end }} labels: {{- include "prometheus.server.labels" . | nindent 4 }} {{- range $key, $value := .Values.prometheus.server.ingress.extraLabels }} {{ $key }}: {{ $value }} {{- end }} name: {{ template "prometheus.server.fullname" . }} namespace: {{ .Release.Namespace }} spec: {{- if .Values.prometheus.server.ingress.className }} ingressClassName: {{ .Values.prometheus.server.ingress.className }} {{- end }} rules: {{- range .Values.prometheus.server.ingress.hosts }} {{- $url := splitList "/" . }} - host: {{ first $url }} http: paths: {{ if $extraPaths }} {{ toYaml $extraPaths | indent 10 }} {{- end }} - path: /{{ rest $url | join "/" }} pathType: {{ $pathType }} backend: service: name: {{ $serviceName }} port: number: {{ $servicePort }} {{- end -}} {{- if .Values.prometheus.server.ingress.tls }} tls: {{ toYaml .Values.prometheus.server.ingress.tls | indent 4 }} {{- end -}} {{- end }}