2023-02-06 00:50:10 +01:00
|
|
|
# Build the main Kanidmd server
|
2020-06-18 02:30:42 +02:00
|
|
|
ARG BASE_IMAGE=opensuse/tumbleweed:latest
|
2024-02-06 11:01:06 +01:00
|
|
|
# ARG BASE_IMAGE=opensuse/leap:15.5
|
2023-08-14 02:06:53 +02:00
|
|
|
|
2022-05-26 13:13:07 +02:00
|
|
|
FROM ${BASE_IMAGE} AS repos
|
2023-08-14 02:06:53 +02:00
|
|
|
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=""
|
2020-04-10 07:50:45 +02:00
|
|
|
|
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 \
|
2023-08-17 07:52:12 +02:00
|
|
|
gawk \
|
2023-08-14 02:06:53 +02:00
|
|
|
make \
|
|
|
|
automake \
|
|
|
|
autoconf \
|
|
|
|
libopenssl-3-devel \
|
|
|
|
pam-devel \
|
2021-03-26 02:22:00 +01:00
|
|
|
sqlite3-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
|
2020-05-06 09:37:07 +02:00
|
|
|
|
|
|
|
COPY . /usr/src/kanidm
|
2018-12-27 06:22:03 +01:00
|
|
|
|
2022-08-02 08:11:42 +02:00
|
|
|
# ======================
|
|
|
|
|
2023-03-02 03:47:23 +01:00
|
|
|
# WORKDIR /usr/src/kanidm/server/web_ui
|
2022-10-05 01:48:48 +02:00
|
|
|
# # This can't be used in the wasm build for now.
|
|
|
|
# # ENV RUSTFLAGS="-Clinker=clang"
|
2023-02-06 00:50:10 +01:00
|
|
|
# RUN ./build_wasm.sh
|
2022-08-02 08:11:42 +02:00
|
|
|
|
|
|
|
# ======================
|
2022-06-20 03:37:39 +02:00
|
|
|
|
|
|
|
WORKDIR /usr/src/kanidm/kanidmd/daemon
|
|
|
|
|
2022-08-02 08:11:42 +02:00
|
|
|
# Exports don't persist through RUN statements.
|
2023-08-14 02:06:53 +02:00
|
|
|
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 \
|
2020-05-06 09:37:07 +02:00
|
|
|
timezone \
|
2023-02-06 00:50:10 +01:00
|
|
|
openssl-3 \
|
2020-08-06 08:05:33 +02:00
|
|
|
sqlite3 \
|
2022-05-08 05:00:34 +02:00
|
|
|
pam
|
2020-04-11 02:32:56 +02:00
|
|
|
|
2020-05-08 02:50:05 +02:00
|
|
|
COPY --from=builder /usr/src/kanidm/target/release/kanidmd /sbin/
|
2023-03-02 03:47:23 +01:00
|
|
|
COPY --from=builder /usr/src/kanidm/server/web_ui/pkg /pkg
|
2024-07-15 10:06:15 +02:00
|
|
|
COPY --from=builder /usr/src/kanidm/server/core/static /hpkg
|
2022-07-05 03:39:38 +02:00
|
|
|
RUN chmod +x /sbin/kanidmd
|
2018-12-27 06:22:03 +01:00
|
|
|
|
2020-06-10 04:07:43 +02:00
|
|
|
EXPOSE 8443 3636
|
2020-05-02 12:33:52 +02:00
|
|
|
VOLUME /data
|
2020-05-06 09:37:07 +02:00
|
|
|
|
|
|
|
ENV RUST_BACKTRACE 1
|
2023-08-14 02:06:53 +02:00
|
|
|
|
2024-07-20 04:30:06 +02:00
|
|
|
HEALTHCHECK \
|
|
|
|
--interval=60s \
|
|
|
|
--timeout=10s \
|
|
|
|
--start-period=60s \
|
|
|
|
--start-interval=5s \
|
|
|
|
--retries=3 \
|
|
|
|
CMD [ "/sbin/kanidmd", "healthcheck", "-c", "/data/server.toml"]
|
|
|
|
|
2022-07-05 03:39:38 +02:00
|
|
|
CMD [ "/sbin/kanidmd", "server", "-c", "/data/server.toml"]
|