[Unit]
Description = Mistborn Base
Requires = docker.service
After = docker.service
[Service]
Restart = always
User = root
Group = docker
PermissionsStartOnly = true
# Shutdown container (if running) when unit is stopped
ExecStartPre = /usr/local/bin/docker-compose -f /opt/mistborn/base.yml down
ExecStartPre = /usr/local/bin/docker-compose -f /opt/mistborn/base.yml build
ExecStartPre = /sbin/ip address add 10.2.3.1/30 dev DIFACE || true
ExecStartPre = /sbin/iptables -I DOCKER-USER -i DIFACE -p udp --dport 53 -j MISTBORN_LOG_DROP
ExecStartPre = /sbin/iptables -I DOCKER-USER -i DIFACE -p tcp --dport 53 -j MISTBORN_LOG_DROP
ExecStartPre = /sbin/iptables -I DOCKER-USER -i DIFACE -p tcp --dport 80 -j MISTBORN_LOG_DROP
ExecStartPre = /sbin/iptables -I DOCKER-USER -i DIFACE -p tcp --dport 5555 -j MISTBORN_LOG_DROP
ExecStartPre = /sbin/iptables -A OUTPUT -o DIFACE -p udp --dport 53 -j MISTBORN_LOG_DROP
ExecStartPre = /sbin/ip6tables -A OUTPUT -p udp --dport 53 -j MISTBORN_LOG_DROP
ExecStartPre = /sbin/resolvconf -u
# Start container when unit is started
ExecStart = /usr/local/bin/docker-compose -f /opt/mistborn/base.yml up
# Stop container when unit is stopped
ExecStop = /usr/local/bin/docker-compose -f /opt/mistborn/base.yml down
# Post stop
ExecStopPost = /sbin/iptables -D DOCKER-USER -i DIFACE -p udp --dport 53 -j MISTBORN_LOG_DROP || true
ExecStopPost = /sbin/iptables -D DOCKER-USER -i DIFACE -p tcp --dport 53 -j MISTBORN_LOG_DROP || true
ExecStopPost = /sbin/iptables -D DOCKER-USER -i DIFACE -p tcp --dport 80 -j MISTBORN_LOG_DROP || true
ExecStopPost = /sbin/iptables -D DOCKER-USER -i DIFACE -p tcp --dport 5555 -j MISTBORN_LOG_DROP || true
ExecStopPost = /sbin/iptables -D OUTPUT -o DIFACE -p udp --dport 53 -j MISTBORN_LOG_DROP || true
ExecStopPost = /sbin/ip6tables -D OUTPUT -p udp --dport 53 -j MISTBORN_LOG_DROP || true
[Install]
WantedBy = multi-user.target