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/APKBUILD | 18 ++++++++++ testing/upgrade-notify/upgrade-notify.trigger | 52 +++++++++++++++++++++++++++ 2 files changed, 70 insertions(+) create mode 100644 testing/upgrade-notify/APKBUILD create mode 100644 testing/upgrade-notify/upgrade-notify.trigger (limited to 'testing') diff --git a/testing/upgrade-notify/APKBUILD b/testing/upgrade-notify/APKBUILD new file mode 100644 index 0000000000..9174a17622 --- /dev/null +++ b/testing/upgrade-notify/APKBUILD @@ -0,0 +1,18 @@ +# Maintainer: Natanael Copa +pkgname="upgrade-notify" +pkgver=0.1 +license="GPL" +pkgdesc="Get notifications about what services need to restart after an upgrade" +url="http://git.alpinelinux.org/alpine/tree/testing/upgrade-notify" +arch=noarch +triggers="$pkgname.trigger=/etc/init.d:/boot" + +build() { + return 0 +} + +package() { + mkdir -p "$pkgdir" +} + + 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