diff options
author | Nicolas Iooss | 2014-06-29 16:21:22 +0200 |
---|---|---|
committer | Nicolas Iooss | 2015-06-27 11:44:56 +0800 |
commit | 9e55f3aa8f85fad087e903775febfc498a5e14d0 (patch) | |
tree | 61d94d5390d641b21f143a5e820b45854e5d1604 /systemd.install | |
parent | 0e14689503e3bebaa6ee2e7b7a6bc8264bd5c291 (diff) | |
download | aur-9e55f3aa8f85fad087e903775febfc498a5e14d0.tar.gz |
systemd-selinux 214-1 update
Diffstat (limited to 'systemd.install')
-rw-r--r-- | systemd.install | 120 |
1 files changed, 75 insertions, 45 deletions
diff --git a/systemd.install b/systemd.install index ecd9afd5b64f..062e9a97d20d 100644 --- a/systemd.install +++ b/systemd.install @@ -1,7 +1,7 @@ -#!/bin/sh +#!/bin/bash sd_booted() { - [ -d /run/systemd/system ] + [[ -d run/systemd/system ]] } add_privs() { @@ -13,13 +13,13 @@ add_privs() { add_journal_acls() { # ignore errors, since the filesystem might not support ACLs - setfacl -Rnm g:wheel:rx,d:g:wheel:rx,g:adm:rx,d:g:adm:rx /var/log/journal/ 2>/dev/null + setfacl -Rnm g:wheel:rx,d:g:wheel:rx,g:adm:rx,d:g:adm:rx var/log/journal/ 2>/dev/null : } maybe_reexec() { # don't reexec on 209-1 upgrade due to large infrastructural changes. - if [ "$(vercmp 209-1 "$2")" -eq 1 ]; then + if [[ $(vercmp 209-1 "$2") -eq 1 ]]; then echo ':: systemd has not been reexecuted. It is recommended that you' echo ' reboot at your earliest convenience.' return @@ -32,32 +32,47 @@ maybe_reexec() { _dir_empty() { set -- "$1"/* - [ ! -e "$1" ] && [ ! -L "$1" ] + [[ ! -e $1 && ! -L $1 ]] } post_common() { systemd-machine-id-setup - add_privs usr/bin/systemd-detect-virt 'cap_dac_override,cap_sys_ptrace+ep' - udevadm hwdb --update journalctl --update-catalog } -_208_changes() { - chown root:systemd-journal var/log/journal - chmod 2755 var/log/journal +_204_1_changes() { + printf '==> The /bin/systemd symlink has been removed. Any references in your\n' + printf ' bootloader (or elsewhere) must be updated to /usr/lib/systemd/systemd.\n' +} - if [ -e var/lib/backlight ] && [ ! -e var/lib/systemd/backlight ]; then +_205_1_changes() { + printf '==> systemd 205 restructures the cgroup hierarchy and changes internal\n' + printf ' protocols. You should reboot at your earliest convenience.\n' +} + +_206_1_changes() { + printf '==> The "timestamp" hook for mkinitcpio no longer exists. If you used\n' + printf ' this hook, you must remove it from /etc/mkinitcpio.conf. A "systemd"\n' + printf ' hook has been added which provides this functionality, and more.\n' +} + +_208_1_changes() { + if [[ -e var/lib/backlight && ! -e var/lib/systemd/backlight ]]; then mv -T var/lib/backlight var/lib/systemd/backlight fi - if [ -e var/lib/random-seed ] && [ ! -e var/lib/systemd/random-seed ]; then + if [[ -e var/lib/random-seed && ! -e var/lib/systemd/random-seed ]]; then mv -T var/lib/random-seed var/lib/systemd/random-seed fi } -_209_changes() { +_208_8_changes() { + add_journal_acls +} + +_209_1_changes() { # attempt to preserve existing behavior local old_rule=etc/udev/rules.d/80-net-name-slot.rules @@ -81,7 +96,7 @@ _209_changes() { fi } -_210_changes() { +_210_1_changes() { if sd_booted; then # If /etc/systemd/network is non-empty, then this is a 209 user who used # networkd. Re-enable it for them. @@ -91,6 +106,37 @@ _210_changes() { fi } +_213_4_changes() { + if sd_booted; then + # if /etc/resolv.conf is a symlink, just assume that it was being managed + # by systemd-networkd, and re-enable systemd-resolved. + if [[ -L etc/resolv.conf ]]; then + systemctl enable systemd-resolved + fi + fi +} + +_214_2_changes() { + # /run/systemd/network/resolv.conf -> /run/systemd/resolve/resolv.conf + if [[ etc/resolv.conf -ef run/systemd/network/resolv.conf ]]; then + ln -sf /run/systemd/resolve/resolv.conf /etc/resolv.conf + + if sd_booted; then + if [[ ! -d run/systemd/resolve ]]; then + mkdir run/systemd/resolve + fi + + if [[ -f run/systemd/network/resolv.conf ]]; then + mv run/systemd/{network,resolve}/resolv.conf + fi + fi + fi + + echo ':: coredumps are no longer sent to the journal by default. To re-enable:' + echo ' echo >/etc/sysctl.d/50-coredump.conf \' + echo ' "kernel.core_pattern=|/usr/lib/systemd/systemd-coredump %p %u %g %s %t %e"' +} + post_install() { post_common "$@" @@ -108,37 +154,21 @@ post_upgrade() { maybe_reexec "$@" - if [ "$(vercmp 204-1 "$2")" -eq 1 ]; then - printf '==> The /bin/systemd symlink has been removed. Any references in your\n' - printf ' bootloader (or elsewhere) must be updated to /usr/lib/systemd/systemd.\n' - fi - - if [ "$(vercmp 205-1 "$2")" -eq 1 ]; then - printf '==> systemd 205 restructures the cgroup hierarchy and changes internal\n' - printf ' protocols. You should reboot at your earliest convenience.\n' - fi - - if [ "$(vercmp 206-1 "$2")" -eq 1 ]; then - printf '==> The "timestamp" hook for mkinitcpio no longer exists. If you used\n' - printf ' this hook, you must remove it from /etc/mkinitcpio.conf. A "systemd"\n' - printf ' hook has been added which provides this functionality, and more.\n' - fi - - if [ "$(vercmp 208-1 "$2")" -eq 1 ]; then - _208_changes - fi - - if [ "$(vercmp 208-8 "$2")" -eq 1 ]; then - add_journal_acls - fi - - if [ "$(vercmp 209-1 "$2")" -eq 1 ]; then - _209_changes - fi - - if [ "$(vercmp 210-1 "$2")" -eq 1 ]; then - _210_changes - fi + local v upgrades=(204-1 + 205-1 + 206-1 + 208-1 + 208-8 + 209-1 + 210-1 + 213-4 + 214-2) + + for v in "${upgrades[@]}"; do + if [[ $(vercmp "$v" "$2") -eq 1 ]]; then + "_${v//-/_}_changes" + fi + done } # vim:set ts=2 sw=2 et: |