kanidm/kanidm_tools/Dockerfile

81 lines
2 KiB
Docker
Raw Normal View History

2023-02-06 00:50:10 +01:00
# This builds the kanidm CLI tools
ARG BASE_IMAGE=opensuse/tumbleweed:latest
FROM ${BASE_IMAGE} AS repos
RUN zypper refresh --force
RUN zypper dup -y
FROM repos AS builder
ARG KANIDM_FEATURES
ARG KANIDM_BUILD_PROFILE
ARG KANIDM_BUILD_OPTIONS=""
2023-02-06 00:50:10 +01:00
RUN echo Profile $KANIDM_BUILD_PROFILE
RUN echo Features $KANIDM_FEATURES
RUN zypper install -y --no-recommends \
2022-09-28 02:31:19 +02:00
rustup wasm-pack \
2023-02-06 00:50:10 +01:00
clang \
make automake autoconf \
2023-02-06 00:50:10 +01:00
libopenssl-3-devel \
pam-devel \
libudev-devel \
sqlite3-devel \
2023-02-06 00:50:10 +01:00
rsync \
mold
RUN zypper clean -a
2022-09-28 02:31:19 +02:00
RUN rustup default stable
COPY . /usr/src/kanidm
2023-02-06 00:50:10 +01:00
RUN mkdir -p /usr/src/kanidm/.cargo
RUN cp /usr/src/kanidm/cargo_vendor_config /usr/src/kanidm/.cargo/config.toml
WORKDIR /usr/src/kanidm/
2023-02-06 00:50:10 +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"
# build the CLI
RUN if [ -z "${KANIDM_FEATURES}" ]; then \
2023-02-06 00:50:10 +01:00
cargo build -p kanidm_tools ${KANIDM_BUILD_OPTIONS} \
2022-12-21 00:53:57 +01:00
--target-dir="/usr/src/kanidm/target/" \
--release; \
2023-02-06 00:50:10 +01:00
cargo build -p kanidm-ipa-sync ${KANIDM_BUILD_OPTIONS} \
--target-dir="/usr/src/kanidm/target/" \
--release; \
else \
2023-02-06 00:50:10 +01:00
cargo build -p kanidm_tools ${KANIDM_BUILD_OPTIONS} \
2022-12-21 00:53:57 +01:00
--target-dir="/usr/src/kanidm/target/" \
--features="${KANIDM_FEATURES}" \
--release; \
2023-02-06 00:50:10 +01:00
cargo build -p kanidm-ipa-sync ${KANIDM_BUILD_OPTIONS} \
--target-dir="/usr/src/kanidm/target/" \
--features="${KANIDM_FEATURES}" \
--release; \
fi
RUN ls -al /usr/src/kanidm/target/release
2022-11-09 22:42:03 +01:00
# == Construct the tools container
FROM repos
2023-02-06 00:50:10 +01:00
RUN zypper install -y timezone busybox-adduser openssl-3 && \
2022-11-09 22:42:03 +01:00
zypper clean -a
COPY --from=builder /usr/src/kanidm/target/release/kanidm /sbin/
2022-12-21 00:53:57 +01:00
COPY --from=builder /usr/src/kanidm/target/release/kanidm-ipa-sync /sbin/
RUN chmod +x /sbin/kanidm
2022-12-21 00:53:57 +01:00
RUN chmod +x /sbin/kanidm-ipa-sync
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
USER kanidm
2022-11-09 22:42:03 +01:00
CMD [ "/sbin/kanidm", "-h" ]