From 09f840a804864e4eb8d6eea8e7e8feabb99bf628 Mon Sep 17 00:00:00 2001 From: bill-auger Date: Wed, 30 May 2018 19:47:41 -0400 Subject: housekeeping --- .../etc/skel/Desktop/parabola-installer.desktop | 2 +- .../root/customize_root_image-constants.inc | 45 +++++++--- .../root-image/root/customize_root_image.sh | 99 ++++++++++++---------- 3 files changed, 86 insertions(+), 60 deletions(-) (limited to 'configs/profile/root-image') diff --git a/configs/profile/root-image/etc/skel/Desktop/parabola-installer.desktop b/configs/profile/root-image/etc/skel/Desktop/parabola-installer.desktop index 89eb06c..a5d96b6 100644 --- a/configs/profile/root-image/etc/skel/Desktop/parabola-installer.desktop +++ b/configs/profile/root-image/etc/skel/Desktop/parabola-installer.desktop @@ -9,7 +9,7 @@ Name[pt_BR]=Instalador do Parabola GenericName=System Installer Keywords=calamares;system;installer TryExec=calamares -Exec=pkexec /usr/bin/calamares +Exec=sudo /usr/bin/calamares Comment=Distribution-independent installer framework - Parabola edition Icon=calamares Terminal=false diff --git a/configs/profile/root-image/root/customize_root_image-constants.inc b/configs/profile/root-image/root/customize_root_image-constants.inc index d0359a6..4bf75c6 100644 --- a/configs/profile/root-image/root/customize_root_image-constants.inc +++ b/configs/profile/root-image/root/customize_root_image-constants.inc @@ -1,3 +1,10 @@ +# environment vars from build.sh: +# ISO_TITLE +# ISO_INIT +# ISO_GUI +# ENABLE_OFFLINE_INSTALL + + readonly LOCALES="en_US\.UTF-8 \ eo \ es_ES\.UTF-8 \ @@ -6,6 +13,7 @@ readonly LOCALES="en_US\.UTF-8 \ it_IT\.UTF-8 \ pt_BR\.UTF-8 \ pl_PL\.UTF-8 " + readonly SYSTEMD_DELETE_FILES="/etc/conf.d/agetty.tty1 \ /etc/conf.d/hostname \ /etc/init.d/pacman-init \ @@ -16,6 +24,7 @@ readonly OPENRC_DELETE_FILES="/etc/hostname /etc/systemd/system/etc-pacman.d-gnupg.mount \ /etc/systemd/system/getty@tty1.service.d/autologin.conf \ /etc/systemd/system/pacman-init.service " + readonly SYSTEMD_SERVICES_ALL="choose-mirror.service \ multi-user.target \ pacman-init.service " @@ -26,28 +35,36 @@ readonly OPENRC_SERVICES_ALL="dbus \ pacman-init " readonly OPENRC_SERVICES_GUI="alsasound \ elogind " -[[ "${iso_gui}" == 'cli' ]] && readonly OPENRC_SERVICES="${OPENRC_SERVICES_ALL}" || - readonly OPENRC_SERVICES="${OPENRC_SERVICES_ALL} ${OPENRC_SERVICES_GUI}" -[[ "${iso_gui}" == 'cli' ]] && readonly SYSTEMD_SERVICES="${SYSTEMD_SERVICES_ALL}" || - readonly SYSTEMD_SERVICES="${SYSTEMD_SERVICES_ALL} ${SYSTEMD_SERVICES_GUI}" -[ "${enable_offline_install}" == 'true' ] && readonly INSTALL_TYPE='Complete' || \ - readonly INSTALL_TYPE='NetInstall' +readonly SYSTEMD_SERVICES="${SYSTEMD_SERVICES_ALL}" +readonly OPENRC_SERVICES="${OPENRC_SERVICES_ALL}" +[[ "${ISO_GUI}" != 'cli' ]] && readonly SYSTEMD_SERVICES+=" ${SYSTEMD_SERVICES_GUI}" +[[ "${ISO_GUI}" != 'cli' ]] && readonly OPENRC_SERVICES+=" ${OPENRC_SERVICES_GUI}" + readonly DEFAULT_SHELL=/bin/bash + readonly NETINSTALL_MSG="To install Parabola, the system must be connected to the internet." readonly COMPLETE_MSG="This ISO is capable of installing a complete Parabola system\n\ ->>>>without a connection to the internet. If you would like to fetch\n\ ->>>>the latest packages from the internet, run the following command\n\ ->>>>before beginning the install:\n\ - # cp /etc/pacman-online.conf /etc/pacman.conf" -[ "${INSTALL_TYPE}" == 'Complete' ] && readonly NETWORK_MOTD_MSG=${NETINSTALL_MSG} || \ - readonly NETWORK_MOTD_MSG=${COMPLETE_MSG} + without a connection to the internet.\n\ + To fetch packages from the internet, enter this command first:\n\ + # cp /etc/pacman-online.conf /etc/pacman.conf" +if [[ "${ENABLE_OFFLINE_INSTALL}" == 'true' ]] +then readonly INSTALL_TYPE='Complete' ; readonly NETWORK_MOTD_MSG=${COMPLETE_MSG} ; +else readonly INSTALL_TYPE='NetInstall' ; readonly NETWORK_MOTD_MSG=${NETINSTALL_MSG} ; +fi + readonly ROOT_SKEL_FILES="/etc/skel/.bash_logout \ /etc/skel/.bash_profile \ /etc/skel/install-openrc-lxde.sh \ /etc/skel/install-systemd-mate.sh" + readonly LIVE_USER=parabola readonly LIVE_USER_GROUPS="adm,audio,floppy,log,network,rfkill,scanner,storage,optical,power,wheel" readonly OPENRC_USER_GROUPS="disk,sys" -[[ "${iso_init}" == 'openrc' ]] && readonly USER_GROUPS="${LIVE_USER_GROUPS},${OPENRC_USER_GROUPS}" || +[[ "${ISO_INIT}" == 'openrc' ]] && readonly USER_GROUPS="${LIVE_USER_GROUPS},${OPENRC_USER_GROUPS}" || readonly USER_GROUPS="${LIVE_USER_GROUPS}" -readonly PRETTY_NAME="$(echo ${iso_title} | cut -d ' ' -f -5) - (${INSTALL_TYPE})" + +readonly OS_PRETTY_NAME="$(echo ${ISO_TITLE} | cut -d ' ' -f -5) - (${INSTALL_TYPE})" +readonly OS_VERSION=$( echo ${ISO_TITLE} | cut -d ' ' -f 6 ) +readonly OS_VERSION_ID=$( echo ${ISO_TITLE} | cut -d ' ' -f 6 ) +readonly OS_VARIANT="$( echo ${OS_PRETTY_NAME} | cut -d ' ' -f -3 --complement )" +readonly OS_VARIANT_ID=${ISO_INIT}-${ISO_GUI} diff --git a/configs/profile/root-image/root/customize_root_image.sh b/configs/profile/root-image/root/customize_root_image.sh index 28e522e..522162b 100755 --- a/configs/profile/root-image/root/customize_root_image.sh +++ b/configs/profile/root-image/root/customize_root_image.sh @@ -6,38 +6,35 @@ set -e -u source /root/customize_root_image-constants.inc -# configure timezone and locales +# configure timezone and locales # + ln -sf /usr/share/zoneinfo/UTC /etc/localtime for locale in ${LOCALES} ; do sed -i "s/#${locale}/${locale}/" /etc/locale.gen ; done ; locale-gen -# configure sudo + +# configure sudo # + chmod 750 /etc/sudoers.d chmod 440 /etc/sudoers.d/g_wheel -# configure pacman + +# configure pacman # + sed -i "s|#Server|Server|" /etc/pacman.d/mirrorlist -[ "${INSTALL_TYPE}" == 'Complete' ] && pacman_conf=pacman-offline.conf || pacman_conf=pacman-online.conf -cp /etc/${pacman_conf} /etc/pacman.conf -# KLUDGE begin # FIXME: https://labs.parabola.nu/issues/1527 -# if [[ "${arch}" == "i686" ]] -# then echo "Server = https://repo.parabola.nu/\$repo/os/\$arch" > /etc/pacman.d/mirrorlist -# fi -# echo "Server = https://parabola.isacdaavid.info:8081/\$repo/os/\$arch" > /etc/pacman.d/mirrorlist -# KLUDGE end -# KLUDGE begin - temp until next calamares rebuild # FIXME: -# cp /etc/pacman.conf /etc/pacman-offline.conf ; cp /etc/pacman.conf /etc/pacman-online.conf -# sed -i 's|requiredStorage:.*|requiredStorage: 8.9|' /usr/share/calamares/modules/welcome.conf -# KLUDGE end - -# configure services -if [[ "${iso_init}" == 'systemd' ]] +[ "${INSTALL_TYPE}" == 'Complete' ] && cp /etc/pacman-offline.conf /etc/pacman.conf || \ + cp /etc/pacman-online.conf /etc/pacman.conf + +# configure services # + +if [[ "${ISO_INIT}" == 'systemd' ]] then # delete files that are specific to other init systems rm ${SYSTEMD_DELETE_FILES} # enable services systemctl enable ${SYSTEMD_SERVICES} -elif [[ "${iso_init}" == 'openrc' ]] + +elif [[ "${ISO_INIT}" == 'openrc' ]] then # delete files that are specific to other init systems rm ${OPENRC_DELETE_FILES} @@ -47,53 +44,65 @@ then # delete files that are specific to other init systems # create the dbus user and group if it does not exist if [[ "$(grep 'dbus' /etc/group )" = "" ]] ; then groupadd -g 81 dbus ; fi ; if [[ "$(grep 'dbus' /etc/passwd)" = "" ]] ; then useradd -r -s /sbin/nologin -g 81 -u 81 dbus ; fi ; -else echo "invalid \$iso_init for services '${iso_init}'" + +else echo "invalid \$ISO_INIT for services '${ISO_INIT}'" exit 1 fi -# configure root user, system defaults, and login session + +# configure root user, system defaults, and login session # + usermod -s ${DEFAULT_SHELL} root 2> /dev/null -sed -i "s|_EDITION_TITLE_|${iso_title}|" /etc/motd -sed -i "s|_NETWORK_MOTD_MSG_|${NETWORK_MOTD_MSG}| ; s|^>>>>\(.*\)| \1|g" /etc/motd -sed -i "s|PRETTY_NAME=.*|PRETTY_NAME=\"${PRETTY_NAME}\"|" /usr/lib/os-release -echo "VERSION=\"$( echo ${iso_title} | cut -d ' ' -f 6 )\"" >> /usr/lib/os-release -echo "VERSION_ID=\"$(echo ${iso_title} | cut -d ' ' -f 6 )\"" >> /usr/lib/os-release -echo "VARIANT=\"$( echo ${PRETTY_NAME} | cut -d ' ' -f -3 --complement)\"" >> /usr/lib/os-release -echo "VARIANT_ID=\"${iso_init}-${iso_gui}\"" >> /usr/lib/os-release - -# configure CLI login session -if [[ "${iso_gui}" == 'cli' ]] -then cp ${ROOT_SKEL_FILES} /root/ +sed -i "s|_EDITION_TITLE_|${ISO_TITLE}|" /etc/motd +sed -i "s|_NETWORK_MOTD_MSG_|${NETWORK_MOTD_MSG}|" /etc/motd +sed -i "s|PRETTY_NAME=.*|PRETTY_NAME=\"${OS_PRETTY_NAME}\"|" /usr/lib/os-release +echo "VERSION=\"${OS_VERSION}\"" >> /usr/lib/os-release +echo "VERSION_ID=\"${OS_VERSION_ID}\"" >> /usr/lib/os-release +echo "VARIANT=\"${OS_VARIANT}\"" >> /usr/lib/os-release +echo "VARIANT_ID=\"${OS_VARIANT_ID}\"" >> /usr/lib/os-release + + +# configure login session # + +if [[ "${ISO_GUI}" == 'cli' ]] +then # configure CLI login session + cp ${ROOT_SKEL_FILES} /root/ sed -i "s|_DESKTOP_SESSION_||" /root/.bash_profile else # configure GUI login session and live user + + # configure live user [[ -n "$(id ${LIVE_USER} 2> /dev/null)" ]] && userdel -r ${LIVE_USER} 2> /dev/null useradd -m -p "" -g users -G "${USER_GROUPS}" -s ${DEFAULT_SHELL} ${LIVE_USER} - if [[ "${iso_init}" == 'systemd' ]] + + # configure auto-login + if [[ "${ISO_INIT}" == 'systemd' ]] then sed -i "s|--autologin root|--autologin ${LIVE_USER}|" /etc/systemd/system/getty@tty1.service.d/autologin.conf - elif [[ "${iso_init}" == 'openrc' ]] + + elif [[ "${ISO_INIT}" == 'openrc' ]] then sed -i "s|--autologin root|--autologin ${LIVE_USER}|" /etc/conf.d/agetty.tty1 - else echo "invalid \$iso_init for --autologin '${iso_init}'" fi # configure welcome news alert - sed -i "s|_EDITION_TITLE_|${PRETTY_NAME}|" /usr/bin/autostart.sh - sed -i "s|,Don't show this again:0||" /usr/bin/autostart.sh - sed -i "s|620x460|620x520|" /usr/bin/autostart.sh + sed -i "s|_EDITION_TITLE_|${OS_PRETTY_NAME}| ; \ + s|,Don't show this again:0|| ; \ + s|620x460|620x520| " /usr/bin/autostart.sh # configure desktop environment sed -i "s|/issue-tracker/|/isos/|" /home/${LIVE_USER}/Desktop/bug-tracker.desktop - if [[ "${iso_gui}" == 'lxde' ]] - then rm -f /etc/xdg/autostart/octopi-notifier.desktop 2> /dev/null - touch /home/${LIVE_USER}/Desktop/parabola-installer.desktop ; sleep 2 ; # sort - touch /home/${LIVE_USER}/Desktop/parabola-irc.desktop ; sleep 2 ; # sort - touch /home/${LIVE_USER}/Desktop/bug-tracker.desktop # sort + if [[ "${ISO_GUI}" == 'lxde' ]] + then rm -f /etc/xdg/autostart/octopi-notifier.desktop 2> /dev/null # FIXME: issue #1850 + for desktop_file in parabola-installer.desktop parabola-irc.desktop bug-tracker.desktop + do sleep 2 ; touch /home/${LIVE_USER}/Desktop/${desktop_file} ; # sort + done sed -i "s|_DESKTOP_SESSION_|LXDE|" /home/${LIVE_USER}/.bash_profile sed -i "s|_DESKTOP_SESSION_|LXDE|" /home/${LIVE_USER}/.dmrc - elif [[ "${iso_gui}" == 'mate' ]] + + elif [[ "${ISO_GUI}" == 'mate' ]] then sed -i "s|_DESKTOP_SESSION_|mate|" /home/${LIVE_USER}/.bash_profile sed -i "s|_DESKTOP_SESSION_|mate|" /home/${LIVE_USER}/.dmrc - else echo "invalid \$iso_gui for _DESKTOP_SESSION_ '${iso_gui}'" + + else echo "invalid \$ISO_GUI for _DESKTOP_SESSION_ '${ISO_GUI}'" exit 1 fi fi -- cgit v1.2.2