/mandos/release

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

« back to all changes in this revision

Viewing changes to TODO

  • Committer: Björn Påhlsson
  • Date: 2008-07-20 02:52:20 UTC
  • Revision ID: belorn@braxen-20080720025220-r5u0388uy9iu23h6
Added following support:
Pluginbased client handler
rewritten Mandos client
       Avahi instead of udp server discovery
       openpgp encrypted key support
Passprompt stand alone application for direct console input
Added logging for Mandos server

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
-*- org -*-
2
 
 
3
 
* Use _attribute_((nonnull)) wherever possible.
4
 
 
5
 
* mandos-applet
6
 
 
7
 
* mandos-client
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()
12
 
 
13
 
* splashy
14
 
** TODO [#B] use scandir(3) instead of readdir(3)
15
 
 
16
 
* usplash
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]]
20
 
 
21
 
* askpass-fifo
22
 
** TODO [#B] Drop privileges after opening FIFO.
23
 
 
24
 
* password-prompt
25
 
** TODO [#B] lock stdin (with flock()?)
26
 
 
27
 
* plymouth
28
 
 
29
 
* TODO [#B] passdev
30
 
 
31
 
* plugin-runner
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()
38
 
 
39
 
* mandos (server)
40
 
** TODO [#B] Log level                                                    :BUGS:
41
 
** TODO Persistent state                                                  :BUGS:
42
 
   /var/lib/mandos/*
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:
54
 
   Is this the default?
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
63
 
   desired.
64
 
** TODO [#A] Client manual approval mode
65
 
   A client needs manual approval on the server before it gets the
66
 
   secret
67
 
** TODO [#B] Support RFC 3339 time duration syntax
68
 
** More D-Bus methods
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?
86
 
 
87
 
* mandos.xml
88
 
** Add mandos contact info in manual pages
89
 
 
90
 
* mandos-ctl
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
94
 
 
95
 
* TODO mandos-dispatch
96
 
  Listens for specified D-Bus signals and spawns shell commands with
97
 
  arguments.
98
 
 
99
 
* mandos-monitor
100
 
** TODO help should be toggleable
101
 
** Urwid client data displayer
102
 
   Better view of client data in the listing
103
 
*** Properties popup
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
107
 
 
108
 
* mandos-keygen
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.
114
 
 
115
 
* Makefile
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
120
 
 
121
 
* Package
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?
128
 
 
129
 
* Side Stuff
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
132
 
 
133
 
 
134
 
#+STARTUP: showall
 
1
[Client]
 
2
configuration for cert, key, CA and interface
 
3
IPv4 support
 
4
OpenPGP keys support
 
5
 
 
6
[Server]
 
7
config file
 
8
client-list
 
9
run-time communication with server
 
10
 
 
11
handle SIGTERM, SIGQUIT, etc.
 
12
 
 
13
[Mandos-tools/utilities]
 
14
        List clients
 
15
        Enable client
 
16
        Disable client