kanidm/server/Dockerfile

87 lines
2.1 KiB
Docker
Raw Permalink Normal View History

2023-02-06 00:50:10 +01:00
# Build the main Kanidmd server
ARG BASE_IMAGE=opensuse/tumbleweed:latest
# ARG BASE_IMAGE=opensuse/leap:15.5
2022-05-26 13:13:07 +02:00
FROM ${BASE_IMAGE} AS repos
ADD scripts/zypper_fixing.sh /zypper_fixing.sh
RUN --mount=type=cache,id=zypp,target=/var/cache/zypp /zypper_fixing.sh
2022-05-26 13:13:07 +02:00
2022-08-02 08:11:42 +02:00
# ======================
2022-05-26 13:13:07 +02:00
FROM repos AS builder
2023-02-06 00:50:10 +01:00
ARG KANIDM_FEATURES
ARG KANIDM_BUILD_PROFILE="container_generic"
ARG KANIDM_BUILD_OPTIONS=""
2023-02-17 08:02:01 +01:00
# Set the build profile
ENV KANIDM_BUILD_PROFILE=${KANIDM_BUILD_PROFILE:-container_generic}
ENV RUSTFLAGS="-Clinker=clang -Clink-arg=-fuse-ld=/usr/bin/ld.mold"
2023-02-06 00:50:10 +01:00
2023-02-17 08:02:01 +01:00
RUN \
--mount=type=cache,id=zypp,target=/var/cache/zypp \
zypper install -y --no-recommends \
sccache \
cargo \
2023-02-06 00:50:10 +01:00
clang \
gawk \
make \
automake \
autoconf \
libopenssl-3-devel \
pam-devel \
sqlite3-devel \
systemd-devel \
2022-08-01 07:52:01 +02:00
rsync \
2022-08-02 08:11:42 +02:00
findutils \
2023-02-06 00:50:10 +01:00
which \
mold
COPY . /usr/src/kanidm
2018-12-27 06:22:03 +01:00
2022-08-02 08:11:42 +02:00
# ======================
WORKDIR /usr/src/kanidm/kanidmd/daemon
2022-08-02 08:11:42 +02:00
# Exports don't persist through RUN statements.
RUN --mount=type=cache,id=cargo,target=/cargo \
--mount=type=cache,id=sccache,target=/sccache \
export CARGO_HOME=/cargo && \
export SCCACHE_DIR=/sccache && \
export RUSTC_WRAPPER=/usr/bin/sccache && \
export CC="/usr/bin/clang" && \
2023-02-17 08:02:01 +01:00
cargo build -p daemon ${KANIDM_BUILD_OPTIONS} \
--target-dir="/usr/src/kanidm/target/" \
--features="${KANIDM_FEATURES}" \
--release; \
sccache -s
2022-05-26 13:13:07 +02:00
2022-08-02 08:11:42 +02:00
# ======================
2022-05-26 13:13:07 +02:00
FROM repos
2023-02-17 08:02:01 +01:00
RUN \
--mount=type=cache,id=zypp,target=/var/cache/zypp \
zypper install -y \
timezone \
2023-02-06 00:50:10 +01:00
openssl-3 \
2020-08-06 08:05:33 +02:00
sqlite3 \
pam
COPY --from=builder /usr/src/kanidm/target/release/kanidmd /sbin/
2024-07-15 10:06:15 +02:00
COPY --from=builder /usr/src/kanidm/server/core/static /hpkg
RUN chmod +x /sbin/kanidmd
2018-12-27 06:22:03 +01:00
WORKDIR /data
EXPOSE 8443 3636
2024-08-10 11:30:51 +02:00
ENV RUST_BACKTRACE=1
HEALTHCHECK \
--interval=60s \
--timeout=10s \
--start-period=60s \
--start-interval=5s \
--retries=3 \
CMD [ "/sbin/kanidmd", "healthcheck", "-c", "/data/server.toml"]
CMD [ "/sbin/kanidmd", "server", "-c", "/data/server.toml"]