/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: Teddy Hogeborn
  • Date: 2014-07-25 22:44:20 UTC
  • mto: (237.7.272 trunk)
  • mto: This revision was merged to the branch mainline in revision 321.
  • Revision ID: teddy@recompile.se-20140725224420-4a5ct2ptt0hsc92z
Require Python 2.7.

This is in preparation for the eventual move to Python 3, which will
happen as soon as all Python modules required by Mandos are available.
The mandos-ctl and mandos-monitor programs are already portable
between Python 2.6 and Python 3 without changes; this change will
bring the requirement up to Python 2.7.

* INSTALL (Prerequisites/Libraries/Mandos Server): Document
                                                   requirement of
                                                   Python 2.7; remove
                                                   Python-argparse
                                                   which is in the
                                                   Python 2.7 standard
                                                   library.
* debian/control (Source: mandos/Build-Depends-Indep): Depend on
                                                       exactly the
                                                       python2.7
                                                       package and all
                                                       the Python 2.7
                                                       versions of the
                                                       python modules.
  (Package: mandos/Depends): - '' - but still depend on python (<=2.7)
                            and the generic versions of the Python
                            modules; this is for mandos-ctl and
                            mandos-monitor, both of which are
                            compatible with Python 3, and use
                            #!/usr/bin/python.
* mandos: Use #!/usr/bin/python2.7 instead of #!/usr/bin/python.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
-*- org -*-
2
2
 
 
3
* GIT
 
