ACME webhook for Oracle Cloud Infrastructure
This solver can be used when you want to use cert-manager with Oracle Cloud Infrastructure as a DNS provider.
Requirements
Clone
git clone https://github.com/thpham/cert-manager-webhook-oci
Installation
cert-manager
Follow the instructions using the cert-manager documentation to install it within your cluster.
helm repo add jetstack https://charts.jetstack.io
helm repo update
helm upgrade --install --create-namespace \
--version v1.11.2 \
-n cert-manager \
--set installCRDs=true \
cert-manager jetstack/cert-manager
Webhook
From local checkout
helm upgrade --install \
-n cert-manager \
cert-manager-webhook-oci deploy/cert-manager-webhook-oci
Note: The kubernetes resources used to install the Webhook should be deployed within the same namespace as the cert-manager.
To uninstall the webhook run
helm uninstall -n cert-manager cert-manager-webhook-oci
Issuer
Create a ClusterIssuer
or Issuer
resource as following:
apiVersion: cert-manager.io/v1
kind: ClusterIssuer
metadata:
name: letsencrypt-staging
spec:
acme:
# The ACME server URL
server: https://acme-staging-v02.api.letsencrypt.org/directory
# Email address used for ACME registration
email: mail@example.com # REPLACE THIS WITH YOUR EMAIL!!!
# Name of a secret used to store the ACME account private key
privateKeySecretRef:
name: letsencrypt-staging
solvers:
- dns01:
webhook:
groupName: acme.d-n.be
solverName: oci
# next is only need with OCI API key auth
config:
ociProfileSecretName: oci-profile
compartmentOCID: ocid-of-compartment-to-use
Credentials
OCI Workload principal auth
A new feature was introduced in March 2023 that allow to write an OCI policy that identify kubernetes service account
as an identity principal which we can delegate permission to access OCI services.
related blog announcement and documentation.
Policy statement example:
Allow any-user to manage dns in compartment id <compartment_ocid> where all { request.principal.type = 'workload', request.principal.namespace = 'cert-manager', request.principal.service_account = 'cert-manager-webhook-oci', request.principal.cluster_id = 'ocid1.cluster.oc1...' }
OCI API key auth (deprecated)
In order to access the Oracle Cloud Infrastructure API, the webhook needs an OCI profile configuration.
If you choose another name for the secret than oci-profile
, ensure you modify the value of ociProfileSecretName
in the [Cluster]Issuer
.
The secret for the example above will look like this:
apiVersion: v1
kind: Secret
metadata:
name: oci-profile
type: Opaque
stringData:
tenancy: "your tenancy ocid"
user: "your user ocid"
region: "your region"
fingerprint: "your key fingerprint"
privateKey: |
-----BEGIN RSA PRIVATE KEY-----
...KEY DATA HERE...
-----END RSA PRIVATE KEY-----
privateKeyPassphrase: "private keys passphrase or empty string if none"
Create a certificate
Finally you can create certificates, for example:
apiVersion: cert-manager.io/v1
kind: Certificate
metadata:
name: example-cert
namespace: cert-manager
spec:
commonName: example.com
dnsNames:
- example.com
issuerRef:
name: letsencrypt-staging
secretName: example-cert
Scripts
A collection of BaSH scripts is available in the scripts directory. These are meant to help you prepare, install, and uninstall this webhook.
- Prepare
- Builds, tags, and pushes container image to a container image repository
- Target repository provider is OCIR
- Update environment variables
- Run this script only if you choose to host your own version of this webhook image in a private container image repository
- Install
- Helm chart local install
- Update environment variables
- Uncomment lines for pull secret creation only if you are hosting your own version of this webhook image
- Uninstall
- Helm chart local uninstall
Development
Updating dependencies
Update the version of go
in go.mod
(currently 1.19), then:
go get -u
go mod tidy
Running the test suite
All DNS providers must run the DNS01 provider conformance testing suite,
else they will have undetermined behaviour when used with cert-manager.
It is essential that you configure and run the test suite when creating a
DNS01 webhook.
First, create an Oracle Cloud Infrastructure account and ensure you have a DNS zone set up.
Next, create config files based on the *.sample
files in the testdata/oci
directory.
You can then run the test suite with:
TEST_ZONE_NAME=example.com. make test
Credits