/mandos/trunk

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

« back to all changes in this revision

Viewing changes to TODO

  • Committer: Teddy Hogeborn
  • Date: 2008-12-10 01:26:02 UTC
  • mfrom: (237.1.2 mandos)
  • Revision ID: teddy@fukt.bsnet.se-20081210012602-vhz3h75xkj24t340
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
 
* Use _attribute_((nonnull)) wherever possible.
4
 
 
5
 
* [[http://www.undeadly.org/cgi?action=article&sid=20110530221728][OpenBSD]]
6
 
 
7
 
* mandos-applet
8
 
 
9
3
* mandos-client
10
 
** TODO [#A] Document network hook functionality
11
 
** TODO [#B] Use capabilities instead of seteuid().
12
 
** TODO [#B] Use struct sockaddr_storage instead of a union
13
 
** TODO [#B] Use getaddrinfo(hints=AI_NUMERICHOST) instead of inet_pton()
14
 
** TODO [#B] Use getnameinfo(serv=NULL, NI_NUMERICHOST) instead of inet_ntop()
15
 
** TODO [#B] Prefer /run/tmp over /tmp, if it exists
16
 
 
17
 
* splashy
18
 
** TODO [#B] use scandir(3) instead of readdir(3)
19
 
 
20
 
* usplash (Deprecated)
21
 
** TODO [#A] Make it work again
22
 
** TODO [#B] use scandir(3) instead of readdir(3)
23
 
** TODO Use [[info:libc:Argz%20Functions][argz_extract]]
24
 
 
25
 
* askpass-fifo
26
 
** TODO [#B] Drop privileges after opening FIFO.
27
 
 
28
 
* password-prompt
29
 
** TODO [#B] lock stdin (with flock()?)
30
 
 
31
 
* plymouth
32
 
 
33
 
* TODO [#B] passdev
34
 
 
35
 
* plugin-runner
36
 
** TODO handle printing for errors for plugins
37
 
*** Hook up stderr of plugins, buffer them, and prepend mandos pluig [plugin name]
38
 
** TODO [#B] use scandir(3) instead of readdir(3)
39
 
** TODO [#C] use same file name rules as run-parts(8)
40
 
** kernel command line option for debug info
41
 
** TODO [#B] Use openat()
 
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
42
8
 
43
9
* mandos (server)
44
 
** TODO [#B] Log level                                                    :BUGS:
45
 
** TODO Persistent state                                                  :BUGS:
46
 
   /var/lib/mandos/*
47
 
*** TODO /etc/mandos/clients.d/*.conf
48
 
    Watch this directory and add/remove/update clients?
49
 
** TODO [#C] config for TXT record
50
 
** TODO Log level option
51
 
   syslogger.setLevel(logging.WARNING)
52
 
   + SetLogLevel D-Bus call
53
 
** TODO Implement --foreground                                            :BUGS:
 
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:
54
24
   [[info:standards:Option%20Table][Table of Long Options]]
55
25
** TODO Implement --socket
56
26
   [[info:standards:Option%20Table][Table of Long Options]]
57
 
** TODO Date+time on console log messages                                 :BUGS:
 
27
** TODO Date+time on console log messages       :bugs:
58
28
   Is this the default?
59
 
** TODO [#C] DBusServiceObjectUsingSuper
60
 
** TODO [#B] Global enable/disable flag
61
 
** TODO [#B] By-client countdown on secrets given
62
 
** TODO [#B] Support RFC 3339 time duration syntax
63
 
** More D-Bus methods
64
 
*** NeedsPassword(50) - Timeout, default disapprove
65
 
    + SetPass(u"gazonk", True) -> Approval, persistent
66
 
    + Approve(False) -> Close client connection immediately
67
 
** TODO [#C] python-parsedatetime
68
 
** TODO [#C] systemd/launchd
69
 
   http://0pointer.de/blog/projects/systemd.html
70
 
   http://wiki.debian.org/systemd
71
 
** TODO Separate logging logic to own object
72
 
** TODO make clients to a dict!
73
 
** TODO [#A] Limit approval_delay to max gnutls/tls timeout value
74
 
** TODO [#B] break the wait on approval_delay if connection dies
75
 
** TODO Generate Client.runtime_expansions from client options + extra
76
 
** TODO Allow %%(checker)s as a runtime expansion
77
 
** TODO Use python-tlslite?
78
 
 
79
 
* mandos.xml
80
 
** Add mandos contact info in manual pages
81
 
 
82
 
* mandos-ctl
83
 
*** Handle "no D-Bus server" and/or "no Mandos server found" better
84
 
*** [#B] --dump option
85
 
** TODO Support RFC 3339 time duration syntax
86
 
** TODO Send milliseconds if bare integer is passed as time duration
87
 
 
88
 
* TODO mandos-dispatch
89
 
  Listens for specified D-Bus signals and spawns shell commands with
90
 
  arguments.
91
 
 
92
 
* mandos-monitor
93
 
** TODO help should be toggleable
94
 
** Urwid client data displayer
95
 
   Better view of client data in the listing
96
 
*** Properties popup
97
 
** Nicer crashes. Stack traces Messes up shell.
98
 
*** Print a nice "We are sorry" message, save stack trace to log.
99
 
** Show timeout countdown for approval
 
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
100
39
 
101
40
* mandos-keygen
102
41
** TODO "--secfile" option
104
43
** TODO [#B] "--test" option
105
44
   For testing decryption before rebooting.
106
45
 
107
 
* Makefile
108
 
** TODO [#C] Implement DEB_BUILD_OPTIONS
109
 
   http://www.debian.org/doc/debian-policy/ch-source.html#s-debianrules-options
110
 
 
111
 
* Package
 
46
* [#A] Package
112
47
** /usr/share/initramfs-tools/hooks/mandos
113
 
*** TODO [#C] use same file name rules as run-parts(8)
114
 
*** TODO [#C] Do not install in initrd.img if configured not to.
115
 
    Use "/etc/initramfs-tools/hooksconf.d/mandos"?
116
 
** TODO [#C] /etc/bash_completion.d/mandos
 
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
117
52
   From XML sources directly?
118
53
 
119
 
* Side Stuff
120
 
** TODO Locate which package moves the other bin/sh when busybox is deactivated
121
 
** TODO contact owner of package, and ask them to have that shell static in position regardless of busybox
122
 
 
123
54
 
124
55
#+STARTUP: showall