2015-07-06 01:39:54 +02:00
|
|
|
#! /bin/sh
|
|
|
|
|
|
|
|
KEYS_DIR="/opt/dnscrypt-wrapper/etc/keys"
|
|
|
|
STKEYS_DIR="${KEYS_DIR}/short-term"
|
|
|
|
|
|
|
|
prune() {
|
|
|
|
find "$STKEYS_DIR" -type f -cmin +86400 -exec rm -f {} \;
|
|
|
|
}
|
|
|
|
|
|
|
|
rotation_needed() {
|
2015-07-12 15:43:57 +02:00
|
|
|
if [ ! -f "${STKEYS_DIR}/dnscrypt.cert" ]; then
|
2015-07-06 01:39:54 +02:00
|
|
|
echo true
|
|
|
|
else
|
2015-07-12 15:43:57 +02:00
|
|
|
if [ $(find "$STKEYS_DIR" -type f -cmin -43200 -print -quit | wc -l | sed 's/[^0-9]//g') -le 0 ]; then
|
|
|
|
echo true
|
|
|
|
else
|
|
|
|
echo false
|
|
|
|
fi
|
2015-07-06 01:39:54 +02:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
new_key() {
|
|
|
|
ts=$(date '+%s')
|
|
|
|
/opt/dnscrypt-wrapper/sbin/dnscrypt-wrapper --gen-crypt-keypair \
|
|
|
|
--crypt-secretkey-file="${STKEYS_DIR}/${ts}.key" &&
|
|
|
|
/opt/dnscrypt-wrapper/sbin/dnscrypt-wrapper --gen-cert-file \
|
|
|
|
--provider-publickey-file="${KEYS_DIR}/public.key" \
|
|
|
|
--provider-secretkey-file="${KEYS_DIR}/secret.key" \
|
|
|
|
--crypt-secretkey-file="${STKEYS_DIR}/${ts}.key" \
|
2015-07-12 15:45:44 +02:00
|
|
|
--provider-cert-file="${STKEYS_DIR}/${ts}.cert" \
|
2015-07-06 02:10:51 +02:00
|
|
|
--cert-file-expire-days=1 && \
|
2015-07-06 01:39:54 +02:00
|
|
|
mv -f "${STKEYS_DIR}/${ts}.cert" "${STKEYS_DIR}/dnscrypt.cert"
|
|
|
|
}
|
|
|
|
|
|
|
|
stkeys_files() {
|
|
|
|
res=""
|
|
|
|
for file in $(ls "$STKEYS_DIR"/[0-9]*.key); do
|
|
|
|
res="${res}${file},"
|
|
|
|
done
|
|
|
|
echo "$res"
|
|
|
|
}
|
|
|
|
|
|
|
|
if [ ! -f "$KEYS_DIR/provider_name" ]; then
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
provider_name=$(cat "$KEYS_DIR/provider_name")
|
|
|
|
|
|
|
|
mkdir -p "$STKEYS_DIR"
|
|
|
|
prune
|
|
|
|
[ $(rotation_needed) = true ] && new_key
|
|
|
|
|
|
|
|
exec /opt/dnscrypt-wrapper/sbin/dnscrypt-wrapper \
|
|
|
|
--user=_dnscrypt-wrapper \
|
|
|
|
--listen-address=0.0.0.0:443 \
|
|
|
|
--resolver-address=127.0.0.1 \
|
|
|
|
--provider-name="$provider_name" \
|
|
|
|
--provider-cert-file="${STKEYS_DIR}/dnscrypt.cert" \
|
|
|
|
--crypt-secretkey-file=$(stkeys_files)
|