/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:
17
17
 
18
18
. /usr/share/debconf/confmodule
19
19
 
20
 
set -e
21
 
 
22
20
case "$1" in
23
21
    configure)
24
22
        # Rename old "mandos" user and group
25
 
        if dpkg --compare-versions "$2" lt "1.0.3-1"; then
26
 
            case "`getent passwd mandos`" in
27
 
                *:Mandos\ password\ system,,,:/nonexistent:/bin/false)
28
 
                    usermod --login _mandos mandos
29
 
                    groupmod --new-name _mandos mandos
30
 
                    ;;
31
 
            esac
32
 
        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
33
29
        # Create new user and group
34
30
        if ! getent passwd _mandos >/dev/null; then
35
31
            adduser --system --force-badname --quiet \
36
32
                --home /nonexistent --no-create-home --group \
37
33
                --disabled-password --gecos "Mandos password system" \
38
34
                _mandos
39
 
        elif dpkg --compare-versions "$2" eq 1.7.4-1 \
40
 
                || dpkg --compare-versions "$2" eq "1.7.4-1~bpo8+1"
41
 
        then
42
 
            start=no
43
 
            if ! [ -f /var/lib/mandos/clients.pickle ]; then
44
 
                invoke-rc.d mandos stop
45
 
                start=yes
46
 
            fi
47
 
            chown _mandos:_mandos /var/lib/mandos/clients.pickle \
48
 
                  2>/dev/null || :
49
 
            if [ "$start" = yes ]; then
50
 
                invoke-rc.d mandos start
51
 
            fi
52
 
        fi
53
 
        if ! dpkg-statoverride --list "/var/lib/mandos" >/dev/null \
54
 
             2>&1; then
55
 
            chown _mandos:_mandos /var/lib/mandos
56
 
            chmod u=rwx,go= /var/lib/mandos
57
 
        fi
 
35
        fi
 
36
        ;;
58
37
 
59
 
        gnutls_version=$(dpkg-query --showformat='${Version}' \
60
 
                                    --show libgnutls30 \
61
 
                                    2>/dev/null || :)
62
 
        if [ -n "$gnutls_version" ] \
63
 
               && dpkg --compare-versions $gnutls_version ge 3.6.6; then
64
 
            db_version 2.0
65
 
            db_input critical mandos/key_id || true
66
 
            db_go
67
 
            db_stop
68
 
        fi
69
 
        ;;
70
 
    
71
38
    abort-upgrade|abort-deconfigure|abort-remove)
72
39
        ;;
73
 
    
 
40
 
74
41
    *)
75
 
        echo "$0 called with unknown argument '$1'" 1>&2
 
42
        echo "$0 called with unknown argument \`$1'" 1>&2
76
43
        exit 1
77
44
        ;;
78
45
esac
79
46
 
80
 
# Avahi version 0.6.31-2 and older provides "avahi" (instead of
81
 
# "avahi-daemon") in its /etc/init.d script header.  To make
82
 
# insserv(8) happy, we edit our /etc/init.d script header to contain
83
 
# the correct string before the code added by dh_installinit calls
84
 
# update.rc-d, which calls insserv.
85
 
avahi_version="`dpkg-query --showformat='${Version}' --show avahi-daemon`"
86
 
if dpkg --compare-versions "$avahi_version" le 0.6.31-2; then
87
 
    sed --in-place --expression='/^### BEGIN INIT INFO$/,/^### END INIT INFO$/s/^\(# Required-\(Stop\|Start\):.*avahi\)-daemon\>/\1/g' /etc/init.d/mandos
88
 
fi
89
 
 
90
47
#DEBHELPER#
91
48
 
92
49
exit 0