Use DNSPod with letsencrypt.sh and the DNS challenge type
Switch branches/tags
Nothing to show
Clone or download
Pull request Compare This branch is 11 commits ahead, 24 commits behind kappataumu:master.
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Failed to load latest commit information.
LICENCE
README.md
hook.py
requirements-python-2.txt
requirements.txt

README.md

DNSPOD hook for dehydrated

This a hook for dehydrated (a Let's Encrypt ACME client) that allows you to use DNSPod DNS records to respond to dns-01 challenges. Requires Python and your DNSPod account API token being in the environment.

Installation

$ git clone https://github.com/lukas2511/dehydrated
$ cd dehydrated
$ mkdir hooks
$ git clone https://github.com/ftao/letsencrypt-dnspod-hook hooks/dnspod
$ pip install -r hooks/dnspod/requirements.txt

If using Python 2, replace the last step with the one below and check the urllib3 documentation for other possible caveats.

$ pip install -r hooks/dnspod/requirements-python-2.txt

Configuration

Your account's DNSPod LOGIN Token are expected to be in the environment, so make sure to:

$ export DNSPOD_LOGIN_TOKEN='YOUR-DNSPOD-LOGIN-TOKEN'

Alternatively, these statements can be placed in dehydrated/config.sh, which is automatically sourced by dehydrated on startup:

echo "export DNSPOD_LOGIN_TOKEN='YOUR-DNSPOD-LOGIN-TOKEN'" >> config.sh

Usage

$ ./dehydrated -c -d example.com -t dns-01 -k 'hooks/dnspod/hook.py'
#
# !! WARNING !! No main config file found, using default config!
#
Processing example.com
 + Signing domains...
 + Creating new directory /home/user/dehydrated/certs/example.com ...
 + Generating private key...
 + Generating signing request...
 + Requesting challenge for example.com...
 + DNSPod hook executing: deploy_challenge
 + DNS not propagated, waiting 30s...
 + DNS not propagated, waiting 30s...
 + Responding to challenge for example.com...
 + DNSPod hook executing: clean_challenge
 + Challenge is valid!
 + Requesting certificate...
 + Checking certificate...
 + Done!
 + Creating fullchain.pem...
 + DNSPod hook executing: deploy_cert
 + ssl_certificate: /home/user/dehydrated/certs/example.com/fullchain.pem
 + ssl_certificate_key: /home/user/dehydrated/certs/example.com/privkey.pem
 + Done!