# syntax=docker/dockerfile:experimental FROM rust as rust RUN mkdir -p /tmp/work WORKDIR /tmp/work RUN apt-get update && apt-get install -y \ protobuf-compiler RUN git clone https://github.com/containers/netavark/ WORKDIR /tmp/work/netavark ENV CARGO_TARGETS_DIR = targets RUN rustup target add aarch64-unknown-linux-gnu RUN --mount=type=cache,target=/usr/local/cargo/registry \ --mount=type=cache,target=/home/root/app/target \ cargo build --target aarch64-unknown-linux-gnu --release && cargo build --target aarch64-unknown-linux-gnu --bin netavark-dhcp-proxy-client --release && cp targets/$(profile)/* /tmp/work/netavark/bin/ FROM golang:1.18.3-stretch # Currenrtly supported versions: UDM-Base UDM-Pro-SE ARG UDM_PLATFORM=UDM-Base ARG PODMAN_VERSION=v4.4.2 ARG RUNC_VERSION=v1.1.4 ARG CONMON_VERSION=v2.1.7 ARG CRUN_VERSION=1.8.2 ARG DEBIAN_FRONTEND=noninteractive RUN mkdir -p /tmp/install/podman-${PODMAN_VERSION}-${UDM_PLATFORM}/usr/bin \ && mkdir -p /tmp/install/podman-${PODMAN_VERSION}-${UDM_PLATFORM}/usr/libexec/podman/ \ && mkdir -p /tmp/install/podman-${PODMAN_VERSION}-${UDM_PLATFORM}/usr/share/containers/ \ && mkdir -p /tmp/install/podman-${PODMAN_VERSION}-${UDM_PLATFORM}/etc/containers/ COPY --from=rust /tmp/work/netavark/bin/* /tmp/install/podman-${PODMAN_VERSION}-${UDM_PLATFORM}/usr/libexec/podman # Install dependencies RUN apt-get update && apt-get install -y \ bc \ binutils-aarch64-linux-gnu \ bison \ build-essential \ flex \ gcc-aarch64-linux-gnu \ git \ libc6-arm64-cross \ libc6-dev-arm64-cross \ libncurses5-dev \ libssl-dev \ pkg-config \ systemd \ zip \ && rm -rf /var/lib/apt/lists/* RUN dpkg --add-architecture arm64 RUN apt-get update && apt-get install -y \ gperf:arm64 \ libglib2.0-dev:arm64 \ libseccomp-dev:arm64 \ libsystemd-dev:arm64 \ && rm -rf /var/lib/apt/lists/* ENV GOOS=linux RUN wget https://github.com/containers/crun/releases/download/${CRUN_VERSION}/crun-${CRUN_VERSION}-linux-arm64 -o /tmp/install/podman-${PODMAN_VERSION}-${UDM_PLATFORM}/usr/bin/crun COPY ./podman.Makefile.${UDM_PLATFORM}.patch /tmp RUN mkdir -p /build \ && mkdir -p /tmp/release WORKDIR /build RUN git clone https://github.com/containers/podman.git \ && git clone https://github.com/opencontainers/runc.git \ && git clone https://github.com/containers/conmon.git WORKDIR /build/runc RUN git checkout ${RUNC_VERSION} \ && ./script/release_build.sh -a arm64 -r /tmp/release ENV PKG_CONFIG_PATH=/usr/lib/aarch64-linux-gnu/pkgconfig/ ENV GOARCH=arm64 ENV CC='aarch64-linux-gnu-gcc' WORKDIR /build/podman RUN git checkout ${PODMAN_VERSION} \ && patch Makefile /tmp/podman.Makefile.${UDM_PLATFORM}.patch \ && make vendor local-cross \ && cp ./bin/podman.cross.linux.arm64 /tmp/release/podman-${PODMAN_VERSION} \ && chmod +x /tmp/release/podman-${PODMAN_VERSION} WORKDIR /build/conmon RUN git checkout ${CONMON_VERSION} \ && make vendor bin/conmon \ && cp bin/conmon /tmp/release/conmon-${CONMON_VERSION} \ && chmod +x /tmp/release/conmon-$CONMON_VERSION COPY seccomp.json /tmp/install/podman-${PODMAN_VERSION}-${UDM_PLATFORM}/usr/share/containers/ COPY containers.conf /tmp/install/podman-${PODMAN_VERSION}-${UDM_PLATFORM}/etc/containers/ COPY storage.conf /tmp/install/podman-${PODMAN_VERSION}-${UDM_PLATFORM}/etc/containers/ COPY registries.conf /tmp/install/podman-${PODMAN_VERSION}-${UDM_PLATFORM}/etc/containers/ COPY policy.json /tmp/install/podman-${PODMAN_VERSION}-${UDM_PLATFORM}/etc/containers/ RUN cp /tmp/release/podman-${PODMAN_VERSION} /tmp/install/podman-${PODMAN_VERSION}-${UDM_PLATFORM}/usr/bin/podman \ && cp /tmp/release/runc.arm64 /tmp/install/podman-${PODMAN_VERSION}-${UDM_PLATFORM}/usr/bin/runc \ && cp /tmp/release/conmon-${CONMON_VERSION} /tmp/install/podman-${PODMAN_VERSION}-${UDM_PLATFORM}/usr/libexec/podman/conmon WORKDIR /tmp/install