2026-02-25 03:11:29 +00:00
|
|
|
# debian:sid-slim is required for the build stage to support riscv64 (golang:bookworm does not).
|
|
|
|
|
# For the runtime stage we use debian:bookworm-slim for stable, predictable package names.
|
2025-02-15 16:07:15 +00:00
|
|
|
FROM debian:sid-slim AS build
|
2020-06-01 13:51:24 +00:00
|
|
|
|
2025-04-24 21:03:50 +00:00
|
|
|
ARG version
|
|
|
|
|
|
2026-02-25 03:11:29 +00:00
|
|
|
# Install build dependencies
|
2026-02-25 02:15:39 +00:00
|
|
|
RUN apt-get update && apt-get install -y golang build-essential libsecret-1-dev libfido2-dev libcbor-dev
|
2020-06-01 13:51:24 +00:00
|
|
|
|
|
|
|
|
# Build
|
2025-04-24 21:03:50 +00:00
|
|
|
ADD https://github.com/ProtonMail/proton-bridge.git#${version} /build/
|
2020-06-01 13:51:24 +00:00
|
|
|
WORKDIR /build/
|
2025-04-24 21:03:50 +00:00
|
|
|
RUN make build-nogui vault-editor
|
2020-06-01 13:51:24 +00:00
|
|
|
|
2026-02-25 03:11:29 +00:00
|
|
|
FROM debian:bookworm-slim
|
2026-02-25 02:15:39 +00:00
|
|
|
LABEL maintainer="Dan Williams <dancwilliams@github>"
|
2020-06-01 13:51:24 +00:00
|
|
|
|
|
|
|
|
EXPOSE 25/tcp
|
|
|
|
|
EXPOSE 143/tcp
|
|
|
|
|
|
2026-02-25 02:15:39 +00:00
|
|
|
# Monitor proton-bridge process health
|
|
|
|
|
HEALTHCHECK --interval=30s --timeout=10s --retries=3 --start-period=60s \
|
|
|
|
|
CMD bash -c "pgrep -f proton-bridge || exit 1"
|
|
|
|
|
|
2026-02-25 03:11:29 +00:00
|
|
|
# Install runtime dependencies
|
2020-06-01 13:51:24 +00:00
|
|
|
RUN apt-get update \
|
2026-02-25 02:36:42 +00:00
|
|
|
&& apt-get install -y --no-install-recommends socat pass libsecret-1-0 libfido2-1 ca-certificates \
|
2020-06-01 13:51:24 +00:00
|
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
|
|
|
|
|
|
# Copy bash scripts
|
|
|
|
|
COPY gpgparams entrypoint.sh /protonmail/
|
|
|
|
|
|
|
|
|
|
# Copy protonmail
|
2025-04-24 21:03:50 +00:00
|
|
|
COPY --from=build /build/bridge /protonmail/
|
|
|
|
|
COPY --from=build /build/proton-bridge /protonmail/
|
|
|
|
|
COPY --from=build /build/vault-editor /protonmail/
|
2020-06-01 13:51:24 +00:00
|
|
|
|
2026-02-25 02:15:39 +00:00
|
|
|
# Prevent the bridge's built-in auto-updater from replacing the container binary at runtime.
|
|
|
|
|
# Version management is handled externally via the update-check workflow.
|
|
|
|
|
RUN chmod -w /protonmail/bridge /protonmail/proton-bridge /protonmail/vault-editor
|
|
|
|
|
|
2020-06-01 13:51:24 +00:00
|
|
|
ENTRYPOINT ["bash", "/protonmail/entrypoint.sh"]
|