/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-07-29 03:35:39 UTC
  • Revision ID: teddy@fukt.bsnet.se-20080729033539-08zecoj3jwlkpjhw
* server.conf: New file.

* mandos-clients.conf: Renamed to clients.conf.

* Makefile (FORTIFY): New.
  (CFLAGS): Include $(FORTIFY).

* plugins.d/mandosclient.c (main): New "if_index" variable.  Bug fix:
                                   check if interface exists.  New
                                   "--connect" option.

* server.py (serviceInterface): Removed; replaced by
                                "AvahiService.interface".  All users
                                changed.
  (AvahiError, AvahiServiceError, AvahiGroupError): New exception
                                                    classes.
  (AvahiService): New class.
  (serviceName): Removed; replaced by "AvahiService.name".  All users
                 changed.
  (serviceType): Removed; replaced by "AvahiService.type".  All users
                 changed.
  (servicePort): Removed; replaced by "AvahiService.port".  All users
                 changed.
  (serviceTXT): Removed; replaced by "AvahiService.TXT".  All users
                changed.
  (domain): Removed; replaced by "AvahiService.domain".  All users
            changed.
  (host): Removed; replaced by "AvahiService.host".  All users
          changed.
  (rename_count): Removed; replaced by "AvahiService.rename_count" and
                 "AvahiService.max_renames".  All users changed.
  (Client.__init__): If no secret or secfile, raise TypeError instead
                     of RuntimeError.
  (Client.last_seen): Renamed to "Client.last_checked_ok".  All users
                      changed.
  (Client.stop, Client.stop_checker): Use "getattr" with default value
                                      instead of "hasattr".
  (Client.still_valid): Removed "now" argument.
  (Client.handle): Separate the "no client found" and "client invalid"
                   cases for clearer code.
  (IPv6_TCPServer.__init__): "options" argument replaced by
                             "settings".  All callers changed.
  (IPv6_TCPServer.options): Replaced by "IPv6_TCPServer.settings".
                            All users changed.
  (IPv6_TCPServer.server_bind): Use getattr instead of hasattr.
  (add_service): Removed; replaced by "AvahiService.add".  All callers
                 changed.
  (remove_service): Removed; replaced by "AvahiService.remove".  All
                    callers changed.
  (entry_group_state_changed): On entry group collision, call the new
                               AvahiService.rename method.  Raise
                               AvahiGroupError on group error.
  (if_nametoindex): Use ctypes.utils.find_library to locate the C
                    library.  Cache the result.  Loop on EINTR.
  (daemon): Use os.path.devnull to locate "/dev/null".
  (killme): Removed.  All callers changed to do "sys.exit()" instead,
            except where stated otherwise.
  (main): Removed "exitstatus".  Removed all default values from all
          non-bool options.  New option "--configdir".  New variables
          "server_defaults" and "server_settings", read from
          "%(configdir)s/server.conf".  Let any supplied command line
          options override server settings.   Variable "defaults"
          renamed to "client_defaults", which is read from
          "clients.conf" instead of "mandos-clients.conf".  New global
          AvahiService object "service" replaces old global variables.
          Catch AvahiError and exit with error if caught.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
-*- org -*-
2
 
 
3
 
* mandos-client
4
 
