/mandos/release

To get this branch, use:
bzr branch http://bzr.recompile.se/loggerhead/mandos/release

« back to all changes in this revision

Viewing changes to debian/mandos.postinst

First version of a somewhat complete D-Bus server interface.  Also
change user/group name to "_mandos".

* debian/mandos.postinst: Rename old "mandos" user and group to
                          "_mandos"; create "_mandos" user and group
                          if none exist.
* debian/mandos-client.postinst: - '' -

* initramfs-tools-hook: Try "_mandos" before "mandos" as user and
                        group name.

* mandos (_datetime_to_dbus_struct): New; was previously local.
  (Client.started): Renamed to "last_started".  All users changed.
  (Client.started): New; boolean.
  (Client.dbus_object_path): New.
  (Client.check_command): Renamed to "checker_command".  All users
                          changed.
  (Client.__init__): Set and use "self.dbus_object_path".  Set
                     "self.started".
  (Client.start): Update "self.started".  Emit "self.PropertyChanged"
                  signals for both "started" and "last_started".
  (Client.stop): Update "self.started".  Emit "self.PropertyChanged"
                 signal for "started".
  (Client.checker_callback): Take additional "command" argument.  All
                             callers changed. Emit
                             "self.PropertyChanged" signal.
  (Client.bump_timeout): Emit "self.PropertyChanged" signal for
                         "last_checked_ok".
  (Client.start_checker): Emit "self.PropertyChanged" signal for
                          "checker_running".
  (Client.stop_checker): Emit "self.PropertyChanged" signal for
                         "checker_running".
  (Client.still_valid): Bug fix: use "getattr(self, started, False)"
                        instead of "self.started" in case this client
                        object is so new that the "started" attribute
                        has not been created yet.
  (Client.IntervalChanged, Client.CheckerIsRunning, Client.GetChecker,
  Client.GetCreated, Client.GetFingerprint, Client.GetHost,
  Client.GetInterval, Client.GetName, Client.GetStarted,
  Client.GetTimeout, Client.StateChanged, Client.TimeoutChanged):
  Removed; all callers changed.
  (Client.CheckerCompleted): Add "condition" and "command" arguments.
                             All callers changed.
  (Client.GetAllProperties, Client.PropertyChanged): New.
  (Client.StillValid): Renamed to "IsStillValid".
  (Client.StartChecker): Changed to its own function to avoid the
                         return value from "Client.start_checker()".
  (Client.Stop): Changed to its own function to avoid the return value
                 from "Client.stop()".
  (main): Try "_mandos" before "mandos" as user and group name.
          Removed inner function "remove_from_clients".  New inner
          class "MandosServer".

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
#!/bin/sh
 
1
#!/bin/bash -e
2
2
# This script can be called in the following ways:
3
3
#
4
4
# After the package was installed:
15
15
# If prerm fails during replacement due to conflict:
16
16
#       <postinst> abort-remove in-favour <new-package> <version>
17
17
 
18
 
set -e
 
18
. /usr/share/debconf/confmodule
19
19
 
20
20
case "$1" in
21
21
    configure)
22
22
        # Rename old "mandos" user and group
23
 
        if dpkg --compare-versions "$2" lt "1.0.3-1"; then
24
 
            case "`getent passwd mandos`" in
25
 
                *:Mandos\ password\ system,,,:/nonexistent:/bin/false)
26
 
                    usermod --login _mandos mandos
27
 
                    groupmod --new-name _mandos mandos
28
 
                    ;;
29
 
            esac
30
 
        fi
 
23
        case "$(getent passwd mandos)" in
 
24
            *:Mandos\ password\ system,,,:/nonexistent:/bin/false)
 
25
                usermod --login _mandos mandos
 
26
                groupmod --new-name _mandos mandos
 
27
                ;;
 
28
        esac
31
29
        # Create new user and group
32
30
        if ! getent passwd _mandos >/dev/null; then
33
31
            adduser --system --force-badname --quiet \
34
32
                --home /nonexistent --no-create-home --group \
35
33
                --disabled-password --gecos "Mandos password system" \
36
34
                _mandos
37
 
        elif dpkg --compare-versions "$2" eq 1.7.4-1 \
38
 
                || dpkg --compare-versions "$2" eq "1.7.4-1~bpo8+1"
39
 
        then
40
 
            start=no
41
 
            if ! [ -f /var/lib/mandos/clients.pickle ]; then
42
 
                invoke-rc.d mandos stop
43
 
                start=yes
44
 
            fi
45
 
            chown _mandos:_mandos /var/lib/mandos/clients.pickle \
46
 
                  2>/dev/null || :
47
 
            if [ "$start" = yes ]; then
48
 
                invoke-rc.d mandos start
49
 
            fi
50
35
        fi
51
 
        chown _mandos:_mandos /var/lib/mandos
52
36
        ;;
53
 
    
 
37
 
54
38
    abort-upgrade|abort-deconfigure|abort-remove)
55
39
        ;;
56
 
    
 
40
 
57
41
    *)
58
 
        echo "$0 called with unknown argument '$1'" 1>&2
 
42
        echo "$0 called with unknown argument \`$1'" 1>&2
59
43
        exit 1
60
44
        ;;
61
45
esac
62
46
 
63
 
# Avahi version 0.6.31-2 and older provides "avahi" (instead of
64
 
# "avahi-daemon") in its /etc/init.d script header.  To make
65
 
# insserv(8) happy, we edit our /etc/init.d script header to contain
66
 
# the correct string before the code added by dh_installinit calls
67
 
# update.rc-d, which calls insserv.
68
 
avahi_version="`dpkg-query --showformat='${Version}' --show avahi-daemon`"
69
 
if dpkg --compare-versions "$avahi_version" le 0.6.31-2; then
70
 
    sed --in-place --expression='/^### BEGIN INIT INFO$/,/^### END INIT INFO$/s/^\(# Required-\(Stop\|Start\):.*avahi\)-daemon\>/\1/g' /etc/init.d/mandos
71
 
fi
72
 
 
73
47
#DEBHELPER#
74
48
 
75
49
exit 0