/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 initramfs-tools-script

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 -e
 
2
 
3
# This script will run in the initrd environment at boot and edit
 
4
# /conf/conf.d/cryptroot to set /lib/mandos/plugin-runner as keyscript
 
5
# when no other keyscript is set, before cryptsetup.
 
6
 
7
 
 
8
# This script should be installed as
 
9
# "/usr/share/initramfs-tools/scripts/local-top/mandos" which will
 
10
# eventually be "/scripts/local-top/mandos" in the initrd.img file.
 
11
 
 
12
# No initramfs pre-requirements; we must instead run BEFORE cryptroot.
 
13
# This is not a problem, since cryptroot forces itself to run LAST.
 
14
PREREQ=""
 
15
prereqs()
 
16
{
 
17
     echo "$PREREQ"
 
18
}
 
19
 
 
20
case $1 in
 
21
prereqs)
 
22
     prereqs
 
23
     exit 0
 
24
     ;;
 
25
esac
 
26
 
 
27
chmod a=rwxt /tmp
 
28
 
 
29
test -w /conf/conf.d/cryptroot
 
30
 
 
31
# Do not replace cryptroot file unless we need to.
 
32
replace_cryptroot=no
 
33
 
 
34
# Our keyscript
 
35
mandos=/lib/mandos/plugin-runner
 
36
 
 
37
# parse /conf/conf.d/cryptroot.  Format:
 
38
# target=sda2_crypt,source=/dev/sda2,key=none,keyscript=/foo/bar/baz
 
39
exec 3>/conf/conf.d/cryptroot.mandos
 
40
while read options; do
 
41
    newopts=""
 
42
    # Split option line on commas
 
43
    old_ifs="$IFS"
 
44
    IFS="$IFS,"
 
45
    for opt in $options; do
 
46
        # Find the keyscript option, if any
 
47
        case "$opt" in
 
48
            keyscript=*)
 
49
                keyscript="${opt#keyscript=}"
 
50
                newopts="$newopts,$opt"
 
51
                ;;
 
52
            "") : ;;
 
53
            *)
 
54
                newopts="$newopts,$opt"
 
55
                ;;
 
56
        esac
 
57
    done
 
58
    IFS="$old_ifs"
 
59
    unset old_ifs
 
60
    # If there was no keyscript option, add one.
 
61
    if [ -z "$keyscript" ]; then
 
62
        replace_cryptroot=yes
 
63
        newopts="$newopts,keyscript=$mandos"
 
64
    fi
 
65
    newopts="${newopts#,}"
 
66
    echo "$newopts" >&3
 
67
done < /conf/conf.d/cryptroot
 
68
exec 3>&-
 
69
 
 
70
# If we need to, replace the old cryptroot file with the new file.
 
71
if [ "$replace_cryptroot" = yes ]; then
 
72
    mv /conf/conf.d/cryptroot /conf/conf.d/cryptroot.mandos-old
 
73
    mv /conf/conf.d/cryptroot.mandos /conf/conf.d/cryptroot
 
74
else
 
75
    rm /conf/conf.d/cryptroot.mandos
 
76
fi