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]
3
* Use _attribute_((nonnull)) wherever possible.
8
** TODO [#B] Use capabilities instead of seteuid().
9
** TODO [#B] Use struct sockaddr_storage instead of a union
10
** TODO [#B] Use getaddrinfo(hints=AI_NUMERICHOST) instead of inet_pton()
11
** TODO [#B] Use getnameinfo(serv=NULL, NI_NUMERICHOST) instead of inet_ntop()
14
** TODO [#B] use scandir(3) instead of readdir(3)
17
** TODO [#A] Make it work again
18
** TODO [#B] use scandir(3) instead of readdir(3)
19
** TODO Use [[info:libc:Argz%20Functions][argz_extract]]
22
** TODO [#B] Drop privileges after opening FIFO.
25
** TODO [#B] lock stdin (with flock()?)
32
** TODO handle printing for errors for plugins
33
*** Hook up stderr of plugins, buffer them, and prepend mandos pluig [plugin name]
34
** TODO [#B] use scandir(3) instead of readdir(3)
35
** TODO [#C] use same file name rules as run-parts(8)
36
** kernel command line option for debug info
37
** TODO [#B] Use openat()
40
** TODO [#B] Log level :BUGS:
41
** TODO Persistent state :BUGS:
43
*** TODO /etc/mandos/clients.d/*.conf
44
Watch this directory and add/remove/update clients?
45
** TODO [#C] config for TXT record
46
** TODO Log level option
47
syslogger.setLevel(logging.WARNING)
48
+ SetLogLevel D-Bus call
49
** TODO Implement --foreground :BUGS:
50
[[info:standards:Option%20Table][Table of Long Options]]
51
** TODO Implement --socket
52
[[info:standards:Option%20Table][Table of Long Options]]
53
** TODO Date+time on console log messages :BUGS:
55
** TODO [#C] DBusServiceObjectUsingSuper
56
** TODO [#B] Global enable/disable flag
57
** TODO [#B] By-client countdown on secrets given
58
** TODO [#B] Fix problem with fsck taking a really long time
59
Whenever a client successfully gets a secret it could get a
60
one-time timeout boost to allow for an fsck-incurred delay
61
** TODO [#A] Delay before client receives key
62
This would give an operator opportunity to cancel the request if
64
** TODO [#A] Client manual approval mode
65
A client needs manual approval on the server before it gets the
67
** TODO [#B] Support RFC 3339 time duration syntax
69
*** NeedsApproval(50, True) -> timeout, default approve
70
Default approval is configurable, but True by default
71
+ Approve(True) -> approve sending saved
72
+ Approve(False) -> Close client connection immediately
73
*** NeedsPassword(50) - Timeout, default disapprove
74
+ SetPass(u"gazonk", True) -> Approval, persistent
75
+ Approve(False) -> Close client connection immediately
76
** TODO [#C] python-parsedatetime
77
** TODO [#C] systemd/launchd
78
http://0pointer.de/blog/projects/systemd.html
79
** TODO Separate logging logic to own object
80
** TODO make clients to a dict!
81
** TODO [#A] Limit approval_delay to max gnutls/tls timeout value
82
** TODO [#B] break the wait on approval_delay if connection dies
83
** TODO Generate Client.runtime_expansions from client options + extra
84
** TODO Allow %%(checker)s as a runtime expansion
85
** TODO Use python-tlslite?
88
** Add mandos contact info in manual pages
91
*** Handle "no D-Bus server" and/or "no Mandos server found" better
92
*** [#B] --dump option
93
** TODO Support RFC 3339 time duration syntax
95
* TODO mandos-dispatch
96
Listens for specified D-Bus signals and spawns shell commands with
100
** TODO help should be toggleable
101
** Urwid client data displayer
102
Better view of client data in the listing
104
** Nicer crashes. Stack traces Messes up shell.
105
*** Print a nice "We are sorry" message, save stack trace to log.
106
** Show timeout countdown for approval
109
** TODO Loop until passwords match when run interactively
110
** TODO "--secfile" option
111
Using the "secfile" option instead of "secret"
112
** TODO [#B] "--test" option
113
For testing decryption before rebooting.
116
** TODO Add "--Xlinker --as-needed"
117
http://udrepper.livejournal.com/19395.html
118
** TODO [#C] Implement DEB_BUILD_OPTIONS
119
http://www.debian.org/doc/debian-policy/ch-source.html#s-debianrules-options
122
** /usr/share/initramfs-tools/hooks/mandos
123
*** TODO [#C] use same file name rules as run-parts(8)
124
*** TODO [#C] Do not install in initrd.img if configured not to.
125
Use "/etc/initramfs-tools/hooksconf.d/mandos"?
126
** TODO [#C] /etc/bash_completion.d/mandos
127
From XML sources directly?
130
** TODO Locate which packet move the other bin/sh when busy box is deactivated
131
** TODO contact owner of packet, and ask them to have that shell static in position regardless of busybox