/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

Added manual pages for:
      clients.conf
      mandos.conf
      mandos
      mandos-client
      password-prompt
      password-request

Show diffs side-by-side

added added

removed removed

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