2016-03-28 16:23:37 +02:00
|
|
|
#!/bin/bash
|
2018-07-11 06:11:44 +02:00
|
|
|
# Lookups may not work for VPN / tun0
|
2019-01-10 04:59:22 +01:00
|
|
|
IP_LOOKUP="$(ip route get 8.8.8.8 | awk '{for(i=1;i<=NF;i++) if ($i=="src") print $(i+1)}')"
|
|
|
|
IPv6_LOOKUP="$(ip -6 route get 2001:4860:4860::8888 | awk '{for(i=1;i<=NF;i++) if ($i=="src") print $(i+1)}')"
|
2018-07-11 06:11:44 +02:00
|
|
|
|
|
|
|
# Just hard code these to your docker server's LAN IP if lookups aren't working
|
2017-01-09 19:04:32 +01:00
|
|
|
IP="${IP:-$IP_LOOKUP}" # use $IP, if set, otherwise IP_LOOKUP
|
2017-05-19 07:36:53 +02:00
|
|
|
IPv6="${IPv6:-$IPv6_LOOKUP}" # use $IPv6, if set, otherwise IP_LOOKUP
|
|
|
|
|
2018-07-11 06:11:44 +02:00
|
|
|
# Default of directory you run this from, update to where ever.
|
2019-01-10 04:59:22 +01:00
|
|
|
DOCKER_CONFIGS="$(pwd)"
|
2018-07-11 06:11:44 +02:00
|
|
|
|
2019-01-10 04:59:22 +01:00
|
|
|
echo -e "### Make sure your IPs are correct, hard code ServerIP ENV VARs if necessary\nIP: ${IP}\nIPv6: ${IPv6}"
|
2016-04-26 06:18:41 +02:00
|
|
|
|
|
|
|
# Default ports + daemonized docker container
|
2017-05-22 19:32:15 +02:00
|
|
|
docker run -d \
|
2017-05-19 07:36:53 +02:00
|
|
|
--name pihole \
|
2018-07-11 06:11:44 +02:00
|
|
|
-p 53:53/tcp -p 53:53/udp \
|
|
|
|
-p 67:67/udp \
|
|
|
|
-p 80:80 \
|
|
|
|
-p 443:443 \
|
2017-05-29 20:59:03 +02:00
|
|
|
-v "${DOCKER_CONFIGS}/pihole/:/etc/pihole/" \
|
|
|
|
-v "${DOCKER_CONFIGS}/dnsmasq.d/:/etc/dnsmasq.d/" \
|
2018-07-11 06:11:44 +02:00
|
|
|
-e ServerIP="${IP}" \
|
|
|
|
-e ServerIPv6="${IPv6}" \
|
|
|
|
--restart=unless-stopped \
|
2018-10-16 05:35:13 +02:00
|
|
|
--cap-add=NET_ADMIN \
|
|
|
|
--dns=127.0.0.1 --dns=1.1.1.1 \
|
2018-08-04 18:40:31 +02:00
|
|
|
pihole/pihole:latest
|
2017-05-19 07:36:53 +02:00
|
|
|
|
2019-01-10 04:59:22 +01:00
|
|
|
|
|
|
|
printf 'Starting up pihole container'
|
|
|
|
while [ "$(docker inspect -f "{{.State.Health.Status}}" pihole)" != "healthy" ]; do
|
|
|
|
sleep 1
|
|
|
|
printf '.'
|
|
|
|
done;
|
|
|
|
|
|
|
|
echo -e "\n$(docker logs pihole 2> /dev/null | grep 'password:') for your pi-hole: https://${IP}/admin/"
|