/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

  • Committer: Teddy Hogeborn
  • Date: 2021-02-03 23:10:42 UTC
  • Revision ID: teddy@recompile.se-20210203231042-2z3egrvpo1zt7nej
mandos-ctl: Fix bad test for command.Remove and related minor issues

The test for command.Remove removes all clients from the spy server,
and then loops over all clients, looking for the corresponding Remove
command as recorded by the spy server.  But since since there aren't
any clients left after they were removed, no assertions are made, and
the test therefore does nothing.  Fix this.

In tests for command.Approve and command.Deny, add checks that clients
were not somehow removed by the command (in which case, likewise, no
assertions are made).

Add related checks to TestPropertySetterCmd.runTest; i.e. test that a
sequence is not empty before looping over it and making assertions.

* mandos-ctl (TestBaseCommands.test_Remove): Save a copy of the
  original "clients" dict, and loop over those instead.  Add assertion
  that all clients were indeed removed.  Also fix the code which looks
  for the Remove command, which now needs to actually work.
  (TestBaseCommands.test_Approve, TestBaseCommands.test_Deny): Add
  assertion that there are still clients before looping over them.
  (TestPropertySetterCmd.runTest): Add assertion that the list of
  values to get is not empty before looping over them.  Also add check
  that there are still clients before looping over clients.

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
3
* Testing
18
4
** python-nemu
19
5
 
20
6
* mandos-applet
21
7
 
22
8
* mandos-client
23
 
