431 lines
16 KiB
Bash
Executable File
431 lines
16 KiB
Bash
Executable File
#!/bin/bash
|
|
# postinst script for core-agent-linux
|
|
#
|
|
# see: dh_installdeb(1)
|
|
|
|
set -e
|
|
|
|
# The postint script may be called in the following ways:
|
|
# * <postinst> 'configure' <most-recently-configured-version>
|
|
# * <old-postinst> 'abort-upgrade' <new version>
|
|
# * <conflictor's-postinst> 'abort-remove' 'in-favour' <package>
|
|
# <new-version>
|
|
# * <postinst> 'abort-remove'
|
|
# * <deconfigured's-postinst> 'abort-deconfigure' 'in-favour'
|
|
# <failed-install-package> <version> 'removing'
|
|
# <conflicting-package> <version>
|
|
#
|
|
# For details, see http://www.debian.org/doc/debian-policy/ or
|
|
# https://www.debian.org/doc/debian-policy/ch-maintainerscripts.html or
|
|
# the debian-policy package
|
|
|
|
# Directory that modified desktop entry config files are stored in
|
|
XDG_CONFIG_QUBES="/usr/share/qubes/xdg"
|
|
|
|
# Install overriden services only when original exists
|
|
installOverridenServices() {
|
|
override_dir="${1}"
|
|
service="${2}"
|
|
retval=1
|
|
|
|
for unit in ${service}; do
|
|
unit="${unit%%.*}"
|
|
unit_name="$(basename ${unit})"
|
|
if [ -f ${unit}.service ]; then
|
|
echo "Installing override for ${unit}.service..."
|
|
cp ${override_dir}/${unit_name}.service /etc/systemd/system/
|
|
retval=0
|
|
fi
|
|
if [ -f ${unit}.socket -a -f ${override_dir}/${unit}.socket ]; then
|
|
echo "Installing override for ${unit}.socket..."
|
|
cp ${override_dir}/${unit_name}.socket /etc/systemd/system/
|
|
retval=0
|
|
fi
|
|
if [ -f ${unit}.path -a -f ${override_dir}/${unit}.path ]; then
|
|
echo "Installing override for ${unit}.path..."
|
|
cp ${override_dir}/${unit_name}.path /etc/systemd/system/
|
|
retval=0
|
|
fi
|
|
done
|
|
|
|
return ${retval}
|
|
}
|
|
|
|
reenableNetworkManager() {
|
|
# Disable original service to enable overriden one
|
|
echo "Disabling original service to enable overriden one..."
|
|
disableSystemdUnits ModemManager.service
|
|
disableSystemdUnits NetworkManager.service
|
|
|
|
# Disable D-BUS activation of NetworkManager - in AppVm it causes problems (eg PackageKit timeouts)
|
|
echo "Disable D-BUS activation of NetworkManager - in AppVm it causes problems (eg PackageKit timeouts)"
|
|
systemctl mask dbus-org.freedesktop.NetworkManager.service 2> /dev/null || echo "Could not disable D-BUS activation of NetworkManager"
|
|
|
|
echo "Re-enabling original service to enable overriden one..."
|
|
enableSystemdUnits ModemManager.service
|
|
enableSystemdUnits NetworkManager.service
|
|
|
|
# Fix for https://bugzilla.redhat.com/show_bug.cgi?id=974811
|
|
echo "Fix for https://bugzilla.redhat.com/show_bug.cgi?id=974811"
|
|
enableSystemdUnits NetworkManager-dispatcher.service
|
|
}
|
|
|
|
remove_ShowIn() {
|
|
if [ -e "${1}" ]; then
|
|
sed -i '/^\(Not\|Only\)ShowIn/d' "${1}"
|
|
fi
|
|
}
|
|
|
|
showIn() {
|
|
desktop_entry="${1}"
|
|
shown_in="${2}"
|
|
message="${shown_in:-"Shown in All;"}"
|
|
desktop_entry_qubes="${XDG_CONFIG_QUBES}/autostart/${desktop_entry##*/}"
|
|
|
|
# Make sure Qubes autostart directory exists
|
|
mkdir -p "${XDG_CONFIG_QUBES}/autostart"
|
|
|
|
# Desktop entry exists, so move to Qubes directory and modify it
|
|
if [ -e "${desktop_entry}" ]; then
|
|
echo "Desktop Entry Modification - ${message} ${desktop_entry##*/}..."
|
|
cp -pf "${desktop_entry}" "${desktop_entry_qubes}"
|
|
|
|
remove_ShowIn "${desktop_entry_qubes}"
|
|
sed -i '/^X-GNOME-Autostart-enabled.*[fF0]/d' "${desktop_entry_qubes}"
|
|
|
|
# Will only be '' if shown in all
|
|
if [ ! "${shown_in}x" == "x" ]; then
|
|
echo "${shown_in}" >> "${desktop_entry_qubes}" || true
|
|
fi
|
|
|
|
# Desktop entry must have been removed, so also remove from Qubes directory
|
|
else
|
|
echo "Desktop Entry Modification - Remove: ${desktop_entry##*/}..."
|
|
rm -f "${desktop_entry_qubes}"
|
|
fi
|
|
}
|
|
|
|
setArrayAsGlobal() {
|
|
local array="$1"
|
|
local export_as="$2"
|
|
local code=$(declare -p "$array")
|
|
local replaced="${code/$array/$export_as}"
|
|
eval ${replaced/declare -/declare -g}
|
|
}
|
|
|
|
systemdInfo() {
|
|
unit=${1}
|
|
return_global_var=${2}
|
|
|
|
declare -A INFO=()
|
|
while read line; do
|
|
INFO[${line%%=*}]="${line##*=}"
|
|
done < <(systemctl show ${unit} 2> /dev/null)
|
|
|
|
setArrayAsGlobal INFO $return_global_var
|
|
return ${#INFO[@]}
|
|
}
|
|
|
|
displayFailedStatus() {
|
|
action=${1}
|
|
unit=${2}
|
|
|
|
# Only display if there are results. In chroot environmnet there will be
|
|
# no results to 'systemctl show' command
|
|
systemdInfo ${unit} info || {
|
|
echo
|
|
echo "==================================================="
|
|
echo "FAILED: systemd ${action} ${unit}"
|
|
echo "==================================================="
|
|
echo " LoadState = ${info[LoadState]}"
|
|
echo " LoadError = ${info[LoadError]}"
|
|
echo " ActiveState = ${info[ActiveState]}"
|
|
echo " SubState = ${info[SubState]}"
|
|
echo "UnitFileState = ${info[UnitFileState]}"
|
|
echo
|
|
}
|
|
}
|
|
|
|
# Disable systemd units
|
|
disableSystemdUnits() {
|
|
for unit in $*; do
|
|
systemctl is-enabled ${unit} > /dev/null 2>&1 && {
|
|
echo "Disabling ${unit}..."
|
|
systemctl is-active ${unit} > /dev/null 2>&1 && {
|
|
systemctl stop ${unit} > /dev/null 2>&1 || displayFailedStatus stop ${unit}
|
|
}
|
|
if [ -f /lib/systemd/system/${unit} ]; then
|
|
if fgrep -q '[Install]' /lib/systemd/system/${unit}; then
|
|
systemctl disable ${unit} > /dev/null 2>&1 || displayFailedStatus disable ${unit}
|
|
else
|
|
echo "Masking service: ${unit}"
|
|
systemctl mask ${unit}
|
|
fi
|
|
else
|
|
systemctl disable ${unit} > /dev/null 2>&1 || displayFailedStatus disable ${unit}
|
|
fi
|
|
} || {
|
|
echo "It appears ${unit} is already disabled!"
|
|
#displayFailedStatus is-disabled ${unit}
|
|
}
|
|
done
|
|
}
|
|
|
|
# Enable systemd units
|
|
enableSystemdUnits() {
|
|
for unit in $*; do
|
|
systemctl is-enabled ${unit} > /dev/null 2>&1 && {
|
|
echo "It appears ${unit} is already enabled!"
|
|
#displayFailedStatus is-enabled ${unit}
|
|
} || {
|
|
echo "Enabling: ${unit}..."
|
|
systemctl enable ${unit} > /dev/null 2>&1 || {
|
|
echo "Could not enable: ${unit}"
|
|
displayFailedStatus enable ${unit}
|
|
}
|
|
}
|
|
done
|
|
}
|
|
|
|
# Manually trigger all triggers to automaticatly configure
|
|
triggerTriggers() {
|
|
path="$(readlink -m ${0})"
|
|
triggers="${path/postinst/triggers}"
|
|
|
|
awk '{sub(/[ \t]*#.*/,"")} NF' ${triggers} | while read line
|
|
do
|
|
/bin/bash -c "${0} triggered ${line##* }" || true
|
|
done
|
|
}
|
|
|
|
case "${1}" in
|
|
configure)
|
|
# disable some Upstart services
|
|
for init in plymouth-shutdown \
|
|
prefdm \
|
|
splash-manager \
|
|
start-ttys \
|
|
tty ; do
|
|
dpkg-divert --divert /etc/init/${init}.conf.qubes-disabled --package qubes-core-agent --rename --add /etc/init/${init}.conf
|
|
done
|
|
|
|
# Create NetworkManager configuration if we do not have it
|
|
if ! [ -e /etc/NetworkManager/NetworkManager.conf ]; then
|
|
echo '[main]' > /etc/NetworkManager/NetworkManager.conf
|
|
echo 'plugins = keyfile' >> /etc/NetworkManager/NetworkManager.conf
|
|
echo '[keyfile]' >> /etc/NetworkManager/NetworkManager.conf
|
|
fi
|
|
|
|
# Remove old firmware updates link
|
|
if [ -L /lib/firmware/updates ]; then
|
|
rm -f /lib/firmware/updates
|
|
fi
|
|
|
|
# ensure that hostname resolves to 127.0.1.1 resp. ::1 and that /etc/hosts is
|
|
# in the form expected by qubes-sysinit.sh
|
|
for ip in '127\.0\.1\.1' '::1'; do
|
|
if grep -q "^${ip}\(\s\|$\)" /etc/hosts; then
|
|
sed -i "/^${ip}\s/,+0s/\(\s`hostname`\)\+\(\s\|$\)/\2/g" /etc/hosts
|
|
sed -i "s/^${ip}\(\s\|$\).*$/\0 `hostname`/" /etc/hosts
|
|
else
|
|
echo "${ip//\\/} `hostname`" >> /etc/hosts
|
|
fi
|
|
done
|
|
# remove hostname from 127.0.0.1 line (in debian the hostname is by default
|
|
# resolved to 127.0.1.1)
|
|
sed -i "/^127\.0\.0\.1\s/,+0s/\(\s`hostname`\)\+\(\s\|$\)/\2/g" /etc/hosts
|
|
|
|
chown user:user /home_volatile/user
|
|
|
|
dpkg-divert --divert /etc/init/serial.conf.qubes-orig --package qubes-core-agent --rename --add /etc/init/serial.conf
|
|
|
|
# Enable Qubes systemd units
|
|
enableSystemdUnits \
|
|
qubes-sysinit.service \
|
|
qubes-misc-post.service \
|
|
qubes-netwatcher.service \
|
|
qubes-network.service \
|
|
qubes-firewall.service \
|
|
qubes-updates-proxy.service \
|
|
qubes-update-check.timer \
|
|
qubes-qrexec-agent.service
|
|
|
|
# Set default "runlevel"
|
|
systemctl set-default multi-user.target
|
|
|
|
# Process all triggers which will set defaults to wanted values
|
|
triggerTriggers
|
|
|
|
disableSystemdUnits \
|
|
alsa-store.service \
|
|
alsa-restore.service \
|
|
auditd.service \
|
|
avahi.service \
|
|
avahi-daemon.service \
|
|
backuppc.service \
|
|
cpuspeed.service \
|
|
crond.service \
|
|
fedora-autorelabel.service \
|
|
fedora-autorelabel-mark.service \
|
|
ipmi.service \
|
|
hwclock-load.service \
|
|
hwclock-save.service \
|
|
mdmonitor.service \
|
|
multipathd.service \
|
|
openct.service \
|
|
rpcbind.service \
|
|
mcelog.service \
|
|
fedora-storage-init.service \
|
|
fedora-storage-init-late.service \
|
|
plymouth-start.service \
|
|
plymouth-read-write.service \
|
|
plymouth-quit.service \
|
|
plymouth-quit-wait.service \
|
|
sshd.service \
|
|
tcsd.service \
|
|
sm-client.service \
|
|
sendmail.service \
|
|
mdmonitor-takeover.service \
|
|
rngd smartd.service \
|
|
upower.service \
|
|
irqbalance.service \
|
|
colord.service
|
|
|
|
rm -f /etc/systemd/system/getty.target.wants/getty@tty*.service
|
|
|
|
# Enable other systemd units
|
|
enableSystemdUnits \
|
|
rsyslog.service \
|
|
netfilter-persistent.service
|
|
|
|
# XXX: TODO: Needs to be implemented still
|
|
# These do not exist on debian; maybe a different package name
|
|
# ntpd.service \
|
|
;;
|
|
|
|
abort-upgrade|abort-remove|abort-deconfigure)
|
|
exit 0
|
|
;;
|
|
|
|
triggered)
|
|
for trigger in ${2}; do
|
|
case "${trigger}" in
|
|
|
|
# Update Qubes App Menus
|
|
/usr/share/applications)
|
|
echo "Updating Qubes App Menus..."
|
|
/usr/lib/qubes/qubes-trigger-sync-appmenus.sh || true
|
|
;;
|
|
|
|
# Install overriden services only when original exists
|
|
/lib/systemd/system/NetworkManager.service | \
|
|
/lib/systemd/system/NetworkManager-wait-online.service | \
|
|
/lib/systemd/system/ModemManager.service)
|
|
UNITDIR=/lib/systemd/system
|
|
OVERRIDEDIR=/usr/lib/qubes/init
|
|
installOverridenServices "${OVERRIDEDIR}" "${trigger}"
|
|
if [ $? -eq 0 ]; then
|
|
reenableNetworkManager
|
|
fi
|
|
;;
|
|
|
|
# Enable cups only when it is real Systemd service
|
|
/lib/systemd/system/cups.service)
|
|
[ -e /lib/systemd/system/cups.service ] && enableSystemdUnits cups.service
|
|
;;
|
|
|
|
# "Enable haveged service"
|
|
/lib/systemd/system/haveged.service)
|
|
[ -e /lib/systemd/system/haveged.service ] && enableSystemdUnits haveged.service
|
|
;;
|
|
|
|
# Install overridden serial.conf init script
|
|
/etc/init/serial.conf)
|
|
echo "Installing over-ridden serial.conf init script..."
|
|
if [ -e /etc/init/serial.conf ]; then
|
|
cp /usr/share/qubes/serial.conf /etc/init/serial.conf
|
|
fi
|
|
;;
|
|
|
|
# Disable SELinux"
|
|
/etc/selinux/config)
|
|
echo "Disabling SELinux..."
|
|
if [ -e /etc/selinux/config ]; then
|
|
sed -e s/^SELINUX=.*$/SELINUX=disabled/ </etc/selinux/config >/etc/selinux/config.processed
|
|
mv /etc/selinux/config.processed /etc/selinux/config
|
|
setenforce 0 2>/dev/null
|
|
fi
|
|
;;
|
|
|
|
# Desktop Entry Modification - Remove existing rules
|
|
/etc/xdg/autostart/gpk-update-icon.desktop | \
|
|
/etc/xdg/autostart/nm-applet.desktop | \
|
|
/etc/xdg/autostart/abrt-applet.desktop | \
|
|
/etc/xdg/autostart/notify-osd.desktop)
|
|
showIn "${trigger}"
|
|
;;
|
|
|
|
# Desktop Entry Modification - Not shown in Qubes
|
|
/etc/xdg/autostart/pulseaudio.desktop | \
|
|
/etc/xdg/autostart/deja-dup-monitor.desktop | \
|
|
/etc/xdg/autostart/imsettings-start.desktop | \
|
|
/etc/xdg/autostart/krb5-auth-dialog.desktop | \
|
|
/etc/xdg/autostart/pulseaudio.desktop | \
|
|
/etc/xdg/autostart/restorecond.desktop | \
|
|
/etc/xdg/autostart/sealertauto.desktop | \
|
|
/etc/xdg/autostart/gnome-power-manager.desktop | \
|
|
/etc/xdg/autostart/gnome-sound-applet.desktop | \
|
|
/etc/xdg/autostart/gnome-screensaver.desktop | \
|
|
/etc/xdg/autostart/orca-autostart.desktop)
|
|
showIn "${trigger}" 'NotShowIn=QUBES;'
|
|
;;
|
|
|
|
# Desktop Entry Modification - Not shown in in DisposableVM
|
|
/etc/xdg/autostart/gcm-apply.desktop)
|
|
showIn "${trigger}" 'NotShowIn=DisposableVM;'
|
|
;;
|
|
|
|
# Desktop Entry Modification - Only shown in AppVM
|
|
/etc/xdg/autostart/gnome-keyring-gpg.desktop | \
|
|
/etc/xdg/autostart/gnome-keyring-pkcs11.desktop | \
|
|
/etc/xdg/autostart/gnome-keyring-secrets.desktop | \
|
|
/etc/xdg/autostart/gnome-keyring-ssh.desktop | \
|
|
/etc/xdg/autostart/gnome-settings-daemon.desktop | \
|
|
/etc/xdg/autostart/user-dirs-update-gtk.desktop | \
|
|
/etc/xdg/autostart/gsettings-data-convert.desktop)
|
|
showIn "${trigger}" 'OnlyShowIn=GNOME;AppVM;'
|
|
;;
|
|
|
|
# Desktop Entry Modification - Only shown in Gnome & UpdateableVM
|
|
/etc/xdg/autostart/gpk-update-icon.desktop)
|
|
showIn "${trigger}" 'OnlyShowIn=GNOME;UpdateableVM;'
|
|
;;
|
|
|
|
# Desktop Entry Modification - Only shown in Gnome & Qubes
|
|
/etc/xdg/autostart/nm-applet.desktop)
|
|
showIn "${trigger}" 'OnlyShowIn=GNOME;QUBES;'
|
|
;;
|
|
|
|
*)
|
|
echo "postinst called with unknown trigger \`${2}'" >&2
|
|
exit 1
|
|
;;
|
|
esac
|
|
done
|
|
;;
|
|
|
|
*)
|
|
echo "postinst called with unknown argument \`${1}'" >&2
|
|
exit 1
|
|
;;
|
|
esac
|
|
|
|
# dh_installdeb will replace this with shell code automatically
|
|
# generated by other debhelper scripts.
|
|
|
|
#DEBHELPER#
|
|
|
|
exit 0
|
|
|
|
# vim: set ts=4 sw=4 sts=4 et :
|