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
header files/symbols tally
11
check exit codes of all system calls
12
change uid to nobody:nogroup
13
other drop privs stuff?
14
pass things in environment, like device name, etc
15
Does cryptsetup already do this?
16
use strsep instead of strtok?
21
protocol version header
22
Run-time communication with server
25
[Mandos-tools/utilities]
4
** General: [[https://www.atlassian.com/git/workflows][Git Workflows]], [[http://gitimmersion.com/][Git Immersion]], [[https://news.ycombinator.com/item?id=7036628][Simple git workflow is simple]] [[https://news.ycombinator.com/item?id=9661349][On undoing, fixing, or removing commits in git]]
5
** Intro: [[http://www.eyrie.org/~eagle/notes/debian/git.html#combine][Using Git for Debian Packaging]]
6
** Use: [[https://honk.sigxcpu.org/piki/projects/git-buildpackage/][git-buildpackage]]
9
Using bzr-fastimport: [[http://www.fusonic.net/en/blog/2013/03/26/migrating-from-bazaar-to-git/][Migrating from Bazaar to Git]]
10
** Unresolved: [[http://jameswestby.net/bzr/builddeb/user_manual/split.html][bzr builddeb split mode]]
11
Maybe: [[http://honk.sigxcpu.org/projects/git-buildpackage/manual-html/gbp.import.html#GBP.IMPORT.UPSTREAM.GIT.NOTARBALL][git-buildpackage - No upstream tarballs]]
12
[[http://www.python.org/dev/peps/pep-0374/][PEP 374 - Choosing a distributed VCS for the Python project]]
13
[[http://www.emacswiki.org/emacs/GitForEmacsDevs][Git For Emacs Devs]]
15
* [[http://www.undeadly.org/cgi?action=article&sid=20110530221728][OpenBSD]]
23
** TODO [#B] Use capabilities instead of seteuid().
24
https://forums.grsecurity.net/viewtopic.php?f=7&t=2522
25
** TODO [#B] Use getaddrinfo(hints=AI_NUMERICHOST) instead of inet_pton()
26
** TODO [#C] Make start_mandos_communication() take "struct server".
27
** TODO [#C] --interfaces=regex,eth*,noregex (bridge-utils-interfaces(5))
28
** TODO [#C] Remove code for GNU libc < 2.15
31
** TODO [#B] use scandir(3) instead of readdir(3)
33
* usplash (Deprecated)
34
** TODO [#B] Make it work again
35
** TODO [#B] use scandir(3) instead of readdir(3)
40
** TODO [#B] lock stdin (with flock()?)
47
** TODO handle printing for errors for plugins
48
*** Hook up stderr of plugins, buffer them, and prepend "Mandos Plugin [plugin name]"
49
** TODO [#C] use same file name rules as run-parts(8)
50
** kernel command line option for debug info
51
** TODO [#C] Remove code for GNU libc < 2.15
54
** TODO [#B] --notify-command
55
This would allow the mandos.service to use
56
--notify-command="systemd-notify --pid READY=1"
57
** TODO [#B] Log level :BUGS:
58
*** TODO /etc/mandos/clients.d/*.conf
59
Watch this directory and add/remove/update clients?
60
** TODO [#C] config for TXT record
61
** TODO Log level dbus option
62
SetLogLevel D-Bus call
63
** TODO [#C] DBusServiceObjectUsingSuper
64
** TODO [#B] Global enable/disable flag
65
** TODO [#B] By-client countdown on number of secrets given
66
** D-Bus Client method NeedsPassword(50) - Timeout, default disapprove
67
+ SetPass(u"gazonk", True) -> Approval, persistent
68
+ Approve(False) -> Close client connection immediately
69
** TODO [#C] python-parsedatetime
70
** TODO Separate logging logic to own object
71
** TODO [#B] Limit approval_delay to max gnutls/tls timeout value
72
** TODO [#B] break the wait on approval_delay if connection dies
73
** TODO Generate Client.runtime_expansions from client options + extra
74
** TODO Allow %%(checker)s as a runtime expansion
75
** TODO Use python-tlslite?
76
** TODO D-Bus AddClient() method on server object
77
** TODO Use org.freedesktop.DBus.Method.NoReply annotation on async methods. :2:
78
** TODO Support [[http://dbus.freedesktop.org/doc/dbus-specification.html#standard-interfaces-objectmanager][org.freedesktop.DBus.ObjectManager]] interface on server object :2:
79
Deprecate methods GetAllClients(), GetAllClientsWithProperties()
80
and signals ClientAdded and ClientRemoved.
81
** TODO Save state periodically to recover better from hard shutdowns
82
** TODO CheckerCompleted method, deprecate CheckedOK
83
** TODO Secret Service API?
84
http://standards.freedesktop.org/secret-service/
85
** TODO Remove D-Bus interfaces with old domain name :2:
86
** TODO Remove old string_to_delta format :2:
87
** TODO http://0pointer.de/blog/projects/stateless.html
88
*** tmpfiles snippet to create /var/lib/mandos with right user+perms
89
*** File in /usr/lib/sysusers.d to create user+group "_mandos"
90
** TODO Error handling on error parsing config files
91
** TODO init.d script error handling
92
** TODO D-Bus server properties; address, port, interface, etc. :2:
93
** TODO [#C] In Python 3.3, use shlex.quote() instead of re.escape()
96
** Add mandos contact info in manual pages
99
*** Handle "no D-Bus server" and/or "no Mandos server found" better
100
*** [#B] --dump option
101
** TODO Remove old string_to_delta format :2:
103
* TODO mandos-dispatch
104
Listens for specified D-Bus signals and spawns shell commands with
108
** TODO help should be toggleable
109
** Urwid client data displayer
110
Better view of client data in the listing
112
** Print a nice "We are sorry" message, save stack trace to log.
113
** Rename module "gobject" to "GObject".
116
** TODO "--secfile" option
117
Using the "secfile" option instead of "secret"
118
** TODO [#B] "--test" option
119
For testing decryption before rebooting.
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] $(pkg-config --variable=completionsdir bash-completion)
127
From XML sources directly?
130
** TODO Locate which package moves the other bin/sh when busybox is deactivated
131
** TODO contact owner of package, and ask them to have that shell static in position regardless of busybox