X-Git-Url: http://ftp.carnet.hr/carnet-debian/scm?a=blobdiff_plain;f=src%2Ffunctions.sh;h=b0ebdb34017cc2c8b029639df1e4e8a0f4dc113d;hb=b1e2c4801db1c37d493a39b6df230c3c6cf3601f;hp=1d83c80be1a0348098072d24ce40d3438d432e43;hpb=ef77c3319e1d5234b7e0a4974c8401bbf8039ec9;p=carnet-upgrade.git diff --git a/src/functions.sh b/src/functions.sh index 1d83c80..b0ebdb3 100644 --- a/src/functions.sh +++ b/src/functions.sh @@ -231,8 +231,13 @@ run_actions() { [ "$check" != "true" ] && checkmsg="if '$check'" if eval $check; then log "$(printf 'action %02d' $lineno) starting: '${action}' $checkmsg " - eval $action - log "$(printf 'action %02d' $lineno) finished: '${action}' $checkmsg" + if ! eval $action; then + log "$(printf 'action %02d' $lineno) failed: '${action}' $checkmsg " + display_action_failure "$action" + exit 1 + else + log "$(printf 'action %02d' $lineno) finished: '${action}' $checkmsg" + fi else log "$(printf 'action %02d' $lineno) skipping: '${action}' $checkmsg" fi @@ -242,6 +247,24 @@ run_actions() { log "-----" } +# report action failure +display_action_failure () { + local action=$1 + + notice " +Doslo je do greske prilikom izvrsavanja akcije '$action'. Detalje problema moguce je vidjeti u log datotekama: + + /var/log/carnet-upgrade.log + /var/log/carnet-upgrade.typescript + +Da bi dovrsili zapocete operacije nad paketima pokrenite: + + # dpkg --configure -a + # apt-get -f install + +Nakon toga ponovno pozovite carnet-upgrade skriptu." +} + # funkcija vraca popis paketa koje treba upgradeati what_upgrade () { local IFSOLD name version package @@ -644,10 +667,11 @@ upgrade_amavis () { fi # move old config aside - conf=/etc/amavis/amavisd.conf - if [ -e $conf -a ! -e $conf.$backup_ext ]; then - mv -v $conf $conf.$backup_ext - fi + for conf in /etc/amavisd.conf /etc/amavis/amavisd.conf; do + if [ -e $conf -a ! -e $conf.$backup_ext ]; then + mv -v $conf $conf.$backup_ext + fi + done # install new packages pkgadd amavisd-cn amavisd-new