-
Notifications
You must be signed in to change notification settings - Fork 0
/
hook
executable file
·62 lines (47 loc) · 1.69 KB
/
hook
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
#!/usr/bin/env bash
SD="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
deploy_challenge() {
local DOMAIN="${1}" TOKEN_FILENAME="${2}" TOKEN_VALUE="${3}"
echo " - Deploying challenge for $DOMAIN"
USERNAME=$(cat $SD/acme-dns.json | jq -r '.domains["'$DOMAIN'"].username')
PASSWORD=$(cat $SD/acme-dns.json | jq -r '.domains["'$DOMAIN'"].password')
SUBDOMAIN=$(cat $SD/acme-dns.json | jq -r '.domains["'$DOMAIN'"].subdomain')
SERVER=$(cat $SD/acme-dns.json | jq -r .config.server)
curl \
--header "Content-Type: application/json" \
--header "X-Api-User: $USERNAME" \
--header "X-Api-Key: $PASSWORD" \
--request POST \
--data "{\"subdomain\":\"${SUBDOMAIN}\",\"txt\":\"${TOKEN_VALUE}\"}" \
$SERVER/update
}
clean_challenge() {
local DOMAIN="${1}" TOKEN_FILENAME="${2}" TOKEN_VALUE="${3}"
echo " - Cleaning challenge for $DOMAIN"
}
deploy_cert() {
local DOMAIN="${1}" KEYFILE="${2}" CERTFILE="${3}" FULLCHAINFILE="${4}" CHAINFILE="${5}" TIMESTAMP="${6}"
echo " - Deploying cert $DOMAIN"
cat $SD/acme-dns.json | jq -r '.certs["'$DOMAIN'"].hook | (arrays | .[]),(strings)' | while read command
do
$command
done
}
HANDLER="$1"; shift
if [[ "${HANDLER}" =~ ^(deploy_challenge|clean_challenge|deploy_cert)$ ]]; then
while [ $# -gt 0 ]
do
"$HANDLER" "$@"
if [ $HANDLER == "deploy_challenge" ]
then
sleep $(cat $SD/acme-dns.json | jq -r '.config."deploy-wait"')
shift 3
elif [ $HANDLER == "clean_challenge" ]
then
shift 3
elif [ $HANDLER == "deploy_cert" ]
then
shift 6
fi
done
fi