infrastructure/pomerium/templates/redis/tls-secrets.yaml
Infrastructure Admin d770504fa5 Initial infrastructure as code deployment
This commit includes the complete Kubernetes infrastructure deployment for NGE6:

- Crossplane setup with providers (Kubernetes, Helm, Civo)
- Ambassador/Emissary ingress controller with SSL termination
- Cert-manager with Let's Encrypt and Gandi webhook for DNS01 challenges
- ExternalDNS integration with Gandi for automatic DNS management
- Keycloak authentication server with PostgreSQL
- Pomerium identity-aware proxy with OIDC integration
- Forgejo Git server with persistent storage and authentication
- Spire/SPIFFE for secure service communication

All services are deployed using Infrastructure as Code principles with
Crossplane managing Kubernetes and Helm resources declaratively.

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-23 08:43:06 -04:00

34 lines
1.3 KiB
YAML

{{- if and ( include "pomerium.redis.tlsCertsGenerated" . ) (or .Release.IsInstall .Values.redis.forceGenerateTLS) }}
{{- $ca := genCA "default-ca" 3650 }}
{{- $redisSN := list (printf "%s-redis-master.%s.svc.cluster.local" (include "pomerium.fullname" .) .Release.Namespace ) (printf "%s-redis-slave.%s.svc.cluster.local" (include "pomerium.fullname" .) .Release.Namespace ) }}
{{- $clientSN := include "pomerium.authenticate.fullname" . }}
{{- $server := genSignedCert "redis" nil $redisSN 3650 $ca }}
apiVersion: v1
kind: Secret
metadata:
labels:
app.kubernetes.io/name: {{ template "pomerium.name" . }}
helm.sh/chart: {{ template "pomerium.chart" . }}
app.kubernetes.io/managed-by: {{ .Release.Service }}
app.kubernetes.io/instance: {{ .Release.Name }}
annotations:
helm.sh/hook-delete-policy: before-hook-creation
{{- if .Values.redis.forceGenerateTLS }}
helm.sh/hook: pre-upgrade
{{- else if .Values.redis.generateTLS }}
helm.sh/hook: pre-install
{{- end }}
{{- if .Values.config.generateTLSAnnotations }}
{{- range $key, $value := .Values.config.generateTLSAnnotations }}
{{ $key }}: {{ $value | quote }}
{{- end }}
{{- end }}
name: {{ template "pomerium.redis.tlsSecret.name" . }}
type: Opaque
data:
ca.crt: {{ $ca.Cert | b64enc }}
tls.crt: {{ $server.Cert | b64enc }}
tls.key: {{ $server.Key | b64enc }}
{{- end -}}