#!/usr/bin/env bash set -eu set -o pipefail # System specific settings export NIX_FIRST_BUILD_UID="${NIX_FIRST_BUILD_UID:-30001}" export NIX_BUILD_USER_NAME_TEMPLATE="nixbld%d" readonly SERVICE_SRC=/lib/systemd/system/nix-daemon.service readonly SERVICE_DEST=/etc/systemd/system/nix-daemon.service readonly SOCKET_SRC=/lib/systemd/system/nix-daemon.socket readonly SOCKET_DEST=/etc/systemd/system/nix-daemon.socket readonly TMPFILES_SRC=/lib/tmpfiles.d/nix-daemon.conf readonly TMPFILES_DEST=/etc/tmpfiles.d/nix-daemon.conf # Path for the systemd override unit file to contain the proxy settings readonly SERVICE_OVERRIDE=${SERVICE_DEST}.d/override.conf create_systemd_override() { header "Configuring proxy for the nix-daemon service" _sudo "create directory for systemd unit override" mkdir -p "$(dirname "$SERVICE_OVERRIDE")" cat < /dev/null 2>&1 } poly_group_id_get() { getent group "$1" | cut -d: -f3 } poly_create_build_group() { _sudo "Create the Nix build group, $NIX_BUILD_GROUP_NAME" \ groupadd -g "$NIX_BUILD_GROUP_ID" --system \ "$NIX_BUILD_GROUP_NAME" >&2 } poly_user_exists() { getent passwd "$1" > /dev/null 2>&1 } poly_user_id_get() { getent passwd "$1" | cut -d: -f3 } poly_user_hidden_get() { echo "1" } poly_user_hidden_set() { true } poly_user_home_get() { getent passwd "$1" | cut -d: -f6 } poly_user_home_set() { _sudo "in order to give $1 a safe home directory" \ usermod --home "$2" "$1" } poly_user_note_get() { getent passwd "$1" | cut -d: -f5 } poly_user_note_set() { _sudo "in order to give $1 a useful comment" \ usermod --comment "$2" "$1" } poly_user_shell_get() { getent passwd "$1" | cut -d: -f7 } poly_user_shell_set() { _sudo "in order to prevent $1 from logging in" \ usermod --shell "$2" "$1" } poly_user_in_group_check() { groups "$1" | grep -q "$2" > /dev/null 2>&1 } poly_user_in_group_set() { _sudo "Add $1 to the $2 group"\ usermod --append --groups "$2" "$1" } poly_user_primary_group_get() { getent passwd "$1" | cut -d: -f4 } poly_user_primary_group_set() { _sudo "to let the nix daemon use this user for builds (this might seem redundant, but there are two concepts of group membership)" \ usermod --gid "$2" "$1" } poly_create_build_user() { username=$1 uid=$2 builder_num=$3 _sudo "Creating the Nix build user, $username" \ useradd \ --home-dir /var/empty \ --comment "Nix build user $builder_num" \ --gid "$NIX_BUILD_GROUP_ID" \ --groups "$NIX_BUILD_GROUP_NAME" \ --no-user-group \ --system \ --shell /sbin/nologin \ --uid "$uid" \ --password "!" \ "$username" } poly_prepare_to_install() { : }