external-dns-cloudflare-tunnel-webhook
Read about how I implemented this here.
[!WARNING]
This provider is experimental
This is a provider for use with external-dns via the webhook mechanism. It provides the ability to create public hostnames and backing DNS records for Cloudflare Tunnels.
[!NOTE]
Due to limitations of the external-dns webhook mechanism and my lack of brainpower, this provider only supports backing a single tunnel. To support more tunnels, deploy more instances of this provider.
Deploying
You will need:
- A Kubernetes cluster
- Helm CLI installed
- A Cloudflare account with some form of authorization with scopes
- All accounts - Cloudflare Tunnel:Edit
- All zones - DNS:Edit
Ensure you have a secret with your Cloudflare credentials.
kubectl create secret generic cloudflare-credentials --from-literal=CLOUDFLARE_API_TOKEN=blah
Create a values file, see below for a minimum config.
cat <<EOF > ./values.yaml
logLevel: info
logFormat: json
interval: 1h
provider:
name: webhook
webhook:
image:
repository: docker.io/axatol/external-dns-cloudflare-tunnel-webhook
tag: latest
env:
- name: CLOUDFLARE_API_TOKEN
valueFrom:
secretKeyRef:
name: cloudflare-credentials
key: CLOUDFLARE_API_TOKEN
EOF
Install the external-dns chart.
helm repo add external-dns https://kubernetes-sigs.github.io/external-dns/
helm repo update
helm upgrade external-dns-cloudflare-tunnel external-dns/external-dns \
--install \
--atomic \
--create-namespace \
--namespace external-dns \
--values ./values.yaml
Configuration
Kubernetes annotations
Environment variable |
Flag |
Type |
Default |
Notes |
LOG_LEVEL |
-log-level |
enum |
"info" |
^4 |
LOG_FORMAT |
-log-format |
enum |
"json" |
^5 |
CLOUDFLARE_API_KEY |
-cloudflare-api-key |
string |
"" |
^1 |
CLOUDFLARE_API_EMAIL |
-cloudflare-api-email |
string |
"" |
^1 |
CLOUDFLARE_API_TOKEN |
-cloudflare-api-token |
string |
"" |
^1 |
CLOUDFLARE_ACCOUNT_ID |
-cloudflare-account-id |
string |
|
^2 |
CLOUDFLARE_TUNNEL_ID |
-cloudflare-tunnel-id |
string |
|
^2 |
PORT |
-port |
int64 |
"8888" |
|
READ_TIMEOUT |
-read-timeout |
time.Duration |
"5s" |
|
WRITE_TIMEOUT |
-write-timeout |
time.Duration |
"10s" |
|
DRY_RUN |
-dry-run |
bool |
"false" |
|
DOMAIN_FILTER |
-domain-filter |
[]string |
"" delimiter:"," |
^3 |
- Must specify:
- both
CLOUDFLARE_API_KEY
and CLOUDFLARE_API_EMAIL
- or
CLOUDFLARE_API_TOKEN
- Required field
- Specify multiple by delimiting with
,
- One of
trace
, debug
, info
, warn
, error
, fatal
- One of
text
, json