-
Notifications
You must be signed in to change notification settings - Fork 10
Expand file tree
/
Copy pathpki.yaml
More file actions
84 lines (78 loc) · 3.03 KB
/
pki.yaml
File metadata and controls
84 lines (78 loc) · 3.03 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
---
# Create a selfsigned Issuer, in order to create a root CA certificate for
# signing webhook serving certificates
apiVersion: cert-manager.io/v1
kind: Issuer
metadata:
name: {{ include "stackit-cert-manager-webhook.selfSignedIssuer" . }}
namespace: {{ .Release.Namespace | quote }}
labels:
app: {{ include "stackit-cert-manager-webhook.name" . }}
chart: {{ include "stackit-cert-manager-webhook.chart" . }}
release: {{ .Release.Name }}
heritage: {{ .Release.Service }}
spec:
selfSigned: {}
---
# Generate a CA Certificate used to sign certificates for the webhook
apiVersion: cert-manager.io/v1
kind: Certificate
metadata:
name: {{ include "stackit-cert-manager-webhook.rootCACertificate" . }}
namespace: {{ .Release.Namespace | quote }}
labels:
app: {{ include "stackit-cert-manager-webhook.name" . }}
chart: {{ include "stackit-cert-manager-webhook.chart" . }}
release: {{ .Release.Name }}
heritage: {{ .Release.Service }}
spec:
secretName: {{ include "stackit-cert-manager-webhook.rootCACertificate" . }}
duration: 43800h0m0s # 5y
issuerRef:
name: {{ include "stackit-cert-manager-webhook.selfSignedIssuer" . }}
commonName: "ca.stackit-cert-manager-webhook.cert-manager"
isCA: true
privateKey:
# Default changed from "Never" to "Always" in cert-manager >= 1.18, ensure
# for now that the behavior does not change when cert-manager is updated.
rotationPolicy: Never
---
# Create an Issuer that uses the above generated CA certificate to issue certs
apiVersion: cert-manager.io/v1
kind: Issuer
metadata:
name: {{ include "stackit-cert-manager-webhook.rootCAIssuer" . }}
namespace: {{ .Release.Namespace | quote }}
labels:
app: {{ include "stackit-cert-manager-webhook.name" . }}
chart: {{ include "stackit-cert-manager-webhook.chart" . }}
release: {{ .Release.Name }}
heritage: {{ .Release.Service }}
spec:
ca:
secretName: {{ include "stackit-cert-manager-webhook.rootCACertificate" . }}
---
# Finally, generate a serving certificate for the webhook to use
apiVersion: cert-manager.io/v1
kind: Certificate
metadata:
name: {{ include "stackit-cert-manager-webhook.servingCertificate" . }}
namespace: {{ .Release.Namespace | quote }}
labels:
app: {{ include "stackit-cert-manager-webhook.name" . }}
chart: {{ include "stackit-cert-manager-webhook.chart" . }}
release: {{ .Release.Name }}
heritage: {{ .Release.Service }}
spec:
secretName: {{ include "stackit-cert-manager-webhook.servingCertificate" . }}
duration: 8760h0m0s # 1y
issuerRef:
name: {{ include "stackit-cert-manager-webhook.rootCAIssuer" . }}
dnsNames:
- {{ include "stackit-cert-manager-webhook.fullname" . }}
- {{ include "stackit-cert-manager-webhook.fullname" . }}.{{ .Release.Namespace }}
- {{ include "stackit-cert-manager-webhook.fullname" . }}.{{ .Release.Namespace }}.svc
privateKey:
# Default changed from "Never" to "Always" in cert-manager >= 1.18, ensure
# for now that the behavior does not change when cert-manager is updated.
rotationPolicy: Never