2020-05-10 13:15:35 +02:00
|
|
|
FROM golang:1.14-alpine as build
|
2020-04-01 04:08:21 +02:00
|
|
|
|
2020-06-15 12:04:08 +02:00
|
|
|
# Create appuser and group.
|
2020-04-01 04:08:21 +02:00
|
|
|
ARG USER=inetmock
|
2020-06-15 12:04:08 +02:00
|
|
|
ARG GROUP=inetmock
|
2020-04-01 04:08:21 +02:00
|
|
|
ARG USER_ID=10001
|
2020-06-15 12:04:08 +02:00
|
|
|
ARG GROUP_ID=10001
|
2020-04-01 04:08:21 +02:00
|
|
|
|
|
|
|
ENV CGO_ENABLED=0
|
|
|
|
|
|
|
|
# Prepare build stage - can be cached
|
|
|
|
WORKDIR /work
|
2020-05-10 13:15:35 +02:00
|
|
|
RUN apk add -U --no-cache \
|
2020-06-15 12:04:08 +02:00
|
|
|
make protoc gcc musl-dev libcap && \
|
|
|
|
addgroup -S -g "${GROUP_ID}" "${GROUP}" && \
|
2020-04-01 04:08:21 +02:00
|
|
|
adduser \
|
|
|
|
--disabled-password \
|
|
|
|
--gecos "" \
|
|
|
|
--home "/nonexistent" \
|
|
|
|
--shell "/sbin/nologin" \
|
|
|
|
--no-create-home \
|
2020-06-15 12:04:08 +02:00
|
|
|
-G "${GROUP}" \
|
2020-04-01 04:08:21 +02:00
|
|
|
--uid "${USER_ID}" \
|
|
|
|
"${USER}"
|
|
|
|
|
|
|
|
# Fetch dependencies
|
|
|
|
COPY Makefile go.mod go.sum ./
|
2020-05-10 13:15:35 +02:00
|
|
|
RUN go mod download && \
|
|
|
|
go get -u github.com/golang/mock/mockgen@latest && \
|
|
|
|
go install github.com/golang/protobuf/protoc-gen-go
|
2020-04-01 04:08:21 +02:00
|
|
|
|
|
|
|
COPY ./ ./
|
|
|
|
|
2020-06-15 12:04:08 +02:00
|
|
|
# Build binaries
|
|
|
|
RUN make CONTAINER=yes && \
|
|
|
|
mkdir -p /usr/lib/inetmock/bin/ && \
|
|
|
|
chown $USER:$GROUP inetmock imctl && \
|
|
|
|
mv inetmock imctl /usr/lib/inetmock/bin/ && \
|
|
|
|
setcap 'cap_net_bind_service=+ep' /usr/lib/inetmock/bin/inetmock
|
2020-04-01 04:08:21 +02:00
|
|
|
|
|
|
|
# Runtime layer
|
|
|
|
|
2020-06-15 12:04:08 +02:00
|
|
|
FROM alpine:3.12
|
2020-04-01 04:08:21 +02:00
|
|
|
|
2020-06-15 12:04:08 +02:00
|
|
|
# Create appuser and group.
|
|
|
|
ARG USER=inetmock
|
|
|
|
ARG GROUP=inetmock
|
|
|
|
ARG USER_ID=10001
|
|
|
|
ARG GROUP_ID=10001
|
|
|
|
|
|
|
|
COPY --from=build /etc/group /etc/passwd /etc/
|
|
|
|
COPY --from=build /usr/lib/inetmock/bin /usr/lib/inetmock/bin
|
|
|
|
COPY config-container.yaml /etc/inetmock/config.yaml
|
|
|
|
|
|
|
|
RUN mkdir -p /var/run/inetmock /var/lib/inetmock/certs /usr/lib/inetmock && \
|
|
|
|
chown -R $USER:$GROUP /var/run/inetmock /var/lib/inetmock /usr/lib/inetmock
|
2020-04-02 00:58:44 +02:00
|
|
|
|
2020-06-15 12:04:08 +02:00
|
|
|
RUN ln -s /usr/lib/inetmock/bin/inetmock /usr/bin/inetmock && \
|
|
|
|
ln -s /usr/lib/inetmock/bin/imctl /usr/bin/imctl
|
2020-04-01 04:08:21 +02:00
|
|
|
|
2020-06-15 12:04:08 +02:00
|
|
|
USER $USER
|
2020-04-01 04:08:21 +02:00
|
|
|
|
2020-06-15 12:04:08 +02:00
|
|
|
VOLUME [ "/var/lib/inetmock/ca", "/var/lib/inetmock/certs" ]
|
2020-04-01 04:08:21 +02:00
|
|
|
|
2020-06-15 12:04:08 +02:00
|
|
|
ENTRYPOINT ["inetmock"]
|