2022-01-19 00:46:04 +00:00
|
|
|
FROM alpine:3.15
|
2019-10-15 14:50:39 +00:00
|
|
|
#
|
2018-04-13 18:22:49 +00:00
|
|
|
# Include dist
|
2022-03-08 23:36:03 +00:00
|
|
|
COPY dist/ /root/dist/
|
2019-10-15 14:50:39 +00:00
|
|
|
#
|
2018-04-13 18:22:49 +00:00
|
|
|
# Setup apk
|
2021-02-18 11:12:21 +00:00
|
|
|
RUN apk -U --no-cache add \
|
2018-05-18 15:40:07 +00:00
|
|
|
build-base \
|
|
|
|
git \
|
|
|
|
go \
|
|
|
|
g++ \
|
|
|
|
iptables-dev \
|
|
|
|
libnetfilter_queue-dev \
|
2018-05-18 20:05:52 +00:00
|
|
|
libcap \
|
2018-05-18 15:40:07 +00:00
|
|
|
libpcap-dev && \
|
2019-10-15 14:50:39 +00:00
|
|
|
#
|
2018-04-13 18:22:49 +00:00
|
|
|
# Setup go, glutton
|
|
|
|
export GOPATH=/opt/go/ && \
|
2019-10-15 14:50:39 +00:00
|
|
|
export GO111MODULE=on && \
|
|
|
|
mkdir -p /opt/go && \
|
|
|
|
cd /opt/go/ && \
|
|
|
|
git clone https://github.com/mushorg/glutton && \
|
|
|
|
cd /opt/go/glutton/ && \
|
2021-02-18 11:12:21 +00:00
|
|
|
git checkout c25045b95b43ed9bfee89b2d14a50f5794a9cf2b && \
|
2019-10-15 14:50:39 +00:00
|
|
|
mv /root/dist/system.go /opt/go/glutton/ && \
|
|
|
|
go mod download && \
|
2018-04-13 18:22:49 +00:00
|
|
|
make build && \
|
|
|
|
cd / && \
|
|
|
|
mkdir -p /opt/glutton && \
|
2019-10-15 14:50:39 +00:00
|
|
|
mv /opt/go/glutton/bin /opt/glutton/ && \
|
|
|
|
mv /opt/go/glutton/config /opt/glutton/ && \
|
|
|
|
mv /opt/go/glutton/rules /opt/glutton/ && \
|
|
|
|
ln -s /sbin/xtables-legacy-multi /sbin/xtables-multi && \
|
2018-05-18 20:05:52 +00:00
|
|
|
setcap cap_net_admin,cap_net_raw=+ep /opt/glutton/bin/server && \
|
2019-10-15 14:50:39 +00:00
|
|
|
setcap cap_net_admin,cap_net_raw=+ep /sbin/xtables-legacy-multi && \
|
|
|
|
#
|
2018-04-13 18:22:49 +00:00
|
|
|
# Setup user, groups and configs
|
|
|
|
addgroup -g 2000 glutton && \
|
2018-05-18 15:40:07 +00:00
|
|
|
adduser -S -s /bin/ash -u 2000 -D -g 2000 glutton && \
|
2018-04-13 18:22:49 +00:00
|
|
|
mkdir -p /var/log/glutton && \
|
|
|
|
mv /root/dist/rules.yaml /opt/glutton/rules/ && \
|
2019-10-15 14:50:39 +00:00
|
|
|
#
|
2018-04-13 18:22:49 +00:00
|
|
|
# Clean up
|
|
|
|
apk del --purge build-base \
|
|
|
|
git \
|
|
|
|
go \
|
2018-05-18 15:40:07 +00:00
|
|
|
g++ && \
|
2018-04-13 18:22:49 +00:00
|
|
|
rm -rf /var/cache/apk/* \
|
|
|
|
/opt/go \
|
2022-03-08 23:36:03 +00:00
|
|
|
/root/*
|
2019-10-15 14:50:39 +00:00
|
|
|
#
|
2018-05-16 16:37:41 +00:00
|
|
|
# Start glutton
|
2018-04-13 18:22:49 +00:00
|
|
|
WORKDIR /opt/glutton
|
2018-05-18 20:05:52 +00:00
|
|
|
USER glutton:glutton
|
2021-01-06 17:05:09 +00:00
|
|
|
CMD exec bin/server -i $(/sbin/ip address show | /usr/bin/awk '/inet.*brd/{ print $NF; exit }') -l /var/log/glutton/glutton.log > /dev/null 2>&1
|