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
** [#A] check return codes of all system calls
18
** [#B] header files/symbols tally
19
** [#B] Fix %d format strings to use [[https://secure.wikimedia.org/wikipedia/en/wiki/Inttypes.h][<inttypes.h>]]
8
** [#B] Temporarily lower kernel log level
9
for less printouts during sucessfull boot.
21
11
** 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)
12
** Do not depend on GnuPG key rings on disk
13
This would mean creating new GnuPG key rings with GPGME by
14
importing the key files from scratch on every program start.
15
** Keydir move: /etc/mandos -> /etc/keys/mandos
16
Must create in preinst if not pre-depending on cryptsetup
38
21
** [#A] /etc/init.d/mandos-server :teddy:
22
** [#B] Log level :bugs:
40
23
** /etc/mandos/clients.d/*.conf
41
24
Watch this directory and add/remove/update clients?
42
25
** config for TXT record
43
** Run-time communication with server
26
** [#B] Run-time communication with server :bugs:
44
27
Probably using D-Bus
45
28
See also [[*Mandos-tools]]
46
** Implement --foreground
29
** Implement --foreground :bugs:
47
30
[[info:standards:Option%20Table][Table of Long Options]]
48
31
** Implement --socket
49
32
[[info:standards:Option%20Table][Table of Long Options]]
33
** Date+time on console log messages :bugs:
51
36
* Mandos-tools/utilities
52
37
All of this probably using D-Bus
44
** Use xinclude for common sections
58
** [#A] Change initrd.img file to not be publically readable
59
** [#A] Create /etc/initramfs-tools/hooks/mandos
60
[[file:/usr/share/doc/initramfs-tools/examples/example_hook][Example initramfs-tools hook script]]
61
** [#A] Create GPG key ring files in initrd
62
** [#A] Create mandos user and group for server
63
** [#A] Create /var/run/mandos directory with perm and ownership
65
* [[http://en.tldp.org/HOWTO/Software-Release-Practice-HOWTO/][Software Release Practice HOWTO]]
50
*** Update initrd.img after installation
51
This seems to use some kind of "trigger" system
52
[[file:/usr/share/doc/dpkg/triggers.txt.gz]]
53
dpkg-trigger(1), deb-triggers(5)
54
*** Keydir move: /etc/mandos -> /etc/keys/mandos
55
Must create in preinst if not pre-depending on cryptsetup
57
**** "--passfile" option
58
Using the "secfile" option instead of "secret"
59
**** [#A] "--test" option
60
For testing decryption before rebooting.
62
*** [#A] Create mandos user and group for server
63
*** [#A] Create /var/run/mandos directory with perm and ownership
66
** /usr/share/initramfs-tools/hooks/mandos
67
*** Do not install in initrd.img if configured not to.
68
Use "/etc/initramfs-tools/conf.d/mandos"? Definitely a debconf
70
** /etc/bash_completion.d/mandos
71
From XML sources directly?
81
* Announce project on news
82
[[news:comp.os.linux.announce]]