4
** General: [[https://www.atlassian.com/git/workflows][Git Workflows]], [[http://gitimmersion.com/][Git Immersion]], [[https://news.ycombinator.com/item?id=7036628][Simple git workflow is simple]]
 
5
** Intro: [[http://www.eyrie.org/~eagle/notes/debian/git.html#combine][Using Git for Debian Packaging]]
 
6
** Use: [[https://honk.sigxcpu.org/piki/projects/git-buildpackage/][git-buildpackage]]
 
7
** Migration
 
8
   tailor?
 
9
   Using bzr-fastimport: [[http://www.fusonic.net/en/blog/2013/03/26/migrating-from-bazaar-to-git/][Migrating from Bazaar to Git]]
 
10
** Unresolved: [[http://jameswestby.net/bzr/builddeb/user_manual/split.html][bzr builddeb split mode]]
 
11
   Maybe: [[http://honk.sigxcpu.org/projects/git-buildpackage/manual-html/gbp.import.html#GBP.IMPORT.UPSTREAM.GIT.NOTARBALL][git-buildpackage - No upstream tarballs]]
 
12
   [[http://www.python.org/dev/peps/pep-0374/][PEP 374 - Choosing a distributed VCS for the Python project]]
 
13
   [[http://www.emacswiki.org/emacs/GitForEmacsDevs][Git For Emacs Devs]]
 
14
 
 
15
* [[http://www.undeadly.org/cgi?action=article&sid=20110530221728][OpenBSD]]
 
16
 
 
17
* Testing
 
18
** python-nemu
 
19
 
 
20
* mandos-applet
 
21
 
3
22
* mandos-client
4
 
** TODO [#B] use scandir(3) instead of readdir(3)
5
 
** TODO [#B] Prefix all debug output with "Mandos plugin " + program_invocation_short_name
6
 
** TODO use error() instead of perror()
7
 
** TODO [#B] Retry a server which has a non-definite reply:
8
 
*** A closed connection during the TLS handshake
9
 
*** A TCP timeout
10
23
** TODO [#B] Use capabilities instead of seteuid().
11
 
** TODO use EX_* from <sysexits.h>
 
24
** TODO [#B] Use getaddrinfo(hints=AI_NUMERICHOST) instead of inet_pton()
 
25
** TODO [#C] Make start_mandos_communication() take "struct server".
12
26
 
13
27
* splashy
14
28
** TODO [#B] use scandir(3) instead of readdir(3)
15
 
** TODO [#B] Prefix all debug output with "Mandos plugin " + program_invocation_short_name
16
 
** TODO use error() instead of perror()
17
29
 
18
 
* usplash
 
30
* usplash (Deprecated)
 
31
** TODO [#A] Make it work again
19
32
** TODO [#B] use scandir(3) instead of readdir(3)
20
 
** TODO [#B] Prefix all debug output with "Mandos plugin " + program_invocation_short_name
21
 
** TODO use error() instead of perror()
22
 
** TODO use EX_* from <sysexits.h>
23
33
 
24
34
* askpass-fifo
25
 
** TODO [#B] Prefix all debug output with "Mandos plugin " + program_invocation_short_name
26
 
** TODO use error() instead of perror()
27
35
** TODO [#B] Drop privileges after opening FIFO.
28
36
 
29
37
* password-prompt
30
 
** TODO [#B] Prefix all debug output with "Mandos plugin " + program_invocation_short_name
31
 
** TODO use error() instead of perror()
32
 
** TODO lock stdin (with flock()?)
33
 
 
34
 
* TODO passdev
 
38
** TODO [#B] lock stdin (with flock()?)
 
39
 
 
40
* plymouth
 
41
 
 
42
* TODO [#B] passdev
35
43
 
36
44
* plugin-runner
37
 
** TODO [#B] use scandir(3) instead of readdir(3)
 
45
** TODO handle printing for errors for plugins
 
46
*** Hook up stderr of plugins, buffer them, and prepend "Mandos Plugin [plugin name]"
38
47
** TODO [#C] use same file name rules as run-parts(8)
39
 
** TODO use EX_* from <sysexits.h>
40
 
** TODO use error() instead of perror()
 
48
** kernel command line option for debug info
41
49
 
42
50
* mandos (server)
43
 
** TODO [#B] Log level                          :BUGS:
44
 
** TODO /etc/mandos/clients.d/*.conf
45
 
   Watch this directory and add/remove/update clients?
46
 
** TODO config for TXT record
47
 
** TODO [#B] Run-time communication with server :BUGS:
48
 
   Probably using D-Bus
49
 
*** Client class
50
 
*** Main server
51
 
    + SetLogLevel
52
 
      syslogger.setLevel(logging.WARNING)
53
 
    + [[http://log.ometer.com/2007-05.html][Best D-Bus practices]]
54
 
** TODO Implement --foreground                  :BUGS:
55
 
   [[info:standards:Option%20Table][Table of Long Options]]
56
 
** TODO Implement --socket
57
 
   [[info:standards:Option%20Table][Table of Long Options]]
58
 
** TODO Date+time on console log messages       :BUGS:
59
 
   Is this the default?
60
 
** TODO DBusServiceObjectUsingSuper
61
 
** TODO Global enable/disable flag
62
 
** TODO By-client countdown on secrets given
63
 
** TODO Fix problem with fsck taking a really long time
64
 
   Whenever a client successfully gets a secret it could get a
65
 
   one-time timeout boost to allow for an fsck-incurred delay
66
 
** TODO Delay before client receives key
67
 
   This would give an operator opportunity to cancel the request if
68
 
   desired.
69
 
** TODO Client manual approval mode
70
 
   A client needs manual approval on the server before it gets the
71
 
   secret
72
 
** TODO Persistent state
73
 
   /var/lib/mandos/*
 
51
** TODO [#B] Log level                                                    :BUGS:
 
52
*** TODO /etc/mandos/clients.d/*.conf
 
53
    Watch this directory and add/remove/update clients?
 
54
** TODO [#C] config for TXT record
 
55
** TODO Log level dbus option
 
56
   SetLogLevel D-Bus call
 
57
** TODO [#C] DBusServiceObjectUsingSuper
 
58
** TODO [#B] Global enable/disable flag
 
59
** TODO [#B] By-client countdown on number of secrets given
 
60
** D-Bus Client method NeedsPassword(50) - Timeout, default disapprove
 
61
    + SetPass(u"gazonk", True) -> Approval, persistent
 
62
    + Approve(False) -> Close client connection immediately
 
63
** TODO [#C] python-parsedatetime
 
64
** TODO Separate logging logic to own object
 
65
** TODO [#A] Limit approval_delay to max gnutls/tls timeout value
 
66
** TODO [#B] break the wait on approval_delay if connection dies
 
67
** TODO Generate Client.runtime_expansions from client options + extra
 
68
** TODO Allow %%(checker)s as a runtime expansion
 
69
** TODO Use python-tlslite?
 
70
** TODO D-Bus AddClient() method on server object
 
71
** TODO Use org.freedesktop.DBus.Method.NoReply annotation on async methods. :2:
 
72
** TODO Emit [[http://dbus.freedesktop.org/doc/dbus-specification.html#standard-interfaces-properties][org.freedesktop.DBus.Properties.PropertiesChanged]] signal         :2:
 
73
   TODO Deprecate se.recompile.Mandos.Client.PropertyChanged - annotate!
 
74
   TODO Can use "invalidates" annotation to also emit on changed secret.
 
75
** TODO Support [[http://dbus.freedesktop.org/doc/dbus-specification.html#standard-interfaces-objectmanager][org.freedesktop.DBus.ObjectManager]] interface on server object :2:
 
76
   Deprecate methods GetAllClients(), GetAllClientsWithProperties()
 
77
   and signals ClientAdded and ClientRemoved.
 
78
** TODO Save state periodically to recover better from hard shutdowns
 
79
** TODO CheckerCompleted method, deprecate CheckedOK
 
80
** TODO Secret Service API?
 
81
   http://standards.freedesktop.org/secret-service/
 
82
** TODO Remove D-Bus interfaces with old domain name                      :2:
 
83
** TODO Remove old string_to_delta format                                 :2:
 
84
** TODO http://0pointer.de/blog/projects/stateless.html
 
85
*** tmpfiles snippet to create /var/lib/mandos with right user+perms
 
86
*** File in /usr/lib/sysusers.d to create user+group "_mandos"
 
87
** TODO Error handling on error parsing config files
 
88
** TODO init.d script error handling
74
89
 
75
90
* mandos.xml
76
 
** [[file:mandos.xml::XXX][Document D-Bus interface]]
77
 
 
78
 
* Provide and install /etc/dbus-1/system.d/mandos.conf
 
91
** Add mandos contact info in manual pages
79
92
 
80
93
* mandos-ctl
81
94
*** Handle "no D-Bus server" and/or "no Mandos server found" better
82
95
*** [#B] --dump option
 
96
** TODO Remove old string_to_delta format                                 :2:
83
97
 
84
98
* TODO mandos-dispatch
85
99
  Listens for specified D-Bus signals and spawns shell commands with
86
100
  arguments.
87
101
 
88
102
* mandos-monitor
89
 
** D-Bus main loop w/ signal receiver
 
103
** TODO help should be toggleable
90
104
** Urwid client data displayer
91
 
*** Urwid scaffolding
92
 
*** Client Widgets
 
105
   Better view of client data in the listing
93
106
*** Properties popup
 
107
** Print a nice "We are sorry" message, save stack trace to log.
 
108
** Rename module "gobject" to "GObject".
94
109
 
95
110
* mandos-keygen
96
 
** TODO Loop until passwords match when run interactively
97
111
** TODO "--secfile" option
98
112
   Using the "secfile" option instead of "secret"
99
113
** TODO [#B] "--test" option
100
114
   For testing decryption before rebooting.
101
115
 
102
 
* Makefile
103
 
** Implement DEB_BUILD_OPTIONS
104
 
   http://www.debian.org/doc/debian-policy/ch-source.html#s-debianrules-options
105
 
 
106
116
* Package
107
117
** /usr/share/initramfs-tools/hooks/mandos
108
118
*** TODO [#C] use same file name rules as run-parts(8)
111
121
** TODO [#C] /etc/bash_completion.d/mandos
112
122
   From XML sources directly?
113
123
 
 
124
* Side Stuff
 
125
** TODO Locate which package moves the other bin/sh when busybox is deactivated
 
126
** TODO contact owner of package, and ask them to have that shell static in position regardless of busybox
 
127
 
114
128
 
115
129
#+STARTUP: showall