summaryrefslogtreecommitdiff
path: root/TODO
blob: 24514d8acb4b775f0c52e8041d6027e2ef88d959 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
                            wallet To-Do List

Client:

 * Handle duplicate kvnos in a newly returned keytab and an existing
   keytab (such as when downloading an unchanging keytab and merging it
   into an existing one) in some reasonable fashion.

 * Support removing old kvnos from a merged keytab (similar to kadmin
   ktremove old).

 * When reading configuration from krb5.conf, we should first try to
   determine our principal from any existing Kerberos ticket cache (after
   obtaining tickets if -u was given) and extract the realm from that
   principal, using it as the default realm when reading configuration
   information.

 * Add readline support to the wallet client to make it easier to issue
   multiple commands.

 * Support authenticating with a keytab.

 * When obtaining tickets in the wallet client with -u, directly obtain
   the service ticket we're going to use for remctl.

 * Provide a way to refresh a file object if and only if what's stored on
   the server is different than what's on disk.  This will require server
   support as well for returning the checksum of a file.

 * Incorporate the wallet-rekey-periodic script (currently in contrib)
   into the package and teach it how to ignore foreign credentials.

Server Interface:

 * Provide a way to get history for deleted objects and ACLs.

 * Provide an interface to mass-change all instances of one ACL to
   another.  (Owner changes are currently supported, but not the other
   ACLs.)

 * Add help functions to wallet-backend and wallet-admin listing the
   commands.

 * Catch exceptions on object creation in wallet-backend so that we can
   log those as well.

 * Provide a way to list all objects for which the connecting user has
   ACLs.

 * Support limiting returned history information by timestamp.

 * Provide a REST implementation of the wallet server.

 * Provide a CGI implementation of the wallet server.

 * Support setting flags and attributes on autocreate.  In general, work
   out a Wallet::Object::Template Perl object that I can return that
   specifies things other than just the ACL.

 * Remove the hard-coded ADMIN ACL in the server with something more
   configurable, perhaps a global ACL table or something.

 * Support leap-of-faith keying of systems by registering an object for
   one-time download (ideally from a specific IP address) and then
   allowing that object to be downloaded anonymously from that IP.  Relies
   on support for Kerberos anonymous authentication.

 * Split "get" and "update" in semantics, and only do keytab rekeying on
   update.  "get" would not be permitted unless the keytab was flagged as
   unchanging, and update would still change even an unchanging keytab
   (maybe).  Or, alternately, maybe we allow get of any keytab?  Requires
   more thought.

 * Add a mechanism to automate owner updates based on default_owner.

 * Partially merge create and autocreate.  create and autocreate should do
   the same thing provided there is an autocreation configuration
   available. If not, autocreate should fail and create should fall back
   on checking for ADMIN privileges.

 * Rewrite server backends to use Net::Remctl::Backend.

 * Merge the Wallet::Logger support written by Commerzbank AG: create a
   new class that handles logging, probably based on Log::Log4perl, and
   add logging points to all of the core classes.

 * Support an authorization hook to determine whether or not to permit
   autocreate.  One requested example feature is to limit autocreate of
   keytab objects to certain hosts involved in deployment.  It should be
   possible to write a hook that takes the information about what object
   is being autocreated and can accept or decline.

ACLs:

 * Error messages from ACL operations should refer to the ACLs by name
   instead of by ID.

 * Write the PTS ACL verifier.

 * Rename Wallet::ACL::* to Wallet::Verifier::*.  Add Wallet::ACL as a
   generic interface with Wallet::ACL::Database and Wallet::ACL::List
   implementations (or some similar name) so that we can create and check
   an ACL without having to write it into the database.  Redo default ACL
   creation using that functionality.

 * Pass a reference to the object for which the ACL is interpreted to the
   ACL API so that ACL APIs can make more complex decisions.

 * Provide an API for verifiers to syntax-check the values before an ACL
   is set and implement syntax checking for the krb5 and ldap-attr
   verifiers.

 * Investigate how best to support client authentication using anonymous
   PKINIT for things like initial system keying.

 * Generalize the current NetDB ACL type to allow a generic remctl query
   for whether a particular user is authorized to create host-based
   objects for a particular host.

 * Add ldap-group ACL scheme (and possibly a root-only version).

 * Add a comment field to ACLs.

Database:

 * Fix case-insensitivity bug in unique keys with MySQL for objects.  When
   creating an http/<host> principal when an HTTP/<host> principal already
   existed, MySQL rejected the row entry as a duplicate.  The name should
   be case-sensitive.

 * On upgrades, support adding new object types and ACL verifiers to the
   class tables.