** TODO [#B] Use capabilities instead of seteuid().
24
 
** TODO [#B] Use getaddrinfo(hints=AI_NUMERICHOST) instead of inet_pton()
25
 
** TODO [#C] Make start_mandos_communication() take "struct server".
 
9
** TODO A ~--server~ option which only adds to the server list.
 
10
   (Unlike ~--connect~, which implicitly disables ZeroConf.)
 
11
** TODO [#B] Use [[man:capabilities][capabilities]] instead of [[info:libc#Setting%20User%20ID][seteuid()]].
 
12
   [[https://forums.grsecurity.net/viewtopic.php?f=7&t=2522]]
 
13
** TODO [#B] Use ~getaddrinfo(hints=AI_NUMERICHOST)~ instead of ~inet_pton()~
 
14
** TODO [#C] Make ~start_mandos_communication()~ take ~struct server~.
 
15
** TODO [#C] ~--interfaces=regex,eth*,noregex~ [[man:bridge-utils-interfaces][bridge-utils-interfaces(5)]]
 
16
** TODO [#A] Detect partial writes to stdout and exit with ~EX_TEMPFAIL~
26
17
 
27
18
* splashy
28
 
** TODO [#B] use scandir(3) instead of readdir(3)
 
19
** TODO [#B] use [[info:libc#Scanning%20Directory%20Content][scandir(3)]] instead of [[info:libc#Reading/Closing%20Directory][readdir(3)]]
 
20
** TODO [#A] Detect partial writes to stdout and exit with ~EX_TEMPFAIL~
29
21
 
30
22
* usplash (Deprecated)
31
 
** TODO [#A] Make it work again
32
 
** TODO [#B] use scandir(3) instead of readdir(3)
 
23
** TODO [#B] Make it work again
 
24
** TODO [#B] use [[info:libc#Scanning%20Directory%20Content][scandir(3)]] instead of [[info:libc#Reading/Closing%20Directory][readdir(3)]]
 
25
** TODO [#A] Detect partial writes to stdout and exit with ~EX_TEMPFAIL~
33
26
 
34
27
* askpass-fifo
 
28
** TODO [#A] Detect partial writes to stdout and exit with ~EX_TEMPFAIL~
35
29
 
36
30
* password-prompt
37
 
** TODO [#B] lock stdin (with flock()?)
 
31
** TODO [#B] lock stdin (with [[info:libc#File%20Locks][flock()]]?)
 
32
** TODO [#A] Detect partial writes to stdout and exit with ~EX_TEMPFAIL~
38
33
 
39
34
* plymouth
 
35
** TODO [#A] Detect partial writes to stdout and exit with ~EX_TEMPFAIL~
40
36
 
41
37
* TODO [#B] passdev
42
38
 
43
39
* plugin-runner
44
40
** TODO handle printing for errors for plugins
45
41
*** Hook up stderr of plugins, buffer them, and prepend "Mandos Plugin [plugin name]"
46
 
** TODO [#C] use same file name rules as run-parts(8)
 
42
** TODO [#C] use same file name rules as [[man:run-parts][run-parts(8)]]
47
43
** kernel command line option for debug info
 
44
** TODO [#A] Restart plugins which exit with ~EX_TEMPFAIL~
48
45
 
49
46
* mandos (server)
 
47
** TODO [#B] ~--notify-command~
 
48
   This would allow the mandos.service to use
 
49
   ~--notify-command="systemd-notify --pid --ready"~
 
50
** TODO [#B] python-systemd
 
51
*** import systemd.daemon; systemd.daemon.notify()
50
52
** TODO [#B] Log level                                                    :BUGS:
51
53
*** TODO /etc/mandos/clients.d/*.conf
52
54
    Watch this directory and add/remove/update clients?
57
59
** TODO [#B] Global enable/disable flag
58
60
** TODO [#B] By-client countdown on number of secrets given
59
61
** D-Bus Client method NeedsPassword(50) - Timeout, default disapprove
60
 
    + SetPass(u"gazonk", True) -> Approval, persistent
 
62
    + SetPass("gazonk", True) -> Approval, persistent
61
63
    + Approve(False) -> Close client connection immediately
62
64
** TODO [#C] python-parsedatetime
63
65
** TODO Separate logging logic to own object
64
 
** TODO [#A] Limit approval_delay to max gnutls/tls timeout value
65
 
** TODO [#B] break the wait on approval_delay if connection dies
66
 
** TODO Generate Client.runtime_expansions from client options + extra
 
66
** TODO [#B] Limit ~approval_delay~ to max GnuTLS/TLS timeout value
 
67
** TODO [#B] break the wait on ~approval_delay~ if connection dies
 
68
** TODO Generate ~Client.runtime_expansions~ from client options + extra
67
69
** TODO Allow %%(checker)s as a runtime expansion
68
 
** TODO Use python-tlslite?
69
70
** TODO D-Bus AddClient() method on server object
70
71
** TODO Use org.freedesktop.DBus.Method.NoReply annotation on async methods. :2:
71
 
** TODO Emit [[http://dbus.freedesktop.org/doc/dbus-specification.html#standard-interfaces-properties][org.freedesktop.DBus.Properties.PropertiesChanged]] signal            :2:
72
 
   TODO Deprecate se.recompile.Mandos.Client.PropertyChanged - annotate!
73
 
   TODO Can use "invalidates" annotation to also emit on changed secret.
74
 
** TODO Support [[http://dbus.freedesktop.org/doc/dbus-specification.html#standard-interfaces-objectmanager][org.freedesktop.DBus.ObjectManager]] interface on server object :2:
75
 
   Deprecate methods GetAllClients(), GetAllClientsWithProperties()
76
 
   and signals ClientAdded and ClientRemoved.
77
72
** TODO Save state periodically to recover better from hard shutdowns
78
73
** TODO CheckerCompleted method, deprecate CheckedOK
79
 
** TODO Secret Service API?
80
 
   http://standards.freedesktop.org/secret-service/
81
 
** TODO Remove D-Bus interfaces with old domain name                         :2:
82
 
** TODO Remove old string_to_delta format                                    :2:
 
74
** TODO [[https://standards.freedesktop.org/secret-service/][Secret Service]] API?
 
75
** TODO Remove D-Bus interfaces with old domain name                      :2:
 
76
** TODO Remove old ~string_to_delta~ format                               :2:
83
77
** TODO http://0pointer.de/blog/projects/stateless.html
84
 
*** tmpfiles snippet to create /var/lib/mandos with right user+perms
85
 
*** File in /usr/lib/sysusers.d to create user+group "_mandos"
 
78
*** File in /usr/lib/sysusers.d to create user+group "~_mandos~"
86
79
** TODO Error handling on error parsing config files
87
80
** TODO init.d script error handling
88
 
** TODO D-Bus server properties; address, port, interface, etc.              :2:
89
 
 
90
 
* mandos.xml
91
 
** Add mandos contact info in manual pages
 
81
** TODO D-Bus server properties; address, port, interface, etc.           :2:
92
82
 
93
83
* mandos-ctl
94
 
*** Handle "no D-Bus server" and/or "no Mandos server found" better
95
 
*** [#B] --dump option
96
 
** TODO Remove old string_to_delta format                                    :2:
 
84
** TODO Remove old string_to_delta format                                 :2:
97
85
 
98
86
* TODO mandos-dispatch
99
87
  Listens for specified D-Bus signals and spawns shell commands with
100
88
  arguments.
101
89
 
102
90
* mandos-monitor
 
91
** TODO ~--servicename~                                                :BUGS:
103
92
** TODO help should be toggleable
104
93
** Urwid client data displayer
105
94
   Better view of client data in the listing
106
95
*** Properties popup
107
96
** Print a nice "We are sorry" message, save stack trace to log.
108
 
** Rename module "gobject" to "GObject".
109
97
 
110
98
* mandos-keygen
111
 
** TODO "--secfile" option
 
99
** TODO "~--secfile~" option
112
100
   Using the "secfile" option instead of "secret"
113
 
** TODO [#B] "--test" option
 
101
** TODO [#B] "~--test~" option
114
102
   For testing decryption before rebooting.
115
103
 
116
104
* Package
117
105
** /usr/share/initramfs-tools/hooks/mandos
118
 
*** TODO [#C] use same file name rules as run-parts(8)
 
106
*** TODO [#C] use same file name rules as [[man:run-parts][run-parts(8)]]
119
107
*** TODO [#C] Do not install in initrd.img if configured not to.
120
108
    Use "/etc/initramfs-tools/hooksconf.d/mandos"?
121
 
** TODO [#C] /etc/bash_completion.d/mandos
 
109
** TODO [#C] ~$(pkg-config --variable=completionsdir bash-completion)~
122
110
   From XML sources directly?
123
111
 
124
112
* Side Stuff
125
113
** TODO Locate which package moves the other bin/sh when busybox is deactivated
126
114
** TODO contact owner of package, and ask them to have that shell static in position regardless of busybox
127
115
 
 
116
* [[http://www.undeadly.org/cgi?action=article&sid=20110530221728][OpenBSD]]
 
117
 
128
118
 
129
119
#+STARTUP: showall
 
120
#+FILETAGS: :mandos: