73 lines
1.8 KiB
YAML
73 lines
1.8 KiB
YAML
{{- if .Values.clusterConfig.gatewayAPI.enabled }}
|
|
apiVersion: gateway.networking.k8s.io/v1
|
|
kind: HTTPRoute
|
|
metadata:
|
|
name: gatus
|
|
namespace: uptime
|
|
spec:
|
|
parentRefs:
|
|
- name: shared-gateway
|
|
namespace: kube-system
|
|
sectionName: https-internal
|
|
hostnames:
|
|
- uptime.{{ .Values.clusterConfig.domain }}
|
|
rules:
|
|
- matches:
|
|
- path:
|
|
type: PathPrefix
|
|
value: "/"
|
|
backendRefs:
|
|
- name: gatus
|
|
port: 80
|
|
---
|
|
apiVersion: cilium.io/v2
|
|
kind: CiliumNetworkPolicy
|
|
metadata:
|
|
name: allow-gateway-to-gatus
|
|
namespace: uptime
|
|
spec:
|
|
endpointSelector:
|
|
matchLabels:
|
|
app.kubernetes.io/name: gatus
|
|
ingress:
|
|
- fromCIDRSet:
|
|
{{- range .Values.clusterConfig.ingress_whitelist }}
|
|
- cidr: {{ . }}
|
|
{{- end }}
|
|
- fromEndpoints:
|
|
- matchLabels:
|
|
"k8s:io.kubernetes.pod.namespace": uptime
|
|
{{- else }}
|
|
apiVersion: networking.k8s.io/v1
|
|
kind: Ingress
|
|
metadata:
|
|
annotations:
|
|
cert-manager.io/cluster-issuer: {{ .Values.clusterConfig.ingress_clusterissuer }}
|
|
nginx.ingress.kubernetes.io/backend-protocol: HTTP
|
|
nginx.ingress.kubernetes.io/cors-allow-headers: Content-Type, x-gatus-cache
|
|
nginx.ingress.kubernetes.io/enable-cors: "true"
|
|
nginx.ingress.kubernetes.io/proxy-buffer-size: 128k
|
|
nginx.ingress.kubernetes.io/ssl-redirect: "true"
|
|
labels:
|
|
app.kubernetes.io/name: gatus
|
|
name: gatus
|
|
namespace: uptime
|
|
spec:
|
|
ingressClassName: nginx
|
|
rules:
|
|
- host: uptime.{{ .Values.clusterConfig.domain }}
|
|
http:
|
|
paths:
|
|
- backend:
|
|
service:
|
|
name: gatus
|
|
port:
|
|
number: 80
|
|
path: /
|
|
pathType: ImplementationSpecific
|
|
tls:
|
|
- hosts:
|
|
- uptime.{{ .Values.clusterConfig.domain }}
|
|
secretName: gatus-tls
|
|
{{- end }}
|