/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

* debian/mandos-client.README.Debian: Improved wording and formatting.
                                      Updated location of nfsroot.txt.
* debian/mandos.README.Debian: Improved wording and formatting.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
-*- org -*-
2
2
 
3
 
* README file
4
 
 
5
 
* COPYING file
6
 
  [[file:/usr/share/common-licenses/GPL-3][GPLv3]]
7
 
 
8
 
* Mandos-client
9
 
** [#A] Man page: man8/mandos-client.8mandos
10
 
** use strsep instead of strtok?
11
 
** use config file in addition to arguments
12
 
** pass things in environment, like device name, etc
13
 
 
14
 
* Password-request
15
 
** [#A] Man page: man8/password-request.8mandos
16
 
** [#A] check return codes of all system calls
17
 
** [#B] header files/symbols tally
18
 
** IPv4 support
19
 
** use strsep instead of strtok?
20
 
** Do not depend on GPG key rings on disk
21
 
   This would mean creating new GPG key rings with GPGME by importing
22
 
   the key files from scratch on every program start.
23
 
 
24
 
* Password-prompt
25
 
** [#A] Man page: man8/password-prompt.8mandos
26
 
** Use getpass(3)?
27
 
   [[info:libc:getpass][GNU LibC Manual: Reading Passwords]]
28
 
 
29
 
* Server
30
 
** [#A] Command man page: man8/mandos.8
31
 
** [#A] Config file man page: man5/mandos.conf (mandos.conf)
32
 
** [#A] Config file man page: man5/mandos-clients.conf (clients.conf)
33
 
** [#A] write PID file
34
 
** [#A] /etc/init.d/mandos-server
35
 
** Better comments in config files
36
 
** Log level
37
 
** /etc/mandos/clients.d/*.conf
 
3
* mandos-client
 
4
** TODO [#A] Clean up /tmp directory and take down interface on signal    :test:
 
5
** TODO [#B] use scandir(3) instead of readdir(3)
 
6
** TODO [#B] Prefix all debug output with argv[0]
 
7
** TODO [#B] Retry a server which has a non-definite reply:
 
8
*** A closed connection during the TLS handshake
 
9
*** A TCP timeout
 
10
** TODO [#B] Use capabilities instead of seteuid().
 
11
 
 
12
* splashy
 
13
** TODO [#A] Re-raise signal received when exiting due to handled signal  :test:
 
14
** TODO [#B] use scandir(3) instead of readdir(3)
 
15
** TODO [#B] Prefix all debug output with "Mandos plugin " + argv[0]
 
16
 
 
17
* usplash
 
18
** TODO [#A] Re-raise signal received when exiting due to handled signal.
 
19
** TODO [#B] use scandir(3) instead of readdir(3)
 
20
** TODO [#B] Prefix all debug output with "Mandos plugin " + argv[0]
 
21
 
 
22
* askpass-fifo
 
23
** TODO [#B] Prefix all debug output with "Mandos plugin " + argv[0]
 
24
** TODO [#B] Drop privileges after opening FIFO.
 
25
 
 
26
* password-prompt
 
27
** TODO [#B] Prefix all debug output with "Mandos plugin " + argv[0]
 
28
 
 
29
* plugin-runner
 
30
** TODO [#B] use scandir(3) instead of readdir(3)
 
31
** TODO [#C] use same file name rules as run-parts(8)
 
32
 
 
33
* mandos (server)
 
34
** TODO [#B] Log level                          :BUGS:
 
35
** TODO /etc/mandos/clients.d/*.conf
38
36
   Watch this directory and add/remove/update clients?
39
 
** config for TXT record
40
 
** Run-time communication with server
41
 
   probably using D-Bus
42
 
** Implement --foreground
43
 
   [[info:standards:Option%20Table][Table of Long Options]]
44
 
** Implement --socket
45
 
   [[info:standards:Option%20Table][Table of Long Options]]
46
 
 
47
 
* Mandos-tools/utilities
48
 
  All of this probably using D-Bus
49
 
** List clients
50
 
** Enable client
51
 
** Disable client
52
 
 
53
 
* Installer
54
 
** [#A] Change initrd.img file to not be publically readable
55
 
** [#A] Create GPG key ring files in initrd
 
37
** TODO config for TXT record
 
38
** TODO [#B] Run-time communication with server :BUGS:
 
39
   Probably using D-Bus
 
40
*** Client class
 
41
*** Main server
 
42
    + SetLogLevel
 
43
      syslogger.setLevel(logging.WARNING)
 
44
    + [[http://log.ometer.com/2007-05.html][Best D-Bus practices]]
 
45
** TODO Implement --foreground                  :BUGS:
 
46
   [[info:standards:Option%20Table][Table of Long Options]]
 
47
** TODO Implement --socket
 
48
   [[info:standards:Option%20Table][Table of Long Options]]
 
49
** TODO Date+time on console log messages       :BUGS:
 
50
   Is this the default?
 
51
** TODO Split IPv6_TCPServer into a generic and Mandos-specific class
 
52
** TODO move handle_ipc out of IPv6_TCPServer
 
53
** TODO DBusServiceObjectUsingSuper
 
54
** Global enable/disable flag
 
55
** By-client countdown on secrets given
 
56
 
 
57
* mandos.xml
 
58
** [[file:mandos.xml::XXX][Document D-Bus interface]]
 
59
 
 
60
* Provide and install /etc/dbus-1/system.d/mandos.conf
 
61
 
 
62
* mandos-ctl
 
63
*** Handle "no D-Bus server" and/or "no Mandos server found" better
 
64
*** [#B] --dump option
 
65
 
 
66
* mandos-name
 
67
** D-Bus mail loop w/ signal receiver
 
68
** Urwid/Newt client data displayer
 
69
*** Urwid scaffolding
 
70
*** Client Widgets
 
71
*** Properties popup
 
72
 
 
73
* mandos-keygen
 
74
** TODO Loop until passwords match when run interactively
 
75
** TODO "--secfile" option
 
76
   Using the "secfile" option instead of "secret"
 
77
** TODO [#B] "--test" option
 
78
   For testing decryption before rebooting.
 
79
 
 
80
* Package
 
81
** /usr/share/initramfs-tools/hooks/mandos
 
82
*** TODO [#C] use same file name rules as run-parts(8)
 
83
*** TODO [#C] Do not install in initrd.img if configured not to.
 
84
    Use "/etc/initramfs-tools/hooksconf.d/mandos"?
 
85
** TODO [#C] /etc/bash_completion.d/mandos
 
86
   From XML sources directly?
56
87
 
57
88
 
58
89
#+STARTUP: showall