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
9
** TODO [#B] Use capabilities instead of seteuid().
12
** TODO [#A] Re-raise signal received when exiting due to handled signal :test:
13
** TODO [#B] use scandir(3) instead of readdir(3)
14
** TODO [#B] Prefix all debug output with "Mandos plugin " + argv[0]
17
** TODO [#A] Re-raise signal received when exiting due to handled signal.
18
** TODO [#B] use scandir(3) instead of readdir(3)
19
** TODO [#B] Prefix all debug output with "Mandos plugin " + argv[0]
22
** TODO [#B] Prefix all debug output with "Mandos plugin " + argv[0]
23
** TODO [#B] Drop privileges after opening FIFO.
26
** TODO [#B] Prefix all debug output with "Mandos plugin " + argv[0]
29
** TODO [#B] use scandir(3) instead of readdir(3)
30
** TODO [#C] use same file name rules as run-parts(8)
33
** TODO [#B] Log level :BUGS:
34
** TODO /etc/mandos/clients.d/*.conf
7
** [#A] check exit codes of all system calls
8
** [#B] header files/symbols tally
10
** use strsep instead of strtok?
11
** Do not depend on GPG key rings on disk
12
This would mean creating new GPG key rings with GPGME by importing
13
the key files from scratch every time we start the program.
20
** [#A] check exit codes of all system calls
21
** [#B] header files/symbols tally
22
** use strsep instead of strtok?
23
** use config file in addition to arguments
24
** pass things in environment, like device name, etc
28
** [#A] write PID file
29
** [#A] /etc/init.d/mandos-server
30
** Better comments in config files
32
** /etc/mandos/clients.d/*.conf
35
33
Watch this directory and add/remove/update clients?
36
** TODO config for TXT record
37
** TODO [#B] Run-time communication with server :BUGS:
42
syslogger.setLevel(logging.WARNING)
43
+ [[http://log.ometer.com/2007-05.html][Best D-Bus practices]]
44
** TODO Implement --foreground :BUGS:
45
[[info:standards:Option%20Table][Table of Long Options]]
46
** TODO Implement --socket
47
[[info:standards:Option%20Table][Table of Long Options]]
48
** TODO Date+time on console log messages :BUGS:
50
** TODO Split IPv6_TCPServer into a generic and Mandos-specific class
51
** TODO move handle_ipc out of IPv6_TCPServer
52
** TODO DBusServiceObjectUsingSuper
53
** Global enable/disable flag
54
** By-client countdown on secrets given
55
** Fix problem with fsck taking a really long time
56
Whenever a client successfully gets a secret it could get a
57
one-time timeout boost to allow for an fsck-incurred delay
60
** [[file:mandos.xml::XXX][Document D-Bus interface]]
62
* Provide and install /etc/dbus-1/system.d/mandos.conf
65
*** Handle "no D-Bus server" and/or "no Mandos server found" better
66
*** [#B] --dump option
69
** D-Bus mail loop w/ signal receiver
70
** Urwid/Newt client data displayer
76
** TODO Loop until passwords match when run interactively
77
** TODO "--secfile" option
78
Using the "secfile" option instead of "secret"
79
** TODO [#B] "--test" option
80
For testing decryption before rebooting.
83
** /usr/share/initramfs-tools/hooks/mandos
84
*** TODO [#C] use same file name rules as run-parts(8)
85
*** TODO [#C] Do not install in initrd.img if configured not to.
86
Use "/etc/initramfs-tools/hooksconf.d/mandos"?
87
** TODO [#C] /etc/bash_completion.d/mandos
88
From XML sources directly?
34
** config for TXT record
35
** Run-time communication with server
38
* Mandos-tools/utilities
39
All of this probably using D-Bus
45
** Change initrd.img file to not be publically readable
46
** Create GPG key ring files in initrd