diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 00000000..90c9ac25 --- /dev/null +++ b/Dockerfile @@ -0,0 +1,49 @@ +# ======================================================== +# Stage: Builder +# ======================================================== +FROM --platform=$BUILDPLATFORM golang:alpine AS builder +WORKDIR /app +ARG TARGETARCH +ENV CGO_ENABLED=1 + +RUN apk --no-cache --update add \ + build-base \ + gcc \ + wget \ + unzip + +COPY . . + +RUN go build -o build/x-ui main.go +RUN ./DockerInit.sh "$TARGETARCH" + +# ======================================================== +# Stage: Final Image of 3x-ui +# ======================================================== +FROM alpine +ENV TZ=Asia/Tehran +WORKDIR /app + +RUN apk add --no-cache --update \ + ca-certificates \ + tzdata \ + fail2ban + +COPY --from=builder /app/build/ /app/ +COPY --from=builder /app/DockerEntrypoint.sh /app/ +COPY --from=builder /app/x-ui.sh /usr/bin/x-ui + +# Configure fail2ban +RUN rm -f /etc/fail2ban/jail.d/alpine-ssh.conf \ + && cp /etc/fail2ban/jail.conf /etc/fail2ban/jail.local \ + && sed -i "s/^\[ssh\]$/&\nenabled = false/" /etc/fail2ban/jail.local \ + && sed -i "s/^\[sshd\]$/&\nenabled = false/" /etc/fail2ban/jail.local \ + && sed -i "s/#allowipv6 = auto/allowipv6 = auto/g" /etc/fail2ban/fail2ban.conf + +RUN chmod +x \ + /app/DockerEntrypoint.sh \ + /app/x-ui \ + /usr/bin/x-ui + +VOLUME [ "/etc/x-ui" ] +ENTRYPOINT [ "/app/DockerEntrypoint.sh" ]