3
* _attribute_((nonnull))
6
** TODO [#B] use scandir(3) instead of readdir(3)
7
** TODO [#B] Prefix all debug output with "Mandos plugin " + program_invocation_short_name
8
** TODO use error() instead of perror()
9
** TODO [#B] Retry a server which has a non-definite reply:
10
*** A closed connection during the TLS handshake
12
** TODO [#B] Use capabilities instead of seteuid().
13
** TODO [#A] Retry --connect forever
16
** TODO [#B] use scandir(3) instead of readdir(3)
17
** TODO [#B] Prefix all debug output with "Mandos plugin " + program_invocation_short_name
18
** TODO [#B] use error() instead of perror()
21
** TODO [#A] Make it work again
22
** TODO [#B] use scandir(3) instead of readdir(3)
23
** TODO [#B] Prefix all debug output with "Mandos plugin " + program_invocation_short_name
24
** TODO [#B] use error() instead of perror()
27
** TODO [#B] Prefix all debug output with "Mandos plugin " + program_invocation_short_name
28
** TODO [#B] use error() instead of perror()
29
** TODO [#B] Drop privileges after opening FIFO.
32
** TODO [#B] Prefix all debug output with "Mandos plugin " + program_invocation_short_name
33
** TODO [#B] use error() instead of perror()
34
** TODO [#B] lock stdin (with flock()?)
39
** TODO [#B] use scandir(3) instead of readdir(3)
40
** TODO [#C] use same file name rules as run-parts(8)
41
** kernel command line option for debug info
42
** TODO [#B] use error() instead of perror()
43
** TODO [$B] Use openat() and readdir64()
44
http://udrepper.livejournal.com/19395.html
47
** TODO [#B] Log level :BUGS:
48
** TODO Persistent state :BUGS:
50
*** TODO /etc/mandos/clients.d/*.conf
51
Watch this directory and add/remove/update clients?
52
** TODO [#C] config for TXT record
53
** TODO Log level option
54
syslogger.setLevel(logging.WARNING)
55
+ SetLogLevel D-Bus call
56
** TODO Implement --foreground :BUGS:
57
[[info:standards:Option%20Table][Table of Long Options]]
58
** TODO Implement --socket
59
[[info:standards:Option%20Table][Table of Long Options]]
60
** TODO Date+time on console log messages :BUGS:
62
** TODO [#C] DBusServiceObjectUsingSuper
63
** TODO [#B] Global enable/disable flag
64
** TODO [#B] By-client countdown on secrets given
65
** TODO [#B] Fix problem with fsck taking a really long time
66
Whenever a client successfully gets a secret it could get a
67
one-time timeout boost to allow for an fsck-incurred delay
68
** TODO [#A] Delay before client receives key
69
This would give an operator opportunity to cancel the request if
71
** TODO [#A] Client manual approval mode
72
A client needs manual approval on the server before it gets the
74
** TODO [#B] Support RFC 3339 time duration syntax
76
*** NeedsApproval(50, True) -> timeout, default approve
77
Default approval is configurable, but True by default
78
+ Approval(True) -> approve sending saved
79
+ Approval(False) -> Close client connection immediately
80
*** NeedsPassword(50) - Timeout, default disapprove
81
+ SetPass(u"gazonk", True) -> Approval, persistent
82
+ Approval(False) -> Close client connection immediately
83
** TODO [#C] python-parsedatetime
84
** TODO [#C] systemd/launchd
85
http://0pointer.de/blog/projects/systemd.html
86
** TODO Separate logging logic to own object
87
** TODO make clients to a dict!
90
** [[file:mandos.xml::XXX][Document D-Bus interface]]
91
Remove mention of lack of such interface in BUGS section
92
** Add mandos contact info in manual pages
94
* TODO [#A] Provide and install /etc/dbus-1/system.d/mandos.conf
97
*** Handle "no D-Bus server" and/or "no Mandos server found" better
98
*** [#B] --dump option
99
** TODO Support RFC 3339 time duration syntax
101
* TODO mandos-dispatch
102
Listens for specified D-Bus signals and spawns shell commands with
106
** Urwid client data displayer
107
Better view of client data in the listing
111
** TODO Loop until passwords match when run interactively
112
** TODO "--secfile" option
113
Using the "secfile" option instead of "secret"
114
** TODO [#B] "--test" option
115
For testing decryption before rebooting.
118
** TODO Add "--Xlinker --as-needed"
119
http://udrepper.livejournal.com/19395.html
120
** TODO [#C] Implement DEB_BUILD_OPTIONS
121
http://www.debian.org/doc/debian-policy/ch-source.html#s-debianrules-options
124
** /usr/share/initramfs-tools/hooks/mandos
125
*** TODO [#C] use same file name rules as run-parts(8)
126
*** TODO [#C] Do not install in initrd.img if configured not to.
127
Use "/etc/initramfs-tools/hooksconf.d/mandos"?
128
** TODO [#C] /etc/bash_completion.d/mandos
129
From XML sources directly?
132
** TODO Locate which packet move the other bin/sh when busy box is deactivated
133
** TODO contact owner of packet, and ask them to have that shell static in position regardless of busybox
2
configuration for OpenPGP key dir
3
header files/symbols tally
4
check exit codes of all system calls
6
protocol version header
7
use strsep instead of strtok?
10
disable certain plugins
11
header files/symbols tally
12
check exit codes of all system calls
13
change uid to nobody:nogroup
14
other drop privs stuff?
15
pass things in environment, like device name, etc
16
Does cryptsetup already do this?
17
Configurable plugin dir
18
use strsep instead of strtok?
23
protocol version header
24
Run-time communication with server
27
[Mandos-tools/utilities]