From 25d8ef878f52ada1ed371ae6f9508a851a74b23c Mon Sep 17 00:00:00 2001 From: Natanael Copa Date: Wed, 22 May 2013 07:17:56 +0000 Subject: testing/upgrade-notify: new aport Get notifications about what services need to restart after an upgrade http://git.alpinelinux.org/alpine/tree/testing/upgrade-notify --- testing/upgrade-notify/upgrade-notify.trigger | 52 +++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100644 testing/upgrade-notify/upgrade-notify.trigger (limited to 'testing/upgrade-notify/upgrade-notify.trigger') diff --git a/testing/upgrade-notify/upgrade-notify.trigger b/testing/upgrade-notify/upgrade-notify.trigger new file mode 100644 index 0000000000..0c3cf462f8 --- /dev/null +++ b/testing/upgrade-notify/upgrade-notify.trigger @@ -0,0 +1,52 @@ +#!/bin/sh + +msg() { + local summary="$1" + shift + echo "" >&2 + echo " $summary" >&2 + local i + for i; do + echo " $i" >&2 + done + echo "" >&2 +} + +# compare the timestamp of "started" symlink with timestamp of /etc/init.d +# if the /etc/init.d/* script is newer than "started" symlink then +# service was upgraded after service was started +services=$(find /run/openrc/started -type l | xargs stat -c "%n %Y" \ + | while read file started; do + svc=${file##*/} + installed=$(stat -c "%Y" /etc/init.d/$svc) + if [ $installed -gt $started ]; then + echo $svc + fi +done) + +need_reboot=false +for i; do + case $i in + /boot) + need_reboot=true + esac +done + +notify=msg +if which notify-send > /dev/null; then + notify="notify-send" +fi + +if [ -n "$services" ]; then + $notify "The following services have been updated and need a restart:" \ + $services +fi + +case "$(rc --sys)" in + LXC|VSERVER) exit 0 ;; +esac + +if $need_reboot ; then + $notify "Kernel(s) were updated. You might need to reboot" +fi + -- cgit v1.2.3