123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- {{- 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 }}: {{ $value | 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: {{ .Release.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.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 }}
- {{- end }}
- {{- if semverCompare ">=1.21.0-0" .Capabilities.KubeVersion.Version -}}
- {{- 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" .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" .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 }}
|