/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-07-19 18:43:24 UTC
  • Revision ID: teddy@fukt.bsnet.se-20080719184324-iwhoa5in75xa0u2u
* mandos-clients.conf ([foo]/dn, [foo]/password, [braxen_client]/dn,
                       [braxen_client]/password): Removed.
  ([foo]/fingerprint, [braxen_client]/fingerprint): New.
  ([foo]/checker): New.
  ([foo]/secfile): New.
  ([braxen_client]/secret): New.

* server.py: New "--debug" option to set debug flag.  Removed "cert",
             "key", "ca", "crl", and "cred" variables.  Added default
             value for "checker" config file setting.  Do not pass
             credentials to IPv6_TCPServer constructor.
  (debug): New global debug flag.  Used by most debugging output code.
  (Client.__init__): Keyword argument "dn" replaced by "fingerprint",
                     "password" renamed to "secret", and "passfile"
                     renamed to "secfile".  New keyword argument
                     "checker". All callers changed.
  (Client.dn): Removed.
  (Client.fingerprint): New.
  (Client.password): Renamed to "secret"; all users changed.
  (Client.passfile): Renamed to "secfile"; all users changed.
  (Client.timeout, Client.interval): Changed to be properties; now
                                     automatically updates the
                                     "_timeout_milliseconds" and
                                     "_interval_milliseconds" values.
  (Client.timeout_milliseconds): Renamed to "_timeout_milliseconds".
  (Client.interval_milliseconds): Renamed to "_interval_milliseconds".
  (Client.check_command): New.
  (Client.start_checker): Use the new "check_command" attribute.
  (peer_certificate, fingerprint): New functions.

  (tcp_handler.handle): Use ClientSession with empty credentials
                        object instead of ServerSession.  Set gnutls
                        priority string.  Do not verify peer.  Use
                        fingerprint instead of DN when searching for
                        clients.  Bug fix: Loop sending data so even large
                        secret data strings are sent.
  (IPv6_TCPServer.credentials): Removed.
  (if_nametoindex): Do not import ctypes since that is now imported
                    globally.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
-*- org -*-
2
 
 
3
 
* [#A] README file
4
 
 
5
 
* plugin-runner
6
 
** [#B] Add more comments to code
7
 
** [#B] Add more if(debug) calls
8
 
** [#B] Seperate more code to function for more readability
9
 
 
10
 
* password-request
11
 
** [#A] Man page: man8/password-request.8mandos
12
 
*** FILES
13
 
    Describe the key files and the key ring files.  Also note that
14
 
    they should normally have been automatically created.
15
 
*** BUGS
16
 
*** EXAMPLE
17
 
    Examples of normal usage, debug usage, debugging by connecting
18
 
    directly, etc.
19
 
*** SECURITY
20
 
*** SEE ALSO
21
 
    Update from mandos.xml
22
 
** [#B] Temporarily lower kernel log level
23
 
   for less printouts during sucessfull boot.
24
 
** IPv4 support
25
 
** use strsep instead of strtok?
26
 
** Do not depend on GnuPG key rings on disk
27
 
   This would mean creating new GnuPG key rings with GPGME by
28
 
   importing the key files from scratch on every program start.
29
 
** Keydir move: /etc/mandos -> /etc/keys/mandos
30
 
   Must create in preinst if not pre-depending on cryptsetup
31
 
 
32
 
* password-prompt
33
 
** [#C] Use getpass(3)?
34
 
   Man page says "obsolete", but [[info:libc:getpass][GNU LibC Manual: Reading Passwords]]
35
 
   does not.  See also [[http://sources.redhat.com/ml/libc-alpha/2003-05/msg00251.html][Marcus Brinkmann: Re: getpass obsolete?]] and
36
 
   [[http://article.gmane.org/gmane.comp.lib.glibc.alpha/4906][Petter Reinholdtsen: Re: getpass obsolete?]], and especially also
37
 
   [[http://www.steve.org.uk/Reference/Unix/faq_4.html#SEC48][Unix Programming FAQ 3.1 How can I make my program not echo input?]]
38
 
 
39
 
* mandos (server)
40
 
** [#A] /etc/init.d/mandos-server               :teddy:
41
 
** [#B] Log level                               :bugs:
42
 
** /etc/mandos/clients.d/*.conf
43
 
   Watch this directory and add/remove/update clients?
44
 
** config for TXT record
45
 
** [#B] Run-time communication with server      :bugs:
46
 
   Probably using D-Bus
47
 
   See also [[*Mandos-tools]]
48
 
** Implement --foreground                       :bugs:
49
 
   [[info:standards:Option%20Table][Table of Long Options]]
50
 
** Implement --socket
51
 
   [[info:standards:Option%20Table][Table of Long Options]]
52
 
** Date+time on console log messages            :bugs:
53
 
   Is this the default?
54
 
 
55
 
* Mandos-tools/utilities
56
 
  All of this probably using D-Bus
57
 
** List clients
58
 
** Disable client
59
 
** Enable client
60
 
 
61
 
* Man pages
62
 
** Use xinclude for common sections
63
 
   Like authors, etc.
64
 
 
65
 
 
66
 
* Installer
67
 
** Client-side
68
 
*** Update initrd.img after installation
69
 
    This seems to use some kind of "trigger" system
70
 
    [[file:/usr/share/doc/dpkg/triggers.txt.gz]]
71
 
    dpkg-trigger(1), deb-triggers(5)
72
 
*** Keydir move: /etc/mandos -> /etc/keys/mandos
73
 
    Must create in preinst if not pre-depending on cryptsetup
74
 
*** mandos-keygen
75
 
**** "--passfile" option
76
 
     Using the "secfile" option instead of "secret"
77
 
**** [#A] "--test" option
78
 
     For testing decryption before rebooting.
79
 
** Server-side
80
 
*** [#A] Create mandos user and group for server
81
 
*** [#A] Create /var/run/mandos directory with perm and ownership
82
 
 
83
 
* [#A] Package
84
 
** /usr/share/initramfs-tools/hooks/mandos
85
 
*** Do not install in initrd.img if configured not to.
86
 
    Use "/etc/initramfs-tools/conf.d/mandos"?  Definitely a debconf
87
 
    question.
88
 
** /etc/bash_completion.d/mandos
89
 
   From XML sources directly?
90
 
** unperish
91
 
** bzr-builddeb
92
 
 
93
 
* INSTALL file
94
 
 
95
 
* Web site
96
 
 
97
 
* Mailing list
98
 
 
99
 
* Announce project on news
100
 
  [[news:comp.os.linux.announce]]
101
 
 
102
 
 
103
 
#+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