#!/bin/sh # strap.sh - install and setup CondorCore keyring # mirror file to fetch and write MIRROR_F="condorcore-mirrorlist" # simple error message wrapper err() { echo >&2 "$(tput bold; tput setaf 1)[-] ERROR: ${*}$(tput sgr0)" exit 1337 } # simple warning message wrapper warn() { echo >&2 "$(tput bold; tput setaf 1)[!] WARNING: ${*}$(tput sgr0)" } # simple echo wrapper msg() { echo "$(tput bold; tput setaf 2)[+] ${*}$(tput sgr0)" } # check for root privilege check_priv() { if [ "$(id -u)" -ne 0 ]; then err "you must be root" fi } # make a temporary directory and cd into make_tmp_dir() { tmp="$(mktemp -d /tmp/condorcore_strap.XXXXXXXX)" trap 'rm -rf $tmp' EXIT cd "$tmp" || err "Could not enter directory $tmp" } set_umask() { OLD_UMASK=$(umask) umask 0022 trap 'reset_umask' TERM } reset_umask() { umask $OLD_UMASK } check_internet() { tool='curl' tool_opts='-s --connect-timeout 8' if ! $tool $tool_opts https://condorbs.net/ > /dev/null 2>&1; then err "You don't have an Internet connection!" fi return $SUCCESS } # retrieve the CondorCore keyring fetch_keyring() { curl -s -O \ 'https://aur.draggane.com/x86_64/condorcore-keyring-20230903-2-any.pkg.tar.zst' curl -s -O \ 'https://aur.draggane.com/x86_64/condorcore-keyring-20230903-2-any.pkg.tar.zst.sig' } # verify the keyring signature # note: this is pointless if you do not verify the key fingerprint verify_keyring() { if ! gpg --keyserver keyserver.ubuntu.com \ --recv-keys 597244DBEA52EC6EFE5F36A4FDD42A59FD43C07B > /dev/null 2>&1 then if ! gpg --keyserver hkps://keyserver.ubuntu.com:443 \ --recv-keys 597244DBEA52EC6EFE5F36A4FDD42A59FD43C07B > /dev/null 2>&1 then if ! gpg --keyserver keys.openpgp.org \ --recv-keys 597244DBEA52EC6EFE5F36A4FDD42A59FD43C07B > /dev/null 2>&1 then err "could not verify the key." fi fi fi if ! gpg --keyserver-options no-auto-key-retrieve \ --with-fingerprint condorcore-keyring-20230903-2-any.pkg.tar.zst.sig > /dev/null 2>&1 then err "invalid keyring signature." fi } # delete the signature files delete_signature() { if [ -f "condorcore-keyring-20230903-2-any.pkg.tar.zst.sig" ]; then rm condorcore-keyring-20230903-2-any.pkg.tar.zst.sig fi } # make sure /etc/pacman.d/gnupg is usable check_pacman_gnupg() { pacman-key --init } # install the keyring install_keyring() { if ! pacman --config /dev/null --noconfirm \ -U condorcore-keyring-20230903-2-any.pkg.tar.zst ; then err 'keyring installation failed' fi # just in case pacman-key --populate } # fetch the CondorCore mirrorlist from the provided URL fetch_mirrorlist() { mirrorlist_url="https://condorcs.net/mrhacker/condorcore-mirrorlist/raw/branch/master/condorcore-mirrorlist" curl -s "$mirrorlist_url" -o "/etc/pacman.d/$MIRROR_F" } # update pacman.conf update_pacman_conf() { # delete CondorCore related entries if existing sed -i '/condorcore/{N;d}' /etc/pacman.conf cat >> "/etc/pacman.conf" << EOF [condorcore] Include = /etc/pacman.d/$MIRROR_F EOF } # synchronize and update pacman_update() { if pacman -Syy; then return $SUCCESS fi warn "Synchronizing pacman has failed. Please try manually: pacman -Syy" return $FAILURE } # upgrade the system pacman_upgrade() { echo 'perform full system upgrade? (pacman -Su) [Yn]:' read conf < /dev/tty case "$conf" in ''|y|Y) pacman -Su ;; n|N) warn 'some CondorCore packages may not work without an up-to-date system.' ;; esac } # setup CondorCore condorcore_setup() { check_priv msg 'installing CondorCore keyring...' set_umask make_tmp_dir check_internet fetch_keyring verify_keyring delete_signature check_pacman_gnupg install_keyring echo msg 'keyring installed successfully' # fetch the CondorCore mirrorlist msg 'fetching CondorCore mirrorlist...' fetch_mirrorlist # update pacman.conf msg 'updating pacman.conf' update_pacman_conf msg 'updating package databases' pacman_update reset_umask msg 'CondorCore repo is ready!' # ask for system upgrade pacman_upgrade } condorcore_setup