/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 TODO

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
1
-*- org -*-
2
2
 
3
 
* Testing
4
 
** python-nemu
5
 
 
6
 
* mandos-applet
7
 
 
8
3
* mandos-client
9
 
** TODO A --server option which only adds to the server list.
10
 
   (Unlike --connect, which implicitly disables zeroconf.)
11
 
** TODO [#B] Use capabilities instead of seteuid().
12
 
   https://forums.grsecurity.net/viewtopic.php?f=7&t=2522
13
 
** TODO [#B] Use getaddrinfo(hints=AI_NUMERICHOST) instead of inet_pton()
14
 
** TODO [#C] Make start_mandos_communication() take "struct server".
15
 
** TODO [#C] --interfaces=regex,eth*,noregex (bridge-utils-interfaces(5))
16
 
** TODO [#A] Detect partial writes to stdout and exit with EX_TEMPFAIL
17
 
 
18
 
* splashy
19
 
** TODO [#B] use scandir(3) instead of readdir(3)
20
 
** TODO [#A] Detect partial writes to stdout and exit with EX_TEMPFAIL
21
 
 
22
 
* usplash (Deprecated)
23
 
** TODO [#B] Make it work again
24
 
** TODO [#B] use scandir(3) instead of readdir(3)
25
 
** TODO [#A] Detect partial writes to stdout and exit with EX_TEMPFAIL
26
 
 
27
 
* askpass-fifo
28
 
** TODO [#A] Detect partial writes to stdout and exit with EX_TEMPFAIL
29
 
 
30
 
* password-prompt
31
 
** TODO [#B] lock stdin (with flock()?)
32
 
** TODO [#A] Detect partial writes to stdout and exit with EX_TEMPFAIL
33
 
 
34
 
* plymouth
35
 
** TODO [#A] Detect partial writes to stdout and exit with EX_TEMPFAIL
36
 
 
37
 
* TODO [#B] passdev
38
 
 
39
 
* plugin-runner
40
 
** TODO handle printing for errors for plugins
41
 
*** Hook up stderr of plugins, buffer them, and prepend "Mandos Plugin [plugin name]"
42
 
** TODO [#C] use same file name rules as run-parts(8)
43
 
** kernel command line option for debug info
44
 
** TODO [#A] Restart plugins which exit with EX_TEMPFAIL
 
4
** TODO [#B] Temporarily lower kernel log level
 
5
   for less printouts during sucessfull boot.
 
6
   klogctl(6, NULL, 0); klogctl(7, NULL, 0);
 
7
** TODO [#C] IPv4 support
45
8
 
46
9
* mandos (server)
47
 
** TODO [#B] --notify-command
48
 
   This would allow the mandos.service to use
49
 
   --notify-command="systemd-notify --pid --ready"
50
 
** TODO [#B] python-systemd
51
 
*** import systemd.daemon; systemd.daemon.notify()
52
 
** TODO [#B] Log level                                                    :BUGS:
53
 
*** TODO /etc/mandos/clients.d/*.conf
54
 
    Watch this directory and add/remove/update clients?
55
 
** TODO [#C] config for TXT record
56
 
** TODO Log level dbus option
57
 
   SetLogLevel D-Bus call
58
 
** TODO [#C] DBusServiceObjectUsingSuper
59
 
** TODO [#B] Global enable/disable flag
60
 
** TODO [#B] By-client countdown on number of secrets given
61
 
** D-Bus Client method NeedsPassword(50) - Timeout, default disapprove
62
 
    + SetPass(u"gazonk", True) -> Approval, persistent
63
 
    + Approve(False) -> Close client connection immediately
64
 
** TODO [#C] python-parsedatetime
65
 
** TODO Separate logging logic to own object
66
 
** TODO [#B] Limit approval_delay to max gnutls/tls timeout value
67
 
** TODO [#B] break the wait on approval_delay if connection dies
68
 
** TODO Generate Client.runtime_expansions from client options + extra
69
 
** TODO Allow %%(checker)s as a runtime expansion
70
 
** TODO D-Bus AddClient() method on server object
71
 
** TODO Use org.freedesktop.DBus.Method.NoReply annotation on async methods. :2:
72
 
** TODO Save state periodically to recover better from hard shutdowns
73
 
** TODO CheckerCompleted method, deprecate CheckedOK
74
 
** TODO Secret Service API?
75
 
   https://standards.freedesktop.org/secret-service/
76
 
** TODO Remove D-Bus interfaces with old domain name                      :2:
77
 
** TODO Remove old string_to_delta format                                 :2:
78
 
** TODO http://0pointer.de/blog/projects/stateless.html
79
 
*** File in /usr/lib/sysusers.d to create user+group "_mandos"
80
 
** TODO Error handling on error parsing config files
81
 
** TODO init.d script error handling
82
 
** TODO D-Bus server properties; address, port, interface, etc.           :2:
83
 
** Python 3                                                               :2:
84
 
*** TODO [#C] In Python 3.3, use shlex.quote() instead of re.escape()
85
 
 
86
 
* mandos-ctl
87
 
*** Handle "no D-Bus server" and/or "no Mandos server found" better
88
 
** TODO Remove old string_to_delta format                                 :2:
89
 
 
90
 
* TODO mandos-dispatch
91
 
  Listens for specified D-Bus signals and spawns shell commands with
92
 
  arguments.
93
 
 
94
 
* mandos-monitor
95
 
** TODO --servicename                                                  :BUGS:
96
 
** TODO help should be toggleable
97
 
** Urwid client data displayer
98
 
   Better view of client data in the listing
99
 
*** Properties popup
100
 
** Print a nice "We are sorry" message, save stack trace to log.
 
10
** TODO [#B] Log level                          :bugs:
 
11
** TODO /etc/mandos/clients.d/*.conf
 
12
   Watch this directory and add/remove/update clients?
 
13
** TODO config for TXT record
 
14
** TODO [#B] Run-time communication with server :bugs:
 
15
   Probably using D-Bus
 
16
   See also [[*Mandos-tools]]
 
17
*** Client class
 
18
*** Main server
 
19
    + SetLogLevel
 
20
      syslogger.setLevel(logging.WARNING)
 
21
    + Quit
 
22
    + [[http://log.ometer.com/2007-05.html][Best D-Bus practices]]
 
23
** TODO Implement --foreground                  :bugs:
 
24
   [[info:standards:Option%20Table][Table of Long Options]]
 
25
** TODO Implement --socket
 
26
   [[info:standards:Option%20Table][Table of Long Options]]
 
27
** TODO Date+time on console log messages       :bugs:
 
28
   Is this the default?
 
29
** TODO delete hook when clients fall out by timeout
 
30
   This will not be strictly necessary when the D-Bus interface is
 
31
   implemented.
 
32
 
 
33
* Mandos-tools/utilities
 
34
  All of this probably using D-Bus
 
35
** TODO List clients
 
36
** TODO Disable client
 
37
** TODO Enable client
 
38
** TODO Reset timer
101
39
 
102
40
* mandos-keygen
103
41
** TODO "--secfile" option
105
43
** TODO [#B] "--test" option
106
44
   For testing decryption before rebooting.
107
45
 
108
 
* Package
 
46
* [#A] Package
109
47
** /usr/share/initramfs-tools/hooks/mandos
110
 
*** TODO [#C] use same file name rules as run-parts(8)
111
 
*** TODO [#C] Do not install in initrd.img if configured not to.
112
 
    Use "/etc/initramfs-tools/hooksconf.d/mandos"?
113
 
** TODO [#C] $(pkg-config --variable=completionsdir bash-completion)
 
48
*** TODO Do not install in initrd.img if configured not to.
 
49
    Use "/etc/initramfs-tools/conf.d/mandos"?  Definitely a debconf
 
50
    question.
 
51
** TODO /etc/bash_completion.d/mandos
114
52
   From XML sources directly?
115
53
 
116
 
* Side Stuff
117
 
** TODO Locate which package moves the other bin/sh when busybox is deactivated
118
 
** TODO contact owner of package, and ask them to have that shell static in position regardless of busybox
119
 
 
120
 
* [[http://www.undeadly.org/cgi?action=article&sid=20110530221728][OpenBSD]]
121
 
 
122
 
* TODO Use raw public keys (RFC 7250) for TLS communications              :2:
123
 
** Support for this is planned for GnuTLS version 3.6
124
 
   https://gitlab.com/gnutls/gnutls/issues/26
125
 
** Rationale
126
 
*** The client key is used both for communication and encryption
127
 
    Using raw keys in GnuTLS instead uses separate keys for
128
 
    communication and password decryption.
129
 
*** GnuTLS 3.5.9 has deprecated the OpenPGP functions
130
 
    The functions are still available, but deprecated:
131
 
    https://gitlab.com/gnutls/gnutls/issues/102
132
 
 
133
54
 
134
55
#+STARTUP: showall