protonmail-bridge-nextcoud-.../build/Dockerfile

47 lines
1.9 KiB
Docker
Raw Normal View History

# ARG before any FROM is global and available in FROM instructions.
# debian:bookworm-slim is the default; the workflow overrides to debian:sid-slim for riscv64
# since bookworm has no riscv64 image.
ARG RUNTIME_IMAGE=debian:bookworm-slim@sha256:74a21da88cf4b2e8fde34558376153c5cd80b00ca81da2e659387e76524edc73
# debian:sid-slim is required for the build stage to support riscv64 (golang:bookworm does not).
FROM debian:sid-slim@sha256:a145cf2bc72431523b8f5d152e9cbcc20cfaeccdb7626802f5ce6fb31a6f58bb AS build
2020-06-01 13:51:24 +00:00
ARG version
# Install build dependencies
RUN apt-get -o Acquire::http::Timeout=30 update && apt-get -o Acquire::http::Timeout=30 install -y golang build-essential libsecret-1-dev libfido2-dev libcbor-dev
2020-06-01 13:51:24 +00:00
# Build
ADD https://github.com/ProtonMail/proton-bridge.git#${version} /build/
2020-06-01 13:51:24 +00:00
WORKDIR /build/
RUN make build-nogui vault-editor
2020-06-01 13:51:24 +00:00
FROM ${RUNTIME_IMAGE}
LABEL maintainer="Dan Williams <dancwilliams@github>"
2020-06-01 13:51:24 +00:00
EXPOSE 25/tcp
EXPOSE 143/tcp
# Monitor proton-bridge process health
HEALTHCHECK --interval=30s --timeout=10s --retries=3 --start-period=60s \
CMD bash -c "pgrep -f proton-bridge || exit 1"
# Install runtime dependencies
RUN apt-get -o Acquire::http::Timeout=30 update \
&& apt-get -o Acquire::http::Timeout=30 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
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
# 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"]