]> git.decadent.org.uk Git - dak.git/blob - TODO
two bug fixes in source_exists changes
[dak.git] / TODO
1                                  TODO
2                                  ====
3
4 [NB: I use this as a thought record/scribble, not everything on here
5      makes sense and/or is actually ever going to get done, so IIWY I
6      wouldn't use it as gospel for the future of katie or as a TODO
7      list for random hacking.]
8
9 ================================================================================
10
11 queue/approved
12 --------------
13
14  o What to do with multi-suite uploads?  Presumably hold in unapproved
15    and warn?  Or what?  Can't accept just for unstable or reject just
16    from stable.
17
18  o Whenever we check for anything in accepted we also need to check in
19    unapproved.
20
21  o non-sourceful uploads should go straight through if they have
22    source in accepted or the archive.
23
24  o security uploads on auric should be pre-approved.
25
26
27 Others
28 ------
29
30   o melanie will happily include packages in the Cc list that aren't
31     being removed...
32
33   o check_dsc_against_db's "delete an entry from files while you're
34     not looking" habit is Evil and Bad.
35
36   o lisa allows you to edit the section and change the component, but
37     really shouldn't.
38
39   o melanie needs to, when not sending bug close mails, promote Cc: to
40     To: and send the mail anyways.
41
42   o the lockfile (Archive_Maintenance_In_Progress) should probably be in a conf file
43
44   o madison should cross-check the b.source field and if it's not null
45     and s.name linked from it != the source given in
46     -S/--source-and-binary ignore.
47
48   o lauren sucks; she should a) only spam d-i for sourceful
49   rejections, b) sort stuff so she rejects sourceful stuff first.  the
50   non-sourceful should probably get a form mail, c) automate the
51   non-sourceful stuff (see b).
52
53   o jennifer should do q-d stuff for faster AA [ryan]
54
55   o split the morgue into source and binary so binaries can be purged first!
56
57   o per-architecture priorities for things like different arch'es
58     gcc's, silly BSD libftw, palo, etc.
59
60   o use postgres 7.2's built-in stat features to figure out how indices are used etc.
61
62   o neve shouldn't be using location, she should run down suites instead
63
64   o halle needs to know about udebs
65
66   o by default hamstring katie's mail sending so that she won't send
67     anything until someone edits a script; she's been used far too
68     much to send spam atm :(
69
70   o $ftpdir/indices isn't created by rose because it's not in katie.conf
71
72   o sanity check depends/recommends/suggests too?  in fact for any
73     empty field?
74
75 [minor] kelly's copychanges, copykatie handling sucks, the per-suite
76         thing is static for all packages, so work out in advance dummy.
77
78 [madison] # filenames ?
79 [madison] # maintainer, component, install date (source only?), fingerprint?
80
81   o UrgencyLog stuff should minimize it's bombing out(?)
82   o Log stuff should open the log file
83
84   o helena should footnote the actual notes, and also * the versions
85     with notes so we can see new versions since being noted...
86
87   o helena should have alternative sorting options, including reverse
88     and without or without differentiaion.
89
90   o julia should sync debadmin and ftpmaster (?)
91
92   o <drow> Can't read file.:
93   /org/security.debian.org/queue/accepted/accepted/apache-perl_1.3.9-14.1-1.21.20000309-1_sparc.katie.
94   You assume that the filenames are relative to accepted/, might want
95   to doc or fix that.
96
97   o <neuro> the orig was in NEW, the changes that caused it to be NEW
98     were pulled out in -2, and we end up with no orig in the archive
99     :(
100
101   o SecurityAcceptedAutoBuild doesn't handle the case of foo_3.3woody1
102     with a new .orig.tar.gz followed by a foo_3.3potato1 with the same
103     .orig.tar.gz; jennifer sees it and copes, but the AA code doesn't
104     and can't really easily know so the potato AA dir is left with no
105     .orig.tar.gz copy.  doh.
106
107   o orig.tar.gz in accepted not handled properly (?)
108
109   o amber doesn't include .orig.tar.gz but it should
110
111   o permissions (paranoia, group write, etc.) configurability and overhaul
112
113   o remember duplicate copyrights in lisaand skip them, per package
114
115   o <M>ove option for lisa byhand proecessing
116
117   o rene could do with overrides
118
119   o db_access.get_location_id should handle the lack of archive_id properly
120
121   o the whole versioncmp thing should be documented
122
123   o lisa doesn't do the right thing with -2 and -1 uploads, as you can
124     end up with the .orig.tar.gz not in the pool
125
126   o lisa exits if you check twice (aj)
127
128   o lisa doesn't trap signals from fernanda properly
129
130   o queued and/or perl on sparc stable sucks - reimplement it.
131
132   o aj's bin nmu changes
133
134   o Lisa:
135     * priority >> optional
136     * arch != {any,all}
137     * build-depends wrong (via andrea)
138     * suid
139     * conficlits
140     * notification/stats to admin daily
141     o trap fernanda exiting
142     o distinguish binary only versus others (neuro)
143
144   o cache changes parsed from ordering (careful tho: would be caching
145     .changes from world writable incoming, not holding)
146
147   o katie doesn't recognise binonlyNMUs correctly in terms of telling
148     who their source is; source-must-exist does, but the info is not
149     propogated down.
150
151   o Fix BTS vs. katie sync issues by queueing(via BSMTP) BTS mail so
152     that it can be released on deman (e.g. ETRN to exim).
153
154   o maintainers file needs overrides
155
156     [ change override.maintainer to override.maintainer-from +
157       override.maintainer-to and have them reference the maintainers
158       table.  Then fix charisma to use them and write some scripting
159       to handle the Santiago situation. ]
160
161   o Validate Depends (et al.) [it should match  \(\s*(<<|<|<=|=|>=|>|>>)\s*<VERSIONREGEXP>\)]
162
163   o Clean up DONE; archive to tar file every 2 weeks, update tar tvzf INDEX file.
164
165   o testing-updates suite: if binary-only and version << version in
166     unstable and source-ver ~= source-ver in testing; then map
167     unstable -> testing-updates ?
168
169   o hooks or configurability for debian specific checks (e.g. check_urgency, auto-building support)
170
171   o morgue needs auto-cleaning (?)
172
173   o saffron: two modes, all included, seperate
174   o saffron: add non-US
175   o saffron: add ability to control components, architectures, archives, suites
176   o saffron: add key to expand header
177
178 ================================================================================
179
180 Less Urgent
181 -----------
182
183   o change utils.copy to try rename() first
184
185   o [hard, long term] unchecked -> accepted should go into the db, not
186     a suite, but similar.  this would allow katie to get even faster,
187     make madison more useful, decomplexify specialacceptedautobuild
188     and generally be more sane.  may even be helpful to have e.g. new
189     in the DB, so that we avoid corner cases like the .orig.tar.gz
190     disappearing 'cos the package has been entirely removed but was
191     still on stayofexecution when it entered new.
192
193   o Logging [mostly done] (todo: rhona (hard), .. ?)
194
195   o jennifer: the tar extractor class doesn't need to be redone for each package
196
197   o reverse of source-must-exist; i.e. binary-for-source-must-not-exist
198   o REJECT reminders in shania.
199   o fernanda should check for conflicts and warn about them visavis priority [rmurray]
200   o store a list of removed/files versions; also compare against them.
201     [but be careful about scalability]
202
203   o fernanda: print_copyright should be a lot more intelligent
204      @ handle copyright.gz
205      @ handle copyright.ja and copyright
206      @ handle (detect at least) symlinks to another package's doc directory
207      @ handle and/or fall back on source files (?)
208
209   o To incorporate from utils:
210      @ unreject
211
212   o auto-purge out-of-date stuff from non-free/contrib so that testing and stuff works
213   o doogie's binary -> source index
214   o jt's web stuff, matt's changelog stuff (overlap)
215
216   o [Hard] Need to merge non-non-US and non-US DBs.
217
218   o experimental needs to auto clean (relative to unstable) [partial: rene warns about this]
219
220   o Do a checkpc(1)-a-like which sanitizes a config files.
221   o fix parse_changes()/build_file_list() to sanity check filenames
222   o saftey check and/or rename debs so they match what they should be
223
224   o Improve andrea.
225   o Need to optimize all the queries by using EXAMINE and building some INDEXs.
226     [postgresql 7.2 will help here]
227   o Need to enclose all the setting SQL stuff in transactions (mostly done).
228   o Need to finish alyson (a way to sync katie.conf and the DB)
229   o Need the ability to rebuild all other tables from dists _or_ pools (in the event of disaster) (?)
230   o Make the --help and --version options do stuff for all scripts
231
232   o charisma can't handle whitespace-only lines (for the moment, this is feature)
233
234   o generic way of saying isabinary and isadsc. (?)
235
236   o s/distribution/suite/g
237
238   o cron.weekly:
239      @ weekly postins to d-c (?)
240      @ backup of report (?)
241      @ backup of changes.tgz (?)
242
243   o --help doesn't work without /etc/katie/katie.conf (or similar) at
244     least existing.
245
246   o rename andrea (clashes with existing andrea)...
247
248  * Harder:
249
250     o interrupting of stracing jennifer causes exceptions errors from apt_inst calls
251     o dependency checking (esp. stable) (partially done)
252     o override checks sucks; it needs to track changes made by the
253       maintainer and pass them onto ftpmaster instead of warning the
254       maintainer.
255     o need to do proper rfc822 escaping of from lines (as opposed to s/\.//g)
256     o Revisit linking of binary->source in install() in katie.
257     o Fix component handling in overrides (aj)
258     o Fix lack of entires in source overrides (aj)
259     o direport misreports things as section 'devel' (? we don't use direport)
260     o vrfy check of every Maintainer+Changed-By address; valid for 3 months.
261     o binary-all should be done on a per-source, per-architecture package
262       basis to avoid, e.g. the perl-modules problem.
263     o a source-missing-diff check: if the version has a - in it, and it
264       is sourceful, it needs orig and diff, e.g. if someone uploads
265       esound_0.2.22-6, and it is sourceful, and there is no diff ->
266       REJECT (version has a dash, therefore not debian native.)
267     o check linking of .tar.gz's to .dsc's.. see proftpd 1.2.1 as an example
268     o archive needs md5sum'ed regularly, but takes too long to do all
269       in one go; make progressive or weekly.
270     o katie/jenna/rhona/whatever needs to clear out .changes
271       files from p-u when removing stuff superseded by newer versions.
272       [but for now we have halle]
273     o test sig checking stuff in test/ (stupid thing is not modularized due to global abuse)
274     o when encountering suspicous things (e.g. file tainting) do something more drastic
275
276  * Easy:
277
278     o suite mapping and component mapping are parsed per changes file,
279       they should probably be stored in a dictionary created at startup.
280     o don't stat/md5sum files you have entries for in the DB, moron
281       boy (Katie.check_source_blah_blah)
282     o promote changes["changes"] to mandatory in katie.py(dump_vars)
283       after a month or so (or all .katie files contain in the queue
284       contain it).
285     o melanie should behave better with -a and without -b; see
286       gcc-defaults removal for an example.
287     o Reject on misconfigured kernel-package uploads
288     o utils.extract_component_from_section: main/utils -> main/utils, main rather than utils, main
289     o Fix jennier to warn if run when not in incoming or p-u
290     o katie should validate multi-suite uploads; only possible valid one
291       is "stable unstable"
292     o cron.daily* should change umask (aj sucks)
293     o Rene doesn't look at debian-installer but should.
294     o Rene needs to check for binary-less source packages.
295     o Rene could accept a suite argument (?)
296     o byhand stuff should send notification
297     o catherine should udpate db; move files, not the other way around [neuro]
298     o melanie should update the stable changelog [joey]
299     o update tagdb.dia
300
301  * Bizzare/uncertain:
302
303     o drop rather dubious currval stuff (?)
304     o rationalize os.path.join() usage
305     o Rene also doesn't seem to warn about missing binary packages (??)
306     o logging: hostname + pid ?
307     o ANAIS should be done in katie (?)
308     o Add an 'add' ability to melanie (? separate prog maybe)
309     o Replicate old dinstall report stuff (? needed ?)
310     o Handle the case of 1:1.1 which would overwrite 1.1 (?)
311     o maybe drop -r/--regex in madison, make it the default and
312       implement -e/--exact (a la joey's "elmo")
313     o dsc files are not checked for existence/perms (only an issue if
314       they're in the .dsc, but not the .changes.. possible?)
315
316  * Cleanups & misc:
317
318     o db_access' get_files needs to use exceptions not this None, > 0, < 0 return val BS (?)
319     o The untouchable flag doesn't stop new packages being added to ``untouchable'' suites
320
321 ================================================================================
322
323 Packaging
324 ---------
325
326   o Fix stuff to look in sensible places for libs and config file in debian package (?)
327
328 ================================================================================
329
330            --help      manpage
331 -----------------------------------------------------------------------------
332 alyson        X
333 amber         X
334 andrea        X
335 ashley        X
336 catherine     X          X
337 charisma      X          X
338 cindy         X          X
339 claire        X
340 denise        X
341 fernanda      X
342 halle         X
343 heidi         X          X
344 helena        X
345 jenna         X
346 jennifer      X
347 jeri          X
348 julia         X          X
349 kelly         X          X
350 lisa          X          X
351 madison       X          X
352 melanie       X          X
353 natalie       X          X
354 neve          X
355 rene          X
356 rose          X
357 rhona         X          X
358 saffron       X
359 shania        X
360 tea           X
361 ziyi          X
362
363 ================================================================================
364
365 <mdz_> SirDibos: that sentence sounds like it wants to be a bug report when it grows up