|
|
|
# Copyright © 2023 OpenIM. All rights reserved.
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
|
|
|
|
{{- if .Values.ingress.enabled -}}
|
|
|
|
{{- $fullName := include "openim-rpc-friend.fullname" . -}}
|
|
|
|
{{- $svcPort := .Values.service.port -}}
|
|
|
|
{{- if and .Values.ingress.className (not (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion)) }}
|
|
|
|
{{- if not (hasKey .Values.ingress.annotations "kubernetes.io/ingress.class") }}
|
|
|
|
{{- $_ := set .Values.ingress.annotations "kubernetes.io/ingress.class" .Values.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 }}
|
|
|
|
labels:
|
|
|
|
{{- include "openim-rpc-friend.labels" . | nindent 4 }}
|
|
|
|
{{- with .Values.ingress.annotations }}
|
|
|
|
annotations:
|
|
|
|
{{- toYaml . | nindent 4 }}
|
|
|
|
{{- end }}
|
|
|
|
spec:
|
|
|
|
{{- if and .Values.ingress.className (semverCompare ">=1.18-0" .Capabilities.KubeVersion.GitVersion) }}
|
|
|
|
ingressClassName: {{ .Values.ingress.className }}
|
|
|
|
{{- end }}
|
|
|
|
{{- if .Values.ingress.tls }}
|
|
|
|
tls:
|
|
|
|
{{- range .Values.ingress.tls }}
|
|
|
|
- hosts:
|
|
|
|
{{- range .hosts }}
|
|
|
|
- {{ . | quote }}
|
|
|
|
{{- end }}
|
|
|
|
secretName: {{ .secretName }}
|
|
|
|
{{- end }}
|
|
|
|
{{- end }}
|
|
|
|
rules:
|
|
|
|
{{- range .Values.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 }}
|
|
|
|
port:
|
|
|
|
number: {{ $svcPort }}
|
|
|
|
{{- else }}
|
|
|
|
serviceName: {{ $fullName }}
|
|
|
|
servicePort: {{ $svcPort }}
|
|
|
|
{{- end }}
|
|
|
|
{{- end }}
|
|
|
|
{{- end }}
|
|
|
|
{{- end }}
|