/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: 2008-11-09 06:40:29 UTC
  • mto: (24.1.113 mandos) (237.2.1 mandos)
  • mto: This revision was merged to the branch mainline in revision 238.
  • Revision ID: teddy@fukt.bsnet.se-20081109064029-df71jpoce308cq3v
First steps of a D-Bus interface to the server.

* mandos: Also import "dbus.service".
  (Client): Inherit from "dbus.service.Object", which is a new-style
            class, so inheriting from "object" is no longer necessary.
  (Client.interface): New temporary variable which only exists during
                     class definition.

  (Client.getName, Client.getFingerprint): New D-Bus getter methods.
  (Client.setSecret): New D-Bus setter method.
  (Client._set_timeout): Emit D-Bus signal "TimeoutChanged".
  (Client.getTimeout): New D-Bus getter method.
  (Client.TimeoutChanged): New D-Bus signal.
  (Client._set_interval): Emit D-Bus signal "IntervalChanged".
  (Client.getInterval): New D-Bus getter method.
  (Client.intervalChanged): New D-Bus signal.
  (Client.__init__): Also call "dbus.service.Object.__init__".
  (Client.started): New boolean attribute.
  (Client.start, Client.stop): Update "self.started", and emit D-Bus
                               signal "StateChanged".
  (Client.StateChanged): New D-Bus signal.
  (Client.stop): Use "self.started" instead of misusing "self.secret".
                 Also simplify code by using "getattr" instead of
                 "hasattr".
  (Client.checker_callback): Emit D-Bus signal "CheckerCompleted".
  (Client.CheckerCompleted): New D-Bus signal.
  (Client.bumpTimeout): D-Bus method name for "bump_timeout".
  (Client.start_checker): Emit D-Bus signal "CheckerStarted".
  (Client.CheckerStarted): New D-Bus signal.
  (Client.checkerIsRunning): New D-Bus method.
  (Client.StopChecker): D-Bus method name for "stop_checker".
  (Client.still_valid): First check "self.started".
  (Client.stillValid): D-Bus method name for "still_valid".

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
-*- org -*-
2
2
 
3
 
* README file
4
 
 
5
 
* COPYING file
6
 
  [[file:/usr/share/common-licenses/GPL-3][GPLv3]]
7
 
 
8
 
* Mandos-client
9
 
** [#A] Man page: man8/mandos-client.8mandos
10
 
** [#A] check return codes of all system calls
11
 
** [#B] header files/symbols tally
12
 
** use strsep instead of strtok?
13
 
** use config file in addition to arguments
14
 
** pass things in environment, like device name, etc
15
 
 
16
 
* Password-request
17
 
** [#A] Man page: man8/password-request.8mandos
18
 
** [#A] check return codes of all system calls
19
 
** [#B] header files/symbols tally
20
 
** IPv4 support
21
 
** use strsep instead of strtok?
22
 
** Do not depend on GPG key rings on disk
23
 
   This would mean creating new GPG key rings with GPGME by importing
24
 
   the key files from scratch on every program start.
25
 
 
26
 
* Password-prompt
27
 
** [#A] Man page: man8/password-prompt.8mandos
28
 
** Use getpass(3)?
29
 
   [[info:libc:getpass][GNU LibC Manual: Reading Passwords]]
30
 
 
31
 
* Server
32
 
** [#A] Command man page: man8/mandos.8
33
 
** [#A] Config file man page: man5/mandos.conf (mandos.conf)
34
 
** [#A] Config file man page: man5/mandos-clients.conf (clients.conf)
35
 
** [#A] /etc/init.d/mandos-server
36
 
** Log level
37
 
** /etc/mandos/clients.d/*.conf
 
3
* mandos-client
 
4
** TODO [#B] Temporarily lower kernel log level
 
5
   for less printouts during sucessfull boot.
 
6
   klogctl(6, NULL, 0); klogctl(7, NULL, 0);
 
7
** TODO [#C] IPv4 support
 
8
 
 
9
* mandos (server)
 
10
** TODO [#B] Log level                          :bugs:
 
11
** TODO /etc/mandos/clients.d/*.conf
38
12
   Watch this directory and add/remove/update clients?
39
 
** config for TXT record
40
 
** Run-time communication with server
41
 
   probably using D-Bus
42
 
** Implement --foreground
43
 
   [[info:standards:Option%20Table][Table of Long Options]]
44
 
** Implement --socket
45
 
   [[info:standards:Option%20Table][Table of Long Options]]
 
13
** TODO config for TXT record
 
14
** TODO [#B] Run-time communication with server :bugs:
 
15
   Probably using D-Bus
 
16
   See also [[*Mandos-tools]]
 
17
*** Client class
 
18
    + getHostname
 
19
    + getChecker
 
20
    + setChecker
 
21
*** Main server
 
22
    + Clients
 
23
      out_signature="ao"
 
24
      Does this have to be "getClients" so as not to collide with the
 
25
      interface name?
 
26
    + setLogLevel
 
27
      syslogger.setLevel(logging.WARNING)
 
28
    + quit
 
29
** TODO Implement --foreground                  :bugs:
 
30
   [[info:standards:Option%20Table][Table of Long Options]]
 
31
** TODO Implement --socket
 
32
   [[info:standards:Option%20Table][Table of Long Options]]
 
33
** TODO Date+time on console log messages       :bugs:
 
34
   Is this the default?
 
35
** TODO delete hook when clients fall out by timeout
46
36
 
47
37
* Mandos-tools/utilities
48
38
  All of this probably using D-Bus
49
 
** List clients
50
 
** Enable client
51
 
** Disable client
52
 
 
53
 
* Installer
54
 
** [#A] Change initrd.img file to not be publically readable
55
 
** [#A] Create GPG key ring files in initrd
56
 
** [#A] Create mandos user and group for server
57
 
** [#A] Create /var/run/mandos directory with perm and ownership
 
39
** TODO List clients
 
40
** TODO Disable client
 
41
** TODO Enable client
 
42
** TODO Reset timer
 
43
 
 
44
* mandos-keygen
 
45
** TODO "--secfile" option
 
46
   Using the "secfile" option instead of "secret"
 
47
** TODO [#B] "--test" option
 
48
   For testing decryption before rebooting.
 
49
 
 
50
* [#A] Package
 
51
** /usr/share/initramfs-tools/hooks/mandos
 
52
*** TODO Do not install in initrd.img if configured not to.
 
53
    Use "/etc/initramfs-tools/conf.d/mandos"?  Definitely a debconf
 
54
    question.
 
55
** TODO /etc/bash_completion.d/mandos
 
56
   From XML sources directly?
58
57
 
59
58
 
60
59
#+STARTUP: showall