-
Notifications
You must be signed in to change notification settings - Fork 2
/
Dockerfile.buildkit
96 lines (86 loc) · 3.63 KB
/
Dockerfile.buildkit
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
ARG REGISTRY=docker.io
ARG ALPINE_VER=3@sha256:8914eb54f968791faf6a8638949e480fef81e697984fba772b3976835194c6d4
ARG GO_VER=1.19-alpine@sha256:a9b24b67dc83b3383d22a14941c2b2b2ca6a103d805cac6820fd1355943beaf1
ARG NODE_VER=18-alpine@sha256:a136ed7b0df71082cdb171f36d640ea3b392a5c70401c642326acee767b8c540
FROM --platform=$BUILDPLATFORM ${REGISTRY}/library/golang:${GO_VER} as golang
RUN apk add --no-cache \
ca-certificates \
make
RUN adduser -D appuser
WORKDIR /src
FROM --platform=$BUILDPLATFORM ${REGISTRY}/library/node:${NODE_VER} as node
RUN apk add --no-cache \
ca-certificates \
make
RUN adduser -D appuser
WORKDIR /src
FROM --platform=$BUILDPLATFORM node as ui
COPY ui/files/package*.json ./ui/files/
RUN cd ui/files \
&& npm install --production
COPY . /src/
RUN make ui
FROM --platform=$BUILDPLATFORM golang as dev
COPY . /src/
COPY --from=ui /src/ui/files/build/ /src/ui/files/build/
ENV PATH=${PATH}:/src/bin
CMD make bin/httplock && bin/httplock
FROM --platform=$BUILDPLATFORM dev as build
ARG TARGETOS
ARG TARGETARCH
RUN --mount=type=cache,id=gomod,target=/go/pkg/mod/cache \
--mount=type=cache,id=goroot,target=/root/.cache/go-build \
GOOS=${TARGETOS} GOARCH=${TARGETARCH} \
make bin/httplock
RUN mkdir -p /var/lib/httplock/data /var/lib/httplock/tmp \
&& chown -R appuser:appuser /var/lib/httplock
USER appuser
ENV TMPDIR=/var/lib/httplock/tmp
CMD [ "bin/httplock" ]
FROM scratch as artifact
COPY --from=build /src/bin/httplock /httplock
FROM ${REGISTRY}/library/alpine:${ALPINE_VER} as release-alpine
COPY --from=build /etc/passwd /etc/group /etc/
COPY --from=build /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/
COPY --from=build --chown=appuser /home/appuser /home/appuser
COPY --from=build --chown=appuser /var/lib/httplock /var/lib/httplock
COPY --from=build /src/bin/httplock /usr/local/bin/httplock
USER appuser
CMD [ "httplock", "--help" ]
ARG BUILD_DATE
ARG VCS_REF
LABEL maintainer="" \
org.opencontainers.image.created=$BUILD_DATE \
org.opencontainers.image.authors="httplock maintainers" \
org.opencontainers.image.url="https://github.com/httplock/httplock" \
org.opencontainers.image.documentation="https://github.com/httplock/httplock" \
org.opencontainers.image.source="https://github.com/httplock/httplock" \
org.opencontainers.image.version="latest" \
org.opencontainers.image.revision=$VCS_REF \
org.opencontainers.image.vendor="" \
org.opencontainers.image.licenses="Apache 2.0" \
org.opencontainers.image.title="httplock" \
org.opencontainers.image.description=""
FROM scratch as release-scratch
COPY --from=build /etc/passwd /etc/group /etc/
COPY --from=build /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/
COPY --from=build --chown=appuser /home/appuser /home/appuser
COPY --from=build --chown=appuser /var/lib/httplock /var/lib/httplock
COPY --from=build /src/bin/httplock /httplock
USER appuser
ENV TMPDIR=/var/lib/httplock/tmp
ENTRYPOINT [ "/httplock" ]
ARG BUILD_DATE
ARG VCS_REF
LABEL maintainer="" \
org.opencontainers.image.created=$BUILD_DATE \
org.opencontainers.image.authors="httplock maintainers" \
org.opencontainers.image.url="https://github.com/httplock/httplock" \
org.opencontainers.image.documentation="https://github.com/httplock/httplock" \
org.opencontainers.image.source="https://github.com/httplock/httplock" \
org.opencontainers.image.version="latest" \
org.opencontainers.image.revision=$VCS_REF \
org.opencontainers.image.vendor="" \
org.opencontainers.image.licenses="Apache 2.0" \
org.opencontainers.image.title="httplock" \
org.opencontainers.image.description=""