# syntax=docker/dockerfile:1 FROM ghcr.io/linuxserver/baseimage-alpine:arm64v8-3.19 # set version label ARG BUILD_DATE ARG VERSION ARG WIREGUARD_RELEASE LABEL build_version="Linuxserver.io version:- ${VERSION} Build-date:- ${BUILD_DATE}" LABEL maintainer="thespad" RUN \ echo "**** install dependencies ****" && \ apk add --no-cache --virtual=build-dependencies \ build-base \ elfutils-dev \ git \ linux-headers && \ apk add --no-cache \ bc \ coredns \ grep \ iproute2 \ iptables \ iptables-legacy \ ip6tables \ iputils \ libcap-utils \ libqrencode-tools \ net-tools \ openresolv && \ echo "wireguard" >> /etc/modules && \ cd /sbin && \ for i in ! !-save !-restore; do \ rm -rf iptables$(echo "${i}" | cut -c2-) && \ rm -rf ip6tables$(echo "${i}" | cut -c2-) && \ ln -s iptables-legacy$(echo "${i}" | cut -c2-) iptables$(echo "${i}" | cut -c2-) && \ ln -s ip6tables-legacy$(echo "${i}" | cut -c2-) ip6tables$(echo "${i}" | cut -c2-); \ done && \ echo "**** install wireguard-tools ****" && \ if [ -z ${WIREGUARD_RELEASE+x} ]; then \ WIREGUARD_RELEASE=$(curl -sX GET "https://api.github.com/repos/WireGuard/wireguard-tools/tags" \ | jq -r .[0].name); \ fi && \ cd /app && \ git clone https://git.zx2c4.com/wireguard-tools && \ cd wireguard-tools && \ git checkout "${WIREGUARD_RELEASE}" && \ sed -i 's|\[\[ $proto == -4 \]\] && cmd sysctl -q net\.ipv4\.conf\.all\.src_valid_mark=1|[[ $proto == -4 ]] \&\& [[ $(sysctl -n net.ipv4.conf.all.src_valid_mark) != 1 ]] \&\& cmd sysctl -q net.ipv4.conf.all.src_valid_mark=1|' src/wg-quick/linux.bash && \ make -C src -j$(nproc) && \ make -C src install && \ rm -rf /etc/wireguard && \ ln -s /config/wg_confs /etc/wireguard && \ echo "**** clean up ****" && \ apk del --no-network build-dependencies && \ rm -rf \ /tmp/* # add local files COPY /root / # ports and volumes EXPOSE 51820/udp