# syntax = docker/dockerfile:1 FROM quay.io/archlinux/archlinux:base-devel USER root # Exempt from image pruning LABEL prune="do_not_delete" # Build ARG for additional packages to install (eg, openssh) ARG addpkg # Build ARG: use "root" for debugging ARG debug # Copy mirrorlist COPY mirrorlist /etc/pacman.d/mirrorlist # Copy app folder COPY entrypoint /entrypoint # Install packages RUN --mount=type=cache,sharing=locked,target=/var/cache/pacman \ pacman-key --init \ && sed -i '/ParallelDownloads/c ParallelDownloads = 10' /etc/pacman.conf \ && pacman -Sy --ask 4 archlinux-keyring \ && pacman -Su --ask 4 --needed ${addpkg} \ sudo bash bash-completion \ tigervnc \ cuda openssh vim pacman-contrib rsync git \ plasma plasma-x11-session konsole kate dolphin kompare kcalc \ jack2 \ ttf-dejavu noto-fonts-cjk \ firefox firefox-decentraleyes firefox-ublock-origin \ torbrowser-launcher \ shotwell ffmpegthumbs ark okular \ remmina libvncserver \ && pacman -Scc --ask 4 \ && useradd --create-home --gid users --shell /usr/bin/bash user \ && printf '%s\n' 'user ALL=(ALL:ALL) NOPASSWD: /usr/bin/pacman' \ 'Defaults lecture = never' >/etc/sudoers.d/zz-DOCKER \ && passwd -l root >/dev/null 2>&1 # Default environment USER ${debug:-user} WORKDIR /home/user ENV HOME=/home/user ENV DISPLAY=:0 ENV SHELL=/usr/bin/bash ENV PS1="[\u@myvnc \W \$?]\$ " # X session environment variable ENV STARTXBIN=startplasma-x11 # configure nvidia container runtime # https://github.com/NVIDIA/nvidia-container-runtime#environment-variables-oci-spec ENV NVIDIA_VISIBLE_DEVICES=all ENV NVIDIA_DRIVER_CAPABILITIES=compute,utility # Docker entrypoint ENTRYPOINT ["/entrypoint"]