forked from clicktruck/cert-manager-webhook-oci
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinstall-cert-manager-webhook-oci.sh
executable file
·135 lines (116 loc) · 3.67 KB
/
install-cert-manager-webhook-oci.sh
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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
#!/usr/bin/env bash
set -eox pipefail
indent4() { sed 's/^/ /'; }
# Install the necessary resources to support cert-manager deployed on OKE
# vending valid certificate via a Let's Encrypt ClusterIssuer
# Set environment variables (these are sample values, please replace with your own)
export DOMAIN=foo.me
export [email protected]
export COMPARTMENT_OCID=ocid1.compartment.oc1..aaaaaaaa_
export TENANCY_OCID=ocid1.tenancy.oc1..aaaaaaaa_
export USER_OCID=ocid1.user.oc1..aaaaaaaa_
export REGION=us-phoenix-1
export FINGERPRINT=47:5f:c7:0d:a3:a5:ac:d6:53:41:d2:23:c6:c9:24:a2
export IMAGE_REPOSITORY_NAME=phx.ocir.io/axyd58snjxbf/cert-manager-webhook-oci
# Oracle Cloud credentials
export OCI_CONFIG_HOME=$HOME/.oci
export OCI_PEM_PRIVATE_KEY_FILE_PATH=$OCI_CONFIG_HOME/oci_api_key.pem
# Convert PEM private key to RSA
openssl rsa -in $OCI_PEM_PRIVATE_KEY_FILE_PATH -out $OCI_CONFIG_HOME/oci_api_rsa_key
export RSA_PRIVATE_KEY=$(cat $OCI_CONFIG_HOME/oci_api_rsa_key | indent4)
# Install Contour ingress
kubectl apply -f https://projectcontour.io/quickstart/contour.yaml
# Install cert-manager
helm repo add jetstack https://charts.jetstack.io
helm repo update
helm install \
cert-manager jetstack/cert-manager \
--namespace cert-manager \
--create-namespace \
--version v1.11.2 \
--set installCRDs=true \
--set prometheus.enabled=false \
--set webhook.timeoutSeconds=30
# Install cert-manager OCI webhook
# This is from a fork of https://gitlab.com/dn13/cert-manager-webhook-oci
# @see https://gitlab.com/jcotton/cert-manager-webhook-oci.git
cd /tmp
git clone https://github.com/thpham/cert-manager-webhook-oci.git
cd cert-manager-webhook-oci
helm install --namespace cert-manager cert-manager-webhook-oci ./deploy/cert-manager-webhook-oci \
--set image.repository=$IMAGE_REPOSITORY_NAME
# Create an image pull secret
# Uncomment lines below, then add appropriate credentials, but only if you choose to host your own image and have updated the IMAGE_REPOSITORY_NAME above
#export DOCKER_USERNAME=
#export DOCKER_PASSWORD=
#export DOCKER_HOST=
#kubectl create secret docker-registry regcred \
# --docker-server=${DOCKER_HOST} \
# --docker-username=${DOCKER_USERNAME} \
# --docker-password="${DOCKER_PASSWORD}" \
# --docker-email=${EMAIL_ADDRESS} \
# --namespace cert-manager
# Create namespace to store secret
kubectl create ns contour-tls
mkdir -p /tmp/oci
cd /tmp/oci
# Define ClusterIssuer
cat << EOF > cluster-issuer-oci.yml
apiVersion: cert-manager.io/v1
kind: ClusterIssuer
metadata:
name: letsencrypt-prod
spec:
acme:
# The ACME server URL
server: https://acme-v02.api.letsencrypt.org/directory
# Email address used for ACME registration
email: $EMAIL_ADDRESS
# Name of a secret used to store the ACME account private key
privateKeySecretRef:
name: letsencrypt-prod
solvers:
- dns01:
webhook:
groupName: acme.d-n.be
solverName: oci
config:
ociProfileSecretName: oci-profile
compartmentOCID: $COMPARTMENT_OCID
EOF
# Define Secret with OCI credentials
cat << EOF > secret-oci.yml
apiVersion: v1
kind: Secret
metadata:
name: oci-profile
namespace: cert-manager
type: Opaque
stringData:
tenancy: "$TENANCY_OCID"
user: "$USER_OCID"
region: "$REGION"
fingerprint: "$FINGERPRINT"
privateKey: |
$RSA_PRIVATE_KEY
privateKeyPassphrase: ""
EOF
# Define Certificate
cat << EOF > certificate-oci.yml
apiVersion: cert-manager.io/v1
kind: Certificate
metadata:
name: tls
namespace: contour-tls
spec:
commonName: $DOMAIN
dnsNames:
- $DOMAIN
issuerRef:
kind: ClusterIssuer
name: letsencrypt-prod
secretName: tls
EOF
cd ..
# Let it rip!
kubectl apply -f oci/