9
** TODO A --server option which only adds to the server list.
10
(Unlike --connect, which implicitly disables zeroconf.)
11
** TODO [#B] Use capabilities instead of seteuid().
12
https://forums.grsecurity.net/viewtopic.php?f=7&t=2522
13
** TODO [#B] Use getaddrinfo(hints=AI_NUMERICHOST) instead of inet_pton()
14
** TODO [#C] Make start_mandos_communication() take "struct server".
15
** TODO [#C] --interfaces=regex,eth*,noregex (bridge-utils-interfaces(5))
18
** TODO [#B] use scandir(3) instead of readdir(3)
20
* usplash (Deprecated)
21
** TODO [#B] Make it work again
22
** TODO [#B] use scandir(3) instead of readdir(3)
27
** TODO [#B] lock stdin (with flock()?)
34
** TODO handle printing for errors for plugins
35
*** Hook up stderr of plugins, buffer them, and prepend "Mandos Plugin [plugin name]"
36
** TODO [#C] use same file name rules as run-parts(8)
37
** kernel command line option for debug info
40
** TODO Fix bug: it does not exit on SIGTERM until poked via D-Bus
41
** TODO Convert to Python 3 by using own Avahi module, same as GnuTLS
42
** TODO [#B] --notify-command
43
This would allow the mandos.service to use
44
--notify-command="systemd-notify --pid READY=1"
45
** TODO [#B] Log level :BUGS:
46
*** TODO /etc/mandos/clients.d/*.conf
47
Watch this directory and add/remove/update clients?
48
** TODO [#C] config for TXT record
49
** TODO Log level dbus option
50
SetLogLevel D-Bus call
51
** TODO [#C] DBusServiceObjectUsingSuper
52
** TODO [#B] Global enable/disable flag
53
** TODO [#B] By-client countdown on number of secrets given
54
** D-Bus Client method NeedsPassword(50) - Timeout, default disapprove
55
+ SetPass(u"gazonk", True) -> Approval, persistent
56
+ Approve(False) -> Close client connection immediately
57
** TODO [#C] python-parsedatetime
58
** TODO Separate logging logic to own object
59
** TODO [#B] Limit approval_delay to max gnutls/tls timeout value
60
** TODO [#B] break the wait on approval_delay if connection dies
61
** TODO Generate Client.runtime_expansions from client options + extra
62
** TODO Allow %%(checker)s as a runtime expansion
63
** TODO D-Bus AddClient() method on server object
64
** TODO Use org.freedesktop.DBus.Method.NoReply annotation on async methods. :2:
65
** TODO Save state periodically to recover better from hard shutdowns
66
** TODO CheckerCompleted method, deprecate CheckedOK
67
** TODO Secret Service API?
68
http://standards.freedesktop.org/secret-service/
69
** TODO Remove D-Bus interfaces with old domain name :2:
70
** TODO Remove old string_to_delta format :2:
71
** TODO http://0pointer.de/blog/projects/stateless.html
72
*** tmpfiles snippet to create /var/lib/mandos with right user+perms
73
*** File in /usr/lib/sysusers.d to create user+group "_mandos"
74
** TODO Error handling on error parsing config files
75
** TODO init.d script error handling
76
** TODO D-Bus server properties; address, port, interface, etc. :2:
77
** TODO [#C] In Python 3.3, use shlex.quote() instead of re.escape()
80
*** Handle "no D-Bus server" and/or "no Mandos server found" better
81
*** [#B] --dump option
82
** TODO Remove old string_to_delta format :2:
84
* TODO mandos-dispatch
85
Listens for specified D-Bus signals and spawns shell commands with
89
** TODO --servicename :BUGS:
90
** TODO help should be toggleable
91
** Urwid client data displayer
92
Better view of client data in the listing
94
** Print a nice "We are sorry" message, save stack trace to log.
97
** TODO "--secfile" option
98
Using the "secfile" option instead of "secret"
99
** TODO [#B] "--test" option
100
For testing decryption before rebooting.
6
** [#B] Add more comments to code
7
** [#B] Add more if(debug) calls
8
** [#B] Seperate more code to function for more readability
9
** [#A] Man page: man8/plugin-runner.8mandos
13
Examples of normal usage, debug usage, debugging single or all
14
plugins, examples of crypttab lines with plus syntax, etc.
22
Explaining text on what you can read
23
** Keydir move: /etc/mandos -> /etc/keys/mandos
24
Must create in preinst if not pre-depending on cryptsetup
27
** [#A] Man page: man8/password-request.8mandos
28
** [#B] Temporarily lower kernel log level
29
for less printouts during sucessfull boot.
31
Move options to new OPTIONS section.
32
State that this command is not meant to be invoked directly, but
33
is run as a plugin from mandos-client(8) and only run in the
34
initrd environment, not the real system.
38
Examples of normal usage, debug usage, debugging by connecting
41
Describe the key files and the key ring files. Also note that
42
they should normally have been automatically created.
50
Refer to mandos-client(8mandos) and password-prompt(8mandos)
52
Document use of "cryptsource" and "crypttarget".
54
** use strsep instead of strtok?
55
** Do not depend on GnuPG key rings on disk
56
This would mean creating new GnuPG key rings with GPGME by
57
importing the key files from scratch on every program start.
60
** [#A] Man page: man8/password-prompt.8mandos
62
Move options to new OPTIONS section.
63
Note that this is more or less a simple getpass(3) wrapper, even
64
though actual use of getpass(3) is not guaranteed.
68
Examples of normal usage, debug usage, with a prefix, etc.
73
Not much to do here but it is noteworthy to state the danger of
74
not having a fallback option.
78
Refer to mandos-client(8mandos) and password-request(8mandos)
80
Man page says "obsolete", but [[info:libc:getpass][GNU LibC Manual: Reading Passwords]]
81
does not. See also [[http://sources.redhat.com/ml/libc-alpha/2003-05/msg00251.html][Marcus Brinkmann: Re: getpass obsolete?]] and
82
[[http://article.gmane.org/gmane.comp.lib.glibc.alpha/4906][Petter Reinholdtsen: Re: getpass obsolete?]], and especially also
83
[[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?]]
86
** [#A] Command man page: man8/mandos.8
90
Describe briefly that the server gets global settings from
91
mandos.conf and clients from clients.conf, but refer to their man
92
pages for more details.
99
** [#A] Config file man page: man5/mandos.conf (mandos.conf)
100
** [#A] Config file man page: man5/mandos-clients.conf (clients.conf)
101
** [#A] /etc/init.d/mandos-server :teddy:
103
** /etc/mandos/clients.d/*.conf
104
Watch this directory and add/remove/update clients?
105
** config for TXT record
106
** Run-time communication with server
108
See also [[*Mandos-tools]]
109
** Implement --foreground
110
[[info:standards:Option%20Table][Table of Long Options]]
111
** Implement --socket
112
[[info:standards:Option%20Table][Table of Long Options]]
113
** Date+time on console log messages
116
* Mandos-tools/utilities
117
All of this probably using D-Bus
124
*** DONE [#A] Change initrd.img file to not be publically readable
125
/usr/share/initramfs-tools/conf-hooks.d/mandos
127
*** Update initrd.img after installation
129
*** [#A] Create mandos user and group for server
130
*** [#A] Create /var/run/mandos directory with perm and ownership
133
*** [#A] Command man page: man8/mandos-keygen.8
139
*** [#A] Output cut-and-paste ready snippet for clients.conf.
103
142
** /usr/share/initramfs-tools/hooks/mandos
104
*** TODO [#C] use same file name rules as run-parts(8)
105
*** TODO [#C] Do not install in initrd.img if configured not to.
106
Use "/etc/initramfs-tools/hooksconf.d/mandos"?
107
** TODO [#C] $(pkg-config --variable=completionsdir bash-completion)
108
From XML sources directly?
111
** TODO Locate which package moves the other bin/sh when busybox is deactivated
112
** TODO contact owner of package, and ask them to have that shell static in position regardless of busybox
114
* [[http://www.undeadly.org/cgi?action=article&sid=20110530221728][OpenBSD]]
143
*** Do not install in initrd.img if configured not to.
144
Use "/etc/initramfs-tools/conf.d/mandos"? Definitely a debconf
146
** /etc/bash_completion.d/mandos
147
*** From XML sources directly?
157
* Announce project on news
158
[[news:comp.os.linux.announce]]
117
161
#+STARTUP: showall