/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

Changed ForkingMixIn in favor of multiprocessing
Added approval functionallity

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
-*- org -*-
2
2
 
3
 
* [#A] README file
 
3
* _attribute_((nonnull))
 
4
 
 
5
* mandos-client
 
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
 
11
*** A TCP timeout
 
12
** TODO [#B] Use capabilities instead of seteuid().
 
13
** TODO [#A] Retry --connect forever
 
14
 
 
15
* splashy
 
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()
 
19
 
 
20
* usplash
 
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()
 
25
 
 
26
* askpass-fifo
 
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.
 
30
 
 
31
* password-prompt
 
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()?)
 
35
 
 
36
* TODO [#B] passdev
4
37
 
5
38
* plugin-runner
6
 
** [#B] Add more comments to code
7
 
** [#B] Add more if(debug) calls
8
 
** [#B] Seperate more code to function for more readability
9
 
** [#A] Man page: man8/plugin-runner.8mandos
10
 
*** SEE ALSO
11
 
    Explaining text on what you can read
12
 
 
13
 
* password-request
14
 
** [#A] Man page: man8/password-request.8mandos
15
 
*** SYNOPSIS
16
 
    Document short options
17
 
*** DESCRIPTION
18
 
    State that this command is not meant to be invoked directly, but
19
 
    is run as a plugin from mandos-client(8) and only run in the
20
 
    initrd environment, not the real system.
21
 
*** PURPOSE
22
 
    As in mandos.xml
23
 
*** OVERVIEW
24
 
    As in mandos.xml
25
 
*** EXIT STATUS
26
 
*** ENVIRONMENT
27
 
    Note that it does *not* currently use cryptsource or crypttarget.
28
 
*** FILES
29
 
    Describe the key files and the key ring files.  Also note that
30
 
    they should normally have been automatically created.
31
 
*** BUGS
32
 
*** EXAMPLE
33
 
    Examples of normal usage, debug usage, debugging by connecting
34
 
    directly, etc.
35
 
*** SECURITY
36
 
*** SEE ALSO
37
 
    Update from mandos.xml
38
 
** [#B] Temporarily lower kernel log level
39
 
   for less printouts during sucessfull boot.
40
 
** IPv4 support
41
 
** use strsep instead of strtok?
42
 
** Do not depend on GnuPG key rings on disk
43
 
   This would mean creating new GnuPG key rings with GPGME by
44
 
   importing the key files from scratch on every program start.
45
 
** Keydir move: /etc/mandos -> /etc/keys/mandos
46
 
   Must create in preinst if not pre-depending on cryptsetup
47
 
 
48
 
* password-prompt
49
 
** [#C] Use getpass(3)?
50
 
   Man page says "obsolete", but [[info:libc:getpass][GNU LibC Manual: Reading Passwords]]
51
 
   does not.  See also [[http://sources.redhat.com/ml/libc-alpha/2003-05/msg00251.html][Marcus Brinkmann: Re: getpass obsolete?]] and
52
 
   [[http://article.gmane.org/gmane.comp.lib.glibc.alpha/4906][Petter Reinholdtsen: Re: getpass obsolete?]], and especially also
53
 
   [[http://www.steve.org.uk/Reference/Unix/faq_4.html#SEC48][Unix Programming FAQ 3.1 How can I make my program not echo input?]]
 
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
54
45
 
55
46
* mandos (server)
56
 
** [#A] /etc/init.d/mandos-server               :teddy:
57
 
** [#B] Log level                               :bugs:
58
 
** /etc/mandos/clients.d/*.conf
59
 
   Watch this directory and add/remove/update clients?
60
 
** config for TXT record
61
 
** [#B] Run-time communication with server      :bugs:
62
 
   Probably using D-Bus
63
 
   See also [[*Mandos-tools]]
64
 
** Implement --foreground                       :bugs:
65
 
   [[info:standards:Option%20Table][Table of Long Options]]
66
 
** Implement --socket
67
 
   [[info:standards:Option%20Table][Table of Long Options]]
68
 
** Date+time on console log messages            :bugs:
 
47
** TODO [#B] Log level                                                    :BUGS:
 
48
** TODO Persistent state                                                  :BUGS:
 
49
   /var/lib/mandos/*
 
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:
69
61
   Is this the default?
70
 
 
71
 
* Mandos-tools/utilities
72
 
  All of this probably using D-Bus
73
 
** List clients
74
 
** Disable client
75
 
** Enable client
76
 
 
77
 
* Man pages
78
 
** Use xinclude for common sections
79
 
   Like authors, etc.
80
 
 
81
 
 
82
 
* Installer
83
 
** Client-side
84
 
*** Update initrd.img after installation
85
 
    This seems to use some kind of "trigger" system
86
 
    [[file:/usr/share/doc/dpkg/triggers.txt.gz]]
87
 
    dpkg-trigger(1), deb-triggers(5)
88
 
*** Keydir move: /etc/mandos -> /etc/keys/mandos
89
 
    Must create in preinst if not pre-depending on cryptsetup
90
 
*** mandos-keygen
91
 
**** "--passfile" option
92
 
     Using the "secfile" option instead of "secret"
93
 
**** [#A] "--test" option
94
 
     For testing decryption before rebooting.
95
 
** Server-side
96
 
*** [#A] Create mandos user and group for server
97
 
*** [#A] Create /var/run/mandos directory with perm and ownership
98
 
 
99
 
* [#A] Package
 
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
 
70
   desired.
 
71
** TODO [#A] Client manual approval mode
 
72
   A client needs manual approval on the server before it gets the
 
73
   secret
 
74
** TODO [#B] Support RFC 3339 time duration syntax
 
75
** More D-Bus methods
 
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!
 
88
 
 
89
* mandos.xml
 
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
 
93
 
 
94
* TODO [#A] Provide and install /etc/dbus-1/system.d/mandos.conf
 
95
 
 
96
* mandos-ctl
 
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
 
100
 
 
101
* TODO mandos-dispatch
 
102
  Listens for specified D-Bus signals and spawns shell commands with
 
103
  arguments.
 
104
 
 
105
* mandos-monitor
 
106
** Urwid client data displayer
 
107
   Better view of client data in the listing
 
108
*** Properties popup
 
109
 
 
110
* mandos-keygen
 
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.
 
116
 
 
117
* Makefile
 
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
 
122
 
 
123
* Package
100
124
** /usr/share/initramfs-tools/hooks/mandos
101
 
*** Do not install in initrd.img if configured not to.
102
 
    Use "/etc/initramfs-tools/conf.d/mandos"?  Definitely a debconf
103
 
    question.
104
 
** /etc/bash_completion.d/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
105
129
   From XML sources directly?
106
 
** unperish
107
 
** bzr-builddeb
108
 
 
109
 
* INSTALL file
110
 
 
111
 
* Web site
112
 
 
113
 
* Mailing list
114
 
 
115
 
* Announce project on news
116
 
  [[news:comp.os.linux.announce]]
 
130
 
 
131
* Side Stuff
 
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
117
134
 
118
135
 
119
136
#+STARTUP: showall