2
0
mirror of https://github.com/dnscrypt/dnscrypt-server-docker synced 2024-11-19 09:25:47 +00:00
dnscrypt-server-docker/entrypoint.sh

115 lines
3.2 KiB
Bash
Raw Normal View History

#! /usr/bin/env bash
2015-07-05 23:39:54 +00:00
set -e
action="$1"
KEYS_DIR="/opt/dnscrypt-wrapper/etc/keys"
2018-01-22 19:23:54 +00:00
# -N provider-name -E external-ip-address:port
2015-07-05 23:39:54 +00:00
init() {
if [ $(is_initialized) = yes ]; then
start
exit $?
fi
2018-01-22 19:23:54 +00:00
while getopts "h?N:E:" opt; do
2015-07-05 23:39:54 +00:00
case "$opt" in
h|\?) usage ;;
N) provider_name=$(echo "$OPTARG" | sed -e 's/^[ \t]*//' | tr A-Z a-z) ;;
2018-01-22 19:23:54 +00:00
E) ext_address=$(echo "$OPTARG" | sed -e 's/^[ \t]*//' | tr A-Z a-z) ;;
2015-07-05 23:39:54 +00:00
esac
done
[ -z "$provider_name" ] && usage
case "$provider_name" in
.*) usage ;;
2.dnscrypt-cert.*) ;;
*) provider_name="2.dnscrypt-cert.${provider_name}"
esac
2018-01-22 17:21:50 +00:00
2018-01-22 19:23:54 +00:00
[ -z "$ext_address" ] && usage
case "$ext_address" in
2018-01-22 17:21:50 +00:00
.*) usage ;;
0.*) echo "Do not use 0.0.0.0, use an actual external IP address" >&2 ; exit 1 ;;
esac
2018-01-22 19:23:54 +00:00
2018-01-22 17:21:50 +00:00
echo "Provider name: [$provider_name]"
2015-07-05 23:39:54 +00:00
cd "$KEYS_DIR"
2018-01-22 17:21:50 +00:00
/opt/dnscrypt-wrapper/sbin/dnscrypt-wrapper \
--gen-provider-keypair --nolog --dnssec \
2018-01-22 19:23:54 +00:00
--provider-name="$provider_name" --ext-address="$ext_address" | \
2015-07-05 23:39:54 +00:00
tee "${KEYS_DIR}/provider-info.txt"
chmod 640 "${KEYS_DIR}/secret.key"
chmod 644 "${KEYS_DIR}/public.key"
chown root:_dnscrypt-signer "${KEYS_DIR}/public.key" "${KEYS_DIR}/secret.key"
echo "$provider_name" > "${KEYS_DIR}/provider_name"
chmod 644 "${KEYS_DIR}/provider_name"
hexdump -ve '1/1 "%.2x"' < "${KEYS_DIR}/public.key" > "${KEYS_DIR}/public.key.txt"
chmod 644 "${KEYS_DIR}/public.key.txt"
echo
echo -----------------------------------------------------------------------
echo
echo "Congratulations! The container has been properly initialized."
echo "Take a look up above at the way dnscrypt-proxy has to be configured in order"
echo "to connect to your resolver. Then, start the container with the default command."
}
provider_info() {
ensure_initialized
echo "Provider name:"
cat "${KEYS_DIR}/provider_name"
echo
echo "Provider public key:"
cat "${KEYS_DIR}/public.key.txt"
echo
}
is_initialized() {
if [ ! -f "${KEYS_DIR}/public.key" -a ! -f "${KEYS_DIR}/secret.key" -a ! -f "${KEYS_DIR}/provider_name" ]; then
echo no
else
echo yes
fi
}
ensure_initialized() {
if [ $(is_initialized) = no ]; then
2018-01-22 19:23:54 +00:00
echo "Please provide an initial configuration (init -N <provider_name> -E <external IP>)" >&2
2015-07-05 23:39:54 +00:00
exit 1
fi
}
start() {
ensure_initialized
echo "Starting DNSCrypt service for provider: "
cat "${KEYS_DIR}/provider_name"
2017-04-19 08:56:02 +00:00
exec /sbin/start_runit
2015-07-05 23:39:54 +00:00
}
usage() {
cat << EOT
Commands
========
2018-01-22 19:23:54 +00:00
* init -N <provider_name> -E <external ip>:<port>
2018-01-22 17:21:50 +00:00
initialize the container for a server accessible at ip <external ip> on port
<port>, for a provider named <provider_name>. This is required only once.
2015-07-05 23:39:54 +00:00
* start (default command): start the resolver and the dnscrypt server proxy.
Ports 443/udp and 443/tcp have to be publicly exposed.
2018-01-22 19:23:54 +00:00
* provider-info: prints the provide namer and provider public key.
2015-07-05 23:39:54 +00:00
This container has a single volume that you might want to securely keep a
backup of: /opt/dnscrypt-wrapper/etc/keys
EOT
exit 1
}
case "$action" in
start) start ;;
init) shift ; init $* ;;
provider-info) provider_info ;;
*) usage ;;
esac