/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-08-04 22:46:32 UTC
  • mto: (237.7.1 mandos) (24.1.154 mandos)
  • mto: This revision was merged to the branch mainline in revision 46.
  • Revision ID: belorn@braxen-20080804224632-k1v16lxkiryurd0n
mandosclient
        segmentation fault bug fixed

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
 
* [[http://www.undeadly.org/cgi?action=article&sid=20110530221728][OpenBSD]]
6
 
 
7
 
* mandos-applet
8
 
 
9
 
* mandos-client
10
 
** TODO [#A] Document network hook functionality
11
 
** TODO [#B] Use capabilities instead of seteuid().
12
 
** TODO [#B] Use struct sockaddr_storage instead of a union
13
 
** TODO [#B] Use getaddrinfo(hints=AI_NUMERICHOST) instead of inet_pton()
14
 
** TODO [#B] Use getnameinfo(serv=NULL, NI_NUMERICHOST) instead of inet_ntop()
15
 
** TODO [#B] Prefer /run/tmp over /tmp, if it exists
16
 
 
17
 
* splashy
18
 
** TODO [#B] use scandir(3) instead of readdir(3)
19
 
 
20
 
* usplash (Deprecated)
21
 
** TODO [#A] Make it work again
22
 
** TODO [#B] use scandir(3) instead of readdir(3)
23
 
** TODO Use [[info:libc:Argz%20Functions][argz_extract]]
24
 
 
25
 
* askpass-fifo
26
 
** TODO [#B] Drop privileges after opening FIFO.
27
 
 
28
 
* password-prompt
29
 
** TODO [#B] lock stdin (with flock()?)
30
 
 
31
 
* plymouth
32
 
 
33
 
* TODO [#B] passdev
34
 
 
35
 
* plugin-runner
36
 
** TODO handle printing for errors for plugins
37
 
*** Hook up stderr of plugins, buffer them, and prepend mandos pluig [plugin name]
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 Persistent state                                                  :BUGS:
45
 
   /var/lib/mandos/*
46
 
*** TODO /etc/mandos/clients.d/*.conf
47
 
    Watch this directory and add/remove/update clients?
48
 
** TODO [#C] config for TXT record
49
 
** TODO Log level dbus option
50
 
   SetLogLevel D-Bus call
51
 
** TODO Implement --foreground                                            :BUGS:
52
 
   [[info:standards:Option%20Table][Table of Long Options]]
53
 
** TODO Implement --socket
54
 
   [[info:standards:Option%20Table][Table of Long Options]]
55
 
** TODO Date+time on console log messages                                 :BUGS:
56
 
   Is this the default?
57
 
** TODO [#C] DBusServiceObjectUsingSuper
58
 
** TODO [#B] Global enable/disable flag
59
 
** TODO [#B] By-client countdown on number of secrets given
60
 
** TODO [#B] Support RFC 3339 time duration syntax
61
 
** More D-Bus methods
62
 
*** NeedsPassword(50) - Timeout, default disapprove
63
 
    + SetPass(u"gazonk", True) -> Approval, persistent
64
 
    + Approve(False) -> Close client connection immediately
65
 
** TODO [#C] python-parsedatetime
66
 
** TODO [#C] systemd/launchd
67
 
   http://0pointer.de/blog/projects/systemd.html
68
 
   http://wiki.debian.org/systemd
69
 
** TODO Separate logging logic to own object
70
 
** TODO make clients to a dict!
71
 
** TODO [#A] 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
 
 
77
 
* mandos.xml
78
 
** Add mandos contact info in manual pages
79
 
 
80
 
* mandos-ctl
81
 
*** Handle "no D-Bus server" and/or "no Mandos server found" better
82
 
*** [#B] --dump option
83
 
** TODO Support RFC 3339 time duration syntax
84
 
** TODO Send milliseconds if bare integer is passed as time duration
85
 
 
86
 
* TODO mandos-dispatch
87
 
  Listens for specified D-Bus signals and spawns shell commands with
88
 
  arguments.
89
 
 
90
 
* mandos-monitor
91
 
** TODO help should be toggleable
92
 
** Urwid client data displayer
93
 
   Better view of client data in the listing
94
 
*** Properties popup
95
 
** Nicer crashes. Stack traces Messes up shell.
96
 
*** Print a nice "We are sorry" message, save stack trace to log.
97
 
** Show timeout countdown for approval
98
 
 
99
 
* mandos-keygen
100
 
** TODO "--secfile" option
101
 
   Using the "secfile" option instead of "secret"
102
 
** TODO [#B] "--test" option
103
 
   For testing decryption before rebooting.
104
 
 
105
 
* Makefile
106
 
** TODO [#C] Implement DEB_BUILD_OPTIONS
107
 
   http://www.debian.org/doc/debian-policy/ch-source.html#s-debianrules-options
108
 
 
109
 
* Package
110
 
** /usr/share/initramfs-tools/hooks/mandos
111
 
*** TODO [#C] use same file name rules as run-parts(8)
112
 
*** TODO [#C] Do not install in initrd.img if configured not to.
113
 
    Use "/etc/initramfs-tools/hooksconf.d/mandos"?
114
 
** TODO [#C] /etc/bash_completion.d/mandos
115
 
   From XML sources directly?
116
 
 
117
 
* Side Stuff
118
 
** TODO Locate which package moves the other bin/sh when busybox is deactivated
119
 
** TODO contact owner of package, 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
120
47
 
121
48
 
122
49
#+STARTUP: showall