FROM node:lts-bookworm@sha256:0c0734eb7051babbb3e95cd74e684f940552b31472152edf0bb23e54ab44a0d7 AS ui WORKDIR /build COPY .git ./.git COPY Makefile ./Makefile # download yarn dependencies COPY ui/yarn.lock ./ui/yarn.lock COPY ui/package.json ./ui/package.json RUN make yarn # build ui COPY ./ui/ ./ui/ RUN make build-ui FROM golang:1.24-bookworm@sha256:940ac576af6f5d674dd5a173ee0d93cd8ad317890e823ae309f9c2c7b8fa788c AS build WORKDIR /go/src/github.com/pomerium/pomerium RUN apt-get update \ && apt-get -y --no-install-recommends install zip # cache dependency downloads COPY go.mod go.sum ./ RUN go mod download COPY . . COPY --from=ui /build/ui/dist ./ui/dist # build RUN make build-debug NAME=pomerium RUN touch /config.yaml RUN go install github.com/go-delve/delve/cmd/dlv@latest FROM debian:bookworm@sha256:b16cef8cbcb20935c0f052e37fc3d38dc92bfec0bcfb894c328547f81e932d67 ENV AUTOCERT_DIR=/data/autocert WORKDIR /pomerium COPY --from=build /go/src/github.com/pomerium/pomerium/bin/* /bin/ COPY --from=build /config.yaml /pomerium/config.yaml COPY --from=build /go/bin/dlv /bin COPY scripts/debug-entrypoint.sh / ENTRYPOINT [ "/bin/pomerium" ] CMD ["-config","/pomerium/config.yaml"]