# Stage 1: deps FROM golang:1.26.0-alpine AS deps HEALTHCHECK NONE # package version does not matter # libgcc and libstdc++ are needed for bun # trunk-ignore(hadolint/DL3018) RUN apk add --no-cache tzdata make libcap-setcap libgcc libstdc++ ENV GOPATH=/root/go ENV GOCACHE=/root/.cache/go-build WORKDIR /src COPY goutils/go.mod goutils/go.sum ./goutils/ COPY internal/go-oidc/go.mod internal/go-oidc/go.sum ./internal/go-oidc/ COPY internal/gopsutil/go.mod internal/gopsutil/go.sum ./internal/gopsutil/ COPY internal/go-proxmox/go.mod internal/go-proxmox/go.sum ./internal/go-proxmox/ COPY go.mod go.sum ./ # for minify-js COPY --from=oven/bun:1.3.9-alpine /usr/local/bin/bun /usr/local/bin/bun COPY --from=oven/bun:1.3.9-alpine /usr/local/bin/bunx /usr/local/bin/bunx # remove godoxy stuff from go.mod first RUN --mount=type=cache,target=/root/.cache/go-build \ --mount=type=cache,target=/root/go/pkg/mod \ sed -i '/^module github\.com\/yusing\/godoxy/!{/github\.com\/yusing\/godoxy/d}' go.mod && \ sed -i '/^module github\.com\/yusing\/goutils/!{/github\.com\/yusing\/goutils/d}' go.mod && \ go mod download -x # Stage 2: builder FROM deps AS builder WORKDIR /src COPY go.mod go.sum ./ COPY Makefile ./ COPY cmd ./cmd COPY internal ./internal COPY pkg ./pkg COPY agent ./agent COPY socket-proxy ./socket-proxy COPY goutils ./goutils ARG VERSION ENV VERSION=${VERSION} ARG MAKE_ARGS ENV MAKE_ARGS=${MAKE_ARGS} ARG BRANCH ENV BRANCH=${BRANCH} RUN --mount=type=cache,target=/root/.cache/go-build \ --mount=type=cache,target=/root/go/pkg/mod \ make ${MAKE_ARGS} docker=1 build # Stage 3: Final image FROM scratch LABEL maintainer="yusing@6uo.me" LABEL proxy.exclude=1 LABEL proxy.#1.healthcheck.disable=true # copy timezone data COPY --from=builder /usr/share/zoneinfo /usr/share/zoneinfo # copy binary COPY --from=builder /app/run /app/run # copy certs COPY --from=builder /etc/ssl/certs /etc/ssl/certs ENV DOCKER_HOST=unix:///var/run/docker.sock WORKDIR /app CMD ["/app/run"]