2022-07-05 03:39:38 +02:00
|
|
|
# This builds the kanidm CLI tool
|
|
|
|
ARG BASE_IMAGE=opensuse/tumbleweed:latest
|
|
|
|
FROM ${BASE_IMAGE} AS repos
|
2022-07-06 02:54:44 +02:00
|
|
|
|
2022-07-05 03:39:38 +02:00
|
|
|
RUN zypper refresh --force
|
|
|
|
RUN zypper dup -y
|
|
|
|
|
|
|
|
FROM repos AS builder
|
2022-07-06 02:54:44 +02:00
|
|
|
ARG SCCACHE_REDIS=""
|
|
|
|
ARG KANIDM_FEATURES
|
|
|
|
ARG KANIDM_BUILD_PROFILE
|
|
|
|
ARG KANIDM_BUILD_OPTIONS=""
|
2022-07-05 03:39:38 +02:00
|
|
|
|
|
|
|
RUN zypper install -y \
|
2022-09-28 02:31:19 +02:00
|
|
|
rustup wasm-pack \
|
2022-07-06 02:54:44 +02:00
|
|
|
gcc clang lld \
|
2022-07-05 03:39:38 +02:00
|
|
|
make automake autoconf \
|
|
|
|
libopenssl-devel \
|
|
|
|
pam-devel \
|
|
|
|
libudev-devel \
|
|
|
|
sqlite3-devel \
|
|
|
|
sccache \
|
|
|
|
rsync
|
|
|
|
RUN zypper clean -a
|
2022-09-28 02:31:19 +02:00
|
|
|
RUN rustup default stable
|
2022-07-05 03:39:38 +02:00
|
|
|
|
|
|
|
COPY . /usr/src/kanidm
|
|
|
|
|
|
|
|
RUN mkdir /scratch
|
|
|
|
RUN echo $KANIDM_BUILD_PROFILE
|
2022-07-06 02:54:44 +02:00
|
|
|
ENV KANIDM_BUILD_PROFILE=${KANIDM_BUILD_PROFILE:-container_generic}
|
|
|
|
RUN echo Features $KANIDM_FEATURES
|
2022-07-05 03:39:38 +02:00
|
|
|
|
|
|
|
ENV CARGO_HOME=/scratch/.cargo
|
|
|
|
ENV RUSTFLAGS="-Clinker=clang -Clink-arg=-fuse-ld=/usr/bin/ld.lld"
|
|
|
|
|
2022-07-06 02:54:44 +02:00
|
|
|
# set up sccache if you've done the thing
|
2022-07-05 03:39:38 +02:00
|
|
|
RUN if [ "${SCCACHE_REDIS}" != "" ]; \
|
|
|
|
then \
|
|
|
|
export CARGO_INCREMENTAL=false && \
|
|
|
|
export CC="/usr/bin/sccache /usr/bin/clang" && \
|
|
|
|
export RUSTC_WRAPPER=sccache && \
|
|
|
|
sccache --start-server; \
|
|
|
|
else \
|
|
|
|
export CC="/usr/bin/clang"; \
|
|
|
|
fi
|
|
|
|
|
2022-07-06 02:54:44 +02:00
|
|
|
WORKDIR /usr/src/kanidm/
|
2022-07-05 03:39:38 +02:00
|
|
|
# build the CLI
|
|
|
|
RUN if [ -z "${KANIDM_FEATURES}" ]; then \
|
|
|
|
cargo build -p kanidm_tools --bin kanidm ${KANIDM_BUILD_OPTIONS} \
|
|
|
|
--target-dir="/usr/src/kanidm/target/" \
|
|
|
|
--release; \
|
|
|
|
else \
|
|
|
|
cargo build -p kanidm_tools --bin kanidm ${KANIDM_BUILD_OPTIONS} \
|
|
|
|
--target-dir="/usr/src/kanidm/target/" \
|
|
|
|
--features="${KANIDM_FEATURES}" \
|
|
|
|
--release; \
|
|
|
|
fi
|
|
|
|
|
|
|
|
RUN if [ "${SCCACHE_REDIS}" != "" ]; then sccache -s; fi
|
|
|
|
|
|
|
|
RUN ls -al /usr/src/kanidm/target/release
|
|
|
|
|
2022-11-09 22:42:03 +01:00
|
|
|
# == Construct the tools container
|
2022-07-05 03:39:38 +02:00
|
|
|
FROM repos
|
|
|
|
|
2022-11-09 22:42:03 +01:00
|
|
|
RUN zypper install -y timezone busybox-adduser && \
|
|
|
|
zypper clean -a
|
2022-07-05 03:39:38 +02:00
|
|
|
|
|
|
|
COPY --from=builder /usr/src/kanidm/target/release/kanidm /sbin/
|
|
|
|
RUN chmod +x /sbin/kanidm
|
|
|
|
ENV RUST_BACKTRACE 1
|
|
|
|
|
|
|
|
RUN adduser -D -H kanidm
|
2022-11-09 22:42:03 +01:00
|
|
|
RUN mkdir /etc/kanidm && \
|
|
|
|
touch /etc/kanidm/config
|
2022-07-05 03:39:38 +02:00
|
|
|
|
|
|
|
USER kanidm
|
|
|
|
|
2022-11-09 22:42:03 +01:00
|
|
|
CMD [ "/sbin/kanidm", "-h" ]
|
|
|
|
|