2022-08-23 13:10:29 +02:00
#syntax=docker/dockerfile:1.2
2022-02-15 18:40:48 +01:00
# A local development Complement dockerfile, to be used with host mounts
# /cache -> Contains the entire dendrite code at Dockerfile build time. Builds binaries but only keeps the generate-* ones. Pre-compilation saves time.
# /dendrite -> Host-mounted sources
# /runtime -> Binaries and config go here and are run at runtime
# At runtime, dendrite is built from /dendrite and run in /runtime.
#
# Use these mounts to make use of this dockerfile:
# COMPLEMENT_HOST_MOUNTS='/your/local/dendrite:/dendrite:ro;/your/go/path:/go:ro'
2022-07-11 15:31:31 +02:00
FROM golang:1.18-stretch
2022-02-15 18:40:48 +01:00
RUN apt-get update && apt-get install -y sqlite3
ENV SERVER_NAME=localhost
2022-12-23 14:28:15 +01:00
ENV COVER=0
2022-02-15 18:40:48 +01:00
EXPOSE 8008 8448
2022-08-23 13:10:29 +02:00
WORKDIR /runtime
2022-02-15 18:40:48 +01:00
# This script compiles Dendrite for us.
RUN echo '\
2022-07-11 15:31:31 +02:00
#!/bin/bash -eux \n\
2023-02-14 12:47:47 +01:00
if test -f "/runtime/dendrite" && test -f "/runtime/dendrite-cover"; then \n\
2022-02-15 18:40:48 +01:00
echo "Skipping compilation; binaries exist" \n\
exit 0 \n\
2022-07-11 15:31:31 +02:00
fi \n\
cd /dendrite \n\
2023-02-14 12:47:47 +01:00
go build -v -o /runtime /dendrite/cmd/dendrite \n\
go test -c -cover -covermode=atomic -o /runtime/dendrite-cover -coverpkg "github.com/matrix-org/..." /dendrite/cmd/dendrite \n\
2022-07-11 15:31:31 +02:00
' > compile.sh && chmod +x compile.sh
2022-02-15 18:40:48 +01:00
# This script runs Dendrite for us. Must be run in the /runtime directory.
RUN echo '\
2022-07-11 15:31:31 +02:00
#!/bin/bash -eu \n\
./generate-keys --private-key matrix_key.pem \n\
2022-08-23 13:10:29 +02:00
./generate-keys -keysize 1024 --server $SERVER_NAME --tls-cert server.crt --tls-key server.key --tls-authority-cert /complement/ca/ca.crt --tls-authority-key /complement/ca/ca.key \n\
2022-07-11 15:31:31 +02:00
./generate-config -server $SERVER_NAME --ci > dendrite.yaml \n\
cp /complement/ca/ca.crt /usr/local/share/ca-certificates/ && update-ca-certificates \n\
2023-02-14 12:47:47 +01:00
[ ${COVER} -eq 1 ] && exec ./dendrite-cover --test.coverprofile=integrationcover.log --really-enable-open-registration --tls-cert server.crt --tls-key server.key --config dendrite.yaml \n\
exec ./dendrite --really-enable-open-registration --tls-cert server.crt --tls-key server.key --config dendrite.yaml \n\
2022-07-11 15:31:31 +02:00
' > run.sh && chmod +x run.sh
2022-02-15 18:40:48 +01:00
WORKDIR /cache
# Build the monolith in /cache - we won't actually use this but will rely on build artifacts to speed
# up the real compilation. Build the generate-* binaries in the true /runtime locations.
# If the generate-* source is changed, this dockerfile needs re-running.
2022-08-23 13:10:29 +02:00
RUN --mount=target=. \
--mount=type=cache,target=/go/pkg/mod \
--mount=type=cache,target=/root/.cache/go-build \
go build -o /runtime ./cmd/generate-config && \
go build -o /runtime ./cmd/generate-keys
2022-02-15 18:40:48 +01:00
WORKDIR /runtime
2022-08-23 13:10:29 +02:00
CMD /runtime/compile.sh && exec /runtime/run.sh