bouncer/Dockerfile

63 lines
2.3 KiB
Docker
Raw Permalink Normal View History

2024-09-26 14:46:28 +02:00
FROM reg.cadoles.com/proxy_cache/library/golang:1.23 AS BUILD
2023-04-24 20:52:12 +02:00
RUN apt-get update \
&& apt-get install -y make
ARG YQ_VERSION=4.34.1
RUN mkdir -p /usr/local/bin \
&& wget -O /usr/local/bin/yq https://github.com/mikefarah/yq/releases/download/v${YQ_VERSION}/yq_linux_amd64 \
&& chmod +x /usr/local/bin/yq
2023-04-24 20:52:12 +02:00
WORKDIR /src
COPY go.mod .
COPY go.sum .
RUN go mod download
COPY . /src
2023-04-24 20:52:12 +02:00
RUN make GORELEASER_ARGS='build --rm-dist --single-target --snapshot' goreleaser
# Patch config
RUN /src/dist/bouncer_linux_amd64_v1/bouncer -c '' config dump > /src/dist/bouncer_linux_amd64_v1/config.yml \
2024-06-26 14:36:28 +02:00
&& yq -i '.proxy.templates.dir = "/usr/share/bouncer/templates"' /src/dist/bouncer_linux_amd64_v1/config.yml \
&& yq -i '.layers.queue.templateDir = "/usr/share/bouncer/layers/queue/templates"' /src/dist/bouncer_linux_amd64_v1/config.yml \
&& yq -i '.layers.authn.templateDir = "/usr/share/bouncer/layers/authn/templates"' /src/dist/bouncer_linux_amd64_v1/config.yml \
&& yq -i '.admin.auth.privateKey = "/etc/bouncer/admin-key.json"' /src/dist/bouncer_linux_amd64_v1/config.yml \
2024-03-27 09:19:08 +01:00
&& yq -i '.redis.adresses = ["redis:6379"]' /src/dist/bouncer_linux_amd64_v1/config.yml \
&& yq -i '.redis.writeTimeout = "30s"' /src/dist/bouncer_linux_amd64_v1/config.yml \
&& yq -i '.redis.readTimeout = "30s"' /src/dist/bouncer_linux_amd64_v1/config.yml \
&& yq -i '.redis.dialTimeout = "30s"' /src/dist/bouncer_linux_amd64_v1/config.yml \
&& yq -i '.bootstrap.lockTimeout = "30s"' /src/dist/bouncer_linux_amd64_v1/config.yml \
&& yq -i '.integrations.kubernetes.lockTimeout = "30s"' /src/dist/bouncer_linux_amd64_v1/config.yml
FROM reg.cadoles.com/proxy_cache/library/alpine:3.20 AS RUNTIME
2023-04-24 20:52:12 +02:00
RUN apk add --no-cache ca-certificates dumb-init
2023-04-24 20:52:12 +02:00
ENTRYPOINT ["/usr/bin/dumb-init", "--"]
2023-04-24 20:52:12 +02:00
2023-06-30 04:13:56 +02:00
RUN mkdir -p /usr/local/bin /usr/share/bouncer/bin /etc/bouncer
COPY --from=BUILD /src/dist/bouncer_linux_amd64_v1/bouncer /usr/share/bouncer/bin/bouncer
COPY --from=BUILD /src/layers /usr/share/bouncer/layers
COPY --from=BUILD /src/templates /usr/share/bouncer/templates
COPY --from=BUILD /src/dist/bouncer_linux_amd64_v1/config.yml /etc/bouncer/config.yml
2023-06-30 04:13:56 +02:00
RUN ln -s /usr/share/bouncer/bin/bouncer /usr/local/bin/bouncer
2023-04-24 20:52:12 +02:00
EXPOSE 8080
EXPOSE 8081
EXPOSE 8082
2023-04-24 20:52:12 +02:00
2024-05-29 14:18:40 +02:00
RUN adduser -D -s /bin/sh bouncer
2024-03-27 09:19:08 +01:00
2023-06-30 04:13:56 +02:00
ENV BOUNCER_CONFIG=/etc/bouncer/config.yml
2023-04-24 20:52:12 +02:00
2024-03-27 09:19:08 +01:00
USER bouncer
2024-05-29 14:18:40 +02:00
WORKDIR /home/bouncer
2023-06-30 04:13:56 +02:00
CMD ["bouncer"]