6
[[file:/usr/share/common-licenses/GPL-3][GPLv3]]
9
** [#A] Man page: man8/mandos-client.8mandos
10
** [#B] Fix %d format strings to use [[https://secure.wikimedia.org/wikipedia/en/wiki/Inttypes.h][<inttypes.h>]]
11
** use strsep instead of strtok?
12
** use config file in addition to arguments
13
** pass things in environment, like device name, etc
16
** [#A] Man page: man8/password-request.8mandos
17
** [#B] Fix %d format strings to use [[https://secure.wikimedia.org/wikipedia/en/wiki/Inttypes.h][<inttypes.h>]]
18
** start_mandos_communication: loop around gnutls_handshake
19
[[info:gnutls.info.gz:Core%20functions][gnutls_handshake]]
21
** use strsep instead of strtok?
22
** Do not depend on GPG key rings on disk
23
This would mean creating new GPG key rings with GPGME by importing
24
the key files from scratch on every program start.
27
** [#A] Man page: man8/password-prompt.8mandos
29
Man page says "obsolete", but [[info:libc:getpass][GNU LibC Manual: Reading Passwords]]
30
does not. See also [[http://sources.redhat.com/ml/libc-alpha/2003-05/msg00251.html][Marcus Brinkmann: Re: getpass obsolete?]] and
31
[[http://article.gmane.org/gmane.comp.lib.glibc.alpha/4906][Petter Reinholdtsen: Re: getpass obsolete?]], and especially also
32
[[http://www.steve.org.uk/Reference/Unix/faq_4.html#SEC48][Unix Programming FAQ 3.1 How can I make my program not echo input?]]
35
** [#A] Command man page: man8/mandos.8
36
** [#A] Config file man page: man5/mandos.conf (mandos.conf)
37
** [#A] Config file man page: man5/mandos-clients.conf (clients.conf)
38
** [#A] /etc/init.d/mandos-server :teddy:
40
** /etc/mandos/clients.d/*.conf
4
** TODO [#A] Clean up /tmp directory on signal
5
** TODO [#C] IPv4 support
8
** TODO [#B] use scandir(3) instead of readdir(3)
11
** TODO [#B] Log level :bugs:
12
** TODO /etc/mandos/clients.d/*.conf
41
13
Watch this directory and add/remove/update clients?
42
** config for TXT record
43
** Run-time communication with server
14
** TODO config for TXT record
15
** TODO [#B] Run-time communication with server :bugs:
44
16
Probably using D-Bus
45
17
See also [[*Mandos-tools]]
46
** Implement --foreground
47
[[info:standards:Option%20Table][Table of Long Options]]
49
[[info:standards:Option%20Table][Table of Long Options]]
51
* Mandos-tools/utilities
52
All of this probably using D-Bus
58
** [#A] Change initrd.img file to not be publically readable
59
/etc/initramfs-tools/conf.d/mandos
61
** [#A] Create /etc/initramfs-tools/hooks/mandos
62
[[file:/usr/share/doc/initramfs-tools/examples/example_hook][Example initramfs-tools hook script]]
63
** [#A] Create GPG key ring files in initrd
64
** [#A] Create mandos user and group for server
65
** [#A] Create /var/run/mandos directory with perm and ownership
73
* Announce project on news
74
news:comp.os.linux.announce
21
syslogger.setLevel(logging.WARNING)
23
+ [[http://log.ometer.com/2007-05.html][Best D-Bus practices]]
24
** TODO Implement --foreground :bugs:
25
[[info:standards:Option%20Table][Table of Long Options]]
26
** TODO Implement --socket
27
[[info:standards:Option%20Table][Table of Long Options]]
28
** TODO Date+time on console log messages :bugs:
30
** TODO delete hook when clients fall out by timeout
31
This will not be strictly necessary when the D-Bus interface is
35
** [[file:mandos.xml::XXX][Document D-Bus interface]]
37
* Provide and install /etc/dbus-1/system.d/mandos.conf
40
*** Handle "no D-Bus server" and/or "no Mandos server found" better
41
*** [#B] --dump option
46
** TODO Loop until passwords match when run interactively
47
** TODO "--secfile" option
48
Using the "secfile" option instead of "secret"
49
** TODO [#B] "--test" option
50
For testing decryption before rebooting.
53
** /usr/share/initramfs-tools/hooks/mandos
54
*** TODO [#C] Do not install in initrd.img if configured not to.
55
Use "/etc/initramfs-tools/conf.d/mandos"? Definitely a debconf
57
** TODO [#C] /etc/bash_completion.d/mandos
58
From XML sources directly?