/mandos/trunk

To get this branch, use:
bzr branch http://bzr.recompile.se/loggerhead/mandos/trunk

« back to all changes in this revision

Viewing changes to TODO

merge

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
-*- org -*-
2
2
 
3
 
* _attribute_((nonnull))
4
 
 
5
 
* Release critical
6
 
** TODO Change make-run-server to not include --no-dbus
7
 
 
8
 
* mandos-client
9
 
** TODO [#B] use scandir(3) instead of readdir(3)
10
 
** TODO [#B] Prefix all debug output with "Mandos plugin " + program_invocation_short_name
11
 
** TODO [#B] Retry a server which has a non-definite reply:
12
 
*** A closed connection during the TLS handshake
13
 
*** A TCP timeout
14
 
** TODO [#B] Use capabilities instead of seteuid().
15
 
** TODO [#A] Retry --connect forever
16
 
 
17
 
* splashy
18
 
** TODO [#B] use scandir(3) instead of readdir(3)
19
 
** TODO [#B] Prefix all debug output with "Mandos plugin " + program_invocation_short_name
20
 
 
21
 
* usplash
22
 
** TODO [#A] Make it work again
23
 
** TODO [#B] use scandir(3) instead of readdir(3)
24
 
** TODO [#B] Prefix all debug output with "Mandos plugin " + program_invocation_short_name
25
 
** TODO Use [[info:libc:Argz%20Functions][argz_extract]]
26
 
 
27
 
* askpass-fifo
28
 
** TODO [#B] Prefix all debug output with "Mandos plugin " + program_invocation_short_name
29
 
** TODO [#B] Drop privileges after opening FIFO.
30
 
 
31
 
* password-prompt
32
 
** TODO [#B] Prefix all debug output with "Mandos plugin " + program_invocation_short_name
33
 
** TODO [#B] lock stdin (with flock()?)
34
 
 
35
 
* plymouth
36
 
** TODO Use [[info:libc:Argz%20Functions][argz_extract]]
37
 
 
38
 
* TODO [#B] passdev
39
 
 
40
 
* plugin-runner
41
 
** TODO [#B] use scandir(3) instead of readdir(3)
42
 
** TODO [#C] use same file name rules as run-parts(8)
43
 
** kernel command line option for debug info
44
 
** TODO [$B] Use openat() and readdir64()
45
 
   http://udrepper.livejournal.com/19395.html
46
 
 
47
 
* mandos (server)
48
 
** TODO [#B] Log level                                                    :BUGS:
49
 
** TODO Persistent state                                                  :BUGS:
50
 
   /var/lib/mandos/*
51
 
*** TODO /etc/mandos/clients.d/*.conf
52
 
    Watch this directory and add/remove/update clients?
53
 
** TODO [#C] config for TXT record
54
 
** TODO Log level option
55
 
   syslogger.setLevel(logging.WARNING)
56
 
   + SetLogLevel D-Bus call
57
 
** TODO Implement --foreground                                            :BUGS:
58
 
   [[info:standards:Option%20Table][Table of Long Options]]
59
 
** TODO Implement --socket
60
 
   [[info:standards:Option%20Table][Table of Long Options]]
61
 
** TODO Date+time on console log messages                                 :BUGS:
62
 
   Is this the default?
63
 
** TODO [#C] DBusServiceObjectUsingSuper
64
 
** TODO [#B] Global enable/disable flag
65
 
** TODO [#B] By-client countdown on secrets given
66
 
** TODO [#B] Fix problem with fsck taking a really long time
67
 
   Whenever a client successfully gets a secret it could get a
68
 
   one-time timeout boost to allow for an fsck-incurred delay
69
 
** TODO [#A] Delay before client receives key
70
 
   This would give an operator opportunity to cancel the request if
71
 
   desired.
72
 
** TODO [#A] Client manual approval mode
73
 
   A client needs manual approval on the server before it gets the
74
 
   secret
75
 
** TODO [#B] Support RFC 3339 time duration syntax
76
 
** More D-Bus methods
77
 
*** NeedsApproval(50, True) -> timeout, default approve
78
 
    Default approval is configurable, but True by default
79
 
    + Approval(True) -> approve sending saved
80
 
    + Approval(False) -> Close client connection immediately
81
 
*** NeedsPassword(50) - Timeout, default disapprove
82
 
    + SetPass(u"gazonk", True) -> Approval, persistent
83
 
    + Approval(False) -> Close client connection immediately
84
 
** TODO [#C] python-parsedatetime
85
 
** TODO [#C] systemd/launchd
86
 
   http://0pointer.de/blog/projects/systemd.html
87
 
** TODO Separate logging logic to own object
88
 
** TODO make clients to a dict!
89
 
** TODO PropertyChanged should be a python generic property for client variables
90
 
 
91
 
* mandos.xml
92
 
** [[file:mandos.xml::XXX][Document D-Bus interface]]
93
 
   Remove mention of lack of such interface in BUGS section
94
 
** Add mandos contact info in manual pages
95
 
 
96
 
* TODO [#A] Provide and install /etc/dbus-1/system.d/mandos.conf
97
 
 
98
 
* mandos-ctl
99
 
*** Handle "no D-Bus server" and/or "no Mandos server found" better
100
 
*** [#B] --dump option
101
 
** TODO Support RFC 3339 time duration syntax
102
 
 
103
 
* TODO mandos-dispatch
104
 
  Listens for specified D-Bus signals and spawns shell commands with
105
 
  arguments.
106
 
 
107
 
* mandos-monitor
108
 
** TODO help should be toggable
109
 
** Urwid client data displayer
110
 
   Better view of client data in the listing
111
 
*** Properties popup
112
 
** Nicer crashes. Stack traces Messes up shell.
113
 
*** Print a nice "We are sorry" message, save stack trace to log.
114
 
 
115
 
* mandos-keygen
116
 
** TODO Loop until passwords match when run interactively
117
 
** TODO "--secfile" option
118
 
   Using the "secfile" option instead of "secret"
119
 
** TODO [#B] "--test" option
120
 
   For testing decryption before rebooting.
121
 
 
122
 
* Makefile
123
 
** TODO Add "--Xlinker --as-needed"
124
 
   http://udrepper.livejournal.com/19395.html
125
 
** TODO [#C] Implement DEB_BUILD_OPTIONS
126
 
   http://www.debian.org/doc/debian-policy/ch-source.html#s-debianrules-options
127
 
 
128
 
* Package
129
 
** /usr/share/initramfs-tools/hooks/mandos
130
 
*** TODO [#C] use same file name rules as run-parts(8)
131
 
*** TODO [#C] Do not install in initrd.img if configured not to.
132
 
    Use "/etc/initramfs-tools/hooksconf.d/mandos"?
133
 
** TODO [#C] /etc/bash_completion.d/mandos
134
 
   From XML sources directly?
135
 
 
136
 
* Side Stuff
137
 
** TODO Locate which packet move the other bin/sh when busy box is deactivated
138
 
** TODO contact owner of packet, and ask them to have that shell static in position regardless of busybox
 
3
* README file
 
4
 
 
5
* Mandos client
 
6
** [#A] Man page
 
7
** [#A] check exit codes of all system calls
 
8
** [#B] header files/symbols tally
 
9
** IPv4 support
 
10
** use strsep instead of strtok?
 
11
** Do not depend on GPG key rings on disk
 
12
   This would mean creating new GPG key rings with GPGME by importing
 
13
   the key files from scratch every time we start the program.
 
14
 
 
15
* Passprompt
 
16
** [#A] Man page
 
17
 
 
18
* Pluginbasedclient
 
19
** [#A] Man page
 
20
** [#A] check exit codes of all system calls
 
21
** [#B] header files/symbols tally
 
22
** use strsep instead of strtok?
 
23
** use config file in addition to arguments
 
24
** pass things in environment, like device name, etc
 
25
 
 
26
* Server
 
27
** [#A] Man page
 
28
** [#A] write PID file
 
29
** [#A] /etc/init.d/mandos-server
 
30
** Better comments in config files
 
31
** Log level
 
32
** /etc/mandos/clients.d/*.conf
 
33
   Watch this directory and add/remove/update clients?
 
34
** config for TXT record
 
35
** Run-time communication with server
 
36
   probably using D-Bus
 
37
 
 
38
* Mandos-tools/utilities
 
39
  All of this probably using D-Bus
 
40
** List clients
 
41
** Enable client
 
42
** Disable client
 
43
 
 
44
* Installer
 
45
** Change initrd.img file to not be publically readable
 
46
** Create GPG key ring files in initrd
139
47
 
140
48
 
141
49
#+STARTUP: showall