Objects:

 * Check whether we can just drop the realm restriction on keytabs and
   allow the name to contain the realm if the Kerberos type is Heimdal.

 * Use the Perl Authen::Krb5::Admin module instead of rolling our own
   kadmin code with Expect now that MIT Kerberos has made the kadmin API
   public.

 * Implement an ssh keypair wallet object.  The server can run ssh-keygen
   to generate a public/private key pair and return both to the client,
   which would split them apart.  Used primarily for host keys.  May need
   a side table to store key types, or a naming convention.

 * Implement an X.509 certificate object.  I expect this would store the
   public and private key as a single file in the same format that Apache
   can read for combined public and private keys.  There were requests for
   storing the CSR, but I don't see why you'd want to do that.  Start with
   store support.  The file code is mostly sufficient here, but it would
   be nice to automatically support object expiration based on the
   expiration time for the certificate.

 * Implement an X.509 CA so that you can get certificate objects without
   storing them first.  Need to resolve naming conventions if you want to
   run multiple CAs on the same wallet server (but why?).  Should this be
   a different type than stored certificates?  Consider using hxtool as
   the underlying CA mechanism.

 * Support returning the checksum of a file object stored in wallet so
   that one can determine whether the version stored on disk is identical.

 * Support setting the disallow-svr flag on created principals.  In
   general, support setting arbitrary principal flags.

Reports:

 * Add audit for references to unknown ACLs, possibly introduced by
   previous versions before ACL deletion was checked with database
   backends that don't do referential integrity.

 * For objects tied to hostnames, report on objects referring to hosts
   which do not exist.  For the initial pass, this is probably only keytab
   objects with names containing a slash where the part after the slash
   looks like a hostname.  This may need some configuration help.

 * Make contrib/wallet-summary generic and include it in wallet-report,
   with additional configuration in Wallet::Config.  Enhance it to report
   on any sort of object, not just on keytabs, and to give numbers on
   downloaded versus not downloaded objects.

 * Write a tool to mail the owners of wallet objects, taking the list of
   objects and the mail message to send as inputs.  This could possibly
   use the notification service, although a version that sends mail
   directly would be useful external to Stanford.

 * Merge the Commerzbank AG work to dump all the object history, applying
   various search criteria to it, or clear parts of the object history.

Administrative Interface:

 * Add a function to wallet-admin to purge expired entries.  Possibly also
   check expiration before allowing anyone to get or store objects.

 * Add a function or separate script to automate removal of DNS-based
   objects for which the hosts no longer exist.  Will need to support a
   site-specific callout to determine whether the host exists.

 * Database creation appears not to work without the SQL files, but it's
   supposed to work directly from the classes.  Double-check this.

Documentation:

 * Write a conventions document for ACL naming, object naming, and similar
   issues.

 * Write a future design and roadmap document to collect notes about how
   unimplemented features should be handled.

 * Document using the wallet system over something other than remctl.

 * Document all diagnostics for all wallet APIs.

 * Document configuration with an Oracle database.

Code Style and Cleanup:

 * There is a lot of duplicate code in wallet-backend.  Convert that to
   use some sort of data-driven model with argument count and flags so
   that the method calls can be written only once.  Convert wallet-admin
   to use the same code.

 * There's a lot of code duplication in the dispatch functions in the
   Wallet::Server class.  Find a way to rewrite that so that the dispatch
   doesn't duplicate the same code patterns.

 * The wallet-backend and wallet documentation share the COMMANDS section.
   Work out some means to assemble the documentation without duplicating
   content.

 * The Wallet::Config class is very ugly and could use some better
   internal API to reference the variables in it.

 * Consider using Class::Accessor to get rid of the scaffolding code to
   access object data.  Alternately, consider using Moose.

 * Rewrite the error handling to use exceptions instead of the C-style
   return value and separate error call.

Test Suite:

 * The ldap-attr verifier test case is awful and completely specific to
   people with admin access to the Stanford LDAP tree.  Write a real test.

 * Rename the tests to use a subdirectory organization.

 * Add POD coverage testing using Test::POD::Coverage for the server
   modules.

 * Rewrite the client test suite to use Perl and to make better use of
   shared code so that it can be broken into function components.

 * Refactor the test suite for the wallet backend to try to reduce the
   duplicated code.  Using a real mock infrastructure should make this
   test suite much easier to write.

 * Pull common test suite code into a Perl library that can be reused.

 * Write a test suite to scan all wallet code looking for diagnostics that
   aren't in the documentation and warn about them.