# syntax=docker/dockerfile:1 FROM node:22-alpine AS ui-builder WORKDIR /src/web COPY web/package*.json ./ RUN npm ci COPY web/ ./ RUN npm run build FROM --platform=$BUILDPLATFORM golang:1.25.0 AS builder WORKDIR /src COPY go.mod go.sum ./ RUN go mod download COPY . . COPY --from=ui-builder /src/web/dist ./internal/server/ui-dist ARG TARGETOS ARG TARGETARCH RUN CGO_ENABLED=0 \ GOOS=${TARGETOS:-linux} \ GOARCH=${TARGETARCH:-$(go env GOARCH)} \ go build -trimpath -ldflags="-s -w" -o /out/soteria ./cmd/soteria FROM gcr.io/distroless/static-debian12:nonroot COPY --from=builder /out/soteria /soteria USER 65532:65532 EXPOSE 8080 ENTRYPOINT ["/soteria"]