2026-03-11 09:45:42 +01:00
|
|
|
FROM debian:bookworm-slim
|
|
|
|
|
|
2026-03-11 09:58:44 +01:00
|
|
|
LABEL description="dante SOCKS5 + purevpn-cli exit node"
|
2026-03-11 09:45:42 +01:00
|
|
|
|
2026-03-11 10:11:01 +01:00
|
|
|
# ── System dependencies (all in one layer so apt cache is fresh for installer) ─
|
2026-03-11 09:45:42 +01:00
|
|
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
2026-03-11 09:58:44 +01:00
|
|
|
dante-server \
|
2026-03-11 09:45:42 +01:00
|
|
|
curl wget ca-certificates \
|
|
|
|
|
iproute2 iptables iputils-ping \
|
|
|
|
|
netcat-openbsd procps dnsutils \
|
|
|
|
|
expect \
|
2026-03-11 10:11:01 +01:00
|
|
|
openvpn wireguard wireguard-tools \
|
|
|
|
|
net-tools openresolv \
|
2026-03-11 09:45:42 +01:00
|
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
|
|
2026-03-11 10:56:34 +01:00
|
|
|
# ── Stub openvpn-systemd-resolved ────────────────────────────────────────────
|
|
|
|
|
# This package is not in Debian repos. Its absence is what triggers purevpn-cli
|
|
|
|
|
# to call `sudo --install-missing-components`. A no-op stub satisfies the check.
|
|
|
|
|
RUN mkdir -p /usr/lib/openvpn \
|
|
|
|
|
&& printf '#!/bin/sh\nexit 0\n' \
|
|
|
|
|
| tee /usr/local/bin/openvpn-systemd-resolved \
|
|
|
|
|
/usr/lib/openvpn/openvpn-systemd-resolved > /dev/null \
|
|
|
|
|
&& chmod +x /usr/local/bin/openvpn-systemd-resolved \
|
|
|
|
|
/usr/lib/openvpn/openvpn-systemd-resolved
|
|
|
|
|
|
2026-03-11 10:11:01 +01:00
|
|
|
# ── Install purevpn-cli ───────────────────────────────────────────────────────
|
2026-03-11 09:45:42 +01:00
|
|
|
RUN curl -fsSL https://apps.purevpn-tools.com/cross-platform/linux-cli/production/cli-install.sh \
|
|
|
|
|
-o /tmp/cli-install.sh \
|
|
|
|
|
&& bash /tmp/cli-install.sh \
|
2026-03-11 10:11:01 +01:00
|
|
|
&& rm -f /tmp/cli-install.sh
|
|
|
|
|
|
2026-03-11 10:56:34 +01:00
|
|
|
# ── Inspect binary (visible in build log, remove once confirmed working) ──────
|
|
|
|
|
RUN echo "=== binary type ===" \
|
|
|
|
|
&& file /opt/purevpn-cli/bin/purevpn-cli /opt/purevpn-cli/purevpn-cli 2>/dev/null || true \
|
|
|
|
|
&& echo "=== bin/purevpn-cli header ===" \
|
|
|
|
|
&& head -3 /opt/purevpn-cli/bin/purevpn-cli 2>/dev/null || true
|
|
|
|
|
|
2026-03-12 07:23:19 +01:00
|
|
|
# ── Fake sudo wrapper ────────────────────────────────────────────────────────
|
|
|
|
|
# Strips --install-missing-components (crashes pkg bootstrap when combined with
|
|
|
|
|
# --connect) then re-runs the binary with a CLEAN environment (env -i) so that
|
|
|
|
|
# any env vars set by the parent purevpn-cli don't corrupt the child's pkg
|
|
|
|
|
# bootstrap. Prints env key names and exec'd command for diagnosis.
|
|
|
|
|
RUN printf '#!/bin/bash\necho "[sudo] env: $(env | cut -d= -f1 | tr "\\n" " ")"\nnew=()\nfor a in "$@"; do\n [[ "$a" == "--install-missing-components" ]] && { echo "[sudo] stripped --install-missing-components"; continue; }\n new+=("$a")\ndone\necho "[sudo] exec (clean env): ${new[*]}"\nexec env -i PATH="$PATH" HOME=/root USER=root "${new[@]}"\n' \
|
2026-03-11 10:34:00 +01:00
|
|
|
> /usr/local/bin/sudo && chmod +x /usr/local/bin/sudo
|
2026-03-11 10:23:35 +01:00
|
|
|
|
2026-03-11 10:56:34 +01:00
|
|
|
# ── PATH ──────────────────────────────────────────────────────────────────────
|
2026-03-11 10:11:01 +01:00
|
|
|
ENV PATH=/opt/purevpn-cli/bin:/opt/purevpn-cli:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
|
2026-03-11 09:45:42 +01:00
|
|
|
|
|
|
|
|
# ── Location list ─────────────────────────────────────────────────────────────
|
|
|
|
|
COPY servers.txt /etc/vpndock/servers.txt
|
|
|
|
|
|
|
|
|
|
# ── Entrypoint ────────────────────────────────────────────────────────────────
|
|
|
|
|
COPY entrypoint.sh /entrypoint.sh
|
|
|
|
|
RUN chmod +x /entrypoint.sh
|
|
|
|
|
|
|
|
|
|
EXPOSE 1080
|
|
|
|
|
|
|
|
|
|
ENTRYPOINT ["/entrypoint.sh"]
|