This is a certbot plugin to perform dns-01 authentication using the Hetzner Cloud (Console) API
Project description
Hetzner Cloud DNS Authenticator plugin for Certbot
This plugin automates the process of completing a dns-01 challenge by creating, and subsequently removing, TXT records using the Hetzner Console API.
Installation
pip install certbot-dns-hcloud
Named Arguments
To start using DNS authentication for HCloud, pass the following arguments on certbot’s command line:
--authenticator dns-hcloud |
select the authenticator plugin (Required) |
--dns-hcloud-credentials |
Hetzner Console API credentials INI file. (Required) |
--dns-hcloud-propagation-seconds |
waiting time for DNS to propagate before asking
the ACME server to verify the DNS record.
(Default: 60, Recommended: >= 120)
|
Credentials
An example credentials.ini file:
dns_hcloud_api_token = j8foaU8u2irpupAHwaf...
The path to this file can be provided interactively or using the --dns-hcloud-credentials command-line argument. Certbot records the path to this file for use during renewal, but does not store the file’s contents.
Caution: You should protect these API credentials as you would the password to your ispconfig account. Users who can read this file can use these credentials to issue arbitrary API calls on your behalf. Users who can cause Certbot to run using these credentials can complete a dns-01 challenge to acquire new certificates or revoke existing certificates for associated domains, even if those domains aren’t being managed by this server.
Certbot will emit a warning if it detects that the credentials file can be accessed by other users on your system. The warning reads “Unsafe permissions on credentials configuration file”, followed by the path to the credentials file. This warning will be emitted each time Certbot uses the credentials file, including for renewal, and cannot be silenced except by addressing the issue (e.g., by using a command like chmod 600 to restrict access to the file).
Examples
To acquire a single certificate for both example.com and *.example.com, waiting 900 seconds for DNS propagation:
certbot certonly \
--authenticator dns-hcloud \
--dns-hcloud-credentials /etc/letsencrypt/.secrets/hetzner/certbot.ini \
--dns-hcloud-propagation-seconds 900 \
-d 'example.com' \
-d '*.example.com'
It is suggested to secure the folder as follows:
chown root:root /etc/letsencrypt/.secrets
chmod 600 /etc/letsencrypt/.secrets
Recommended Setup (Debian 13)
Install system dependencies
sudo apt update
sudo apt install -y python3 python3-venv python3-dev libaugeas-dev gcc git
I do generaly not recommended to run certbot as root. Therefor you create a new system user:
sudo useradd -r -m certbot
Create letsencrypt directories and change permissions
sudo mkdir -p {/etc,/var/log,/var/lib}/letsencrypt
sudo chown -R certbot:certbot {/etc,/var/log,/var/lib}/letsencrypt
sudo find {/etc,/var/log,/var/lib}/letsencrypt -type d -exec sudo chmod 755 {} +
sudo find {/etc,/var/log,/var/lib}/letsencrypt -type f -exec sudo chmod 644 {} +
Install certbot and certbot-dns-hcloud inside a virtual environment
# install venv for certbot
sudo python3 -m venv /opt/certbot
# change owner of the venv
sudo chown certbot:certbot -R /opt/certbot
# switch to certbot
sudo -su certbot
# install certbot
/opt/certbot/bin/python -m pip install --upgrade pip
/opt/certbot/bin/python -m pip install certbot certbot-dns-hcloud
# create credentials file
mkdir -p ~/.secrets/hetzner
echo "dns_hcloud_api_token = <PLACE TOKEN HERE>" | tee ~/.secrets/hetzner/hcloud.ini
chmod 600 ~/.secrets/hetzner/hcloud.ini
# exit from certbot
exit
# expose certbot executable
sudo ln -s /opt/certbot/bin/certbot /bin/certbot
If you did not replace the <PLACE TOKEN HERE> with your Hetzner Console API token, edit the file with your prefered text editor i.e. nvim, vi or nano.
Caution: You have to use a Hetzner Console API token. Dont’t confuse with the old konsoleH API token. The DNS console has been moved from konsoleH to Hetzner Console and now you have to use the Hetzner Cloud API to manage your DNS zones.
Test if the installation was successful
sudo -su certbot
certbot certonly -n \
--agree-tos \
--dry-run \
--test-cert \
--authenticator dns-hcloud \
--dns-hcloud-credentials ~/.secrets/hetzner/hcloud.ini \
--dns-hcloud-propagation-seconds 120 \
-d example.com \
-d *.example.com
exit
If certbot is installed correctly this should run without errors. If the challenge fails, change --dns-hcloud-credentials and check API token then try again.
Request your certificates
sudo -su certbot
certbot certonly -n \
--agree-tos \
--authenticator dns-hcloud \
--dns-hcloud-credentials ~/.secrets/hetzner/hcloud.ini \
--dns-hcloud-propagation-seconds 120 \
-d example.com \
-d *.example.com
exit
Setup cron job for automated renewal
# renewal twice a day
echo "0 0,12 * * * certbot /opt/certbot/bin/python -c 'import random; import time; time.sleep(random.random() * 3600)' && certbot renew -q" | sudo tee -a /etc/crontab > /dev/null
Setup cron job for automated updates
# update every Monday at 6 am
echo "0 6 * * 1 certbot /opt/certbot/bin/python -m pip install --upgrade certbot certbot-dns-hcloud" | sudo tee -a /etc/crontab > /dev/null
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file certbot_dns_hcloud-1.1.2.tar.gz.
File metadata
- Download URL: certbot_dns_hcloud-1.1.2.tar.gz
- Upload date:
- Size: 10.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
859587dfa29b9de73340c9434e7769ae44356d136c4d9926bcd6c002faa9ddb6
|
|
| MD5 |
1f80be56cda0537dabe13b63253fea9c
|
|
| BLAKE2b-256 |
9943c46f88908a182f4bdd73ea8d8d0f2948e3572e0064d21066b09b273b50ef
|
File details
Details for the file certbot_dns_hcloud-1.1.2-py3-none-any.whl.
File metadata
- Download URL: certbot_dns_hcloud-1.1.2-py3-none-any.whl
- Upload date:
- Size: 11.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
40ae4fd97c9817faf75ccddb451a1baf6be230cb3b2492c1a916d4de527a15b5
|
|
| MD5 |
7f0c08110423500b0c44a385077728a1
|
|
| BLAKE2b-256 |
2dd5a68a2453a906d95f0db0f652df634babd0acfc78c927eb7f6a3081871ca8
|