** TODO [#B] use scandir(3) instead of readdir(3)
5
 
** TODO [#B] Prefix all debug output with argv[0]
6
 
** TODO [#B] Retry a server which has a non-definite reply:
7
 
*** A closed connection during the TLS handshake
8
 
*** A TCP timeout
9
 
** TODO [#B] Use capabilities instead of seteuid().
10
 
 
11
 
* splashy
12
 
** TODO [#B] use scandir(3) instead of readdir(3)
13
 
** TODO [#B] Prefix all debug output with "Mandos plugin " + argv[0]
14
 
 
15
 
* usplash
16
 
** TODO [#B] use scandir(3) instead of readdir(3)
17
 
** TODO [#B] Prefix all debug output with "Mandos plugin " + argv[0]
18
 
 
19
 
* askpass-fifo
20
 
** TODO [#B] Prefix all debug output with "Mandos plugin " + argv[0]
21
 
** TODO [#B] Drop privileges after opening FIFO.
22
 
 
23
 
* password-prompt
24
 
** TODO [#B] Prefix all debug output with "Mandos plugin " + argv[0]
25
 
 
26
 
* plugin-runner
27
 
** TODO [#B] use scandir(3) instead of readdir(3)
28
 
** TODO [#C] use same file name rules as run-parts(8)
29
 
 
30
 
* mandos (server)
31
 
** TODO [#B] Log level                          :BUGS:
32
 
** TODO /etc/mandos/clients.d/*.conf
33
 
   Watch this directory and add/remove/update clients?
34
 
** TODO config for TXT record
35
 
** TODO [#B] Run-time communication with server :BUGS:
36
 
   Probably using D-Bus
37
 
*** Client class
38
 
*** Main server
39
 
    + SetLogLevel
40
 
      syslogger.setLevel(logging.WARNING)
41
 
    + [[http://log.ometer.com/2007-05.html][Best D-Bus practices]]
42
 
** TODO Implement --foreground                  :BUGS:
43
 
   [[info:standards:Option%20Table][Table of Long Options]]
44
 
** TODO Implement --socket
45
 
   [[info:standards:Option%20Table][Table of Long Options]]
46
 
** TODO Date+time on console log messages       :BUGS:
47
 
   Is this the default?
48
 
** TODO DBusServiceObjectUsingSuper
49
 
** Global enable/disable flag
50
 
** By-client countdown on secrets given
51
 
** Fix problem with fsck taking a really long time
52
 
   Whenever a client successfully gets a secret it could get a
53
 
   one-time timeout boost to allow for an fsck-incurred delay
54
 
 
55
 
* mandos.xml
56
 
** [[file:mandos.xml::XXX][Document D-Bus interface]]
57
 
 
58
 
* Provide and install /etc/dbus-1/system.d/mandos.conf
59
 
 
60
 
* mandos-ctl
61
 
*** Handle "no D-Bus server" and/or "no Mandos server found" better
62
 
*** [#B] --dump option
63
 
 
64
 
* mandos-monitor
65
 
** D-Bus mail loop w/ signal receiver
66
 
** Snack/Newt client data displayer
67
 
*** Client Widgets
68
 
*** Properties popup
69
 
 
70
 
* mandos-keygen
71
 
** TODO Loop until passwords match when run interactively
72
 
** TODO "--secfile" option
73
 
   Using the "secfile" option instead of "secret"
74
 
** TODO [#B] "--test" option
75
 
   For testing decryption before rebooting.
76
 
 
77
 
* Makefile
78
 
** Implement DEB_BUILD_OPTIONS
79
 
   http://www.debian.org/doc/debian-policy/ch-source.html#s-debianrules-options
80
 
 
81
 
* Package
82
 
** /usr/share/initramfs-tools/hooks/mandos
83
 
*** TODO [#C] use same file name rules as run-parts(8)
84
 
*** TODO [#C] Do not install in initrd.img if configured not to.
85
 
    Use "/etc/initramfs-tools/hooksconf.d/mandos"?
86
 
** TODO [#C] /etc/bash_completion.d/mandos
87
 
   From XML sources directly?
88
 
 
89
 
 
90
 
#+STARTUP: showall
 
1
[Mandos client]
 
2
configuration for OpenPGP key dir
 
3
header files/symbols tally
 
4
check exit codes of all system calls
 
5
IPv4 support
 
6
protocol version header
 
7
use strsep instead of strtok?
 
8
 
 
9
[Pluginbasedclient]
 
10
disable certain plugins
 
11
header files/symbols tally
 
12
check exit codes of all system calls
 
13
change uid to nobody:nogroup
 
14
        other drop privs stuff?
 
15
pass things in environment, like device name, etc
 
16
        Does cryptsetup already do this?
 
17
Configurable plugin dir
 
18
use strsep instead of strtok?
 
19
 
 
20
[Server]
 
21
config for:
 
22
        TXT record
 
23
protocol version header
 
24
Run-time communication with server
 
25
        probably using D-Bus
 
26
 
 
27
[Mandos-tools/utilities]
 
28
        List clients
 
29
        Enable client
 
30
        Disable client
 
31
 
 
32
[Installer]
 
33
...