#!/bin/bash set -e [ -n "$AHRIMAN_DEBUG" ] && set -x # configuration tune sed -i "s|root = /var/lib/ahriman|root = $AHRIMAN_REPOSITORY_ROOT|g" "/etc/ahriman.ini" sed -i "s|database = /var/lib/ahriman/ahriman.db|database = $AHRIMAN_REPOSITORY_ROOT/ahriman.db|g" "/etc/ahriman.ini" sed -i "s|host = 127.0.0.1|host = $AHRIMAN_HOST|g" "/etc/ahriman.ini" sed -i "s|handlers = syslog_handler|handlers = ${AHRIMAN_OUTPUT}_handler|g" "/etc/ahriman.ini.d/logging.ini" AHRIMAN_DEFAULT_ARGS=("--architecture" "$AHRIMAN_ARCHITECTURE") if [[ "$AHRIMAN_OUTPUT" == "syslog" ]]; then if [ ! -e "/dev/log" ]; then # by default ahriman uses syslog which is not available inside container # to make noise less we force quiet mode in case if /dev/log was not mounted AHRIMAN_DEFAULT_ARGS+=("--quiet") fi fi # create repository root inside the [[mounted]] directory and set correct ownership [ -d "$AHRIMAN_REPOSITORY_ROOT" ] || mkdir "$AHRIMAN_REPOSITORY_ROOT" chown "$AHRIMAN_USER":"$AHRIMAN_USER" "$AHRIMAN_REPOSITORY_ROOT" # run built-in setup command AHRIMAN_SETUP_ARGS=("--build-as-user" "$AHRIMAN_USER") AHRIMAN_SETUP_ARGS+=("--packager" "$AHRIMAN_PACKAGER") AHRIMAN_SETUP_ARGS+=("--repository" "$AHRIMAN_REPOSITORY") if [ -n "$AHRIMAN_PORT" ]; then # in addition it must be handled in docker run command AHRIMAN_SETUP_ARGS+=("--web-port" "$AHRIMAN_PORT") fi ahriman "${AHRIMAN_DEFAULT_ARGS[@]}" repo-setup "${AHRIMAN_SETUP_ARGS[@]}" # add user for api if set if [ -n "$AHRIMAN_API_USER" ]; then # python getpass does not read from stdin # see thread https://mail.python.org/pipermail/python-dev/2008-February/077235.html # WARNING with debug mode password will be put to stdout ahriman "${AHRIMAN_DEFAULT_ARGS[@]}" user-list --error-on-empty "$AHRIMAN_API_USER" > /dev/null || ahriman "${AHRIMAN_DEFAULT_ARGS[@]}" user-add --as-service --role write --secure "$AHRIMAN_API_USER" -p "$(openssl rand -base64 20)" fi # refresh database runuser -u build -- yay --noconfirm -Syy &> /dev/null # create machine-id which is required by build tools systemd-machine-id-setup &> /dev/null # if AHRIMAN_FORCE_ROOT is set or command is unsafe we can run without sudo # otherwise we prepend executable by sudo command if [ -n "$AHRIMAN_FORCE_ROOT" ]; then AHRIMAN_EXECUTABLE=("ahriman") elif ahriman help-commands-unsafe --command="$*" &> /dev/null; then AHRIMAN_EXECUTABLE=("sudo" "-u" "$AHRIMAN_USER" "--" "ahriman") else AHRIMAN_EXECUTABLE=("ahriman") fi exec "${AHRIMAN_EXECUTABLE[@]}" "${AHRIMAN_DEFAULT_ARGS[@]}" "$@"