mirror of
				https://github.com/arcan1s/ahriman.git
				synced 2025-11-03 23:33:41 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			66 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Docker
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Docker
		
	
	
	
	
	
FROM archlinux:base
 | 
						|
 | 
						|
# image configuration
 | 
						|
ENV AHRIMAN_ARCHITECTURE="x86_64"
 | 
						|
ENV AHRIMAN_DEBUG=""
 | 
						|
ENV AHRIMAN_FORCE_ROOT=""
 | 
						|
ENV AHRIMAN_HOST="0.0.0.0"
 | 
						|
ENV AHRIMAN_MULTILIB="yes"
 | 
						|
ENV AHRIMAN_OUTPUT=""
 | 
						|
ENV AHRIMAN_PACKAGER="ahriman bot <ahriman@example.com>"
 | 
						|
ENV AHRIMAN_PACMAN_MIRROR=""
 | 
						|
ENV AHRIMAN_PORT=""
 | 
						|
ENV AHRIMAN_POSTSETUP_COMMAND=""
 | 
						|
ENV AHRIMAN_PRESETUP_COMMAND=""
 | 
						|
ENV AHRIMAN_REPOSITORY="aur-clone"
 | 
						|
ENV AHRIMAN_REPOSITORY_SERVER=""
 | 
						|
ENV AHRIMAN_REPOSITORY_ROOT="/var/lib/ahriman/ahriman"
 | 
						|
ENV AHRIMAN_UNIX_SOCKET=""
 | 
						|
ENV AHRIMAN_USER="ahriman"
 | 
						|
ENV AHRIMAN_VALIDATE_CONFIGURATION="yes"
 | 
						|
 | 
						|
# install environment
 | 
						|
## update pacman.conf with multilib
 | 
						|
RUN echo "[multilib]" >> "/etc/pacman.conf" && \
 | 
						|
    echo "Include = /etc/pacman.d/mirrorlist" >> "/etc/pacman.conf"
 | 
						|
## refresh packages, install sudo and install packages for building
 | 
						|
RUN pacman -Syu --noconfirm sudo && \
 | 
						|
    pacman -Sy --noconfirm --asdeps fakeroot python-tox
 | 
						|
## create build user
 | 
						|
RUN useradd -m -d "/home/build" -s "/usr/bin/nologin" build && \
 | 
						|
    echo "build ALL=(ALL) NOPASSWD: ALL" > "/etc/sudoers.d/build"
 | 
						|
COPY "docker/install-aur-package.sh" "/usr/local/bin/install-aur-package"
 | 
						|
## install package dependencies
 | 
						|
## darcs is not installed by reasons, because it requires a lot haskell packages which dramatically increase image size
 | 
						|
RUN pacman -Sy --noconfirm --asdeps devtools git pyalpm python-cerberus python-inflection python-passlib python-requests python-srcinfo && \
 | 
						|
    pacman -Sy --noconfirm --asdeps python-build python-flit python-installer python-wheel && \
 | 
						|
    pacman -Sy --noconfirm --asdeps breezy git mercurial python-aiohttp python-boto3 python-cryptography python-jinja python-requests-unixsocket python-systemd rsync subversion && \
 | 
						|
    runuser -u build -- install-aur-package python-aioauth-client python-aiohttp-apispec-git python-aiohttp-cors \
 | 
						|
                                            python-aiohttp-jinja2 python-aiohttp-session python-aiohttp-security
 | 
						|
 | 
						|
## FIXME since 1.0.4 devtools requires dbus to be run, which doesn't work now in container
 | 
						|
COPY "docker/systemd-nspawn.sh" "/usr/local/bin/systemd-nspawn"
 | 
						|
 | 
						|
# install ahriman
 | 
						|
## copy tree
 | 
						|
COPY --chown=build . "/home/build/ahriman"
 | 
						|
## create package archive and install it
 | 
						|
RUN cd "/home/build/ahriman" && \
 | 
						|
    tox -e archive && \
 | 
						|
    cp ./dist/*.tar.gz "package/archlinux" && \
 | 
						|
    cd "package/archlinux" && \
 | 
						|
    runuser -u build -- makepkg --noconfirm --install --skipchecksums && \
 | 
						|
    cd / && rm -r "/home/build/ahriman"
 | 
						|
 | 
						|
# cleanup unused
 | 
						|
RUN find "/var/cache/pacman/pkg" -type f -delete
 | 
						|
RUN pacman -Qdtq | pacman -Rscn --noconfirm -
 | 
						|
 | 
						|
VOLUME ["/var/lib/ahriman"]
 | 
						|
 | 
						|
# minimal runtime ahriman setup
 | 
						|
COPY "docker/entrypoint.sh" "/usr/local/bin/entrypoint"
 | 
						|
ENTRYPOINT ["entrypoint"]
 | 
						|
# default command
 | 
						|
CMD ["repo-update", "--refresh"]
 |