# 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"]
