47 lines
1.7 KiB
Bash
47 lines
1.7 KiB
Bash
|
#!/bin/sh
|
||
|
|
||
|
echo ----------------
|
||
|
echo "Generating certs - hostname: $HOST_NAME; IP: $HOST_IP; SAN: $SAN, expiry days: $EXPIRY_DAYS"
|
||
|
echo ----------------
|
||
|
|
||
|
openssl rand -base64 32 > ca.password
|
||
|
|
||
|
openssl genrsa -aes256 -passout file:ca.password -out ca-key.pem 4096
|
||
|
openssl req -subj "/C=UK/ST=LONDON/L=London/O=KIAMOL/OU=elton" -new -x509 -days $EXPIRY_DAYS -passin file:ca.password -key ca-key.pem -sha256 -out ca.pem
|
||
|
|
||
|
openssl genrsa -out server-key.pem 4096
|
||
|
openssl req -subj "/CN=$HOST_NAME" -sha256 -new -key server-key.pem -out server.csr
|
||
|
|
||
|
echo "subjectAltName = $SAN" >> extfile.cnf
|
||
|
echo extendedKeyUsage = serverAuth >> extfile.cnf
|
||
|
openssl x509 -req -days $EXPIRY_DAYS -sha256 -in server.csr -CA ca.pem -CAkey ca-key.pem -CAcreateserial -out server-cert.pem -extfile extfile.cnf -passin file:ca.password
|
||
|
|
||
|
rm *.cnf
|
||
|
rm *.csr
|
||
|
rm *.srl
|
||
|
|
||
|
echo ----------------
|
||
|
echo Certs generated.
|
||
|
echo ----------------
|
||
|
|
||
|
if [ -n "$CREATE_SECRET" ]; then
|
||
|
# set up access to Kube API
|
||
|
kubectl config set-cluster default --server=https://kubernetes.default.svc.cluster.local --certificate-authority=/var/run/secrets/kubernetes.io/serviceaccount/ca.crt
|
||
|
kubectl config set-context default --cluster=default
|
||
|
kubectl config set-credentials user --token=$(cat /var/run/secrets/kubernetes.io/serviceaccount/token)
|
||
|
kubectl config set-context default --user=user
|
||
|
kubectl config use-context default
|
||
|
|
||
|
mv server-cert.pem tls.crt
|
||
|
mv server-key.pem tls.key
|
||
|
kubectl create secret tls $CREATE_SECRET --key=tls.key --cert=tls.crt
|
||
|
kubectl label secret $CREATE_SECRET kiamol=$SECRET_LABEL
|
||
|
|
||
|
echo ---------------
|
||
|
echo Created secret.
|
||
|
echo ---------------
|
||
|
|
||
|
openssl base64 -A <"ca.pem" > ca.base64
|
||
|
fi
|
||
|
|
||
|
trap : TERM INT; (while true; do sleep 1000; done) & wait
|