]> git.decadent.org.uk Git - dak.git/blob - ChangeLog
* daklib/queue.py (check_valid): allow debian-installer specific sources to have...
[dak.git] / ChangeLog
1 2008-06-01  Otavio Salvador  <otavio@debian.org>
2
3         * daklib/queue.py (check_valid): allow debian-installer specific
4         sources to have 'debian-installer' section.
5
6 2008-05-28  Frans Pop  <fjp@debian.org>
7
8         * add autobyhand support for task overrides (from tasksel)
9
10 2008-05-27  Joerg Jaspert  <joerg@debian.org>
11
12         * config/debian/pseudo-packages.maintainers: Change ftp.debian.org
13         pseudopackage maintainer name.
14
15 2008-05-12  Joerg Jaspert  <joerg@debian.org>
16
17         * dak/transitions.py: use yaml.dump instead of syck.dump, as syck
18         seems to have a bug in its dump(), causing it to write illegal entries
19         And also do this for load.
20
21 2008-05-10  Stephen Gran   <sgran@debian.org>
22        * tools/debianqueued-0.9/debianqueued: First pass at a send_mail
23          implementation that sucks less
24        * Update debian/control to reflect new perl dependency
25
26 2008-05-09  Joerg Jaspert  <joerg@debian.org>
27
28         * dak/override.py (main): substitute value in X-Debian-Package
29         header
30
31         * templates/override.bug-close: Add X-Debian-Package header
32         * templates/reject-proposed-updates.rejected: dito
33         * templates/queue.rejected: dito
34         * templates/process-unchecked.new: dito
35         * templates/process-unchecked.bug-nmu-fixed: dito
36         * templates/process-unchecked.bug-experimental-fixed: dito
37         * templates/process-unchecked.bug-close: dito
38         * templates/process-unchecked.announce: dito
39         * templates/process-unchecked.accepted: dito
40         * templates/process-new.prod: dito
41         * templates/process-accepted.unaccept: dito
42         * templates/process-accepted.install: dito
43         * templates/process-unchecked.override-disparity: dito
44
45 2008-05-08  Joerg Jaspert  <joerg@debian.org>
46
47         * templates/override.bug-close: Add X-Debian header
48         * templates/rm.bug-close: dito
49         * templates/reject-proposed-updates.rejected: dito
50         * templates/queue.rejected: dito
51         * templates/process-unchecked.new: dito
52         * templates/process-unchecked.bug-nmu-fixed: dito
53         * templates/process-unchecked.bug-experimental-fixed: dito
54         * templates/process-unchecked.bug-close: dito
55         * templates/process-unchecked.announce: dito
56         * templates/process-unchecked.accepted: dito
57         * templates/process-new.prod: dito
58         * templates/process-accepted.unaccept: dito
59         * templates/process-accepted.install: dito
60         * templates/process-unchecked.override-disparity: dito, but also
61         mention that people should include the package lists with the
62         override disparities.
63
64 2008-05-06  Joerg Jaspert  <joerg@debian.org>
65
66         * config/debian/cron.dinstall: Put the timestamp stuff into an own
67         function, call that from everywhere. Also change the timestamp
68         format to not be local dependent.
69
70 2008-05-05  Joerg Jaspert  <joerg@debian.org>
71
72         * daklib/dak_exceptions.py (dakerrors): add TransitionsError
73         * dak/transitions.py: Use it, instead of the own definition
74
75 2008-05-05  Mark Hymers  <mhy@debian.org>
76
77         * daklib/dak_exceptions.py: Add a default message and tidy up our string
78         representation
79
80 2008-05-05  Joerg Jaspert  <joerg@debian.org>
81
82         * daklib/dak_exceptions.py: New file, central place for all those
83         own exceptions dak may raise.
84
85         * daklib/utils.py: Use dak_exceptions and delete all those string
86         exception raising stuff, which is depcreated.
87         During that delete the unknown_hostname_exc, as it wasnt used.
88
89         * dak/import_archive.py: use the new Exception class
90         * dak/rm.py: dito
91         * dak/generate_releases.py: dito
92         * dak/queue_report.py: dito
93         * daklib/queue.py: dito
94
95 2008-05-04  Joerg Jaspert  <joerg@debian.org>
96
97         * daklib/queue.py: Various pychecker cleanups
98
99         * dak/import_keyring.py: Remove unused daklib.logging and Logger
100         and add the actually used daklib/utils
101
102         * dak/examine_package.py: remove daklib.queue import, never used
103
104         * dak/check_proposed_updates.py: Import stuff from daklib as
105         "import daklib.foo as foo"
106         * dak/clean_proposed_updates.py: likewise
107         * dak/clean_queues.py: likewise
108         * dak/clean_suites.py: likewise
109         * dak/compare_suites.py: likewise
110         * dak/cruft_report.py: likewise
111         (get_suite_binaries): Seperated in own function, out of main. More
112         of main should be splitted. (Or well, cruft_report redesigned a
113         little, so its easier to run on multiple suites with differing tests)
114
115         * dak/examine_package.py: likewise
116         * dak/find_null_maintainers.py: likewise
117         * dak/generate_index_diffs.py: likewise
118         * dak/generate_releases.py: likewise
119         * dak/import_archive.py: likewise
120         * dak/import_ldap_fingerprints.py: likewise
121         * dak/import_users_from_passwd.py: likewise
122         * dak/init_db.py: likewise
123         * dak/init_dirs.py: likewise
124         * dak/ls.py: likewise
125         * dak/make_maintainers.py: likewise
126         * dak/make_overrides.py: likewise
127         * dak/make_suite_file_list.py: likewise
128         * dak/new_security_install.py: likewise
129         * dak/override.py: likewise
130         * dak/process_accepted.py: likewise
131         * dak/process_new.py: likewise
132         * dak/process_unchecked.py: likewise
133         * dak/rm.py: likewise
134         * dak/show_new.py: likewise
135         * dak/split_done.py: likewise
136         * dak/stats.py: likewise
137         * dak/transitions.py: likewise
138
139         * dak/check_archive.py (check_files_not_symlinks): Remove
140         long-time unused and commented code. Import stuff from daklib as
141         "import daklib.foo as foo"
142
143 2008-05-04  Thomas Viehmann  <tv@beamnet.de>
144
145         * dak/process_unchecked.py (check_signed_by_key): cater for uid_email
146         None in sponsor notification
147
148 2008-05-03  Joerg Jaspert  <joerg@debian.org>
149
150         * dak/examine_package.py: clean up pychecker warnings (merged with
151         Thomas changes to the NEW display)
152
153 2008-05-03  Mark Hymers <mhy@debian.org>
154
155         * dak/check_archive.py: clean up pychecker warnings
156         * dak/check_overrides.py: likewise
157         * dak/check_proposed_updates.py: likewise
158         * dak/clean_proposed_updates.py: likewise
159         * dak/clean_queues.py: likewise
160         * dak/control_overrides.py: likewise
161         * dak/control_suite.py: likewise
162         * dak/decode_dot_dak.py: likewise
163         * dak/examine_package.py: likewise
164         * dak/process_new.py: likewise
165         * dak/process_unchecked.py: likewise
166         * dak/queue_report.py: likewise
167         * dak/reject_proposed_updates.py: likewise
168         * dak/security_install.py: likewise
169         * dak/show_new.py: likewise
170         * dak/stats.py: likewise
171         * dak/symlink_dists.py: likewise
172         * dak/transitions.py: likewise
173
174 2008-05-03  Joerg Jaspert  <joerg@debian.org>
175
176         * config/debian/cron.daily: Rename to
177         * config/debian/cron.dinstall: this, as its not really something run
178         daily for some time now. And while dinstall is an OLD name, its
179         recognized pretty well within Debian
180         Also add some more timing information
181         Do not allow automated [o-]p-u-new processing to break dinstall
182
183 2008-05-03  Thomas Viehmann  <tv@beamnet.de>
184
185         * web/,web/style.css: add web dir and current style.css
186
187         * dak/examine_package.py, dak/show_new.py: improve NEW html pages,
188         based on mock-up by M. Ferrari.
189         remove Checksums-* from examine-package output
190
191 2008-05-03  Thomas Viehmann  <tv@beamnet.de>
192
193         * dak/process_unchecked.py (check_hashes): Reject on error while
194         parsing Checksums-*.
195
196 2008-05-02  Joerg Jaspert  <joerg@debian.org>
197
198         * config/debian/pseudo-packages*: Removed listarchives, closes #468667
199         added wiki.debian.org (currently pointing to debian-www), closes #194206
200         added security-tracker, closes #436152
201         added release.debian.org, closes #451005
202
203         * config/debian/cron.buildd: Cleanup unreachable code. (If someone
204         still wants it - its in revision control...)
205
206         * config/debian/cron.daily: Modify call to update-ftpstats to only
207         use files log/2*, instead of log/*, so it ignores the new cron/
208         subdir. Makes sure it can't get confused, and is also safe for
209         nearly thousand years. If this code is really in use in year 3000,
210         im sure people can adjust it! :)
211
212         * config/debian/vars: Add logdir as a place for cronjob log output
213
214         * config/debian/cron.daily: Use a logfile and be more verbose of
215         whats going on.
216           Also moved the commented VACUUM ; VACUUM ANALYZE calls over to
217         cron.weekly, ...
218         * config/debian/cron.weekly: likewise,
219           ... and activate those calls again. Once a week, as an
220         additional safety bet to be sure the stuff does get run is ok,
221         even if we have autovacuum by default.
222
223 2008-05-02  Thomas Viehmann  <tv@beamnet.de>
224
225         * dak/process_unchecked.py (check_hashes): fix typo in
226           checksum reject message.
227
228 2008-05-02  Joerg Jaspert  <joerg@debian.org>
229
230         * config/debian/extensions.py: used reindent.py from the python
231         2.x source examples to get all dak code use the same indentation
232         style, no longer a mix of 4 spaces / 1 tab.
233         * dak/check_archive.py: likewise
234         * dak/check_overrides.py: likewise
235         * dak/check_proposed_updates.py: likewise
236         * dak/clean_proposed_updates.py: likewise
237         * dak/clean_queues.py: likewise
238         * dak/clean_suites.py: likewise
239         * dak/compare_suites.py: likewise
240         * dak/control_overrides.py: likewise
241         * dak/control_suite.py: likewise
242         * dak/cruft_report.py: likewise
243         * dak/dak.py: likewise
244         * dak/decode_dot_dak.py: likewise
245         * dak/examine_package.py: likewise
246         * dak/find_null_maintainers.py: likewise
247         * dak/generate_index_diffs.py: likewise
248         * dak/generate_releases.py: likewise
249         * dak/import_archive.py: likewise
250         * dak/import_keyring.py: likewise
251         * dak/import_ldap_fingerprints.py: likewise
252         * dak/import_users_from_passwd.py: likewise
253         * dak/init_db.py: likewise
254         * dak/init_dirs.py: likewise
255         * dak/ls.py: likewise
256         * dak/make_maintainers.py: likewise
257         * dak/make_overrides.py: likewise
258         * dak/make_suite_file_list.py: likewise
259         * dak/mirror_split.py: likewise
260         * dak/new_security_install.py: likewise
261         * dak/override.py: likewise
262         * dak/poolize.py: likewise
263         * dak/process_accepted.py: likewise
264         * dak/process_new.py: likewise
265         * dak/process_unchecked.py: likewise
266         * dak/queue_report.py: likewise
267         * dak/reject_proposed_updates.py: likewise
268         * dak/rm.py: likewise
269         * dak/security_install.py: likewise
270         * dak/show_new.py: likewise
271         * dak/split_done.py: likewise
272         * dak/stats.py: likewise
273         * dak/symlink_dists.py: likewise
274         * dak/test/001/test.py: likewise
275         * dak/test/002/test.py: likewise
276         * dak/transitions.py: likewise
277         * daklib/extensions.py: likewise
278         * daklib/logging.py: likewise
279         * daklib/queue.py: likewise
280         * daklib/utils.py: likewise
281         * scripts/debian/insert_missing_changedby.py: likewise
282
283         * dak/process_new.py (recheck): Make the path check more robust,
284         so we no longer have to keep process_new seperate trees between
285         security and normal archive.
286
287 2008-04-27  Joerg Jaspert  <joerg@debian.org>
288
289         * dak/process_accepted.py (Urgency_Log.__init__): Warn if the
290         configured path does not exist or is not writeable by us. Use a
291         tmp path if so, so we do not lose the urgencies in such cases.
292
293         * config/debian/dak.conf: Changed path for UrgencyLog
294         Same for the ReleaseTransitions file
295
296         * config/debian/cron.daily: Notify qa user on merkel of dinstall
297         start, Remove the britney call
298
299 2008-04-26  Joerg Jaspert  <joerg@debian.org>
300
301         * dak/process_new.py: Call end() whenever we try to leave by
302         pressing Q
303
304         * config/debian/cron.daily: Also report NBS in experimental
305
306 2008-04-25  Joerg Jaspert  <joerg@debian.org>
307
308         * dak/cruft_report.py (main): Make it possible to look at
309         experimental too, especially NBS
310
311         * dak/split_done.py (main): Only move files into their subdirs if
312         they are older than 30 days. That enables us to run this script as
313         part of a cronjob.
314
315         * config/debian/cron.weekly: Run dak split-done
316
317 2008-04-23  Thomas Viehmann  <tviehmann@debian.org>
318
319         * dak/process_unchecked.py: add changes["sponsoremail"]
320           for sponsored uploads if desired
321         * daklib/queue.py: add changes["sponsoremail"] to
322           Subst["__MAINTAINER_TO__"] if present
323         * daklib/utils.py: add functions
324           is_email_alias to check which accounts allow email forwarding,
325           which_alias_file to find the alias file, and
326           gpg_get_key_addresses to find uid addresses for a given
327             fingerprint
328
329 2008-04-22  Joerg Jaspert  <joerg@debian.org>
330
331         * setup/init_pool.sql: added a function/aggregate for the release
332         team to base some script on it.
333
334         * config/debian/cron.daily: push katie@merkel to immediately start
335         the sync of projectb there.
336
337 2008-04-21  Joerg Jaspert  <joerg@debian.org>
338
339         * scripts/debian/expire_dumps: New script, expires old database
340         dumps, using a scheme to keep more of the recent dumps.
341
342         * config/debian/cron.daily: Use the new script. Also - compress
343         all files older than 7 days, instead of 30.
344
345         * dak/process_accepted.py (install): Do not break if a
346         source/maintainer combination is already in src_uploaders, "just"
347         warn us.
348
349 2008-04-20  Thomas Viehmann  <tviehmann@debian.org>
350
351         * daklib/utils.py (build_file_list): Deal with "Format 3 style"
352         Format lines (ie. those having extra text appended).
353
354 2008-04-19  Joerg Jaspert  <joerg@debian.org>
355
356         * dak/process_unchecked.py (check_files): Sanity check the
357         provides field, which closes #472783
358
359 2008-04-18  Joerg Jaspert  <joerg@debian.org>
360
361         * config/debian/dak.conf: Add mapping stable-proposed-updates
362           -> proposed-updates.
363
364         * dak/transitions.py (load_transitions): Additionally check for
365         invalid package list indentation
366
367 2008-04-17  Joerg Jaspert  <joerg@debian.org>
368
369         * config/debian/dak.conf: Add TempPath statement for the Release
370         Transitions script
371
372         * dak/transitions.py (temp_transitions_file): Use the TempPath
373         (write_transitions_from_file): Check if the file we should get our
374         transitions from is in our TempPath, error out if it isnt
375         (main): Check for TempPath existance
376
377 2008-04-12  James Troup  <troup@debian.org>
378
379         * dak/clean_proposed_updates.py: add support for -s/--suite and
380         -n/--no-action.
381
382 2008-04-11  Anthony Towns  <ajt@debian.org>
383
384         * dak/utils.py: build_file_list() extra parameters so it can
385         build a file list for checksums-foo fields. Don't use float() to
386         compare formats, because Format: 1.10 should compare greater than
387         Format: 1.9 (use "1.9".split(".",1) and tuple comparison instead)
388
389         * dak/process_unchecked.py: check_md5sum becomes check_hashes
390         and check_hash. If changes format is 1.8 or later, also check
391         checksums-sha1 and checksums-sha256 for both .changes and .dsc,
392         and reject on presence/absence of un/expected checksums-* fields.
393
394 2008-04-07  Joerg Jaspert  <joerg@debian.org>
395
396         * daklib/utils.py (build_file_list): Check for dpkg .changes
397         adjusted to reject newer (and right now broken) 1.8 version, until
398         dpkg (or debsign) is fixed and doesn't produce invalid .changes anymore
399
400 2008-03-22  Joerg Jaspert  <joerg@debian.org>
401
402         * dak/transitions.py (load_transitions): Check if all our keys are
403         defined, if there are only keys defined we want and also the types
404         of the various keys.
405
406 2008-03-22  Anthony Towns  <ajt@debian.org>
407
408         * dak/edit_transitions.py: Add --import option.
409         Add --use-sudo option. Use fcntl locking for writing.
410         Move writing into a function (write_transitions).
411         Reinvoke self using sudo and --import if necessary.
412         Move temporary file creation into a function, use mkstemp.
413         Rename to "dak transitions".
414
415 2008-03-21  Joerg Jaspert  <joerg@debian.org>
416
417         * dak/edit_transitions.py (edit_transitions): Use sudo to copy the
418         edited file back in place
419         (check_transitions): Use proper locking and also use sudo to copy
420         the new file in place
421
422 2008-03-21  Anthony Towns <ajt@debian.org>
423
424         * config/debian/extensions.py: Add infrastructure for replacing
425         functions in dak modules; add upload blocking for dpkg.
426
427 2008-03-12  Joerg Jaspert  <joerg@debian.org>
428
429         * dak/edit_transitions.py: Done a number of cleanups to make code
430         working. Also changed the way prompting/answering goes, to not
431         have to import daklib/queue.
432         (edit_transitions): When done with a successful edit - also print
433         a final overview about defined transitions
434
435 2008-03-11  Joerg Jaspert  <joerg@debian.org>
436
437         * dak/process_unchecked.py: Import syck module directly, not "from
438         syck import *"
439         (check_transition): Do the check for sourceful upload in here
440         Also adjust the syck loading commands, rename new_vers to
441         expected, curvers to current, to make it more clear what they mean.
442
443         * daklib/database.py (get_suite_version): Renamed from
444         get_testing_version. Also changed the cache variables name
445
446         * The above changes are based on modifications from Anthony.
447
448         * dak/dak.py (init): Renamed check -> edit transitions
449
450         * dak/edit_transitions.py: Renamed from check_transitions.py
451         (main): Also rename new_vers/curvers to expected/current
452         Basically a nice rewrite, so it now does checks and edit,
453         depending on how you call it. Check also removes old transitions,
454         if user wants it.
455
456 2008-03-02  Joerg Jaspert  <joerg@debian.org>
457
458         * debian/control (Suggests): Add python-syck to Depends:
459
460         * dak/dak.py (init): Tell it about check_transitions
461
462         * dak/check_transitions.py (usage): Added, checks the transitions
463         file (if any)
464
465         * daklib/database.py (get_testing_version): Added. Returns the
466         version for the source in testing, if any
467
468         * dak/process_unchecked.py (check_transition): Added. Checks if a
469         release team member defined a transition, and rejects based on
470         that data.
471         (process_it): Use it.
472         (check_transition): Warn on broken transitions file and return,
473         not doing anything.
474         (check_transition): Moved out of here, into daklib/queue
475         (process_it): Call check_transitions only if
476         changes[architecture] has source included.
477         (check_transition): Now call the database.get_testing_version
478
479 2008-02-09  Christoph Berg <myon@debian.org>
480
481         * daklib/queue.py (get_type): fubar does not exist in global
482         namespace.
483
484         * setup/add_constraints.sql setup/init_pool.sql: Add changedby column
485         to source table, and move src_uploaders after source so the REFERNCES
486         clause works.
487         * dak/process_accepted.py (install): Fill the changedby column from
488         the information found in the .changes. This will allow to identify
489         NMUs and sponsored uploads more precisely in tools querying projectb.
490         * scripts/debian/insert_missing_changedby.py: Script to import yet
491         missing fields from filippo's uploads-history DB.
492
493 2008-02-06  Joerg Jaspert  <joerg@debian.org>
494
495         * daklib/utils.py (check_signature): Make variable key available,
496         so we can access it.
497
498 2008-01-07  Joerg Jaspert  <joerg@debian.org>
499
500         * dak/examine_package.py (check_deb): Remove linda call. It
501         provides no added benefit to lintian anymore.
502
503 2008-01-07  Joerg Jaspert  <joerg@debian.org>
504
505         * dak/examine_package.py (check_deb): Remove linda call. It
506         provides no added benefit to lintian anymore.
507
508 2008-01-06  Joerg Jaspert  <joerg@debian.org>
509
510         * dak/examine_package.py (do_lintian): lintian now supports html
511         coloring, so use it.
512         (do_command): Dont escape html chars if param escaped = 1
513
514 2008-01-06  Joerg Jaspert  <joerg@debian.org>
515
516         * dak/examine_package.py (do_lintian): lintian now supports html
517         coloring, so use it.
518         (do_command): Dont escape html chars if param escaped = 1
519
520 2007-12-31  Anthony Towns  <ajt@debian.org>
521
522         * dak/process_new.py (recheck): pass "" for prefix_str to reject()
523         when processing result of check_dsc_against_db so we don't promote
524         warnings to rejections.
525
526 2007-12-31  Anthony Towns  <ajt@debian.org>
527
528         * dak/process_new.py (recheck): pass "" for prefix_str to reject()
529         when processing result of check_dsc_against_db so we don't promote
530         warnings to rejections.
531
532 2007-12-30  Joerg Jaspert  <joerg@debian.org>
533
534         * dak/dak.py (init): add show-new. This is based on a patch
535         submitted by Thomas Viehmann in Bug #408318, but large parts of
536         handling it are rewritten and show-new is done by me.
537
538         * dak/queue_report.py (table_row): Add link to generated html page
539         for NEW package.
540
541         * dak/show_new.py: new file, generates html overview for NEW
542         packages, similar to what we see with examine-package.
543
544         * config/debian/cron.hourly: Add show-new call
545
546         * config/debian/dak.conf: Add HTMLPath for Show-New
547
548         * dak/examine_package.py (print_copyright): ignore stderr when
549         finding copyright file.
550         (main): add html option
551         (html_escape): new function
552         (escape_if_needed): ditto
553         (headline): ditto
554         (colour_output): ditto
555         (print_escaped_text): ditto
556         (print_formatted_text): ditto
557         - use those functions everywhere where we generate output, as they
558         easily know if we want html or not and just DTRT
559         (do_lintian): new function
560         (check_deb): use it
561         (output_deb_info): Use print_escaped_text, not print_formatted_text.
562         Also import daklib.queue, determine_new now lives there
563
564         Also add a variable to see if we want html output. Default is
565         disabled, show_new enables it for its use.
566         Most of html, besides header/footer are in examine_package instead
567         of show_new, as it makes it a whole lot easier to deal with it at
568         the point the info is generated.
569
570
571         * dak/process_new.py (determine_new): Moved out of here.
572         (check_valid): Moved out of here.
573         (get_type): Moved out of here.
574
575         * daklib/queue.py (determine_new): Moved here.
576         (check_valid): Moved here.
577         (get_type): Moved here.
578
579         * dak/init_db.py (do_section): Remove non-US code
580
581         * dak/make_overrides.py (main): ditto
582
583         * dak/process_new.py (determine_new): ditto
584
585         * daklib/queue.py (Upload.in_override_p),
586         (Upload.check_override): ditto
587
588         * daklib/utils.py (extract_component_from_section):,
589         (poolify): ditto
590
591         * dak/import_archive.py (update_section): ditto
592
593         * dak/symlink_dists.py (fix_component_section): ditto
594
595         * scripts/debian/mkmaintainers: ditto
596
597         * scripts/debian/update-mirrorlists (masterlist): ditto
598
599         * config/debian-non-US/*: Remove subdir
600
601         * scripts/debian/update-readmenonus: Removed.
602
603
604 2007-12-30  Joerg Jaspert  <joerg@debian.org>
605
606         * dak/dak.py (init): add show-new. This is based on a patch
607         submitted by Thomas Viehmann in Bug #408318, but large parts of
608         handling it are rewritten and show-new is done by me.
609
610         * dak/queue_report.py (table_row): Add link to generated html page
611         for NEW package.
612
613         * dak/show_new.py: new file, generates html overview for NEW
614         packages, similar to what we see with examine-package.
615
616         * config/debian/cron.hourly: Add show-new call
617
618         * config/debian/dak.conf: Add HTMLPath for Show-New
619
620         * dak/examine_package.py (print_copyright): ignore stderr when
621         finding copyright file.
622         (main): add html option
623         (html_escape): new function
624         (escape_if_needed): ditto
625         (headline): ditto
626         (colour_output): ditto
627         (print_escaped_text): ditto
628         (print_formatted_text): ditto
629         - use those functions everywhere where we generate output, as they
630         easily know if we want html or not and just DTRT
631         (do_lintian): new function
632         (check_deb): use it
633         (output_deb_info): Use print_escaped_text, not print_formatted_text.
634         Also import daklib.queue, determine_new now lives there
635
636         Also add a variable to see if we want html output. Default is
637         disabled, show_new enables it for its use.
638         Most of html, besides header/footer are in examine_package instead
639         of show_new, as it makes it a whole lot easier to deal with it at
640         the point the info is generated.
641
642
643         * dak/process_new.py (determine_new): Moved out of here.
644         (check_valid): Moved out of here.
645         (get_type): Moved out of here.
646
647         * daklib/queue.py (determine_new): Moved here.
648         (check_valid): Moved here.
649         (get_type): Moved here.
650
651         * dak/init_db.py (do_section): Remove non-US code
652
653         * dak/make_overrides.py (main): ditto
654
655         * dak/process_new.py (determine_new): ditto
656
657         * daklib/queue.py (Upload.in_override_p),
658         (Upload.check_override): ditto
659
660         * daklib/utils.py (extract_component_from_section):,
661         (poolify): ditto
662
663         * dak/import_archive.py (update_section): ditto
664
665         * dak/symlink_dists.py (fix_component_section): ditto
666
667         * scripts/debian/mkmaintainers: ditto
668
669         * scripts/debian/update-mirrorlists (masterlist): ditto
670
671         * config/debian-non-US/*: Remove subdir
672
673         * scripts/debian/update-readmenonus: Removed.
674
675
676 2007-12-28  Anthony Towns  <ajt@debian.org>
677
678         * daklib/utils.py (check_signature): add NOTATION_DATA and
679         NOTATION_NAME to known keywords.
680
681         * daklib/queue.py (Upload.check_source_against_db):
682
683         * dak/make_suite_file_list.py: add -f/--force option.
684
685         * dak/generate_releases.py: add -a/--apt-conf=FILE and
686         -f/--force-touch options.  Pull version info from the database.
687         Make suite description optional.
688
689         * config/debian/dak.conf: update
690         Reject-Proposed-Updates::MoreInfoURL.  Comment out
691         Suite::Stable::Version and ::Description.
692
693         * config/debian/apt.conf: Add hurd-i386 to unstable
694         debian-installer stanza.
695
696 2007-12-28  Joerg Jaspert  <joerg@debian.org>
697
698         * KEYEXPIRED is actually a known keyword. We do check it earlier
699         on and reject in case the sig is bad (or unknown)
700
701 2007-12-28  Anthony Towns  <ajt@debian.org>
702
703         * daklib/utils.py (check_signature): add NOTATION_DATA and
704         NOTATION_NAME to known keywords.
705
706         * daklib/queue.py (Upload.check_source_against_db):
707
708         * dak/make_suite_file_list.py: add -f/--force option.
709
710         * dak/generate_releases.py: add -a/--apt-conf=FILE and
711         -f/--force-touch options.  Pull version info from the database.
712         Make suite description optional.
713
714         * config/debian/dak.conf: update
715         Reject-Proposed-Updates::MoreInfoURL.  Comment out
716         Suite::Stable::Version and ::Description.
717
718         * config/debian/apt.conf: Add hurd-i386 to unstable
719         debian-installer stanza.
720
721 2007-12-28  Joerg Jaspert  <joerg@debian.org>
722
723         * KEYEXPIRED is actually a known keyword. We do check it earlier
724         on and reject in case the sig is bad (or unknown)
725
726 2007-12-24  Joerg Jaspert  <joerg@debian.org>
727
728         * Also run lintian on the .dsc file to check the source itself.
729
730         * Fix the direct usage of ar | tar etc to get the copyright file
731         and use dpkg-deb, which is made for this and makes us able to
732         process data.tar.bz2 (or whatever format it will be in the
733         future).
734
735 2007-12-24  Joerg Jaspert  <joerg@debian.org>
736
737         * Also run lintian on the .dsc file to check the source itself.
738
739         * Fix the direct usage of ar | tar etc to get the copyright file
740         and use dpkg-deb, which is made for this and makes us able to
741         process data.tar.bz2 (or whatever format it will be in the
742         future).
743
744 2007-12-21  Joerg Jaspert  <joerg@debian.org>
745
746         * Remove the (now useless) check for a pre-depends on dpkg for
747           binaries that contain bzip2 compressed data tarballs.
748
749 2007-12-21  Joerg Jaspert  <joerg@debian.org>
750
751         * Remove the (now useless) check for a pre-depends on dpkg for
752           binaries that contain bzip2 compressed data tarballs.
753
754 2007-08-28  Anthony Towns  <ajt@debian.org>
755
756         * process_unchecked.py: Add support for automatic BYHAND
757         processing.
758         * config/debian/dak.conf, scripts/debian/byhand-tag: Automatic
759         processing of tag-overrides.
760         * examine_package.py: Summarise duplicate copyright file entries
761         (same md5sum) with a reference to the previous instance, rather
762         than repeating them.
763         * process_new.py: When rejecting from the p-u-new or o-p-u-new
764         holding queues, don't worry if dak has its own reasons for
765         rejecting the package as well as the SRMs.
766
767 2007-08-28  Anthony Towns  <ajt@debian.org>
768
769         * process_unchecked.py: Add support for automatic BYHAND
770         processing.
771         * config/debian/dak.conf, scripts/debian/byhand-tag: Automatic
772         processing of tag-overrides.
773         * examine_package.py: Summarise duplicate copyright file entries
774         (same md5sum) with a reference to the previous instance, rather
775         than repeating them.
776         * process_new.py: When rejecting from the p-u-new or o-p-u-new
777         holding queues, don't worry if dak has its own reasons for
778         rejecting the package as well as the SRMs.
779
780 2007-06-19  Anthony Towns  <ajt@debian.org>
781
782         * Add nm.debian.org pseudopackage
783
784 2007-06-19  Anthony Towns  <ajt@debian.org>
785
786         * Add nm.debian.org pseudopackage
787
788 2007-06-18  Anthony Towns  <ajt@debian.org>
789
790         * daklib/logging.py: Set umask to not exclude group-writability
791         so we don't get reminded at the start of each month. Thanks to
792         Random J.
793         * dak/override.py: More changes from Herr von Wifflepuck: warn
794         if section of source is different to binary section; restore
795         functionality on source-only overrides; croak if trying to set
796         priority of a source override; never set priority of source
797         overrides; correct typo in logging (s/priority/section/ at
798         one place)
799
800         * config/debian/apt.conf.oldstable: Added for oldstable point releases.
801         * config/debian/cron.daily: auotmatically accept/reject
802         oldstable-proposed-updates based on COMMENTS directory
803
804 2007-06-18  Anthony Towns  <ajt@debian.org>
805
806         * config/debian/apt.conf, config/debian/apt.conf.stable,
807         config/debian/dak.conf: update for 4.0r0 (etch), and 3.1r6
808         (sarge), support for oldstable-proposed-updates, dropping m68k
809         from etch, creating etch-m68k suite, creating lenny.
810
811         * config/debian/vars: update for lenny
812
813         * config/debian/dak.conf: typo fix for Dinstall::GPGKeyring,
814         drop upload limitations, add release postgres user
815
816         * dak/process_new.py: support for automatically accepting and rejecting
817         packages from proposed-updates holding queues via COMMENTS directory
818         * cron.daily: automatically process COMMENTS-based approvals
819         and rejections for proposed-updates holding queues
820
821         * dak/process_unchecked.py: add support for oldproposedupdates
822         holding queue
823
824         * dak/control_suite.py: allow control-suite to work with etch-m68k
825
826         * dak/generate_releases.py: unlink old Release files before updating
827         them if nlinks > 1 (ie, if two files used to be the same, maybe they
828         shouldn't be when generate-releases is run)
829
830         * dak/generate_releases.py: add a couple of commented lines to make
831         it easier to deal with point releases
832
833         * dak/make_overrides.py: generate overrides for !contrib udebs
834
835         * docs/README.stable-point-release: update docs for doing a
836         point release
837
838 2007-06-18  Anthony Towns  <ajt@debian.org>
839
840         * daklib/logging.py: Set umask to not exclude group-writability
841         so we don't get reminded at the start of each month. Thanks to
842         Random J.
843         * dak/override.py: More changes from Herr von Wifflepuck: warn
844         if section of source is different to binary section; restore
845         functionality on source-only overrides; croak if trying to set
846         priority of a source override; never set priority of source
847         overrides; correct typo in logging (s/priority/section/ at
848         one place)
849
850         * config/debian/apt.conf.oldstable: Added for oldstable point releases.
851         * config/debian/cron.daily: auotmatically accept/reject
852         oldstable-proposed-updates based on COMMENTS directory
853
854 2007-06-18  Anthony Towns  <ajt@debian.org>
855
856         * config/debian/apt.conf, config/debian/apt.conf.stable,
857         config/debian/dak.conf: update for 4.0r0 (etch), and 3.1r6
858         (sarge), support for oldstable-proposed-updates, dropping m68k
859         from etch, creating etch-m68k suite, creating lenny.
860
861         * config/debian/vars: update for lenny
862
863         * config/debian/dak.conf: typo fix for Dinstall::GPGKeyring,
864         drop upload limitations, add release postgres user
865
866         * dak/process_new.py: support for automatically accepting and rejecting
867         packages from proposed-updates holding queues via COMMENTS directory
868         * cron.daily: automatically process COMMENTS-based approvals
869         and rejections for proposed-updates holding queues
870
871         * dak/process_unchecked.py: add support for oldproposedupdates
872         holding queue
873
874         * dak/control_suite.py: allow control-suite to work with etch-m68k
875
876         * dak/generate_releases.py: unlink old Release files before updating
877         them if nlinks > 1 (ie, if two files used to be the same, maybe they
878         shouldn't be when generate-releases is run)
879
880         * dak/generate_releases.py: add a couple of commented lines to make
881         it easier to deal with point releases
882
883         * dak/make_overrides.py: generate overrides for !contrib udebs
884
885         * docs/README.stable-point-release: update docs for doing a
886         point release
887
888 2007-03-05  Anthony Towns  <ajt@debian.org>
889
890         * config/debian/dak.conf: update for 3.1r5.
891         * scripts/debian/ssh-move: add ssh-move script from debbugs
892         * config/debian/cron.unchecked: push version info to debbugs using
893         ssh-move.
894
895 2007-03-05  Anthony Towns  <ajt@debian.org>
896
897         * config/debian/dak.conf: update for 3.1r5.
898         * scripts/debian/ssh-move: add ssh-move script from debbugs
899         * config/debian/cron.unchecked: push version info to debbugs using
900         ssh-move.
901
902 2007-02-14  James Troup  <troup@ries.debian.org>
903
904         * docs/README.config: remove Dinstall::GroupOverrideFilename.
905         * config/debian/dak.conf: likewise.
906         * config/debian-non-US/dak.conf: likewise.
907         * config/debian-security/dak.conf: likewise.
908
909         * daklib/queue.py (Upload.close_bugs): no longer handle NMUs or
910         experimental differently, just close the bugs and let version
911         tracking sort it out.
912          (nmu_p): remove entire class - now unused.
913          (Upload.__init__): don't use nmu_p.
914
915 2007-02-14  James Troup  <troup@ries.debian.org>
916
917         * docs/README.config: remove Dinstall::GroupOverrideFilename.
918         * config/debian/dak.conf: likewise.
919         * config/debian-non-US/dak.conf: likewise.
920         * config/debian-security/dak.conf: likewise.
921
922         * daklib/queue.py (Upload.close_bugs): no longer handle NMUs or
923         experimental differently, just close the bugs and let version
924         tracking sort it out.
925          (nmu_p): remove entire class - now unused.
926          (Upload.__init__): don't use nmu_p.
927
928 2007-02-08  Anthony Towns  <ajt@debian.org>
929
930         * config/debian/dak.conf: update for 3.1r4.  Use new 'etch'
931         signing key.  Drop maximum index diffs down to 14.
932
933         * config/debian/apt.conf: add udeb support for non-free (testing,
934         unstable) and experimental.
935         * config/debian/dak.conf: likewise.
936
937         * dak/generate_releases.py (main): handle udebs in any component.
938
939         * daklib/queue.py (Upload.build_summaries): handle files without a
940         'type' gracefully.
941
942         * dak/generate_releases.py (print_sha256_files): new function.
943         (main): use it.
944
945         * dak/process_accepted.py (stable_install): fix name of template
946         mail.
947
948         * dak/process_unchecked.py (is_stableupdate): fix invocation of
949         database.get_suite_id().
950
951         * templates/process-new.bxa_notification: Update on request
952         of/after discussion with BIS staff.
953
954         * scripts/debian/mkfilesindices: also handle proposed-updates.
955
956 2007-02-08  Ryan Murray  <rmurray@debian.org>
957
958         * config/debian/cron.monthly: use $ftpgroup instead of hardcoding
959         group name for chgrp of mail archives.
960
961         * daklib/queue.py (Upload.check_dsc_against_db): handle multiple
962         orig.tar.gz's by picking the first one by file id.
963
964         * dak/override.py (main): limit to binary overrides only for now.
965         (usage): update to match.
966
967         * config/debian/cron.daily: track when we have the accepted lock
968         and clean it up on exit if we have it.  Take/check the
969         cron.unchecked lock just before traping to cleanup on exit.
970         Remove potato override handling.  Remove any dangling symlinks in
971         /srv/incoming.d.o/buildd.  Clean up apt-ftparchive's databases.
972
973         * config/debian/apt.conf: change default compression scheme for
974         both Sources and Packages to gzip and bzip2 rather than
975         uncompressed and gzip (Packages) and gzip (Sources).  Use old
976         defaults for proposed-updates.
977
978         * dak/control_overrides.py (main): refuse to operate on
979         untouchable suites.
980
981         * config/debian/pseudo-packages.maintainers: drop install,
982         installation, boot-floppy, slink-cd, potato-cd and
983         nonus.debian.org.  Update base.
984         * config/debian/pseudo-packages.description: likewise.
985
986         * daklib/utils.py (re_srchasver): new regex.
987         (parse_changes): use regex to split 'Source (Version)' style
988         Source fields into 'source' and 'source-version'.
989
990         * config/debian/cron.daily: use $base instead of hardcoding path
991         name.
992
993         * scripts/debian/mkfilesindices: source 'vars' file and use it's
994         variables instead of hardcoding path names.
995
996         * config/debian/apt.conf: switch from /org to /srv.
997         * config/debian/apt.conf.buildd: likewise.
998         * config/debian/apt.conf.stable: likewise.
999         * config/debian/cron.daily: likewise.
1000         * config/debian/cron.hourly: likewise.
1001         * config/debian/cron.monthly: likewise.
1002         * config/debian/cron.unchecked: likewise.
1003         * config/debian/cron.weekly: likewise.
1004         * config/debian/dak.conf: likewise.
1005         * config/debian/vars: likewise.
1006         * scripts/debian/mkfilesindices: likewise.
1007
1008 2007-02-08  James Troup  <james@nocrew.org>
1009
1010         * dak/process_unchecked.py (check_signed_by_key): new function to
1011         ensure .changes files are signed by an authorized uploader.
1012         (process_it): use it.
1013
1014         * config/debian/dak.conf (Binary-Upload-Restrictions): new stanza
1015         to configure per suite/component/architecture binary upload
1016         restrictions.
1017
1018 2007-02-08  Anthony Towns  <ajt@debian.org>
1019
1020         * config/debian/dak.conf: update for 3.1r4.  Use new 'etch'
1021         signing key.  Drop maximum index diffs down to 14.
1022
1023         * config/debian/apt.conf: add udeb support for non-free (testing,
1024         unstable) and experimental.
1025         * config/debian/dak.conf: likewise.
1026
1027         * dak/generate_releases.py (main): handle udebs in any component.
1028
1029         * daklib/queue.py (Upload.build_summaries): handle files without a
1030         'type' gracefully.
1031
1032         * dak/generate_releases.py (print_sha256_files): new function.
1033         (main): use it.
1034
1035         * dak/process_accepted.py (stable_install): fix name of template
1036         mail.
1037
1038         * dak/process_unchecked.py (is_stableupdate): fix invocation of
1039         database.get_suite_id().
1040
1041         * templates/process-new.bxa_notification: Update on request
1042         of/after discussion with BIS staff.
1043
1044         * scripts/debian/mkfilesindices: also handle proposed-updates.
1045
1046 2007-02-08  Ryan Murray  <rmurray@debian.org>
1047
1048         * config/debian/cron.monthly: use $ftpgroup instead of hardcoding
1049         group name for chgrp of mail archives.
1050
1051         * daklib/queue.py (Upload.check_dsc_against_db): handle multiple
1052         orig.tar.gz's by picking the first one by file id.
1053
1054         * dak/override.py (main): limit to binary overrides only for now.
1055         (usage): update to match.
1056
1057         * config/debian/cron.daily: track when we have the accepted lock
1058         and clean it up on exit if we have it.  Take/check the
1059         cron.unchecked lock just before traping to cleanup on exit.
1060         Remove potato override handling.  Remove any dangling symlinks in
1061         /srv/incoming.d.o/buildd.  Clean up apt-ftparchive's databases.
1062
1063         * config/debian/apt.conf: change default compression scheme for
1064         both Sources and Packages to gzip and bzip2 rather than
1065         uncompressed and gzip (Packages) and gzip (Sources).  Use old
1066         defaults for proposed-updates.
1067
1068         * dak/control_overrides.py (main): refuse to operate on
1069         untouchable suites.
1070
1071         * config/debian/pseudo-packages.maintainers: drop install,
1072         installation, boot-floppy, slink-cd, potato-cd and
1073         nonus.debian.org.  Update base.
1074         * config/debian/pseudo-packages.description: likewise.
1075
1076         * daklib/utils.py (re_srchasver): new regex.
1077         (parse_changes): use regex to split 'Source (Version)' style
1078         Source fields into 'source' and 'source-version'.
1079
1080         * config/debian/cron.daily: use $base instead of hardcoding path
1081         name.
1082
1083         * scripts/debian/mkfilesindices: source 'vars' file and use it's
1084         variables instead of hardcoding path names.
1085
1086         * config/debian/apt.conf: switch from /org to /srv.
1087         * config/debian/apt.conf.buildd: likewise.
1088         * config/debian/apt.conf.stable: likewise.
1089         * config/debian/cron.daily: likewise.
1090         * config/debian/cron.hourly: likewise.
1091         * config/debian/cron.monthly: likewise.
1092         * config/debian/cron.unchecked: likewise.
1093         * config/debian/cron.weekly: likewise.
1094         * config/debian/dak.conf: likewise.
1095         * config/debian/vars: likewise.
1096         * scripts/debian/mkfilesindices: likewise.
1097
1098 2007-02-08  James Troup  <james@nocrew.org>
1099
1100         * dak/process_unchecked.py (check_signed_by_key): new function to
1101         ensure .changes files are signed by an authorized uploader.
1102         (process_it): use it.
1103
1104         * config/debian/dak.conf (Binary-Upload-Restrictions): new stanza
1105         to configure per suite/component/architecture binary upload
1106         restrictions.
1107
1108 2006-10-09  James Troup  <james.troup@canonical.com>
1109
1110         * dak/process_unchecked.py (check_timestamps): change match to
1111         search as recent versions of python-apt prefix the string with 'E: '.
1112
1113 2006-10-09  James Troup  <james.troup@canonical.com>
1114
1115         * dak/process_unchecked.py (check_timestamps): change match to
1116         search as recent versions of python-apt prefix the string with 'E: '.
1117
1118 2006-06-26  Ryan Murray  <rmurray@debian.org>
1119
1120         * dak/process_unchecked.py (check_files): strip optional source version
1121         from Source: field in changes file, and ensure what is left is a valid
1122         package name.
1123
1124 2006-06-26  Ryan Murray  <rmurray@debian.org>
1125
1126         * dak/process_unchecked.py (check_files): strip optional source version
1127         from Source: field in changes file, and ensure what is left is a valid
1128         package name.
1129
1130 2006-06-23  Ryan Murray  <rmurray@debian.org>
1131
1132         * dak/process_unchecked.py (check_files): also check ProposedUpdates
1133         queue for source.
1134
1135 2006-06-23  Ryan Murray  <rmurray@debian.org>
1136
1137         * dak/process_unchecked.py (check_files): also check ProposedUpdates
1138         queue for source.
1139
1140 2006-06-18  Ryan Murray  <rmurray@debian.org>
1141
1142         * dak/scripts/debian/update-ftpstats: look for dak named processes in
1143         the log, too.
1144
1145         * dak/process_unchecked.py (check_files): only check embargoed and
1146         unembargoed queues if the keys are set.
1147
1148         * dak/config/debian-security/apt.conf: set Packages::Compress to gzip
1149         and bzip2 for etch.
1150
1151 2006-06-18  Ryan Murray  <rmurray@debian.org>
1152
1153         * dak/scripts/debian/update-ftpstats: look for dak named processes in
1154         the log, too.
1155
1156         * dak/process_unchecked.py (check_files): only check embargoed and
1157         unembargoed queues if the keys are set.
1158
1159         * dak/config/debian-security/apt.conf: set Packages::Compress to gzip
1160         and bzip2 for etch.
1161
1162 2006-06-16  James Troup  <james@nocrew.org>
1163
1164         * dak/dak.py (init): add new-security-install.
1165
1166         * dak/new_security_install.py: cleanups and adapt for new naming
1167         scheme and other changes.
1168
1169 2006-06-16  Anthony Towns  <ajt@debian.org>
1170
1171         * dak/new_security_install.py: initial version imported from
1172         klecker.
1173
1174 2006-06-16  James Troup  <james@nocrew.org>
1175
1176         [Merged changes from klecker - original author unknown.]
1177
1178         * daklib/queue.py (Upload.dump_vars): also save changes["adv id"].
1179
1180         * dak/security_install.py (do_upload): fix check for oldstable and
1181         upload file list handling.
1182
1183         * dak/process_unchecked.py (check_files): update "check for
1184         source" code to also look in Embargoed and Unembargoed queues.
1185         (is_unembargo): fix handling of Dir::Queue::Disembargo.
1186
1187         * dak/decode_dot_dak.py (main): add support for changes["adv id"].
1188
1189         * config/debian-security/vars (disembargo): add.
1190
1191         * config/debian-security/dak.conf (Dinstall::SigningKeyIds):
1192         update.
1193         (Process-Unchecked::AcceptedLockFile): add.
1194         (Suite::Testing): clean up Version and Description.
1195         (SuiteMappings): add silent map from etch-secure to testing.
1196
1197         * config/debian-security/cron.unchecked: add support for
1198         disembargoed queues.
1199
1200         * config/debian-security/apt.conf.buildd: add bzip2ed Packages
1201         files too.
1202
1203         * config/debian-security/apt.conf: add amd64 to architectures for
1204         testing-security.
1205
1206 2006-06-11  James Troup  <troup@spohr.debian.org>
1207
1208         * config/debian/cron.daily: invoke process-accepted not
1209         process-unchecked.
1210
1211         * config/debian/vars (scriptsdir): new variable.
1212         * config/debian/cron.daily: use it.
1213
1214         * scripts/debian/mkmaintainers: put Maintainers_Versions-non-US in
1215         $base/misc/ instead of versioned $masterdir.  Correct 'dak
1216         make-maintainers' invocation to look in $configdir for
1217         pseudo-packages.maintainers.
1218
1219         * daklib/queue.py (Upload.do_reject): use correct name for
1220         rejection template.
1221
1222 2006-06-11  James Troup  <james@nocrew.org>
1223
1224         * dak/override.py (main): temporarily add content of old X-Katie
1225         header back as the PTS apparently filters on it.
1226         * dak/process_accepted.py (main): likewise.
1227         * dak/process_new.py (main): likewise.
1228         * dak/process_unchecked.py (main): likewise.
1229         * dak/reject_proposed_updates.py (main): likewise.
1230         * dak/rm.py (main): likewise.
1231         * daklib/queue.py (Upload.do_reject): likewise.
1232
1233         * config/debian/cron.unchecked: set -u to error out on undefined
1234         variables.  Preset LOCKDAILY to "" accordingly.
1235         * config/debian/cron.hourly: likewise.
1236         * config/debian/cron.monthly: likewise.
1237         * config/debian/cron.weekly: likewise.
1238
1239         * config/debian/vars (configdir): add new variable pointing to
1240         this directory.
1241
1242         * config/debian/cron.daily: use $configdir inplace of $masterdir
1243         when that's what we mean, and don't cd into $masterdir just to run
1244         dak scripts as we don't need to do that anymore.
1245         * config/debian/cron.hourly: likewise.
1246         * config/debian/cron.unchecked: likewise.
1247         * config/debian/cron.weekly: likewise.
1248
1249         * config/debian/dak.conf
1250         (Import-Users-From-Passwd::KnownPostgres): temporarily add 'katie'
1251         user back to list of known users as it's non-trivial to entirely
1252         change the owner of a database with postgresql 7.4.
1253
1254         * daklib/queue.py (Upload.source_exists): use string object
1255         methods rather than string module.
1256         (Upload.get_anyversion): likewise.
1257
1258         * daklib/utils.py (validate_changes_file_arg): update filename
1259         slicing to cope with new .dak filenames.
1260
1261         * dak/ls.py (main): add back 'heidi' as a valid argument for
1262         -f/--format as people are using it in scripts and breaking that
1263         without warning seems rude.
1264
1265 2006-05-21  James Troup  <james@nocrew.org>
1266
1267         * dak/rm.py (main): use string .isdigit() rather than
1268         utils.str_isnum().
1269         * dak/process_new.py (edit_overrides): likewise.
1270
1271         * daklib/utils.py (str_isnum): removed accordingly.  Also drop
1272         string import.
1273
1274 2006-05-21  James Troup  <james@nocrew.org>
1275
1276         * dak/check_archive.py (check_indices_files_exist): use list
1277         comprehension instead of map().  No longer need to import
1278         deprecated string module as a side-effect.
1279         * dak/check_overrides.py (process): likewise.
1280         (main): likewise.
1281         * dak/cruft_report.py (do_obsolete_source): likewise.
1282         (main): likewise.
1283         * dak/ls.py (main): likewise.
1284         * dak/make_suite_file_list.py (write_filelists): likewise.
1285         * dak/process_accepted.py (stable_install): likewise.
1286         * dak/rm.py (main): likewise.
1287         * dak/stats.py (number_of_packages): likewise.
1288         * daklib/logging.py (Logger.log): likewise.
1289         * daklib/queue.py (Upload.source_exists): likewise.
1290         (Upload.cross_suite_version_check): likewise.
1291         * daklib/utils.py (parse_args): likewise.
1292
1293 2006-05-21  James Troup  <james@nocrew.org>
1294
1295         * daklib/utils.py (process_gpgv_output): new function, split out
1296         of check_signature().
1297         (check_signature): adapt accordingly.
1298         (retrieve_key): new function that will try to retrieve the key
1299         that signed a given file from a keyserver.
1300         (check_signature): add 'autofetch' argument that if not set
1301         defaults to the value of Dinstall::KeyAutoFetch (if that exists).
1302         If 'autofetch' is true, invoke retrieve_key().
1303
1304         * docs/README.config: document Dinstall::KeyAutoFetch and
1305         Dinstall:KeyServer.
1306
1307 2006-05-20  James Troup  <james@nocrew.org>
1308
1309         * dak/find_null_maintainers.py (main):
1310         s/createtimestamp/createTimestamp/ to make things work with modern
1311         slapd.
1312
1313         * config/debian/dak.conf: Update StableRejector, MoreInfoURL,
1314         Stable::Version and Stable::Description for 3.1r2.
1315
1316         * config/debian-non-US/dak.conf: sync with klecker - update
1317         version number of 3.0 and MoreInfoURL.
1318
1319         * docs/README.stable-point-release: Add notes about updating
1320         dak.conf and Reject-Proposed-Updates section in particular.
1321         s/woody/stable/.  Also need to update README.html.
1322
1323         * scripts/debian/mklslar: drop support for uncompressed ls-lR file.
1324
1325         * config/debian/apt.conf: Add udeb tree for proposed-updates.
1326
1327 2006-05-20  Ryan Murray  <rmurray@debian.org>
1328
1329         * scripts/debian/update-ftpstats: new script to update daily
1330         architecture size graph data.
1331
1332         * config/debian/cron.buildd: sync with spohr - due to ftp-master /
1333         buildd split, simply ssh to buildd.d.o and call 'trigger.often'
1334         there.
1335
1336         * config/debian/cron.daily: ssh to buildd and run 'trigger.daily'
1337         before we finish.  Don't push to merkel.
1338
1339         * dak/process_unchecked.py (check_changes): Also look in
1340         ProposedUpdates queue dir.
1341         (check_files): likewise.
1342
1343 2006-05-20  Anthony Towns  <ajt@debian.org>
1344
1345         * scripts/debian/mkfilesindices: new script to generate file
1346         indices used for partial mirroring.
1347
1348         * config/debian/cron.daily: add progress timestamps.
1349
1350         * config/debian/dak.conf: update Dinstall::SigningKeyIds. Add
1351         amd64 to testing, unstable and experimental.  Drop sh from
1352         experimental.  Move Experimental to dists/experimental.  Add
1353         Dir::ProposedUpdates.  Add Architectures::amd64.
1354
1355         * config/debian/apt.conf: add amd64 to testing, unstable and
1356         experimental.  Drop uncompressed Packages files from testing. Drop
1357         sh from experimental.  Move experimental to dists/experimental/.
1358
1359         * config/debian/vars (archs): add amd64.
1360
1361         * dak/process_unchecked.py (action): Add support for
1362         proposed-updates approval queue.
1363         (is_stableupdate): new function - checks if the upload is targeted
1364         at proposed-updates.
1365         (do_stableupdate): likewise - moves upload to proposed-updates
1366         holding area.
1367
1368         * dak/process_new.py (do_new): warn if original or new target
1369         suite are invalid.
1370
1371         * dak/generate_releases.py (print_md5sha_files): less whitespace
1372         between the hash and size.
1373
1374         * dak/generate_index_diffs.py (genchanges): don't say we're not
1375         doing anything.  Better formatting of other messages.
1376         (main): don't skip experimental and remove some 'doing stuff'
1377         prints.
1378
1379 2006-05-18  James Troup  <james@nocrew.org>
1380
1381         * dak/clean_suites.py (clean_binaries): remove debug print of SQL
1382         query.
1383
1384         * dak/init_dirs.py: pylint cleanups - long lines, unused globals,
1385         docstrings, untabify, don't shadow builtins, lowercase non-global
1386         variable names, spaces after commas.  Also bail if given any
1387         arguments since we don't accept any.
1388         * dak/init_db.py: likewise.  Also split large main() into
1389         subfunctions and rename get() to sql_get().
1390
1391         * dak/init_db.py (main): check returned value from
1392         database.get_archive_id().
1393
1394         * dak/dak.py: renamed from shell.py.  Update to support new source
1395         layout.  Created init() and usage() functions.  Various
1396         pylint-inspired cleanups.  Use daklib utils.warn() and
1397         utils.fubar().  Change 'functionality' variable to only have
1398         (command, description) and always invoke main() when running the
1399         module.  Also support -h.
1400
1401 2006-05-17  James Troup  <james@nocrew.org>
1402
1403         * dak/check_archive.py: remove $Id$ and $Revision$ strings.  Update
1404         imports of and calls to daklib modules.  Change script name
1405         everywhere, i.e. in output, mails, comments and configuration tree
1406         + filenames.  Also update references to other renamed scripts,
1407         classes and templates.  Use '.dak' instead of '.katie' for the
1408         queue info storage files.
1409         (Renamed from tea)
1410         * dak/check_overrides.py: likewise.  (Renamed from cindy)
1411         * dak/check_proposed_updates.py: likewise.  (Renamed from jeri)
1412         * dak/clean_proposed_updates.py: likewise.  (Renamed from halle)
1413         * dak/clean_queues.py: likewise.  (Renamed from shania)
1414         * dak/clean_suites.py: likewise.  (Renamed from rhona)
1415         * dak/compare_suites.py: likewise.  (Renamed from andrea)
1416         * dak/control_overrides.py: likewise.  (Renamed from natalie)
1417         * dak/control_suite.py: likewise.  (Renamed from heidi)
1418         * dak/cruft_report.py: likewise.  (Renamed from rene)
1419         * dak/decode_dot_dak.py: likewise.  (Renamed from ashley)
1420         * dak/find_null_maintainers.py: likewise.  (Renamed from rosamund)
1421         * dak/generate_index_diffs.py: likewise.  (Renamed from tiffani)
1422         * dak/generate_releases.py: likewise.  (Renamed from ziyi)
1423         * dak/import_archive.py: likewise.  (Renamed from neve)
1424         * dak/import_ldap_fingerprints.py: likewise. (Renamed from emilie)
1425         * dak/import_users_from_passwd.py: likewise. (Renamed from julia)
1426         * dak/init_db.py: likewise. (Renamed from alyson)
1427         * dak/init_dirs.py: likewise. (Renamed from rose)
1428         * dak/ls.py: likewise. (Renamed from madison)
1429         * dak/make_maintainers.py: likewise.  (Renamed from charisma)
1430         * dak/make_overrides.py: likewise.  (Renamed from denise)
1431         * dak/make_suite_file_list.py: likewise.  (Renamed from jenna)
1432         * dak/mirror_split.py: likewise.  (Renamed from billie)
1433         * dak/override.py: likewise.  (Renamed from alicia)
1434         * dak/poolize.py: likewise.  (Renamed from catherine)
1435         * dak/process_accepted.py: likewise.  (Renamed from kelly)
1436         * dak/process_new.py: likewise.  (Renamed from lisa)
1437         * dak/process_unchecked.py: likewise.  (Renamed from jennifer)
1438         * dak/queue_report.py: likewise.  (Renamed from helena)
1439         * dak/reject_proposed_updates.py: likewise.  (Renamed from lauren)
1440         * dak/rm.py: likewise.  (Renamed from melanie)
1441         * dak/security_install.py: likewise.  (Renamed from amber)
1442         * dak/split_done.py: likewise.  (Renamed from nina)
1443         * dak/stats.py: likewise.  (Renamed from saffron)
1444         * dak/symlink_dists.py: likewise.  (Renamed from saffron)
1445         * daklib/database.py: likewise.  (Renamed from db_access)
1446         * daklib/queue.py: likewise.  'Katie' class -> 'Upload'. (Renamed from katie)
1447         * daklib/utils.py: likewise.
1448
1449         * dak/cruft_report.py: Use '[auto-cruft]' as the magic "this removal
1450         doesn't need to notify anyone" string.
1451         * dak/rm.py: likewise, look for '[auto-cruft]' as the magic string.
1452
1453         * dak/process_accepted.py (init): drop -V/--version argument.
1454         * dak/process_new.py (init): likewise.
1455         * dak/process_unchecked.py (init): likewise.
1456         * dak/reject_proposed_updates.py (init): likewise
1457
1458         * dak/shell.py: Renamed from dak.  ".katie" -> ".dak"
1459
1460         * dak/stats.py: in usage() output change STAT to MODE.
1461
1462 2006-05-15  James Troup  <james@nocrew.org>
1463
1464         * dak/queue_report.py: remove unused encodings imports.
1465
1466         * dak/mirror_split.py: drop unused pg, pwd, db_access and logging
1467         imports.  Initalize 'Cnf' as a global.
1468         (BillieDB._internal_recurse): fix 'util.' typo.
1469
1470         * dak/import_ldap_fingerprints.py (main): drop unused time import and
1471         commented out time check for LDAP search.
1472
1473 2005-12-16  Ryan Murray  <rmurray@debian.org>
1474
1475         * halle: add support for udebs
1476         * kelly: stable_install: add support for binNMU versions
1477
1478 2005-12-05  Anthony Towns  <aj@erisian.com.au>
1479
1480         * katie.py: Move accept() autobuilding support into separate function 
1481         (queue_build), and generalise to build different queues
1482
1483         * db_access.py: Add get_or_set_queue_id instead of hardcoding accepted=0
1484
1485         * jennifer: Initial support for enabling embargo handling with the
1486         Dinstall::SecurityQueueHandling option.
1487         * jennifer: Shift common code into remove_from_unchecked and move_to_dir
1488         functions.
1489
1490         * katie.conf-security: Include embargo options
1491         * katie.conf-security: Add Lock dir
1492         * init_pool.sql-security: Create disembargo table
1493         * init_pool.sql-security: Add constraints for disembargo table
1494
1495 2005-11-26  Anthony Towns  <aj@erisian.com.au>
1496
1497         * Merge of changes from klecker, by various people
1498
1499         * amber: special casing for not passing on amd64 and oldstable updates
1500         * amber: security mirror triggering
1501         * templates/amber.advisory: updated advisory structure
1502         * apt.conf.buildd-security: update for sarge's release
1503         * apt.conf-security: update for sarge's release
1504         * cron.buildd-security: generalise suite support, update for sarge's release
1505         * cron.daily-security: update for sarge's release, add udeb support
1506         * vars-security: update for sarge's release
1507         * katie.conf-security: update for sarge's release, add amd64 support,
1508         update signing key
1509
1510         * docs/README.names, docs/README.quotes: include the additions
1511
1512 2005-11-25  Anthony Towns  <aj@erisian.com.au>
1513
1514         * Changed accepted_autobuild to queue_build everywhere.
1515         * Add a queue table.
1516         * Add a "queue" field in the queue_build table (currently always 0)
1517
1518         * jennifer: Restructure to make it easier to support special
1519         purpose queues between unchecked and accepted.
1520
1521 2005-11-25  Anthony Towns  <aj@erisian.com.au>
1522
1523         * Finishing merge of changes from spohr, by various people still
1524
1525         * jennifer: If changed-by parsing fails, set variables to "" so REJECT
1526         works
1527         * jennifer: Re-enable .deb ar format checking
1528         * katie.py: Convert to +bX binNMU special casing
1529         * rhona: Add some debug output when deleting binaries
1530         * cron.daily: Add emilie
1531         * cron.unchecked: Add lock files
1532
1533 2005-11-15  Anthony Towns  <aj@erisian.com.au>
1534
1535         * Merge of changes from spohr, by various people.
1536
1537         * tiffani: new script to do patches to Packages, Sources and Contents
1538         files for quicker downloads.
1539         * ziyi: update to authenticate tiffani generated files
1540
1541         * dak: new script to provide a single binary with less arbitrary names
1542         for access to dak functionality.
1543
1544         * cindy: script implemented
1545
1546         * saffron: cope with suites that don't have a Priority specified
1547         * heidi: use get_suite_id()
1548         * denise: don't hardcode stable and unstable, or limit udebs to unstable
1549         * denise: remove override munging for testing (now done by cindy)
1550         * helena: expanded help, added new, sort and age options, and fancy headers
1551         * jennifer: require description, add a reject for missing dsc file
1552         * jennifer: change lock file
1553         * kelly: propogation support
1554         * lisa: honour accepted lock, use mtime not ctime, add override type_id
1555         * madison: don't say "dep-retry"
1556         * melanie: bug fix in output (missing %)
1557         * natalie: cope with maintainer_override == None; add type_id for overrides
1558         * nina: use mtime, not ctime
1559
1560         * katie.py: propogation bug fixes
1561         * logging.py: add debugging support, use | as the logfile separator
1562
1563         * katie.conf: updated signing key (4F368D5D)
1564         * katie.conf: changed lockfile to dinstall.lock
1565         * katie.conf: added Lisa::AcceptedLockFile, Dir::Lock
1566         * katie.conf: added tiffani, cindy support
1567         * katie.conf: updated to match 3.0r6 release
1568         * katie.conf: updated to match sarge's release
1569
1570         * apt.conf: update for sarge's release
1571         * apt.conf.stable: update for sarge's release
1572         * apt.conf: bump daily max Contents change to 25MB from 12MB
1573
1574         * cron.daily: add accepted lock and invoke cindy
1575         * cron.daily: add daily.lock
1576         * cron.daily: invoke tiffani
1577         * cron.daily: rebuild accepted buildd stuff
1578         * cron.daily: save rene-daily output on the web site
1579         * cron.daily: disable billie
1580         * cron.daily: add stats pr0n
1581
1582         * cron.hourly: invoke helena
1583
1584         * pseudo-packages.maintainers,.descriptions: miscellaneous updates
1585         * vars: add lockdir, add etch to copyoverrides
1586         * Makefile: add -Ipostgresql/server to CXXFLAGS
1587
1588         * docs/: added README.quotes
1589         * docs/: added manpages for alicia, catherine, charisma, cindy, heidi,
1590         julia, katie, kelly, lisa, madison, melanie, natalie, rhona.
1591
1592         * TODO: correct spelling of "conflicts"
1593
1594 2005-05-28  James Troup  <james@nocrew.org>
1595
1596         * helena (process_changes_files): use MTIME rather than CTIME (the
1597         C's not for 'creation', stupid).
1598         * lisa (sort_changes): likewise.
1599
1600         * jennifer (check_distributions): use has_key rather than an 'in'
1601         test which doesn't work with python2.1.  [Probably by AJ]
1602
1603 2005-03-19  James Troup  <james@nocrew.org>
1604
1605         * rene (main): use Suite::<suite>::UdebComponents to determine
1606         what components have udebs rather than assuming only 'main' does.
1607
1608 2005-03-18  James Troup  <james@nocrew.org>
1609
1610         * utils.py (rfc2047_encode): use codecs.lookup() rather than
1611         encodings.<encoding>.Codec().decode() as encodings.utf_8 no longer
1612         has a Codec() module in python2.4.  Thanks to Andrew Bennetts
1613         <andrew@ubuntu.com>.
1614
1615 2005-03-06  Joerg Jaspert  <ganneff@debian.org>
1616
1617         * helena: add -n/--new HTML output option and improved sorting
1618         options.
1619
1620 2005-03-06  Ryan Murray  <rmurray@debian.org>
1621
1622         * shania(main): use Cnf::Dir::Reject instead of REJECT
1623
1624 2005-02-08  James Troup  <james@nocrew.org>
1625
1626         * rene (main): add partial NBS support by checking that binary
1627         packages are built by their real parent and not some random
1628         stranger.
1629         (do_partial_nbs): likewise.
1630
1631 2005-01-18  James Troup  <james@nocrew.org>
1632
1633         * katie.py (Katie.build_summaries): avoid leaking file handle when
1634         extracting package description.
1635         (Katie.force_reject): remember and close each file descriptor we
1636         use.
1637         (Katie.do_reject): s/file/temp_fh/ to avoid pychecker warning.
1638         s/reason_file/reason_fd/ because it's a file descriptor.
1639         (Katie.check_dsc_against_db): avoid leaking file handle whenever
1640         invoking apt_pkg.md5sum().
1641
1642         * jennifer (check_deb_ar): new function: sanity check the ar
1643         contents of a .deb.
1644         (check_files): use it.
1645         (check_timestamps): check for data.tar.bz2 if data.tar.gz can't be
1646         found.
1647         (check_files): accept 'raw-installer' as an alias for 'byhand'.
1648
1649 2005-01-14  Anthony Towns  <ajt@debian.org>
1650
1651         * kelly: when UNACCEPTing, don't double up the "Rejecting:"
1652
1653         * propup stuff (thanks to Andreas Barth)
1654         * katie.conf: add stable MustBeOlderThan testing, add -security
1655           propup
1656         * jennifer: set distribution-version in .katie if propup may be needed
1657         * katie.py: add propogation to cross_suite_version_check
1658
1659 2004-11-27  James Troup  <james@nocrew.org>
1660
1661         * nina: new script to split monolithic queue/done into date-based
1662         hierarchy.
1663
1664         * rene (usage): document -s/--suite.
1665         (add_nbs): use .setdefault().
1666         (do_anais): likewise.
1667         (do_nbs): don't set a string to "" and then += it.
1668         (do_obsolete_source): new function - looks for obsolete source
1669         packages (i.e source packages whose binary packages are ALL a)
1670         claimed by someone else and b) newer when built from the other
1671         source package).
1672         (main): support -s/--suite.  Add 'obsolete source' to both 'daily'
1673         and 'full' check modes.  Check for obsolete source packages.
1674         linux-wlan-ng has been fixed - remove hideous bodge.
1675
1676         * jennifer (check_distributions): support 'reject' suite map type.
1677
1678         * utils.py (validate_changes_file_arg): s/file/filename/.
1679         s/fatal/require_changes/.  If require_changes is -1, ignore errors
1680         and return the .changes filename regardless.
1681         (re_no_epoch): s/\*/+/ as there must be a digit in an epoch.
1682         (re_no_revision): don't escape '-', it's not a special character.
1683         s/\*/+/ as there must be at least one non-dash character after the
1684         dash in a revision.  Thanks to Christian Reis for noticing both of
1685         these.
1686
1687         * ashley (main): pass require_changes=-1 to
1688         utils.validate_changes_file_arg().
1689
1690         * pseudo-packages.maintainers (kernel): switch to 'Debian Kernel
1691         Team <debian-kernel@lists.debian.org>'.
1692
1693         * katie.py (Katie.in_override_p): fix .startswith() usage.
1694
1695         * katie.conf (Dinstall::DefaultSuite): add as 'unstable'.
1696         (Lauren::MoreInfoURL): update to 3.0r3.
1697         (Suite::Stable::Version): likewise.
1698         (Suite::Stable::Description): likewise.
1699
1700         * cron.daily: disable automatic task override generation.
1701
1702         * cindy (process): restrict "find all packages" queries by
1703         component.  Respect Options["No-Action"].
1704         (main): add -n/--no-action support.  Only run on unstable.  Rename
1705         type to otype (pychecker).
1706
1707 2004-11-27  Daniel Silverstone  <dsilvers@digital-scurf.org>
1708
1709         * katie.conf (Billie::BasicTrees): add all architectures.
1710         (Billie::CombinationTrees): remove 'welovehp' and 'embedded', add
1711         'everything'.
1712
1713         * cron.daily: Update a 'current' symlink when creating the
1714         post-daily-cron-job database backup to aid mirroring to merkel.
1715         Run billie.
1716
1717         * billie (BillieTarget.poolish_match): handle .udeb too.
1718
1719 2004-10-13  Ryan Murray  <rmurray@debian.org>
1720
1721         * amber (do_upload): Sort changes files in "katie" order so that
1722           source always arrives before binary-only rebuilds
1723
1724 2004-10-05  James Troup  <james@nocrew.org>
1725
1726         * jennifer (check_dsc): correct reject message on invalid
1727         Maintainer field.
1728
1729 2004-09-20  James Troup  <james@nocrew.org>
1730
1731         * alicia: remove unused 'pwd' import.
1732
1733         * tea (check_override): underline suite name in output properly.
1734
1735         * rene (main): read a compressed Packages file.
1736         * tea (validate_packages): likewise.
1737
1738         * katie.py (re_fdnic): add 'r' prefix.
1739         (re_bin_only_nmu_of_mu): likewise.
1740         (re_bin_only_nmu_of_nmu): likewise.
1741
1742         * madison (main): retrieve component information too and display
1743         it if it's not 'main'.
1744         * melanie (reverse_depends_check): likewise.
1745
1746         * utils.py (pp_dep): renamed...
1747         (pp_deps): ... to this.
1748         * jeri (check_dep): update calls to utils.pp_deps().
1749         * melanie (reverse_depends_check): likewise.
1750
1751         * jennifer (check_changes): move initalization of email variables
1752         from here...
1753         (process_it): ...to here as we no longer always run
1754         check_changes().  Don't bother to initialize
1755         changes["architecture"].
1756
1757         * denise (list): renamed to...
1758         (do_list): ...this to avoid name clash with builtin 'list'.
1759         Similarly, s/file/output_file/, s/type/otype/.  Use .setdefault()
1760         for dictionaries.
1761         (main): Likewise for name clash avoidance and also
1762         s/override_type/suffix/.  Adjust call to do_list().
1763
1764 2004-09-01  Ryan Murray  <rmurray@debian.org>
1765
1766         * tea (check_files): check the pool/ directory instead of dists/
1767
1768 2004-08-04  James Troup  <james@nocrew.org>
1769
1770         * jenna (cleanup): use .setdefault() for dictionaries.
1771         (write_filelists): likewise.
1772
1773         (write_filelists): Use utils.split_args() not split() to split
1774         command line arguments.
1775         (stable_dislocation_p): likewise.
1776
1777         (write_filelists): Add support for mapping side of suite-based
1778         "Arch: all mapping".
1779         (do_da_do_da): ensure that if we're not doing all suites that we
1780         process enough to be able correct map arch: all packages.
1781
1782         * utils.py (cant_open_exc): correct exception string,
1783         s/read/open/, s/.$//.
1784
1785         * templates/amber.advisory: update to match reality a little
1786         better.
1787
1788         * melanie (reverse_depends_check): read Packages.gz rather than
1789         Packages.
1790
1791         * jennifer (check_files): check for unknown component before
1792         checking for NEWness.
1793
1794         * katie.py (Katie.in_override_p): use .startswith in favour of a
1795         slice.
1796
1797         * docs/melanie.1.sgml: document -R/--rdep-check.
1798
1799 2004-07-12  Daniel Silverstone  <dsilvers@digital-scurf.org>
1800
1801         * billie (main): Make the verbatim lists include all the README
1802           elements.
1803         * docs/README.names: Add billie in (correcting oversight)
1804
1805 2004-07-01  James Troup  <james@nocrew.org>
1806
1807         * emilie (main): handle woody's case-sensitive python-ldap,
1808         s/keyfingerprint/keyFingerPrint/.
1809
1810 2004-06-25  James Troup  <james@nocrew.org>
1811
1812         * debian/control (Depends): add dpkg-dev since jennifer uses
1813         dpkg-source.
1814
1815 2004-06-24  James Troup  <james@nocrew.org>
1816
1817         * melanie (main): s/file/temp_file/ and close file handle before
1818         removing the temporary file.
1819         (main): don't warn about needing a --carbon-copy if in no-action
1820         mode.
1821
1822         * rene (do_nbs): pcmcia-cs has been fixed - remove hideous bodge.
1823         (main): likewise.
1824
1825         * test/006/test.py (main): check bracketed email-only form.
1826
1827         * utils.py (fix_maintainer): if the Maintainer string is bracketed
1828         email-only, strip the brackets so we don't end up with
1829         <<james@nocrew.org>>.
1830
1831 2004-06-20  James Troup  <james@nocrew.org>
1832
1833         * jennifer (process_it): only run check_changes() if
1834         check_signature() returns something.  (Likewise)
1835
1836         * utils.py (changes_compare): if there's no changes["version"] use
1837         "0" rather than None.  (Avoids a crash on unsigned changes file.)
1838
1839 2004-06-17  Martin Michlmayr  <tbm@cyrius.com>
1840
1841         * jeri (pp_dep): moved from here to ...
1842         * utils.py (pp_dep): here.
1843
1844         * melanie (main): add reverse dependency checking.
1845
1846 2004-06-17  James Troup  <james@nocrew.org>
1847
1848         * jennifer (check_dsc): s/dsc_whitespace_rules/signing_rules/.
1849         * tea (check_dscs): likewise.
1850
1851         * utils.py (parse_changes): s/dsc_whitespace_rules/signing_rules/,
1852         change from boolean to a variable with 3 possible values, 0 and 1
1853         as before, -1 means don't require a signature.  Makes
1854         parse_changes() useful for parsing arbitary RFC822-style files,
1855         e.g. 'Release' files.
1856         (check_signature): add support for detached signatures by passing
1857         the files the signature is for as an optional third argument.
1858         s/filename/sig_filename/g.  Add a fourth optional argument to
1859         choose the keyring(s) to use.  Don't os.path.basename() the
1860         sig_filename before checking it for taint.
1861         (re_taint_free): allow '/'.
1862
1863 2004-06-11  James Troup  <james@nocrew.org>
1864
1865         * tea (check_files): make override.unreadable optional.
1866         (validate_sources): close the Sources file handle.
1867
1868         * docs/README.first: clarify that 'alyson' and running
1869         add_constraints.sql by hand is something you only want to do if
1870         you're not running 'neve'.
1871
1872         * docs/README.config (Location::$LOCATION::Suites): document.
1873
1874         * db_access.py (do_query): also print out the result of the query.
1875
1876 2004-06-10  James Troup  <james@nocrew.org>
1877
1878         * katie.py (Katie.cross_suite_version_check): post-woody versions
1879         of python-apt's apt_pkg.VersionCompare() function apparently
1880         returns variable integers for less than or greater than results -
1881         update our result checking to match.
1882         * jenna (resolve_arch_all_vs_any): likewise.
1883         * charisma (main): likewise.
1884
1885 2004-06-09  James Troup  <james@nocrew.org>
1886
1887         * jennifer (process_it): s/changes_valid/valid_changes_p/.  Add
1888         valid_dsc_p and don't run check_source() if check_dsc() failed.
1889         (check_dsc): on fatal failures return 0 so check_source() isn't
1890         run (since it makes fatal assumptions about the presence of
1891         mandatory .dsc fields).
1892         Remove unused and obsolete re_bad_diff and re_is_changes regexps.
1893
1894 2004-05-07  James Troup  <james@nocrew.org>
1895
1896         * katie.conf (Rhona::OverrideFilename): unused and obsolete, remove.
1897         * katie.conf-non-US (Rhona::OverrideFilename): likewise.
1898
1899         * katie.conf (Dir::Override): remove duplicate definition.
1900
1901         * neve (get_or_set_files_id): add an always-NULL last_used column
1902         to output.
1903
1904 2004-04-27  James Troup  <james@nocrew.org>
1905
1906         * apt.conf-security (tree "dists/stable/updates"): add
1907         ExtraOverride - noticed by Joey Hess (#246050).
1908         (tree "dists/testing/updates"): likewise.
1909
1910 2004-04-20  James Troup  <james@nocrew.org>
1911
1912         * jennifer (check_files): check for existing .changes or .katie
1913         files of the same name in the Suite::<suite>::Copy{Changes,Katie}
1914         directories.
1915
1916 2004-04-19  James Troup  <james@nocrew.org>
1917
1918         * jennifer (check_source): handle failure to remove the temporary
1919          directory (used for source tree extraction) better, specifically:
1920          if we fail with -EACCES, chmod -R u+rwx the temporary directory
1921          and try again and if that works, REJECT the package.
1922
1923 2004-04-17  James Troup  <james@nocrew.org>
1924
1925         * docs/madison.1.sgml: document -b/--binary-type,
1926         -g/--greaterorequal and -G/--greaterthan.
1927
1928         * madison (usage): -b/--binary-type only takes a single argument.
1929         Document -g/--greaterorequal and -G/--greaterthan.
1930         (main): add support for -g/--greaterorequal and -G/--greaterthan.
1931
1932 2004-04-12  Daniel Silverstone  <dsilvers@digital-scurf.org>
1933
1934         * billie: Cleaned up a load of comments, added /README.non-US to
1935           the verbatim matches list.
1936
1937 2004-04-07  Daniel Silverstone  <dsilvers@digital-scurf.org>
1938
1939         * utils.py (size_type): Make it use real binary megabytes and
1940           kilobytes, instead of the marketing terms used before.
1941
1942 2004-04-07  James Troup  <james@nocrew.org>
1943
1944         * katie.py (Katie.check_dsc_against_db): in the case we're
1945         ignoring an identical-to-existing orig.tar.gz remember the path to
1946         the existent version in pkg.orig_tar_gz.  Adjust query to grab
1947         location.path too to be able to do so.
1948
1949 2004-04-03  James Troup  <james@nocrew.org>
1950
1951         * debian/control (Depends): add python2.1-email | python (>= 2.2)
1952         needed for new utils.rfc2047_encode() function.
1953
1954         * utils.py (re_parse_maintainer): allow whitespace inside the
1955         email address.
1956         (Error): new exception base class.
1957         (ParseMaintError): new exception class.
1958         (force_to_utf8): new function.
1959         (rfc2047_encode): likewise.
1960         (fix_maintainer): rework.  use force_to_utf8() to force name and
1961         rfc822 return values to always use UTF-8.  use rfc2047_encode() to
1962         return an rfc2047 value.  Validate the address to catch missing
1963         email addresses and (some) broken ones.
1964
1965         * katie.py (nmu_p.is_an_nmu): adapt for new utils.fix_maintainer()
1966         by adopting foo2047 return value.
1967         (Katie.dump_vars): add changedby2047 and maintainer2047 as
1968         mandatory changes fields.  Promote changes and maintainer822 to
1969         mandatory fields.
1970         (Katie.update_subst): default maintainer2047 rather than
1971         maintainer822.  User foo2047 rather than foo822 when setting
1972         __MAINTAINER_TO__ or __MAINTAINER_FROM__.
1973
1974         * jennifer (check_changes): set default changes["maintainer2047"]
1975         and changes["changedby2047"] values rather than their 822
1976         equivalents.  Makes changes["changes"] a mandatory field.  Adapt
1977         to new utils.fix_maintainer() - reject on exception and adopt
1978         foo2047 return value.
1979         (check_dsc): if a mandatory field is missing don't do any further
1980         checks and as a result reduce paranoia about dsc[var] existence.
1981         Validate the maintainer field by calling new
1982         utils.fix_maintainer().
1983
1984         * ashley (main): add changedby2047 and maintainer2047 to mandatory
1985         changes fields.  Promote maintainer822 to a mandatory changes
1986         field.  add "pool name" to files fields.
1987
1988         * test/006/test.py: new file - tests for new
1989         utils.fix_maintainer().
1990
1991 2004-04-01  James Troup  <james@nocrew.org>
1992
1993         * templates/lisa.prod (To): use __MAINTAINER_TO__ not __MAINTAINER__.
1994
1995         * jennifer (get_changelog_versions): create a symlink mirror of
1996         the source files in the temporary directory.
1997         (check_source): if check_dsc_against_db() couldn't find the
1998         orig.tar.gz bail out.
1999
2000         * katie.py (Katie.check_dsc_against_db): if the orig.tar.gz is not
2001         part of the upload store the path to it in pkg.orig_tar_gz and if
2002         it can't be found set pkg.orig_tar_gz to -1.
2003
2004         Explicitly return the second value as None in the (usual) case
2005         where we don't have to reprocess.  Remove obsolete diagnostic
2006         logs.
2007
2008         * lisa (prod_maintainer): don't return anything, no one cares. (pychecker)
2009
2010         * utils.py (temp_filename): new helper function that wraps around
2011         tempfile.mktemp().
2012
2013         * katie.py (Katie.do_reject): use it and don't import tempfile.
2014         * lisa (prod_maintainer): likewise.
2015         (edit_note): likewise.
2016         (edit_new): likewise.
2017         * lauren (reject): likewise.
2018         * melanie (main): likewise.
2019         * neve (do_sources): likewise.
2020         * rene (main): likewise.
2021         * tea (validate_sources): likewise.
2022
2023 2004-03-31  James Troup  <james@nocrew.org>
2024
2025         * tea (validate_sources): remove unused 's' temporary variable.
2026
2027 2004-03-15  James Troup  <james@nocrew.org>
2028
2029         * jennifer (check_dsc): check changes["architecture"] for
2030         source before we do anything else.
2031
2032 2004-03-21  Daniel Silverstone  <dsilvers@digital-scurf.org>
2033
2034         * billie: Added
2035         * katie.conf (Billie): Added sample Billie stanza to katie.conf
2036
2037 2004-03-12  James Troup  <james@nocrew.org>
2038
2039         * docs/README.config (Dir::Queue::BTSVersionTrack): document.
2040
2041         * katie.conf (Dir::Queue::BTSVersionTrack): define.
2042
2043         * katie.py (Katie.accept): add support for DebBugs Version
2044         Tracking by writing out .versions (generated in jennifer's
2045         get_changelog_versions()) and .debinfo (mapping of binary ->
2046         source) files.
2047
2048         * ashley (main): add dsc["bts changelog"].
2049
2050         * katie.py (Katie.dump_vars): store dsc["bts changelog"] too.
2051
2052         * jennifer (check_diff): obsoleted by check_source(), removed.
2053         (check_source): new function: create a temporary directory and
2054         move into it and call get_changelog_versions().
2055         (get_changelog_versions): new function: extract the source package
2056         and optionally parse debian/changelog to obtain the version
2057         history for the BTS.
2058         (process_it): call check_source() rather than check_diff().
2059
2060 2004-03-08  James Troup  <james@nocrew.org>
2061
2062         * lisa (edit_index): Fix logic swapo from 'use "if varfoo in
2063         listbar" rather than "if listbar.count(varfoo)"' change on
2064         2004-02-24.
2065
2066 2004-03-05  James Troup  <james@nocrew.org>
2067
2068         * alicia (main): don't warn about not closing bugs - we don't
2069         manage overrides through the BTS.
2070
2071 2004-02-27  Martin Michlmayr  <tbm@cyrius.com>
2072
2073         * docs/README.config: lots of updates and corrections.
2074         * docs/README.first: likewise.
2075
2076         * docs/README.config: drop unused Dir::Queue::Root.
2077         * katie.conf-non-US: likewise.
2078         * katie.conf: likewise.
2079         * katie.conf-security: likewise.
2080
2081 2004-02-27  James Troup  <james@nocrew.org>
2082
2083         * rose (process_tree): use 'if var in [ list ]' rather than long
2084         'if var == foo or var == bar or var == baz'.  Suggested by Martin
2085         Michlmayr.
2086
2087         * jennifer (check_files): reduce 'if var != None' to 'if var' as
2088         suggested by Martin Michlmayr.
2089         * catherine (poolize): likewise.
2090         * charisma (main): likewise.
2091         * halle (check_changes): likewise.
2092         * heidi (main): likewise.
2093         (process_file): likewise.
2094         * kelly (install): likewise.
2095         (stable_install): likewise.
2096         * utils.py (fix_maintainer): likewise.
2097
2098         * apt.conf: add support for debian-installer in testing-proposed-updates.
2099         * katie.conf (Suite::Testing-Proposed-Updates::UdebComponents):
2100         add - set to main.
2101
2102         * mkmaintainers: add "-T15" option to wget of non-US packages file
2103         so that we don't hang cron.daily if non-US is down.
2104
2105         * templates/lisa.prod (Subject): Prefix with "Comments regarding".
2106
2107         * templates/jennifer.bug-close: add Source and Source-Version
2108         pseudo-headers that may be used for BTS Version Tracking someday
2109         [ajt@].
2110
2111         * rene (do_nbs): special case linux-wlan-ng like we do for pcmcia.
2112         (main): likewise.
2113
2114         * cron.unchecked: it's /org/ftp.debian.org not ftp-master.
2115
2116 2004-02-25  James Troup  <james@nocrew.org>
2117
2118         * katie.conf (SuiteMappings): don't map testing-security to
2119         proposed-updates.
2120
2121 2004-02-24  James Troup  <james@nocrew.org>
2122
2123         * katie.py (Katie.__init__): remove unused 'values' field.
2124
2125         * utils.py (extract_component_from_section): use 's.find(c) != -1'
2126         rather than 's.count(c) > 0'.
2127
2128         * katie.py (Katie.source_exists): use "if varfoo in listbar"
2129         rather than "if listbar.count(varfoo)".
2130         * halle (check_joey): likewise.
2131         * jeri (check_joey): likewise.
2132         * lisa (edit_index): likewise.
2133         * jenna (stable_dislocation_p): likewise.
2134
2135         * jennifer (main): remove unused global 'nmu'.
2136
2137 2004-02-03  Daniel Silverstone  <dsilvers@digital-scurf.org>
2138
2139         * pseudo-packages.maintainers (ftp.debian.org): Changed the maintainer
2140           to be ftpmaster@ftp-master.debian.org to bring it into line with how
2141           the dak tools close bugs.
2142
2143 2004-02-02  Daniel Silverstone  <dsilvers@digital-scurf.org>
2144
2145         * katie.conf (Alicia): Added an Alicia section with email address
2146         * templates/alicia.bug-close: Added
2147         * docs/alicia.1.sgml: Added the docs for the -d/--done argument
2148         * alicia (main): Added a -d/--done argument
2149
2150 2004-02-02  Daniel Silverstone  <dsilvers@digital-scurf.org>
2151
2152         * templates/lisa.prod: Oops, missed a BITCH->PROD conversion
2153
2154 2004-01-29  Daniel Silverstone  <dsilvers@digital-scurf.org>
2155
2156         * lisa (prod_maintainer): Added function to prod the maintainer without
2157           accepting or rejecting the package
2158         * templates/lisa.prod: Added this template for the prodding mail
2159
2160         * .cvsignore: Added neve-files which turns up in new installations
2161
2162 2004-01-30  Daniel Silverstone  <dsilvers@digital-scurf.org>
2163
2164         * alicia (usage): Fixed usage message to offer section and priority
2165           as seperately optional arguments.
2166         * alicia (main): Added a % (arg) interpolation needed when only
2167           one of section or priority is provided and it cannot be found.
2168
2169 2004-01-29  Daniel Silverstone  <dsilvers@digital-scurf.org>
2170
2171         * alicia: Added
2172         * docs/alicia.1.sgml: Added
2173         * docs/Makefile: Added alicia to the list of manpages to build
2174         * docs/README.names: Noted what alicia does
2175         * docs/README.first: Noted where alicia is useful
2176
2177 2004-01-21  James Troup  <james@nocrew.org>
2178
2179         * madison (main): add -b/--binary-type.
2180         (usage): likewise.
2181
2182         * denise (main): generate debian-installer overrides for testing
2183         too.
2184         * apt.conf: add support for debian-installer in testing.
2185         * katie.conf (Suite::Testing::UdebComponents): set to main.
2186
2187         * katie.conf (Dinstall::SigningKeyIds): 2004 key.
2188         * katie.conf-non-US (Dinstall::SigningKeyIds): likewise.
2189         * katie.conf-security (Dinstall::SigningKeyIds): likewise.
2190
2191         * utils.py (parse_changes): don't process data not inside the
2192         signed data.  Thanks to Andrew Suffield <asuffield@debian.org> for
2193         pointing this out.
2194         * test/005/test.py (main): new test to test for above.
2195
2196 2004-01-04  James Troup  <james@nocrew.org>
2197
2198         * jenna (write_filelists): correct typo, s/Components/Component/
2199         for Options.
2200
2201 2004-01-04  Ryan Murray  <rmurray@debian.org>
2202
2203         * cron.buildd: move update of overrides and Packages file...
2204         * cron.unchecked: to here.
2205         * katie.conf-non-US: (Dinstall::SingingKeyIds) update for 2003v2 key
2206         * katie.conf-security: likewise
2207
2208 2003-11-20  James Troup  <james@nocrew.org>
2209
2210         * jenna (main): don't use utils.try_with_debug(), it produces way
2211         too much output.
2212
2213         * halle (check_changes): don't error out if a .changes refers to a
2214         non-existent package, just warn and skip the file.
2215
2216         * docs/README.stable-point-release: mention halle and .changes
2217         obsoleted by removal through melanie.  Update for 3.0r2.
2218
2219         * katie.conf (Suite::Stable::Version): bump to 3.0r2.
2220         (Suite::Stable::Description): update for 3.0r2.
2221         (Lauren::MoreInfoURL): likewise.
2222         * katie.conf-non-US (Suite::Stable::Version): likewise.
2223         (Suite::Stable::Description): likewise.
2224         (Lauren::MoreInfoURL): likewise.
2225
2226         * apt.conf.stable (Default): don't define MaxContentsChange.
2227         * apt.conf.stable-non-US (Default): likewise.
2228
2229         * lauren (reject): hack to work around partial replacement of an
2230         upload, i.e. one or more binaries superseded by another source
2231         package.
2232
2233 2003-11-17  James Troup  <james@nocrew.org>
2234
2235         * pseudo-packages.maintainers: point installation-reports at
2236         debian-boot@l.d.o rather than debian-testing@l.d.o at jello@d.o's
2237         request.
2238
2239         * utils.py (parse_changes): calculate the number of lines once
2240         with len() rather than max().
2241
2242         * jennifer (check_dsc): handle the .orig.tar.gz disappearing from
2243         files, since check_dsc_against_db() deletes the .orig.tar.gz
2244         entry.
2245
2246 2003-11-13  Ryan Murray  <rmurray@debian.org>
2247
2248         * apt.conf: specify a src override file for debian-installer
2249
2250 2003-11-10  James Troup  <james@nocrew.org>
2251
2252         * fernanda.py (strip_pgp_signature): new function - strips PGP
2253         signature from a file and returns the modified contents of the
2254         file in a string.
2255         (display_changes): use it.
2256         (read_dsc): likewise.
2257
2258 2003-11-09  Ryan Murray  <rmurray@debian.org>
2259
2260         * cron.buildd: export accepted_autobuild table for unstable, and use
2261         it to generate the incoming Packages/Sources rather than having apt
2262         walk the directory.
2263         * apt.conf.buildd: use exported table from cron.buildd to generate
2264         Packages/Sources
2265
2266 2003-11-07  James Troup  <james@nocrew.org>
2267
2268         * kelly: import errno.
2269
2270         * katie.py (Katie.build_summaries): sort override disparities.
2271
2272         * kelly (install): set dsc_component based on the .dsc's component
2273         not a random binaries.
2274
2275 2003-10-29  James Troup  <james@nocrew.org>
2276
2277         * katie.py (Katie.build_summaries): don't assume changes["source"]
2278         exists since it might not.
2279
2280 2003-10-20  James Troup  <james@nocrew.org>
2281
2282         * pseudo-packages.maintainers: update security.d.o to use
2283         team@s.d.o at joy@'s request.
2284
2285 2003-10-17  James Troup  <james@nocrew.org>
2286
2287         * jennifer (check_dsc): use .startswith rather than .find() == 0.
2288
2289 2003-10-17  Martin Michlmayr  <tbm@cyrius.com>
2290
2291         * tea (chk_bd_process_dir): use .endswith rather than slice.
2292
2293 2003-10-14  James Troup  <james@nocrew.org>
2294
2295         * tea (check_build_depends): new function.
2296         (chk_bd_process_dir): likewise.  Validates build-depends in .dsc's
2297         in the archive.
2298         (main): update for new function.
2299         (usage): likewise.
2300
2301         * katie.py (Katie.do_reject): sanitize variable names,
2302         s/reject_filename/reason_filename/, s/fd/reason_fd/.  Move shared
2303         os.close() to outside if clause.
2304
2305         * jennifer (check_dsc): check build-depends and
2306         build-depends-indep by running them past apt_pkg.ParseSrcDepends.
2307         Fold the ARRAY check into the same code block and tidy up it's
2308         rejection message.
2309         (check_changes): ensure that the Files field is non-empty.
2310         Suggested by Santiago Vila <sanvila@unex.es>
2311         (check_changes): normalize reject messages.
2312         (check_dsc): instead of doing most of the checks inside a for loop
2313         and an if, find the dsc_filename in a short loop over files first
2314         and then do all the checks.  Add check for more than one .dsc in a
2315         .changes which we can't handle.  Normalize reject messages.
2316
2317 2003-10-13  James Troup  <james@nocrew.org>
2318
2319         * katie.conf (Dinstall::Reject::NoSourceOnly): set to true.
2320         * katie.conf-non-US (Dinstall::Reject::NoSourceOnly): likewise.
2321
2322         * jennifer (check_files): Set 'has_binaries' and 'has_source'
2323         variables while iterating over 'files'.  Don't regenerate it when
2324         checking for source if source is mentioned.
2325
2326         Reject source only uploads if the config variable
2327         Dinstall::Reject::NoSourceOnly is set.
2328
2329 2003-10-03  James Troup  <james@nocrew.org>
2330
2331         * rene (main): add nasty hardcoded reference to debian-installer
2332         so we detect NBS .udebs.
2333
2334 2003-09-29  James Troup  <james@nocrew.org>
2335
2336         * apt.conf (old-proposed-updates): remove.
2337         * apt.conf-non-US (old-proposed-updates): likewise.
2338
2339 2003-09-24  James Troup  <james@nocrew.org>
2340
2341         * tea (check_files_not_symlinks): new function, ensure files
2342         mentioned in the database aren't symlinks.  Includes code to
2343         update any files that are like this to their real filenames +
2344         location; commented out by though.
2345         (usage): update for new function.
2346         (main): likewise.
2347
2348 2003-09-24  Anthony Towns  <ajt@debian.org>
2349
2350         * vars: external-overrides variable added
2351         * cron.daily: Update testing/unstable Task: overrides from joeyh
2352         managed external source.
2353
2354 2003-09-22  James Troup  <james@nocrew.org>
2355
2356         * kelly (install): if we can't move the .changes into queue/done,
2357         fail don't warn and carry on.  The old behaviour pre-dates NI and
2358         doesn't make much sense now since jennifer checks both
2359         queue/accepted and queue/done for any .changes files it's
2360         processing.
2361
2362         * utils.py (move): don't throw exceptions on existing files or
2363         can't overwrite, instead just fubar out.
2364
2365         * jennifer (check_dsc): also check Build-Depends-Indep for
2366         ARRAY-lossage.  Noticed by Matt Zimmerman <mdz@debian.org>.
2367
2368 2003-09-18  James Troup  <james@nocrew.org>
2369
2370         * katie.py (Katie.close_bugs): only log the bugs we've closed
2371         once.
2372
2373         * kelly (main): log as 'kelly', not 'katie'.
2374
2375 2003-09-16  James Troup  <james@nocrew.org>
2376
2377         * katie.py (Katie.check_binary_against_db): likewise noramlize.
2378
2379         * jennifer (check_changes): normalize reject message for "changes
2380         file already exists" to be %s: <foo>.
2381         (check_dsc): add a check for 'Build-Depends: ARRAY(<hex>)'
2382         produced by broken dpkg-source in 1.10.11.  Tone down and
2383         normalize rejection message for incompatible 'Format' version
2384         numbers.
2385         (check_diff): likewise tone down and normalize.
2386
2387 2003-09-07  James Troup  <james@nocrew.org>
2388
2389         * utils.py (parse_changes): if dsc_whitespace_rules is false,
2390         don't bomb out on bogus empty lines.
2391         (build_file_list): check for changes["files"] earlier.  use Dict
2392         to create files[name] dictionary.
2393         (send_mail): don't bother validating arguments.
2394         (check_signature): minor improvements to some of the rejection
2395         messages including listing the key id of the key that wasn't found
2396         in the keyring.
2397         (wrap): new function.
2398
2399         * tea: add new check 'validate-indices' that ensures all files
2400         mentioned in indices (Packages, Sources) files do in fact exist.
2401
2402         * catherine (poolize): use a local re_isadeb which handles legacy
2403         (i.e. no architecture) style .deb filenames.
2404
2405         * rosamund: new script.
2406
2407         * rhona (check_binaries): when checking for binary packages not in
2408         a suite, don't bother selecting files that already have a
2409         last_used date.
2410         (check_sources): likewise.
2411
2412         * rhona: change all SQL EXISTS sub-query clauses to use the
2413         postgres suggested convention of "SELECT 1 FROM".
2414         * andrea (main): likewise.
2415         * tea (check_override): likewise.
2416         * catherine (main): likewise.
2417
2418         * katie.conf (Suite): remove OldStable and Old-Proposed-Updates
2419         entries and in other suites MustBeNewerThan's.
2420         (SuiteMappings): likewise
2421         * katie.conf-non-US: likewise.
2422         * katie.conf-security: likewise.
2423
2424         * apt.conf-security: remove oldstable.
2425         * apt.conf.stable: likewise.
2426         * apt.conf.stable-non-US: likewise.
2427         * cron.buildd-security: likewise.
2428         * cron.daily-security: likewise.
2429         * vars-security (suites): likewise.
2430         * wanna-build/trigger.daily: likewise.
2431
2432         * claire.py (clean_symlink): move...
2433         * utils.py (clean_symlink): here.
2434
2435         * claire.py (find_dislocated_stable): update accordingly.
2436
2437 2003-08-16  Anthony Towns  <ajt@debian.org>
2438
2439         * katie.py (source_exists): expand the list of distributions
2440         the source may exist in to include any suite that's mapped to
2441         the destination suite (even transitively (a->b->c)). This should
2442         unbreak binary uploads to *-proposed-updates.
2443
2444 2003-08-09  Randall Donald  <rdonald@debian.org>
2445
2446         * lisa (recheck): change changes["distribution"].keys() to
2447         Katie.pkg.changes...
2448
2449 2003-08-08  Randall Donald  <rdonald@debian.org>
2450
2451         * katie.py: only tag bugs as fixed-in-experimental for
2452         experimental uploads
2453
2454 2003-07-26  Anthony Towns  <ajt@debian.org>
2455
2456         * katie.py (source_exists): add an extra parameter to limit the
2457         distribution(s) the source must exist in.
2458         * kelly, lisa, jennifer: update to use the new source_exists
2459
2460 2003-07-15  Anthony Towns  <ajt@debian.org>
2461
2462         * ziyi: quick hack to support a FakeDI line in apt.conf to generate
2463         checksums for debian-installer stuff even when it's just a symlink to
2464         another suite
2465
2466         * apt.conf: add the FakeDI line
2467
2468 2003-06-09  James Troup  <james@nocrew.org>
2469
2470         * kelly (check): make sure the 'file' we're looking for in 'files'
2471         hasn't been deleted by katie.check_dsc_against_db().
2472
2473 2003-05-07  James Troup  <james@nocrew.org>
2474
2475         * helena (time_pp): fix s/years/year/ typo.
2476
2477 2003-04-29  James Troup  <james@nocrew.org>
2478
2479         * madison (usage): document -c/--component.
2480
2481         * madison (usage): Fix s/seperated/separated/.
2482         * melanie (usage): likewise.
2483         * jenna (usage): likewise.
2484
2485 2003-04-24  James Troup  <james@nocrew.org>
2486
2487         * cron.daily-non-US: if there's nothing for kelly to install, say
2488         so.
2489
2490         * jennifer (check_timestamps): print sys.exc_value as well as
2491         sys.exc_type when capturing exceptions.  Prefix 'timestamp check
2492         failed' with 'deb contents' to make it clearer what timestamp(s)
2493         are being checked.
2494
2495 2003-04-15  James Troup  <james@nocrew.org>
2496
2497         * cron.daily-non-US: only run kelly if there are some .changes
2498         files in accepted.
2499
2500         * rene: add -m/--mode argument which can be either daily (default)
2501         or full.  In daily mode only 'nviu' and 'nbs' checks are run.
2502         Various changes to make this possible including a poor attempt at
2503         splitting main() up a little.  De-hardcode suite numbers from SQL
2504         queries and return quietly from do_nviu() if experimental doesn't
2505         exist (i.e. non-US).  Hardcode pcmcia-cs as dubious NBS since it
2506         is.
2507
2508         * debian/control (Depends): remove python-zlib as it's obsolete.
2509
2510         * charisma (main): don't slice the \n off strings when we're
2511         strip()-ing it anyway.
2512         * heidi (set_suite): likewise.
2513         (process_file): likewise.
2514         * natalie (process_file): likewise.
2515
2516 2003-04-08  James Troup  <james@nocrew.org>
2517
2518         * katie.py (Katie.check_dsc_against_db): improve the speed of two
2519         slow queries by using one LIKE '%foo%' and then matching against
2520         '%s' or '/%s$' in python.  Also only join location when we need it
2521         (i.e. the .orig.tar.gz query).  On auric, this knocks ~3s of each
2522         query, so 6s for each sourceful package.
2523
2524         * cron.daily: invoke rene and send the report to ftpmaster.
2525         * cron.daily-non-US: likewise.
2526
2527 2003-03-14  James Troup  <james@nocrew.org>
2528
2529         * utils.py (send_mail): default filename to blank.
2530         * amber (make_advisory): adapt.
2531         * jennifer (acknowledge_new): likewise.
2532         * katie.py (Katie.close_bugs): likewise.
2533         (Katie.announce): likewise.
2534         (Katie.accept): likewise.
2535         (Katie.check_override): likewise.
2536         (Katie.do_reject): likewise.
2537         * kelly (do_reject): likewise.
2538         (stable_install): likewise.
2539         * lisa (do_bxa_notification): likewise.
2540         * lauren (reject): likewise.
2541         * melanie (main): likewise.
2542
2543         * rene (add_nbs): check any NBS packages against unstable to see
2544         if they haven't been removed already.
2545
2546         * templates/katie.rejected: remove paragraph about rejected files
2547         since they're o-rwx due to c-i-m and the uploader can't do
2548         anything about them and shania will take care of them anyway.
2549
2550         * madison (usage): update usage example to use comma seperation.
2551         * melanie (usage): likewise.
2552
2553         * utils.py (split_args): new function; splits command line
2554         arguments either by space or comma (whichever is used).  Also has
2555         optional-but-default DWIM spurious space detection to avoid
2556         'command -a i386, m68k' problems.
2557         (parse_args): use it.
2558         * melanie (main): likewise.
2559
2560         * melanie (main): force the admin to tell someone if we're not
2561         doing a rene-led removal (or closing a bug, which counts as
2562         telling someone).
2563
2564 2003-03-05  James Troup  <james@nocrew.org>
2565
2566         * katie.conf (Section): add embedded, gnome, kde, libdevel, perl
2567         and python sections.
2568         * katie.conf-security (Section): likewise.
2569
2570         * add_constraints.sql: add uid and uid_id_seq to grants.
2571
2572         * lisa (determine_new): also warn about adding overrides to
2573         oldstable.
2574
2575         * madison (main): make the -S/--source-and-binary query obey
2576         -s/--suite restrictions.
2577
2578 2003-03-03  James Troup  <james@nocrew.org>
2579
2580         * madison (main): if the Archive_Maintenance_In_Progress lockfile
2581         exists, warn the user that our output might seem strange.  (People
2582         get confused by multiple versions in a suite which happens
2583         post-kelly but pre-jenna.)
2584
2585 2003-02-21  James Troup  <james@nocrew.org>
2586
2587         * kelly (main): we don't need to worry about StableRejector.
2588
2589         * melanie (main): sort versions with apt_pkg.VersionCompare()
2590         prior to output.
2591
2592         * lauren: new script to manually reject packages from
2593         proposed-updates.  Updated code from pre-NI kelly (nee katie).
2594
2595 2003-02-20  James Troup  <james@nocrew.org>
2596
2597         * kelly (init): remove unused -m/--manual-reject argument.
2598
2599         * katie.py (Katie.force_reject): renamed from force_move to make
2600         it more explicit what this function does.
2601         (Katie.do_reject): update to match.
2602
2603         * utils.py (prefix_multi_line_string): add an optional argument
2604         include_blank_lines which defaults to 0.  If non-zero, blank lines
2605         will be includes in the output.
2606
2607         * katie.py (Katie.do_reject): don't add leading space to each line
2608         of the reject message.  Include blank lines when showing the
2609         message to the user.
2610
2611 2003-02-19  Martin Michlmayr  <tbm@cyrius.com>
2612
2613         * utils.py (fix_maintainer): replace pointless re.sub() with
2614         simple string format.
2615
2616 2003-02-11  James Troup  <james@nocrew.org>
2617
2618         * lisa (edit_overrides): only strip-to-one-char and upper-case
2619         non-numeric answers.  Fixes editing of items with indices >= 10;
2620         noticed by Randall.
2621         (edit_overrides): correct order of arguments to "not a valid
2622         index" error message.
2623
2624         * jenna (cleanup): call resolve_arch_all_vs_any() rather than
2625         remove_duplicate_versions(); thanks to aj for the initial
2626         diagnosis.
2627         (remove_duplicate_versions): correct how we return
2628         dominant_versions.
2629         (resolve_arch_all_vs_any): arch_all_versions needs to be a list of
2630         a tuple rather than just a tuple.
2631
2632 2003-02-10  James Troup  <james@nocrew.org>
2633
2634         * emilie: new script - sync fingerprint and uid tables with a
2635         debian.org LDAP DB.
2636
2637         * init_pool.sql: new table 'uid'; contains user ids.  Reference it
2638         in 'fingerprint'.
2639
2640         * db_access.py (get_or_set_uid_id): new function.
2641
2642         * jennifer (main): update locking to a) not used FCNTL (deprecated
2643         in python >= 2.2) and b) acknowledge upstream's broken
2644         implementation of lockf (see Debian bug #74777), c) try to acquire
2645         the lock non-blocking.
2646         * kelly (main): likewise.
2647
2648         * contrib/python_1.5.2-fcntl_lockf.diff: obsolete, removed.
2649
2650         * madison (main): only append the package to new_packages if it's
2651         not already in there; fixes -S/--source-and-binary for cases where
2652         the source builds a binary package of the same name.
2653
2654 2003-02-10  Anthony Towns  <ajt@debian.org>
2655
2656         * madison (main): use explicit JOIN syntax for
2657         -S/--source-and-binary queries to reduce the query's runtime from
2658         >10 seconds to negligible.
2659
2660 2003-02-08  James Troup  <james@nocrew.org>
2661
2662         * rene (main): in the NVIU output, append items to lists, not
2663         extend them; fixes amusing suggestion that "g n u m e r i c" (sic)
2664         should be removed.
2665
2666 2003-02-07  James Troup  <james@nocrew.org>
2667
2668         * apt.conf (tree "dists/unstable"): Add bzip2-ed Packages and
2669         Sources [aj].
2670
2671         * pseudo-packages.maintainers (bugs.debian.org): s/Darren
2672         O. Benham/Adam Heath/.
2673
2674         * katie.conf (Suite::Stable::Version): bump to 3.0r1a.
2675         (Suite::Stable::Description): update for 3.0r1a.
2676         (Dinstall::SigningKeyIds): update for 2003 key [aj].
2677
2678         * utils.py (gpgv_get_status_output): rename from
2679         get_status_output().
2680
2681         * neve (check_signature): use gpgv_get_status_output and Dict from
2682         utils().  Add missing newline to error message about duplicate tokens.
2683
2684         * saffron (per_arch_space_use): also print space used by source.
2685         (output_format): correct string.join() invocation.
2686
2687         * jennifer (check_signature): ignored duplicate EXPIRED tokens.
2688
2689 2003-02-04  James Troup  <james@nocrew.org>
2690
2691         * cron.buildd: correct generation of Packages/Sources and grep out
2692         non-US/non-free as well as non-free.
2693
2694 2003-02-03  Ryan Murray  <rmurray@debian.org>
2695
2696         * cron.buildd: generate quinn-diff output with full Packages/Sources
2697           files to get out-of-date vs. uncompiled right.
2698         * apt.conf.buildd: no longer generate uncompressed files, as they
2699           are generated in cron.buildd instead
2700         * add -i option to quinn-diff to ignore binary-all packages
2701         * apt.conf.buildd: remove and readd udeb to extensions.  If the udebs
2702           aren't in the packages file, the arch that uploaded them will build
2703           them anyways...
2704
2705 2003-01-30  James Troup  <james@nocrew.org>
2706
2707         * rene (main): only print suggested melanie command when there's
2708         some NBS to remove.
2709
2710 2003-01-30  Ryan Murray  <rmurray@debian.org>
2711
2712         * cron.buildd: fix incorrectly inverted lockfile check
2713
2714 2003-01-29  Ryan Murray  <rmurray@debian.org>
2715
2716         * cron.buildd: generate override.sid.all3.src
2717         * apt.conf.buildd: use generated override.sid.all3.src
2718
2719 2003-01-27  Martin Michlmayr  <tbm@cyrius.com>
2720
2721         * utils.py (get_status_output): moved from jennifer.
2722         (Dict): likewise.
2723         (check_signature): likewise.
2724
2725         * jennifer (get_status_output): moved to utils.py.
2726         (Dict): likewise.
2727         (check_signature): likewise.
2728
2729         * utils.py (check_signature): add an argument to specifiy which
2730         function to call when an error was found.
2731         (check_signature): document this function better.
2732
2733         * jennifer (check_files): pass the reject function as an argument
2734         to utils.check_signature.
2735         (process_it): likewise.
2736
2737 2003-01-20  James Troup  <james@nocrew.org>
2738
2739         * rene (main): lots of changes to improve the output and make it
2740         more useful.
2741
2742         * katie.py (Katie.check_override): make the override messages
2743         clearer (hopefully).
2744
2745 2002-12-26  James Troup  <james@nocrew.org>
2746
2747         * ziyi (usage): document the ability to pass suite(s) as
2748         argument(s).
2749         (main): read apt.conf after checking for -h/--help.
2750
2751         * tea (main): take the check to run as an argument.
2752
2753         * saffron.R: R script to graph daily install runs.
2754
2755         * saffron: new script; various stats functions.
2756
2757         * rhona (main): connect to the database after checking for -h/--help.
2758
2759         * neve (do_da_do_da): if no -a/--action option is given, bail out.
2760
2761         * melanie (main): sort versions with utils.arch_compare_sw().
2762
2763         * madison (usage): alphabetize order of options.
2764         * melanie (usage): likewise.
2765
2766         * kelly (usage): fix usage short description (we aren't dinstall).
2767
2768         * julia (usage): fix usage description and alphabetize order of
2769         options.
2770
2771         * jeri (usage): fix usage short description.
2772
2773         * jennifer (main): move --help and --version checks from here...
2774         (init): to here so that they work with an empty katie.conf.
2775         * kelly: likewise.
2776
2777         * alyson (usage): new function.
2778         (main): use it.
2779         * andrea: likewise.
2780         * ashley: likewise.
2781         * cindy: likewise.
2782         * denise: likewise.
2783         * helena: likewise.
2784         * neve: likewise.
2785         * rene: likewise.
2786         * rose: likewise.
2787         * tea: likewise.
2788
2789         * apt.conf.stable (tree "dists/stable"): add missing ExtraOverride
2790         entry that caused tasks to be omitted from 3.0r1.
2791
2792 2002-12-10  James Troup  <james@nocrew.org>
2793
2794         * jennifer (check_files): sanity check the Depends field to ensure
2795         it's non-empty if present since apt chokes on an empty one.
2796         Thanks to Ryan Murray for the idea.
2797
2798 2002-12-08  James Troup  <james@nocrew.org>
2799
2800         * katie.conf-security (Helena::Directories): new; include accepted
2801         in addition to byhand and new.
2802
2803         * helena (process_changes_files): use utils.arch_compare_sw().
2804         Justify things based on the longest [package, version,
2805         architecture].  Reduce '[note]' to '[N]' to save space, and remove
2806         the commas in architecture and version lists for the same reason.
2807         (main): make directories we process configurable through
2808         Helena::Directories in the config file; if that doesn't exist
2809         default to the old hardcoded values (byhand & new).
2810
2811         * utils.py (arch_compare_sw): moved here from madison.
2812         * madison (main): adjust to compensate.
2813
2814 2002-12-06  James Troup  <james@nocrew.org>
2815
2816         * ziyi (main): fix "suite foo not in apt.conf" msg to use the
2817         right filename.
2818
2819 2002-12-05  James Troup  <james@nocrew.org>
2820
2821         * katie.conf-non-US (Julia::KnownPostgres): add 'udmsearch'.
2822
2823 2002-11-28  Randall Donald  <rdonald@debian.org>
2824
2825         * fernanda.py (read_control): fix typo of 'Architecture'.
2826
2827 2002-11-26  James Troup  <james@nocrew.org>
2828
2829         * lisa (check_pkg): call less with '-R' so we see the colour from
2830         Randall's fernanda changes.
2831
2832         * neve (process_sources): if Directory points to a legacy location
2833         but the .dsc isn't there; assume it's broken and look in the pool.
2834         (update_section): new, borroed from alyson.
2835         (do_da_do_da): use it.
2836         (process_packages): add suite_it to the cache key used for
2837         arch_all_cache since otherwise we only add a package to the first
2838         suite it's in and ignore any subsequent ones.
2839
2840         * katie.conf-non-US (Location): fixed to reflect reality (all
2841         suites, except old-proposed-updates (which is legacy-mixed)) are
2842         pool.
2843
2844         * utils.py (try_with_debug): wrapper for print_exc().
2845         * jenna (main): use it.
2846         * neve (main): likewise.
2847
2848 2002-11-25  Randall Donald  <rdonald@debian.org>
2849
2850         * fernanda.py (main): added -R to less command line for raw control
2851         character support to print colours
2852         (check_deb): Instead of running dpkg -I on deb file, call
2853         output_deb_info, the new colourized control reporter.
2854         (check_dsc): add call to colourized dsc info reader, read_dsc, instead
2855         of printing out each .dsc line.
2856         (output_deb_info): new function. Outputs each key/value pair from
2857         read_control except in special cases where we highlight section,
2858         maintainer, architecture, depends and recommends.
2859         (create_depends_string): new function. Takes Depends tree and looks
2860         up it's compontent via projectb db, colourizes and constructs a
2861         depends string in original order.
2862         (read_dsc): new function. reads and parses .dsc info via
2863         utils.parse_changes. Build-Depends and Build-Depends-Indep are
2864         colourized.
2865         (read_control): new function. reads and parses control info via
2866         apt_pkg. Depends and Recommends are split in to list structures,
2867         Section and Architecture are colourized. Maintainer is colourized
2868         if it has a localhost.localdomain address.
2869         (split_depends): new function. Creates a list of lists of
2870         dictionaries of depends (package,version relation). Top list is
2871         colected from comma delimited items. Sub lists are | delimited.
2872         (get_comma_list): new function. splits string input among commas
2873         (get_or_list): new function. splits string input among | delimiters
2874         (get_depends_parts): new function. Creates dictionary of package name
2875         and version relation from dependancy string.
2876         Colours for section and depends are per component. Unfound depends
2877         are in bold. Lookups using version info is not supported yet.
2878
2879 2002-11-22  James Troup  <james@nocrew.org>
2880
2881         * katie.conf-security (Julia::KnownPostgres): add 'www-data' and
2882         'udmsearch'.
2883
2884         * amber (make_advisory): string.atol() is deprecated and hasn't
2885         been ported to string methods.  Use long() instead.
2886
2887         * init_pool.sql: explicitly specify the encoding (SQL_ASCII) when
2888         creating the database since we'll fail badly if it's created with
2889         e.g. UNICODE encoding.
2890
2891         * rose (main): AptCnf is a global.
2892
2893         * neve (get_location_path): new function determines the location
2894         from the the first (left-most) directory of a Filename/Directory.
2895         (process_sources): don't need 'location' anymore.  Use
2896         utils.warn().  Use the Directory: field for each package to find
2897         the .dsc.  Use get_location_path() to determine the location for
2898         each .dsc.
2899         (process_packages): do't need 'location' anymore.  Use
2900         utils.warn().  Use get_location_path().
2901         (do_sources): don't need 'location', drop 'prefix' in favour of
2902         being told the full path to the Sources file, like
2903         process_packages().
2904         (do_da_do_da): main() renamed, so that main can call us in a
2905         try/except.  Adapt for the changes in do_sources() and
2906         process_packages() above.  Assume Sources and Packages file are in
2907         <root>/dists/<etc.>.  Treat pool locations like we do legacy ones.
2908
2909         * katie.conf-security (Location): fixed to reflect reality (all
2910         suites are pool, not legacy).
2911
2912         * utils.py (print_exc): more useful (i.e. much more verbose)
2913         traceback; a recipe from the Python cookbook.
2914         * jenna (main): use it.
2915         * neve (main): likewise.
2916
2917 2002-11-19  James Troup  <james@nocrew.org>
2918
2919         * kelly (install): fix brain-damaged CopyChanges/CopyKatie
2920         handling which was FUBAR for multi-suite uploads.  Now we just
2921         make a dictionary of destinations to copy to and iterate over
2922         those.
2923
2924         * fernanda.py (check_deb): run linda as well as lintian.
2925
2926 2002-10-21  James Troup  <james@nocrew.org>
2927
2928         * melanie (main): change X-Melanie to X-Katie and prefix it with
2929         'melanie '.
2930
2931         * lisa (main): prefix X-Katie with 'lisa '.
2932
2933         * jennifer (clean_holding): fix typo in string method changes;
2934         s/file.find(file/file.find(/.
2935
2936         * cron.daily: invoke helena and send the report to ftpmaster.
2937         * cron.daily-non-US: likewise.
2938
2939 2002-10-16  James Troup  <james@nocrew.org>
2940
2941         * kelly (check): call reject() with a blank prefix when parsing
2942         the return of check_dsc_against_db() since it does its own
2943         prefix-ing.
2944
2945         * rose: new script; only handles directory creation initally.
2946
2947         * katie.conf (Dinstall::NewAckList): obsolete, removed.
2948         * katie.conf-non-US (Dinstall::NewAckList): likewise.
2949
2950 2002-10-06  James Troup  <james@nocrew.org>
2951
2952         * rene (main): remove bogus argument handling.
2953
2954         * kelly: katie, renamed.
2955         * cron.daily: adapt for katie being renamed to kelly.
2956         * cron.daily-non-US: likewise.
2957         * amber (main): likewise.
2958
2959         * Changes for python 2.1.
2960
2961         * kelly: time.strftime no longer requires a second argument of
2962         "time.localtime(time.time())".
2963         * logging.py: likewise.
2964         * rhona: likewise.
2965         * shania (init): likewise.
2966
2967         * amber: use augmented assignment.
2968         * catherine (poolize): likewise.
2969         * claire.py (fix_component_section): likewise.
2970         * halle (check_changes): likewise.
2971         * helena: likewise.
2972         * jenna: likewise.
2973         * jennifer: likewise.
2974         * jeri: likewise.
2975         * katie.py: likewise.
2976         * kelly: likewise.
2977         * lisa: likewise.
2978         * madison (main): likewise.
2979         * melanie: likewise.
2980         * natalie: likewise.
2981         * neve: likewise.
2982         * rhona: likewise.
2983         * tea: likewise.
2984         * utils.py: likewise.
2985         * ziyi: likewise.
2986
2987         * amber: use .endswith.
2988         * fernanda.py: likewise.
2989         * halle (main): likewise.
2990         * jennifer: likewise.
2991         * jeri: likewise.
2992         * katie.py: likewise.
2993         * kelly: likewise.
2994         * lisa: likewise.
2995         * neve: likewise.
2996         * shania (main): likewise.
2997         * utils.py: likewise.
2998
2999         * alyson: use string methods.
3000         * amber: likewise.
3001         * andrea: likewise.
3002         * ashley: likewise.
3003         * catherine: likewise.
3004         * charisma: likewise.
3005         * claire.py: likewise.
3006         * db_access.py: likewise.
3007         * denise: likewise.
3008         * halle: likewise.
3009         * heidi: likewise.
3010         * helena: likewise.
3011         * jenna: likewise.
3012         * jennifer: likewise.
3013         * jeri: likewise.
3014         * julia: likewise.
3015         * katie.py: likewise.
3016         * kelly: likewise.
3017         * lisa: likewise.
3018         * logging.py: likewise.
3019         * madison: likewise.
3020         * melanie: likewise.
3021         * natalie: likewise.
3022         * neve: likewise.
3023         * rene: likewise.
3024         * tea: likewise.
3025         * utils.py: likewise.
3026         * ziyi: likewise.
3027
3028 2002-09-20  Martin Michlmayr  <tbm@cyrius.com>
3029
3030         * utils.py (parse_changes): use <string>.startswith() rather than
3031         string.find().
3032
3033 2002-08-27  Anthony Towns  <ajt@debian.org>
3034
3035         * katie.py (in_override_p): when searching for a source override,
3036         and the dsc query misses, search for both udeb and deb overrides
3037         as well. Should fix the UNACCEPT issues with udebs.
3038
3039 2002-08-24  James Troup  <james@nocrew.org>
3040
3041         * melanie (main): remove gratuitous WHERE EXISTS sub-select from
3042         source+binary package finding code which was causing severe
3043         performance degradation with postgres 7.2.
3044
3045 2002-08-14  James Troup  <james@nocrew.org>
3046
3047         * julia (main): use the pwd.getpwall() to get system user info
3048         rather than trying to read a password file.  Add a -n/--no-action
3049         option.
3050
3051         * cron.hourly: julia no longer takes any arguments.
3052         * cron.hourly-non-US: likewise.
3053
3054 2002-08-07  James Troup  <james@nocrew.org>
3055
3056         * katie (install): handle multi-suite uploads when CopyChanges
3057         and/or CopyKatie are in use, ensuring we only copy stuff once.
3058
3059 2002-08-01  Ryan Murray  <rmurray@debian.org>
3060
3061         * wanna-build/trigger.daily: initial commit, with locking
3062         * cron.buildd: add locking against daily run
3063
3064 2002-07-30  James Troup  <james@nocrew.org>
3065
3066         * melanie (main): readd creation of suite_ids_list so melanie is
3067         remotely useful again.
3068
3069         * katie.conf: adopt for woody release; diable
3070         StableDislocationSupport, add oldstable, adjust other suites and
3071         mappings, fix up location.
3072         * katie.conf-non-US: likewise.
3073         * katie.conf-security: likewise.
3074
3075         * apt.conf.stable: adapt for woody release; add oldstable, adjust
3076         stable.
3077         * apt.conf.stable-non-US: likewise.
3078
3079         * apt.conf-security: adapt for woody release; adding oldstable,
3080         oldstable, adjust stable and testing.
3081         * cron.daily-security: likewise.
3082         * cron.buildd-security: likewise.
3083
3084         * apt.conf: adapt for woody release; rename woody-proposed-updates
3085         to testing-proposed-updates and proposed-updates to
3086         old-proposed-updates.
3087         * apt.conf-non-US: likewise.
3088
3089         * vars-non-US (copyoverrides): add sarge.
3090         * vars (copyoverrides): likewise.
3091
3092         * vars-security (suites): add oldstable.
3093
3094 2002-07-22  Ryan Murray  <rmurray@debian.org>
3095
3096         * apt.conf.security-buildd: use suite codenames instead of
3097           distnames.
3098
3099 2002-07-16  James Troup  <james@nocrew.org>
3100
3101         * denise (main): fix filenames for testing override files.
3102
3103 2002-07-14  James Troup  <james@nocrew.org>
3104
3105         * jennifer (process_it): call check_md5sums later so we can check
3106         files in the .dsc too
3107         (check_md5sums): check files in the .dsc too.  Check both md5sum
3108         and size.
3109
3110         * melanie (main): use parse_args() and join_with_commas_and() from
3111         utils.  If there's nothing to do, say so and exit, don't ask for
3112         confirmation etc.
3113
3114         * amber (join_with_commas_and): moved from here to ...
3115         * utils.py (join_with_commas_and): here.
3116
3117 2002-07-13  James Troup  <james@nocrew.org>
3118
3119         * madison (main): use parse_args() from utils.  Support
3120         -c/--component.
3121
3122         * jenna (parse_args): moved from here to ...
3123         * utils.py (parse_args): here.
3124
3125         * katie.conf (Architectures): minor corrections to the description
3126         for arm, mips and mipsel.
3127         * katie.conf-non-US (Architectures): likewise.
3128         * katie.conf-security (Architectures): likewise.
3129
3130         * cron.daily-security: use natalie's new -a/--add functionality to
3131         flesh out the security overrides.
3132
3133 2002-07-12  James Troup  <james@nocrew.org>
3134
3135         * cron.buildd (ARCHS): add arm.
3136
3137         * katie.conf: 2.2r7 was released.
3138         * katie.conf-non-US: likewise.
3139
3140         * utils.py (parse_changes): handle a multi-line field with no
3141         starting line.
3142
3143 2002-06-25  James Troup  <james@nocrew.org>
3144
3145         * templates/amber.advisory (To): add missing email address since
3146         __WHOAMI__ is only a name.
3147
3148         * katie.conf-security (Melane::LogFile): correct to go somewhere
3149         katie has write access to.
3150         (Location::/org/security.debian.org/ftp/dists/::Suites): add
3151         Testing.
3152
3153         * natalie: add support for -a/-add which adds packages only
3154         (ignoring changes and deletions).
3155
3156         * katie.py (Katie.announce): Dinstall::CloseBugs is a boolean so
3157         use FindB, not get.
3158
3159 2002-06-22  James Troup  <james@nocrew.org>
3160
3161         * jennifer (check_files): validate the package name and version
3162         field.  If 'Package', 'Version' or 'Architecture' are missing,
3163         don't try any further checks.
3164         (check_dsc): likewise.
3165
3166         * utils.py (re_taint_free): add '~' as a valid character.
3167
3168 2002-06-20  Anthony Towns  <ajt@debian.org>
3169
3170         * katie.conf-non-US: add OverrideSuite for w-p-u to allow uploads
3171
3172 2002-06-09  James Troup  <james@nocrew.org>
3173
3174         * jennifer (check_files): reduce useless code.
3175
3176         * cron.daily-security: run symlinks -dr on $ftpdir.
3177
3178         * vars-security (ftpdir): add.
3179
3180 2002-06-08  James Troup  <james@nocrew.org>
3181
3182         * neve (update_override_type): transaction is handled higher up in
3183         main().
3184         (update_priority): likewise.
3185         (process_sources): remove code that makes testing a duplicate of
3186         stable.
3187         (process_packages): likewise.
3188
3189         * templates/amber.advisory: add missing mail headers.
3190
3191         * cron.daily-security: also call apt-ftparchive clean for
3192         apt.conf.buildd-security.
3193         * cron.weekly: likewise.
3194
3195         * amber (do_upload): write out a list of source packages (and
3196         their version) uploaded for testing.
3197         (make_advisory): add more Subst mappings for the mail headers.
3198         (spawn): check for suspicious characters in the command and abort
3199         if their found.
3200
3201 2002-06-07  James Troup  <james@nocrew.org>
3202
3203         * ziyi (main): remove the 'nonus'/'security' hacks and use
3204         Dinstall::SuiteSuffix (if it exists) instead.  Always try to write
3205         the lower level Release files, even if they don't exist.  fubar
3206         out if we can't open a lower level Release file for writing.
3207
3208         * katie.conf-non-US (Dinstall): add SuiteSuffix, used to simplify
3209         ziyi.
3210         * katie.conf-security (Dinstall): likewise.
3211
3212         * amber (do_upload): renamed from get_file_list().  Determine the
3213         upload host from the original component.
3214         (init): Add a -n/--no-action option.  Fix how we get changes_files
3215         (i.e. from the return value of apt_pkg.ParseCommandLine(), not
3216         sys.argv).  Add an Options global.
3217         (make_advisory): support -n/--no-action.
3218         (spawn): likewise.
3219         (main): likewise.
3220         (usage): document -n/--no-action.
3221
3222         * cron.buildd-security: fix path to Packages-arch-specific in
3223         quinn-diff invocation.
3224
3225         * katie.conf-security (Dinstall::AcceptedAutoBuildSuites): change
3226         to proper suite names (i.e. stable, testing) rather than codenames
3227         (potato, woody).
3228         (Dinstall::DefaultSuite): likewise.
3229         (Suite): likewise.
3230         (Location::/org/security.debian.org/ftp/dists/::Suites): likewise.
3231         * vars-security (suites): likewise.
3232         * apt.conf-security: likewise.
3233
3234         * katie.conf-security (Component): add "updates/" prefix.
3235         (Suite::*::Components): likewise.
3236         (ComponentMappings): new; map all {ftp-master,non-US} components
3237         -> updates/<foo>.
3238
3239         * katie.conf-security (Natalie): removed; the options have
3240         defaults and ComponentPosition is used by alyson which doesn't
3241         work on security.d.o.
3242         (Amber): replace UploadHost and UploadDir with ComponentMappings
3243         which is a mapping of components -> URI.
3244         (Suite::*::CodeName): strip bogus "/updates" suffix hack.
3245         (SuiteMappings): use "silent-map" in preference to "map".
3246
3247         * cron.unchecked-security: fix call to cron.buildd-security.
3248
3249         * cron.daily-security: map local suite (stable) -> override suite
3250         (potato) when fixing overrides.  Correct component in natalie call
3251         to take into account "updates/" prefix.  Fix cut'n'waste in
3252         override.$dist.all3 generation, the old files weren't being
3253         removed, so they were endlessly growing.
3254
3255         * neve (main): don't use .Find for the CodeName since we require
3256         it.  Location::*::Suites is a ValueList.
3257         (check_signature): ignore duplicate SIGEXPIRED tokens.  Don't bomb
3258         out on expired keys, just warn.
3259         (update_override_type): new function; lifted from alyson.
3260         (update_priority): likewise.
3261         (main): use update_{override_type,priority}().
3262
3263         * jennifer (check_distributions): remove redunant test for
3264         SuiteMappings; ValueList("does-not-exist") returns [] which is
3265         fine.  Add support for a "silent-map" type which doesn't warn
3266         about the mapping to the user.
3267         (check_files): add support for ComponentMappings, similar to
3268         SuiteMappings, but there's no type, just a source and a
3269         destination and the original component is stored in "original
3270         component".
3271         * katie.py (Katie.dump_vars): add "original component" as an
3272         optionsal files[file] dump variable.
3273
3274         * claire.py (find_dislocated_stable): dehardcode 'potato' in SQL
3275         query.  Add support for section-less legacy locations like current
3276         security.debian.org through YetAnotherConfigBoolean
3277         'LegacyStableHasNoSections'.
3278         * katie.conf-security (Dinstall): LegacyStableHasNoSections is true.
3279
3280         * utils.py (real_arch): moved here from ziyi.
3281         * ziyi (real_arch): moved to utils.py.
3282         * ziyi (main): likewise.
3283
3284         * claire.py (find_dislocated_stable): use real_arch() with
3285         filter() to strip out source and all.
3286         * neve (main): likewise.
3287         * rene (main): likewise.
3288         * jeri (parse_packages): likewise.
3289
3290 2002-06-06  James Troup  <james@nocrew.org>
3291
3292         * tea (check_missing_tar_gz_in_dsc): modifed patch from Martin
3293         Michlmayr <tbm@cyrius.com> to be more verbose about what we're
3294         doing.
3295
3296 2002-05-23  Martin Michlmayr  <tbm@cyrius.com>
3297
3298         * jeri (check_joey): check if the line contains two elements
3299         before accessing the second.  Also, strip trailing spaces as well
3300         as the newline.
3301         * halle (check_joey): likewise.
3302
3303 2002-06-05  James Troup  <james@nocrew.org>
3304
3305         * cron.unchecked-security: new file; like cron.unchecked but if
3306         there's nothing to do exit so we don't call cron.buildd-security.
3307
3308         * apt.conf.buildd-security: new file.
3309
3310         * vars (archs): alphabetize.
3311         * vars-non-US (archs): likewise.
3312
3313         * vars-security: add unchecked.
3314
3315         * madison (main): reduce rather bizarrely verbose and purposeless
3316         code to print arches to a simple string.join.
3317
3318         * katie.conf (Suites::Unstable): add UdebComponents, a new
3319         valuelist of suites, used by jenna to flesh out the list of
3320         <suite>_main-debian-installer-binary-<arch>.list files generated.
3321         (Dinstall): add StableDislocationSupport, a new boolean used by
3322         jenna to enable or disable stable dislocation support
3323         (i.e. claire), as true.
3324
3325         * katie.conf (Dinstall): add StableDislocationSupport, a new
3326         boolean used by jenna to enable or disable stable dislocation
3327         support (i.e. claire), as true.
3328         * katie.conf-non-US: likewise.
3329         * katie.conf-security: likewise.
3330
3331         * cron.daily-security: generate .all3 overrides for the buildd
3332         support.  Freshen a local copy of Packages-arch-specific from
3333         buildd.debian.org.
3334
3335         * claire.py (find_dislocated_stable): disable the support for
3336         files in legacy-mixed locations since none of the Debian archives
3337         have any anymore.
3338
3339         * helena: new script; produces a report on NEW and BYHAND
3340         packages.
3341
3342         * jenna: rewritten from scratch to fix speed problems.  Run time
3343         on auric goes down from 31.5 minutes to 3.5 minutes.  Of that 3.5
3344         minutes, 105 seconds are the monster query and 70 odd seconds is
3345         claire.
3346
3347         * apt.conf.buildd (Default): remove MaxContentsChange as it's
3348         irrelevant.
3349
3350 2002-06-05  Ryan Murray  <rmurray@debian.org>
3351
3352         * cron.buildd-security: new file.
3353
3354 2002-06-05  Matt Kraai  <kraai@alumni.cmu.edu>
3355
3356         * denise (list): take a file argument and use it.
3357         (main): don't abuse sys.stdout, just write to the file.
3358
3359         * claire.py (usage): Fix misspelling.
3360         (clean_symlink): Simplify.
3361         (find_dislocated_stable): Avoid unnecessary work.
3362
3363 2002-05-29  James Troup  <james@nocrew.org>
3364
3365         * cameron: removed; apt-ftparchive can simply walk the directory.
3366
3367 2002-05-26  Anthony Towns  <ajt@debian.org>
3368
3369         * katie.conf{,-non-US}: Map testing to testing-proposed-updates
3370         for the autobuilders.
3371
3372 2002-05-24  Ryan Murray  <rmurray@debian.org>
3373
3374         * cron.buildd: update override files before running apt-ftparchive
3375
3376 2002-05-23  Martin Michlmayr  <tbm@cyrius.com>
3377
3378         * amber (main): remove extra space in prompt.
3379
3380         * utils.py (validate_changes_file_arg): use original filename in
3381         error messages.
3382
3383         * jeri (check_joey): close file after use.
3384         (parse_packages): likewise.
3385         (main): setup debug option properly.
3386
3387         * melanie (main): remove unused packages variable and simplify the
3388         code to build up con_packages by using repr().
3389
3390 2002-05-23  James Troup  <james@nocrew.org>
3391
3392         * lisa (recheck): when we reject, also return 0 so the package is
3393         skipped.
3394         (sg_compare): fix note sorting.
3395         (recheck): remove the .katie file after rejection.
3396
3397         * katie.py (Katie.accept): accepted auto-build support take 3;
3398         this time adding support for security.  Security needs a) non-pool
3399         files copied rather than symlinked since accepted is readable only
3400         by katie/security and www-data needs to be able to see the files,
3401         b) needs per-suite directories.  SpecialAcceptedAutoBuild becomes
3402         AcceptedAutoBuildSuites and is a ValueList containing the suites.
3403         SecurityAcceptedAutoBuild is a new boolean which controls whether
3404         or not normal or security style is used.  The unstable_accepted
3405         table was renamed to accepted_autobuild and a suite column added.
3406         Also fix a bug noticed by Ryan where an existent orig.tar.gz
3407         didn't have it's last_used/in_accepted flags correctly updated.
3408         * katie (install): likewise.
3409         * rhona (clean_accepted_autobuild): likewise.
3410
3411 2002-05-22  James Troup  <james@nocrew.org>
3412
3413         * lisa (sort_changes): new function; sorts changes properly.
3414         Finally.
3415         (sg_compare): new function; helper for sort_changes().  Sorts by
3416         have note and time of oldest upload.
3417         (indiv_sg_compare): new function; helper for sort_changes().
3418         Sorts by source version, have source and filename.
3419         (main): use sort_changes().
3420         (changes_compare): obsoleted; removed.
3421
3422 2002-05-20  James Troup  <james@nocrew.org>
3423
3424         * rhona (clean_accepted_autobuild): don't die if a file we're
3425         trying to remove doesn't exist.  Makes rhona more friendly to
3426         katie/katie.py crashes/bugs without any undue cost.
3427
3428 2002-05-19  James Troup  <james@nocrew.org>
3429
3430         * lisa (main): if sorting a large number of changes give some
3431         feedback.
3432         (recheck): new function, run the same checks (modulo NEW,
3433         obviously) as katie does, if they fail do the standard
3434         reject/skip/quit dance.
3435         (do_pkg): use it.
3436
3437         * katie (install): don't try to unlink the symlink in the
3438         AcceptedAutoBuild support if the destination is not a symlink (or
3439         doesn't exist).  Avoids unnecessary bombs on previous partial
3440         accepts and will still bomb hard if the file exists and isn't a
3441         symlink.
3442
3443         * utils.py: blah, commands _is_ used when the mail stuff isn't
3444         commented out like it is in my test environment.
3445
3446         * lisa (changes_compare): "has note" overrides everything else.
3447         Use .katie files rather than running parse_changes, faster and
3448         allows "has note" to work.  Correct version compare, it was
3449         reversed.  Ctime check should only kick in if the source packages
3450         are not the same.
3451         (print_new): print out and return any note.  Rename 'ret_code' to
3452         'broken'.
3453         (edit_new): renamed from spawn_editor.  Don't leak file
3454         descriptors.  Clean up error message if editor fails.
3455         (edit_note): new function, allows one to edit notes.
3456         (do_new): add note support, editing and removing.
3457         (init): kill -s/--sort; with notes we always want to use our
3458         sorting method.
3459         (usage): likewise.
3460
3461         * katie.py (Katie.dump_vars): add "lisa note" as an optional
3462         changes field.
3463
3464         * utils.py (build_file_list): rename 'dsc' to 'is_a_dsc' and have
3465         it default to 0.  Adapt tests to assume it's boolean.
3466         * fernanda.py (check_changes): adjust call appropriately.
3467         * halle (check_changes): likewise.
3468         * jennifer (check_changes): likewise.
3469         * jeri (check_changes): likewise.
3470         * shania (flush_orphans): likewise.
3471
3472         * jennifer (check_dsc): pass is_a_dsc by name when calling
3473         build_file_list() for clarity.
3474         * shania (flush_orphans): likewise.
3475         * tea (check_missing_tar_gz_in_dsc): likewise.
3476
3477         * jennifer (check_dsc): pass dsc_whitespace_rules by name when
3478         calling parse_changes() for clarity.
3479         * tea (check_dscs): likewise.
3480
3481         * utils.py (parse_changes): make dsc_whitespace_rules default to
3482         not true.
3483         * halle (check_changes): adjust call appropriately.
3484         * jennifer (check_changes): likewise.
3485         * jeri (check_changes): likewise.
3486         * lisa (changes_compare): likewise.
3487         * utils.py (changes_compare): likewise.
3488         * melanie (main): likewise.
3489         * shania (flush_orphans): likewise.
3490         * fernanda.py (check_changes): likewise.
3491
3492 2002-05-18  James Troup  <james@nocrew.org>
3493
3494         * katie.py (Katie.dump_vars): make the .katie file unreadable,
3495         it's not useful and by and large a duplication of information
3496         available in readable format in other files.
3497
3498 2002-05-16  Ryan Murray  <rmurray@debian.org>
3499
3500         * melanie: Dir::TemplatesDir -> Dir::Templates
3501
3502 2002-05-15  Ryan Murray  <rmurray@debian.org>
3503
3504         * cameron: correct the use of os.path.join
3505
3506 2002-05-15  Anthony Towns  <ajt@debian.org>
3507
3508         * ziyi: Update to match the new format for Architectures/Components
3509         in katie.conf.
3510
3511 2002-05-14  James Troup  <james@nocrew.org>
3512
3513         * amber: new script; 'installer' wrapper script for the security
3514         team.
3515
3516         * katie.py (Katie.announce): remove unused 'dsc' local
3517         variable. (pychecker)
3518
3519         * ziyi: pre-define AptCnf and out globals to None. (pychecker)
3520
3521         * neve: don't import sys, we don't use it. (pychecker)
3522         (check_signature): fix return type mismatch. (pychecker)
3523
3524         * utils.py: don't import commands, we don't use it.  (pychecker)
3525
3526         * katie (install): SpecialAcceptedAutoBuild is a boolean.
3527
3528         * katie.py (Katie.dump_vars): don't store "oldfiles", it's
3529         obsoleted by the change to "othercomponents" handling in jennifer
3530         detailed below.
3531         (Katie.cross_suite_version_check): new function; implements
3532         cross-suite version checking rules specified in the conf file
3533         while also enforcing the standard "must be newer than target
3534         suite" rule.
3535         (Katie.check_binary_against_db): renamed, since it's invoked once
3536         per-binary, "binaries" was inaccurate.  Use
3537         cross_suite_version_check() and don't bother with the "oldfiles"
3538         rubbish as jennifer works out "othercomponents" herself now.
3539         (Katie.check_source_against_db): use cross_suite_version_check().
3540
3541         * katie (check): the version and file overwrite checks
3542         (check_{binary,source,dsc}_against_db) are not per-suite.
3543
3544         * jennifer (check_files): less duplication of
3545         'control.Find("Architecture", "")' by putting it in a local
3546         variable.
3547         (check_files): call check_binary_against_db higher up since it's
3548         not a per-suite check.
3549         (check_files): get "othercomponents" directly rather than having
3550         check_binary_against_db do it for us.
3551
3552         * heidi (main): 'if x:', not 'if x != []:'.
3553         * katie.py (Katie.in_override_p): likewise.
3554         (Katie.check_dsc_against_db): likewise.
3555         * natalie (main): likewise.
3556         * rene (main): likewise.
3557         * ziyi (real_arch): likewise.
3558
3559         * alyson (main): Suite::%s::Architectures, Suite::%s::Components
3560         and OverrideType are now value lists, not lists.
3561         * andrea (main): likewise.
3562         * cindy (main): likewise.
3563         * claire.py (find_dislocated_stable): likewise.
3564         * denise (main): likewise.
3565         * jenna (main): likewise.
3566         * jennifer (check_distributions): likewise.
3567         (check_files): likewise.
3568         (check_urgency): likewise (Urgency::Valid).
3569         * jeri (parse_packages): likewise.
3570         * neve (main): likewise (and Location::%s::Suites).
3571         * rene (main): likewise.
3572
3573 2002-05-13  James Troup  <james@nocrew.org>
3574
3575         * katie.py (Katie.check_source_against_db): correct case of reject
3576         message to be consistent with binary checks.
3577
3578         * jennifer (get_status_output): don't leak 2 file descriptors per
3579         invocation.
3580         (check_signature): add missing '\n' to "duplicate status token"
3581         error message.
3582
3583 2002-05-09  James Troup  <james@nocrew.org>
3584
3585         * utils.py (validate_changes_file_arg): new function; validates an
3586         argument which should be a .changes file.
3587         * ashley (main): use it.
3588         * lisa (main): likewise.
3589
3590         * katie.py (Katie.check_dsc_against_db): since there can be more
3591         than one .orig.tar.gz make sure we don't assume the .orig.tar.gz
3592         entry still exists in files.
3593
3594         * jennifer (check_dsc): handle the .orig.tar.gz disappearing from
3595         files, since check_dsc_against_db() deletes the .orig.tar.gz
3596         entry.
3597
3598         * cameron: cleanups.
3599
3600         * utils.py (changes_compare): change sort order so that source
3601         name and source version trump 'have source'; this should fix
3602         UNACCEPT problems in katie where -1 hppa+source & i386, -2
3603         i386&source & hppa lead to -1 i386 unaccept.  Problem worked out
3604         by Ryan.
3605
3606         * lisa (main): allow the arguments to be .katie files too.
3607
3608 2002-05-07  Ryan Murray  <rmurray@debian.org>
3609
3610         * cron.buildd: add s390 to arch list again
3611
3612 2002-05-05  Ryan Murray  <rmurray@debian.org>
3613
3614         * cron.buildd: new script, update w-b database from unstable_accepted
3615         table
3616         * cameron: new script, take list in unstable_accepted and write out
3617         a file list for apt-ftparchive
3618         * apt.conf.buildd: new apt configuration for Packages/Sources for
3619         unstable_accepted
3620         * vars: add s390 to arch list.
3621
3622 2002-05-03  James Troup  <james@nocrew.org>
3623
3624         * neve (main): don't hard code the calling user as that doesn't
3625         work with modern postgres installs.  Fix psql invocation for
3626         init_pool.sql (database name required).  Dont' hard code the
3627         database name.
3628         (process_sources): add support for fingerprint and install_date.
3629         (process_packages): add support for fingerprint.
3630         (do_sources): pass in the directory, fingerprint support needs it.
3631         (get_status_output): borrowed from jennifer.
3632         (reject): likewise.
3633         (check_signature): likewise.
3634
3635         * katie (install): only try to log urgencies if Urgency_Logger is
3636         defined.
3637         (main): only initialize Urgency_Logger is Dir::UrgencyLog is
3638         defined; only close Urgency_Logger if it's defined.
3639
3640         * catherine (poolize): adapt for Dir rationalization.
3641         * claire.py (find_dislocated_stable): likewise.
3642         * denise (main): likewise.
3643         * halle (check_joey): likewise.
3644         * jenna: likewise.
3645         * jennifer: likewise.
3646         * jeri: likewise.
3647         * katie.py: likewise.
3648         * katie: likewise.
3649         * lisa (do_bxa_notification): likewise.
3650         * logging.py (Logger.__init__): likewise
3651         * rene (main): likewise.
3652         * rhona (clean): likewise.
3653         * shania (init): likewise.
3654         * tea: likewise.
3655         * ziyi: likewise.
3656
3657         * lisa (add_overrides): Dinstall::BXANotify is a boolean, use
3658         FindB, not FindI.
3659
3660         * rhona (clean_accepted_autobuild): SpecialAcceptedAutoBuild is a
3661         boolean, use FindB, not get.
3662
3663         * katie.py (Katie.check_dsc_against_db): ignore duplicate
3664         .orig.tar.gz's which are an exact (size/md5sum) match.
3665
3666         * ashley (main): really allow *.katie files as arguments too;
3667         noticed by aj.
3668
3669         * sql-aptvc.cpp: postgres.h moved to a "server" subdirectory.
3670
3671 2002-05-03  Anthony Towns  <ajt@debian.org>
3672
3673         * ziyi: support for security.
3674
3675 2002-05-02  James Troup  <james@nocrew.org>
3676
3677         * jennifer (accept): call Katie.check_override() unconditional as
3678         no-mail check moved into that function.
3679         (do_byhand): likewise.
3680
3681         * katie.py (Katie.check_override): don't do anything if we're a)
3682         not sending mail or b) the override disparity checks have been
3683         disbled via Dinstall::OverrideDisparityCheck.
3684
3685         * jennifer (check_files): don't hard code Unstable as the suite
3686         used to check for architecture validity; use
3687         Dinstall::DefaultSuite instead, if it exists.
3688         (accept): conditionalize
3689
3690         * katie.py (Katie.update_subst): support global maintainer
3691         override with Dinstall::OverrideMaintainer.
3692
3693         * jennifer (check_distributions): new function, Distribution
3694         validation and mapping.  Uses new SuiteMappings variable from
3695         config file to abstract suite mappings.
3696         (check_changes): call it.
3697
3698         * natalie: renamed; nothing imports or likely will for some time.
3699
3700         * denise (main): remove unused natalie import and init().
3701
3702         * natalie.py (init): removed.
3703         (main): initalize here instead and don't hardcode the database
3704         name.
3705
3706 2002-04-30  James Troup  <james@nocrew.org>
3707
3708         * katie.py (Katie.close_bugs): new function, split out from
3709         announce().
3710         (Katie.announce): only call close_bugs() if Dinstall::CloseBugs is
3711         true.
3712         (Katie.close_bugs): new function, split out
3713         (Katie.close_bugs): return immediately if there are no bugs to
3714         close.
3715
3716         * jennifer (acknowledge_new): adapt for new utils.TemplateSubst().
3717         * katie (do_reject): likewise.
3718         (stable_install): likewise.
3719         * katie.py (Katie.announce): likewise.
3720         (Katie.accept): likewise.
3721         (Katie.check_override): likewise.
3722         (Katie.do_reject): likewise.
3723         * lisa (do_bxa_notification): likewise.
3724         * melanie (main): likewise.
3725
3726         * utils.py (TemplateSubst): change second argument to be a
3727         filename rather than a template since every caller opened a file
3728         on the fly which was ugly and leaked file descriptor.
3729
3730 2002-04-29  James Troup  <james@nocrew.org>
3731
3732         * katie.py (Katie.announce): (modified) patch from Raphael Hertzog
3733         <hertzog@debian.org> to send 'accepted' announce mails to the
3734         PTS. [#128140]
3735
3736 2002-04-24  James Troup  <james@nocrew.org>
3737
3738         * init_pool.sql (unstable_accepted): add two new fields to
3739         unstable_accepted; in_accepted is a boolean indicating whether or
3740         not the file is in accepted and last_used is a timestamp used by
3741         rhona to determine when to remove symlinks for installed packages.
3742
3743         * katie.py (Katie.accept): auto-build support take 2.  Create
3744         symlinks for all files into a seperate directory.  Add files to
3745         unstable_accepted as paths to the new directory; mark them as
3746         being in accepted for cameron.  Properly conditionalize it on a
3747         configuration variable.
3748
3749         * katie (install): likewise.  Update symlinks to point into the
3750         pool; mark the files for later deletion by rhona and mark them as
3751         not being in accepted for cameron.
3752
3753         * rhona (clean_accepted_autobuild): new function.
3754
3755 2002-04-22  James Troup  <james@nocrew.org>
3756
3757         * jennifer (check_files): handle db_access.get_location_id()
3758         returning -1 properly/better.
3759
3760         * rhona (clean_fingerprints): new function.
3761
3762 2002-04-21  James Troup  <james@nocrew.org>
3763
3764         * utils.py (touch_file): unused; remove.
3765         (plural): likewise.
3766
3767         * jennifer (check_files): close file descriptor used to get the
3768         control file.
3769         (check_md5sums): likewise.
3770         (callback): likewise.
3771
3772         * katie.py (Katie.do_reject): handle manual rejects much better;
3773         call the editor first and get confirmation from the user before
3774         proceeding.
3775
3776         * jennifer (check_signature): prefix_multi_line_string() moved to
3777         utils.
3778
3779         * utils.py (prefix_multi_line_string): moved here from jennifer.
3780
3781 2002-04-20  James Troup  <james@nocrew.org>
3782
3783         * lisa (main): handle non-existent files.
3784
3785         * ashley (main): allow *.katie files as arguments too.
3786
3787 2002-04-19  James Troup  <james@nocrew.org>
3788
3789         * katie.py (Katie.accept): add stuff to help auto-building from
3790         accepted; if the .orig.tar.gz is not part of the upload (i.e. it's
3791         in the pool), create a symlink to it in the accepted directory and
3792         add the .dsc and .{u,}deb(s) to a new 'unstable_accepted' table.
3793
3794         * katie (install): undo the "auto-building from accepted" stuff
3795         (i.e. remove the .orig.tar.gz symlink and remove the files from
3796         unstable_accepted table).
3797
3798 2002-04-16  James Troup  <james@nocrew.org>
3799
3800         * jennifer (upload_too_new): fix typo which was causing all
3801         timestamp comparisons to be against the .changes file.  Also move
3802         back to the original directory so we do the comparisons against
3803         accurate timestamps.
3804
3805         * tea (check_missing_tar_gz_in_dsc): new function.
3806
3807         * jennifer (check_dsc): add a check to ensure there is a .tar.gz
3808         file mentioned in the .dsc.
3809
3810         * lisa (main): use X-Katie in the mail headers, not X-Lisa; that
3811         way mails reach debian-{devel-,}changes@l.d.o.
3812
3813 2002-04-02  Ryan Murray  <rmurray@debian.org>
3814
3815         * cron.daily: run shania after rhona
3816         * cron.daily-non-US: likewise.
3817
3818 2002-04-01  James Troup  <james@nocrew.org>
3819
3820         * katie: re-add proposed-updates/stable install support.
3821
3822         * katie.py (Katie.dump_vars): add changes["changes"] as an
3823         optional field; should be mandatory later.
3824
3825 2002-03-31  James Troup  <james@nocrew.org>
3826
3827         * katie (install): support a Suite::<foo>::CopyKatie similar to
3828         CopyChanges.  Done seperately because .katie files don't need to
3829         be mirrored and will probably be copied to another directory as a
3830         result.
3831
3832         * halle (main): add missing debug to options.
3833
3834 2002-03-29  James Troup  <james@nocrew.org>
3835
3836         * madison (main): add a -r/--regex option.
3837
3838 2002-03-26  James Troup  <james@nocrew.org>
3839
3840         * lisa: don't trample on changes["distribution"]; make a copy of
3841         it as changes["suite"] instead and use that.
3842
3843 2002-03-16  Anthony Towns  <ajt@debian.org>
3844
3845         * templates/lisa.bxa_notification: Fix some grammatical errors.
3846         Encourage contact via bxa@ftp-master email address.
3847
3848 2002-03-15  James Troup  <james@nocrew.org>
3849
3850         * jennifer (check_timestamps): remove bogus raise in except.
3851
3852 2002-03-15  Anthony Towns  <ajt@debian.org>
3853
3854         * cron.monthly: rotate mail/archive/bxamail as well as
3855         mail/archive/mail. This is for a complete archive of
3856         correspondence with the BXA.
3857
3858 2002-03-14  Anthony Towns  <ajt@debian.org>
3859
3860         * crypto-in-main changes.
3861
3862         * utils.py (move, copy): add an optional perms= parameter to let you
3863         set the resulting permissions of the moved/copied file
3864         * katie.py (force_move): rejected/morgued files should be unreadable
3865         * jennifer (do_byhand, acknowledge_new): pending new and byhand files
3866         should be unreadable.
3867
3868 2002-03-07  Ryan Murray  <rmurray@debian.org>
3869
3870         * katie (install): check for existance of "files id" key as well as
3871         it being set to a valid value.
3872         * katie (install): check for existense and valid value for location
3873         id as well
3874
3875 2002-03-05  Ryan Murray  <rmurray@debian.org>
3876
3877         * katie.py (do_reject): reread the reason file after editing it.
3878
3879 2002-02-25  James Troup  <james@nocrew.org>
3880
3881         * jennifer (check_changes): don't enforce sanity in .changes file
3882         names since it doesn't seem to be possible; pcmica-cs and similar
3883         freak show packages in particular cause real problems.
3884
3885         * katie.py (Katie.check_dsc_against_db): initialize 'found' for
3886         each dsc_file since the .orig.tar.gz checking code now uses it as
3887         a boolean.  Fixes bizarro rejections which bogusly claimed
3888         .diff.gz md5sum/size was incorrect.
3889
3890 2002-02-24  James Troup  <james@nocrew.org>
3891
3892         * katie (process_it): reset reject_message.
3893
3894 2002-02-22  James Troup  <james@nocrew.org>
3895
3896         * db_access.py(set_files_id): disable use of
3897         currval('files_id_seq') because it was taking 3 seconds on auric
3898         which is insane (most calls take < 0.01) and simply call
3899         get_files_id() for the return value instead.
3900
3901         * katie.py (Katie.do_query): convenience function; unused by
3902         default, useful for profiling.
3903         * db_access.py (do_query): likewise.
3904
3905         * katie (install): fix insert SQL call when binary has no source.
3906
3907         * lisa (determine_new): auto-correct non-US/main to non-US.
3908         (determine_new): add a warning when adding things to stable.
3909         (edit_index): use our_raw_input().
3910         (edit_overrides): likewise.
3911         (do_new): likewise.  Use re.search() not re.match() since the
3912         default answer may not be the first one.
3913         (do_byhand): likewise.
3914         (do_new): Default to 'S'kip and never 'A'dd.
3915
3916         * jennifer (action): pass prompt to our_raw_input().
3917         * melanie (game_over): likewise.
3918         * katie (action): likewise.
3919
3920         * utils.py (our_raw_input): add an optional prompt argument to
3921         make the function more usable as a drop in replacement for
3922         raw_input().
3923
3924         * jennifer (check_files): correct reject() to not double prefix
3925         when using katie.py based functions.
3926         (check_dsc): likewise.
3927
3928         * katie.py (Katie.reject): prepend a new line if appropriate
3929         rathen than appending one to avoid double new lines when caller
3930         adds one of his own.
3931
3932         * lisa (determine_new): warn if the package is also in other
3933         components.
3934
3935 2002-02-20  James Troup  <james@nocrew.org>
3936
3937         * jennifer (check_files): if .changes file lists "source" in
3938         Architecture field, there must be a .dsc.
3939
3940 2002-02-15  James Troup  <james@nocrew.org>
3941
3942         * ashley (main): add some missing fields.
3943
3944         * katie.py (Katie.check_dsc_against_db): fix to take into account
3945         the fact that the .orig.tar.gz might be in byhand, accepted or
3946         new.  Also fix calling of reject().
3947         (Katie.check_binaries_against_db): fix calling of reject().
3948         (Katie.check_source_against_db): likewise.
3949         (Katie.dump_vars): add missing variables used for bug closures.
3950
3951         * lisa (changes_compare_by_time): sort by reverse time.
3952
3953         * katie.py (Katie.accept): log.
3954         (Katie.dump_vars): missing has_key test for optional changes fields.
3955
3956         * jennifer (main): print "Accepted blah blah" to stdout, not stderr.
3957         (process_it): traceback goes to stderr, not stdout.
3958         (acknowledge_new): log.
3959         (do_byhand): likewise.
3960
3961         * katie.py (Katie.update_subst): fix typo (Cnf vs. self.Cnf).
3962
3963         * add_constraints.sql: add grants for the new fingerprint table.
3964
3965 2002-02-13  James Troup  <james@nocrew.org>
3966
3967         * katie (do_reject): basename the .changes filename before trying
3968         to use it to construct the .reason filename.
3969         (process_it): call Katie.update_subst() so do_reject() DTRT with
3970         the mail template.
3971         (do_reject): setup the mail template correctly.
3972
3973 2002-02-12  James Troup  <james@nocrew.org>
3974
3975         * tea (process_dir): renamed 'arg' to 'unused' for clarity.
3976         (check_files): don't abuse global dictionaries.
3977         (Ent): use all variables.
3978         (check_timestamps): don't abuse global dictionaries.
3979
3980         * fernanda.py: renamed to .py so lisa can import it.
3981         (check_dsc): remove unused local variables (pychecker).
3982         (display_changes): split off from check_changes.
3983
3984         * katie: rewritten; most of the functionality moves to jennifer;
3985         what's left is the code to install packages once a day from the
3986         'accepted' directory.
3987
3988         * jennifer: new program, processes packages in 'unchecked'
3989         (i.e. most of the non-install functionality of old katie).
3990
3991         * katie.py: common functions shared between the clique of
3992         jennifer, lisa and katie.
3993
3994         * lisa: new program; handles NEW and BYHAND packages.
3995
3996         * jeri (usage): new function.
3997         (main): use it.
3998         (check_package): remove unused local variable (pychecker).
3999
4000         * init_pool.sql: new table fingerprint.  Add fingerprint colums to
4001         binaries and source.  Add install_date to source.
4002
4003         * halle (usage): new function.
4004         (main): use it.  Remove unused options.
4005         (check_changes): remove unused local variable (pychecker).
4006
4007         * add_constraints.sql: add fingerprint references.
4008
4009         * db_access.py (get_or_set_fingerprint_id): new function.
4010
4011         * ashley (main): new program; dumps the contents of a .katie file
4012         to stdout.
4013
4014         * alyson (main): remove option handling since we don't actually
4015         support any.
4016         * cindy (main): likewise.
4017
4018         * remove unnecessary imports and pre-define globals (pychecker).
4019
4020 2002-02-11  Anthony Towns  <ajt@debian.org>
4021
4022         * added installation-report and upgrade-report pseudo-packages
4023
4024 2002-01-28  Martin Michlmayr  <tbm@cyrius.com>
4025
4026         * katie (update_subst): use Dinstall::TrackingServer.
4027         * melanie (main): likewise.
4028
4029 2002-01-27  James Troup  <james@nocrew.org>
4030
4031         * shania (main): it's IntLevel not IntVal; thanks to tbm@ for
4032         noticing, jgg@ for fix.
4033
4034 2002-01-19  James Troup  <james@nocrew.org>
4035
4036         * utils.py (extract_component_from_section): handle non-US
4037         non-main properly.
4038
4039 2002-01-12  James Troup  <james@nocrew.org>
4040
4041         * madison: add support for -S/--source-and-binary which displays
4042         information for the source package and all it's binary children.
4043
4044 2002-01-13  Anthony Towns  <ajt@debian.org>
4045
4046         * katie.conf: Remove Catherine Limit and bump stable to 2.2r5
4047         * katie.conf: Add Dinstall::SigningKeyIds option, set to the 2001
4048           and 2002 key ids.
4049         * katie.conf-non-US: Likewise.
4050         * ziyi: Suppoer Dinstall::SigningKeyIds to sign a Release file with
4051           multiple keys automatically. This is probably only useful for
4052           transitioning from an expired (or revoked?) key.
4053
4054 2002-01-08  Ryan Murray  <rmurray@debian.org>
4055
4056         * debian/python-dep: new file that prints out python:Depends for
4057           substvars
4058         * debian/control: use python:Depends, build-depend on python
4059           lower Depends: on postgresql to Suggests:
4060         * debian/rules: determine python version, install to the correct
4061           versioned dir
4062
4063 2001-12-18  Anthony Towns  <ajt@debian.org>
4064
4065         * ziyi: unlink Release files before overwriting them (in case they've
4066           been merged)
4067         * ziyi: always include checksums/sizes for the uncompressed versions
4068           of Sources and Packages, even if they're not present on disk
4069
4070 2001-11-26  Ryan Murray  <rmurray@debian.org>
4071
4072         * ziyi (main): add SigningPubKey config option
4073         * katie.conf: use SigningPubKey config option
4074         * katie.conf-non-US: likewise
4075
4076 2001-11-24  James Troup  <james@nocrew.org>
4077
4078         * katie (acknowledge_new): log newness.
4079
4080 2001-11-24  Anthony Towns  <ajt@debian.org>
4081
4082         * ziyi (real_arch): bail out if some moron forgot to reset
4083         untouchable on stable.
4084         (real_arch): source Release files.
4085
4086 2001-11-19  James Troup  <james@nocrew.org>
4087
4088         * claire.py (main): don't use apt_pkg.ReadConfigFileISC and
4089         utils.get_conf().
4090         * shania (main): likewise.
4091
4092         * rhona (main): add default options.
4093
4094         * db_access.py (get_archive_id): case independent.
4095
4096         * katie (action): sort files so that ordering is consistent
4097         between mails; noticed/requested by Joey.
4098
4099 2001-11-17  Ryan Murray  <rmurray@debian.org>
4100
4101         * utils.py: add get_conf function, change startup code to read all
4102           config files to the Cnf that get_conf returns
4103           use the component list from the katie conf rather than the hardcoded
4104           list.
4105         * all scripts: use new get_conf function
4106         * shania: fix try/except around changes files
4107         * jenna: only do debian-installer if it is a section in Cnf
4108
4109 2001-11-16  Ryan Murray  <rmurray@debian.org>
4110
4111         * shania (main): Initialize days to a string of a number.
4112                  (main): Initialize Cnf vars before reading in Cnf
4113
4114 2001-11-14  Ryan Murray  <rmurray@debian.org>
4115
4116         * shania (main): Initialize days to a number.
4117
4118 2001-11-04  James Troup  <james@nocrew.org>
4119
4120         * docs/Makefile: use docbook-utils' docbook2man binary.
4121
4122         * Change all "if foo == []" constructs into "if not foo".
4123
4124         * katie (check_changes): when installing into stable from
4125         proposed-updates, remove all non-stable target distributions.
4126         (check_override): don't check for override disparities on stable
4127         installs.
4128         (stable_install): update install_bytes appropriately.
4129         (reject): stable rejection support; i.e. don't remove files when
4130         rejecting files in the pool, rather remove them from the
4131         proposed-update suite instead, rhona will do the rest.
4132         (manual_reject): support for a stable specific template.
4133         (main): setup up stable rejector in subst.
4134
4135 2001-11-04  Martin Michlmayr  <tbm@cyrius.com>
4136
4137         * debian/control (Build-Depends): docbook2man has been superseded
4138         by docbook-utils.
4139
4140         * neve (main): exit with a more useful error message.
4141         (update_suites): Suite::<suite>::Version, Origin and Description
4142         are not required, so don't fail if they don't exist.
4143
4144         * db_access.py (get_archive_id): return -1 on error rather than
4145         raise an exception.
4146         (get_location_id): likewise.
4147
4148         * madison (main): don't exit on the first not-found package,
4149         rather exit with an appropriate return code after processing all
4150         packages.
4151
4152 2001-11-03  James Troup  <james@nocrew.org>
4153
4154         * claire.py (find_dislocated_stable): add per-architecture
4155         symlinks for dislocated architecture: all debs.
4156
4157 2001-10-19  Anthony Towns  <ajt@debian.org>
4158
4159         * apt.conf*, katie.conf*: add mips, mipsel, s390 to testing.
4160
4161 2001-10-10  Anthony Towns  <ajt@debian.org>
4162
4163         * claire.py (fix_component_section): do _not_ assign to None under
4164         any circumstances
4165
4166 2001-10-07  Martin Michlmayr  <tbm@cyrius.com>
4167
4168         * melanie (main): don't duplicate architectures when removing from
4169         more than one suite.
4170
4171         * heidi (main, process_file, get_list): report suite name not ID.
4172
4173         * naima (nmu_p): be case insensitive.
4174
4175         * naima (action): more list handling clean ups.
4176
4177         * melanie (main): clean up lists handling to use string.join and
4178         IN's.
4179
4180         * madison (main): clean up suite and architecture argument parsing
4181         to use slices less and string.join more.
4182
4183         * utils.py (parse_changes): Use string.find() instead of slices for
4184         string comparisons thereby avoid hardcoding the length of strings.
4185         * ziyi (main): likewise.
4186
4187 2001-10-07  James Troup  <james@nocrew.org>
4188
4189         * Remove mode argument from utils.open_files() calls if it's the
4190         default, i.e. 'r'.
4191
4192 2001-09-27  James Troup  <james@nocrew.org>
4193
4194         * katie (init): new function; options clean up.
4195         (usage): add missing options, remove obsolete ones.
4196         (main): adapt for the two changes above.  If the lock file or
4197         new-ack log file don't exist, create them.  Don't try to open the
4198         new-ack log file except running in new-ack mode.
4199
4200         * alyson (main): initialize all the tables that are based on the
4201         conf file.
4202
4203         * utils.py (touch_file): like touch(1).
4204         (where_am_i): typo.
4205
4206         * catherine (usage): new.
4207         (main): use it.  options cleanup.
4208         * claire.py: likewise.
4209         * fernanda: likewise.
4210         * heidi: likewise.
4211         * jenna: likewise.
4212         * shania: likewise.
4213         * ziyi: likewise.
4214
4215         * andrea: options cleanup.
4216         * charisma: likewise.
4217         * julia: likewise.
4218         * madison: likewise.
4219         * melanie: likewise.
4220         * natalie: likewise.
4221         * rhona: likewise.
4222         * tea: likewise.
4223
4224 2001-09-26  James Troup  <james@nocrew.org>
4225
4226         * utils.py: default to sane config file locations
4227         (/etc/katie/{apt,katie}.conf.  They can be the actual config files
4228         or they can point to the real ones through use of a new Config
4229         section.  Based on an old patch by Adam Heath.
4230         (where_am_i): use the new default config stuff.
4231         (which_conf_file): likewise.
4232         (which_apt_conf_file): likewise.
4233
4234         * charisma (main): output defaults to
4235         `Package~Version\tMaintainer'; input can be of either form.  When
4236         parsing the new format do version comparisons, when parsing the
4237         old format assume anything in the extra file wins.  This fixes the
4238         problem of newer non-US packages being overwhelmed by older
4239         versions still in stable on main.
4240
4241 2001-09-17  James Troup  <james@nocrew.org>
4242
4243         * natalie.py (list): use result_join().
4244
4245         * denise (main): result_join() moved to utils.
4246
4247         * utils.py (result_join): move to utils; add an optional seperator
4248         argument.
4249
4250 2001-09-14  James Troup  <james@nocrew.org>
4251
4252         * heidi (set_suite): new function; does --set like natalie does,
4253         i.e. turns it into a sequence of --add's and --remove's
4254         internally.  This is a major win (~20 minute run time > ~20
4255         seconds) in the common, everday (i.e. testing) case.
4256         (get_id): common code used by set_suite() and process_file().
4257         (process_file): call set_suite() and get_id().
4258         (main): add logging support.
4259
4260         * julia: new script; syncs PostgeSQL with (LDAP-generated) passwd
4261         files.
4262
4263         * utils.py (parse_changes): use slices or simple string comparison
4264         in favour of regexes where possible.
4265
4266         * sql-aptvc.cpp (versioncmp): rewritten to take into account the
4267         fact that the string VARDATA() points to are not null terminated.
4268
4269         * denise (result_join): new function; like string.join() but
4270         handles None's.
4271         (list): use it.
4272         (main): likewise.
4273
4274         * charisma (main): python-pygresql 7.1 returns None not "".
4275
4276 2001-09-14  Ryan Murray  <rmurray@debian.org>
4277
4278         * natalie.py (list): handle python-pygresql 7.1 returning None.
4279
4280 2001-09-10  Martin Michlmayr  <tbm@cyrius.com>
4281
4282         * madison (main): return 1 if no package is found.
4283
4284 2001-09-08  Martin Michlmayr  <tbm@cyrius.com>
4285
4286         * madison (main): better error handling for incorrect
4287         -a/--architecture or -s/--suite arguments.
4288         (usage): new.
4289         (main): use it.
4290
4291 2001-09-05  Ryan Murray  <rmurray@debian.org>
4292
4293         * charisma, madison, katie: remove use of ROUser
4294         * katie.conf,katie.conf-non-US: remove defintion of ROUser
4295
4296 2001-08-26  James Troup  <james@nocrew.org>
4297
4298         * katie (nmu_p.is_an_nmu): use maintaineremail to check for group
4299         maintained packages at cjwatson@'s request.
4300
4301 2001-08-21  James Troup  <james@nocrew.org>
4302
4303         * madison (main): add -a/--architecture support.
4304
4305         * jenna: use logging instead of being overly verbose on stdout.
4306
4307 2001-08-11  Ryan Murray  <rmurray@debian.org>
4308
4309         * melanie: add functional help option
4310
4311 2001-08-07  Anthony Towns  <ajt@debian.org>
4312
4313         * apt.conf, katie.conf: Add ia64 and hppa to testing.
4314
4315 2001-07-28  James Troup  <james@nocrew.org>
4316
4317         * katie (check_dsc): ensure source version is >> than existing
4318         source in target suite.
4319
4320 2001-07-25  James Troup  <james@nocrew.org>
4321
4322         * natalie.py: add logging support.
4323
4324         * utils.py (open_file): make the second argument optional and
4325         default to read-only.
4326
4327         * rene (main): work around broken source packages that duplicate
4328         arch: all packages with arch: !all packages (no longer allowed
4329         into the archive by katie).
4330
4331 2001-07-13  James Troup  <james@nocrew.org>
4332
4333         * katie (action): don't assume distribution is a dictionary.
4334         (update_subst): don't assume architecture is a dictionary and that
4335         maintainer822 is defined.
4336         (check_changes): recognise nk_format exceptions.
4337         (check_changes): reject on 'testing' only uploads.
4338         (check_files): when checking to ensure all packages are newer
4339         versions check against arch-all packages too.
4340         (check_dsc): enforce the existent of a sane set of mandatory
4341         fields.  Ensure the version number in the .dsc (modulo epoch)
4342         matches the version number in the .changes file.
4343
4344         * utils.py (changes_compare): ignore all exceptions when parsing
4345         the changes files.
4346         (build_file_list): don't UNDEF on a changes file with no format
4347         field.
4348
4349 2001-07-07  James Troup  <james@nocrew.org>
4350
4351         * katie (nmu_p.is_an_nmu): check 'changedby822' for emptiness
4352         rather than 'changedbyname' to avoid false negatives on uploads
4353         with an email-address-only Changed-By field.
4354         (check_dsc): don't overwrite reject_message; append to it.
4355         (check_signature): likewise.
4356         (check_changes): likewise.
4357         (announce): condition logging on 'action'.
4358
4359         * logging.py: new logging module.
4360
4361         * katie: Cleaned up code by putting Cnf["Dinstall::Options"]
4362         sub-tree into a separate (global) variable.
4363         (check_dsc): ensure format is 1.0 to retain backwards
4364         compatability with dpkg-source in potato.
4365         (main): only try to obtain the lock when not running in no-action
4366         mode.
4367         Use the new logging module.
4368
4369         * christina: initial version; only partially usable.
4370
4371 2001-06-28  Anthony Towns  <ajt@debian.org>
4372
4373         * apt.conf: Add ExtraOverrides to auric.
4374
4375 2001-06-25  James Troup  <james@nocrew.org>
4376
4377         * katie (nmu_p.is_an_nmu): the wonderful dpkg developers decided
4378         they preferred the name 'Uploaders'.
4379
4380 2001-06-23  James Troup  <james@nocrew.org>
4381
4382         * katie (check_files): fix typo in uncommon rejection message,
4383         s/sourceversion/source version/.
4384
4385         * denise (main): we can't use print because stdout has been
4386         redirected.
4387
4388         * katie (source_exists): new function; moved out of check_files()
4389         and added support for binary-only NMUs of earlier sourceful NMUs.
4390
4391         * rhona (clean): find_next_free has moved.
4392
4393         * utils.py (find_next_free): new function; moved here from rhona.
4394         Change too_many to be an argument with a default value, rather
4395         than a hardcoded variable.
4396
4397         * shania: rewritten to work better; REJECTion reminder mail
4398         handling got lost though.
4399
4400 2001-06-22  James Troup  <james@nocrew.org>
4401
4402         * rhona (main): remove unused override code.
4403
4404         * fernanda (main): remove extraneous \n's from utils.warn calls.
4405         * natalie.py (list): likewise.
4406
4407         * catherine, cindy, denise, heidi, jenna, katie, neve, rhona, tea:
4408         use utils.{warn,fubar} where appropriate.
4409
4410 2001-06-21  James Troup  <james@nocrew.org>
4411
4412         * katie (nmu_p): new class that encapsulates the "is a nmu?"
4413         functionality.
4414         (nmu_p.is_an_nmu): add support for multiple maintainers specified
4415         by the "Maintainers" field in the .dsc file and maintainer groups.
4416         (nmu_p.__init__): read in the list of group maintainer names.
4417         (announce): use nmu_p.
4418
4419 2001-06-20  James Troup  <james@nocrew.org>
4420
4421         * rene (main): hardcode the suite experimental is compared to by
4422         name rather than number.
4423
4424         * katie (check_files): differentiate between doesn't-exist and
4425         permission-denied in "can not read" rejections; requested by edd@.
4426         (check_dsc): use os.path.exists rather than os.access to allow the
4427         above check to kick in.
4428
4429         * heidi (process_file): read all input before doing anything and
4430         use transactions.
4431
4432 2001-06-15  James Troup  <james@nocrew.org>
4433
4434         * fernanda: new script; replaces old 'check' shell script
4435         nastiness.
4436
4437 2001-06-14  James Troup  <james@nocrew.org>
4438
4439         * katie: actually import traceback module to avoid amusing
4440         infinite loop.
4441
4442 2001-06-10  James Troup  <james@nocrew.org>
4443
4444         * utils.py (extract_component_from_section): fix to handle just
4445         'non-free' and 'contrib'.  Also fix to handle non-US in a
4446         completely case insensitive manner as a component.
4447
4448 2001-06-08  James Troup  <james@nocrew.org>
4449
4450         * madison (arch_compare): sort function that sorts 'source' first
4451         then alphabetically.
4452         (main): use it.
4453
4454 2001-06-05  Jeff Licquia  <jlicquia@progeny.com>
4455
4456         * catherine (poolize): explicitly make poolized_size a long so it
4457         doesn't overflow when poolizing e.g. entire archives.
4458
4459 2001-06-01  James Troup  <james@nocrew.org>
4460
4461         * utils.py (send_mail): throw exceptions rather than exiting.
4462
4463         * katie (process_it): catch exceptions and ignore them.
4464
4465 2001-06-01  Michael Beattie  <mjb@debian.org>
4466
4467         * added update-mailingliststxt and update-readmenonus to update
4468         those files, respectively. modified cron.daily{,-non-US} to
4469         use them.
4470
4471 2001-05-31  Anthony Towns  <ajt@debian.org>
4472
4473         * rhona: make StayOfExecution work.
4474
4475 2001-05-31  James Troup  <james@nocrew.org>
4476
4477         * rhona (find_next_free): fixes to not overwrite files but rename
4478         them by appending .<n> instead.
4479         (clean): use find_next_free and use dated sub-directories in the
4480         morgue.
4481
4482         * utils.py (move): don't overwrite files unless forced to.
4483         (copy): likewise.
4484
4485 2001-05-24  James Troup  <james@nocrew.org>
4486
4487         * katie (check_files): determine the source version here instead
4488         of during install().
4489         (check_files): check for existent source with bin-only NMU
4490         support.
4491         (main): sort the list of changes so that the source-must-exist
4492         check Does The Right Thing(tm).
4493
4494         * utils.py (changes_compare): new function; sorts a list of
4495         changes files by 'have-source', source, version.
4496         (cc_fix_changes): helper function.
4497         (parse_changes): use compiled regexes.
4498         (fix_maintainer): likewise.
4499
4500         * rene (main): warn about packages in experimental that are
4501         superseded by newer versions in unstable.
4502
4503 2001-05-21  James Troup  <james@nocrew.org>
4504
4505         * rene (main): add support for checking for ANAIS (Architecture
4506         Not Allowed In Source) packages.
4507
4508 2001-05-17  James Troup  <james@nocrew.org>
4509
4510         * katie (check_changes): initalize `architecture' dictionary in
4511         changes global so that if we can't parse the changes file for
4512         whatever reason we don't undef later on.
4513
4514         * utils.py (parse_changes): fix handling of multi-line fields
4515         where the first line did have data.
4516
4517 2001-05-05  Anthony Towns  <ajt@debian.org>
4518
4519         * ziyi: Add "NotAutomatic: yes" to experimental Release files.
4520         (It should always have been there. Ooopsy.)
4521
4522 2001-05-03  Anthony Towns  <ajt@debian.org>
4523
4524         * jenna: Cleanup packages that move from arch:any to arch:all or
4525         vice-versa.
4526
4527 2001-04-24  Anthony Towns  <ajt@debian.org>
4528
4529         * ziyi: add ``SHA1:'' info to Release files. Also hack them up to
4530         cope with debian-installer and boot-floppies' md5sum.txt.
4531
4532 2001-04-16  James Troup  <james@nocrew.org>
4533
4534         * katie (check_changes): add missing %s format string argument.
4535         (stable_install): temporary work around for morgue location to
4536         move installed changes files into.
4537         (stable_install): helps if you actually read in the template.
4538         (manual_reject): fix for editing of reject messages which was
4539         using the wrong variable name.
4540
4541         * jenna (generate_src_list): typo; s/package/source/; fixes undef crash.
4542
4543 2001-04-13  James Troup  <james@nocrew.org>
4544
4545         * katie (manual_reject): Cc the installer.
4546         (reject): don't.
4547         (check_changes): remove unused maintainer-determination code.
4548         (update_subst): add support for Changed-By when setting the
4549         *MAINTAINER* variables.
4550
4551         * rene (bar): new function to check for packages on architectures
4552         when they shouldn't be.
4553
4554         * natalie.py (main): use fubar() and warn() from utils.
4555
4556         * utils.py (whoami): new mini-function().
4557         * melanie (main): use it.
4558         * katie (manual_reject): likewise.
4559
4560 2001-04-03  James Troup  <james@nocrew.org>
4561
4562         * katie (action): ignore exceptions from os.path.getmtime() so we
4563         don't crash on non-existent changes files (e.g. when they are
4564         moved between the start of the install run in cron.daily and the
4565         time we get round to processing them).
4566
4567         * madison (main): also list source and accept -s/--suite.
4568
4569         * jenna (generate_src_list): missing \n in error message.
4570
4571         * katie (update_subst): add sane defaults for when changes is
4572         skeletal.
4573
4574 2001-03-29  James Troup  <james@nocrew.org>
4575
4576         * melanie (main): use fubar() and warn() from utils.  Remember who
4577         the maintainer for the removed packages are and display that info
4578         to the user.  Readd support for melanie-specific Bcc-ing that got
4579         lost in the TemplateSubst transition.
4580
4581         * utils.py (fubar): new function.
4582         (warn): like wise.
4583
4584         * db_access.py (get_maintainer): as below.
4585
4586         * charisma (get_maintainer): moved the bulk of this function to
4587         db_access so that melanie can use it too.
4588
4589         * claire.py (find_dislocated_stable): restrict the override join
4590         to those entries where the suite is stable; this avoids problems
4591         with packages which have moved to new sections (e.g. science)
4592         between stable and unstable.
4593
4594 2001-03-24  James Troup  <james@nocrew.org>
4595
4596         * catherine (poolize): new function; not really independent of
4597         main() fully, yet.
4598         (main): use it.
4599
4600         * katie (stable_install): __SUITE__ needs to be space prefixed
4601         because buildd's check for 'INSTALLED$'.
4602
4603 2001-03-22  James Troup  <james@nocrew.org>
4604
4605         * utils.py (regex_safe): also need to escape '.'; noticed by ajt@.
4606
4607         * jenna: rewritten; now does deletions on a per-suite level
4608         instead of a per-suite-component-architecture-type level.  This
4609         allows mutli-component packages to be auto-cleaned (and as a
4610         bonus, reduces the code size and duplication).
4611
4612 2001-03-22  Anthony Towns  <ajt@debian.org>
4613
4614         * ziyi (main): fix ziyi to overwrite existing Release.gpg files
4615         instead of just giving a gpg error.
4616
4617 2001-03-21  James Troup  <james@nocrew.org>
4618
4619         * madison (main): use apt_pkg.VersionCompare to sort versions so
4620         that output is correctly sorted for packages like debhlper.
4621         Noticed by ajt@.
4622
4623         * tea (check_source_in_one_dir): actually find problematic source
4624         packages.
4625
4626         * katie (check_dsc): remember the orig.tar.gz's location ID if
4627         it's not in a legacy suite.
4628         (check_diff): we don't use orig_tar_id.
4629         (install): add code to handle sourceful diff-only upload of
4630         packages which change components by copying the .orig.tar.gz into
4631         the new component, if it doesn't already exist there.
4632         (process_it): reset orig_tar_location (as above).
4633
4634         * melanie (main): use template substiution for the bug closing
4635         emails.
4636         (main): don't hardcode bugs.debian.org or packages.debian.org
4637         either; use configuration items.
4638
4639         * katie: likewise.
4640
4641         * natalie.py (init): use None rather than 'localhost' for the
4642         hostname given to pg.connect.
4643
4644         * utils.py (TemplateSubst): new function; lifted from
4645         userdir-ldap.
4646
4647 2001-03-21  Ryan Murray  <rmurray@debian.org>
4648
4649         * katie (announce): fix the case of non-existent
4650         Suite::$SUITE::Announce.
4651
4652 2001-03-20  Ryan Murray  <rmurray@debian.org>
4653
4654         * debian/rules (binary-indep): install melanie into /usr/bin/ not
4655         /usr/.
4656
4657         * alyson (main): use config variable for database name.
4658         * andrea (main): likewise.
4659         * catherine (main): likewise.
4660         * charisma (main): likewise.
4661         * cindy (main): likewise.
4662         * claire.py (main): likewise.
4663         * denise (main): likewise.
4664         * heidi (main): likewise.
4665         * jenna (main): likewise.
4666         * katie (main): likewise.
4667         * madison (main): likewise.
4668         * melanie (main): likewise.
4669         * neve (main): likewise.
4670         * rhona (main): likewise.
4671         * tea (main): likewise.
4672
4673 2001-03-15  James Troup  <james@nocrew.org>
4674
4675         * rhona (check_sources): fixed evil off by one (letter) error
4676         which was causing only .dsc files to be deleted when cleaning
4677         source packages.
4678
4679         * charisma (get_maintainer_from_source): remove really stupid and
4680         gratuitous IN sub-query and replace with normal inner join.
4681         (main): connect as read-only user nobody.
4682
4683         * rhona (clean_maintainers): rewritten to use SELECT and sub-query
4684         with EXISTS.
4685         (check_files): likewise; still disabled by default though.
4686         (clean_binaries): add ' seconds' to the mysterious number in the
4687         output.
4688         (clean): likewise.
4689
4690         * tea (check_files): add missing global declaration on db_files.
4691
4692 2001-03-14  James Troup  <james@nocrew.org>
4693
4694         * rhona: rewritten large chunks. Removed a lot of the silly
4695         selecting into dictionaries and replaced it with 'where exists'
4696         based sub queries.  Added support for StayOfExecution.  Fix the
4697         problem with deleting dsc_files too early and disable cleaning of
4698         unattached files.
4699
4700 2001-03-14  Anthony Towns  <ajt@debian.org>
4701
4702         * katie (announce): also check Changed-By when trying to detect
4703         NMUs.
4704
4705 2001-03-06  Anthony Towns  <ajt@debian.org>
4706
4707         * ziyi (main): Generate Release.gpg files as well, using the key from
4708         Dinstall::SigningKey in katie.conf, if present. That key has to be
4709         passwordless, and hence kept fairly secretly.
4710
4711 2001-03-02  James Troup  <james@nocrew.org>
4712
4713         * utils.py (str_isnum): new function; checks to see if the string
4714         is a number.
4715
4716         * shania (main): fix _hideous_ bug which was causing all files > 2
4717         weeks old to be deleted from incoming, even if they were part of a
4718         valid upload.
4719
4720 2001-02-27  James Troup  <james@nocrew.org>
4721
4722         * melanie (main): accept new argument -C/--carbon-copy which
4723         allows arbitarty carbon-copying of the bug closure messages.
4724         Cleaned up code by putting Cnf["Melanie::Options"] sub-tree into a
4725         separate variable.
4726
4727 2001-02-27  Anthony Towns  <ajt@debian.org>
4728
4729         * ziyi: new program; generates Release files.
4730
4731 2001-02-25  James Troup  <james@nocrew.org>
4732
4733         * katie (reject): add missing '\n' to error message.
4734         (manual_reject): likewise.
4735         (install): catch exceptions from moving the changes file into DONE
4736         and ignore them.
4737
4738         * tea (check_md5sums): new function.
4739
4740 2001-02-25  Michael Beattie  <mjb@debian.org>
4741
4742         * melanie: use $EDITOR if available.
4743
4744 2001-02-15  James Troup  <james@nocrew.org>
4745
4746         * utils.py (parse_changes): don't crash and burn on empty .changes
4747         files.  Symptoms noticed by mjb@.
4748
4749 2001-02-15  Adam Heath  <doogie@debian.org>
4750
4751         * denise (main): use an absolute path for the output filename.
4752
4753         * sql-aptvc.cpp: don't #include <utils/builtins.h> as it causes
4754         compile errors with postgresql-dev >= 7.0.
4755
4756 2001-02-12  James Troup  <james@nocrew.org>
4757
4758         * rene: initial version.
4759
4760         * andrea: initial version.
4761
4762         * catherine (main): remove obsolete assignment of arguments.
4763
4764 2001-02-09  James Troup  <james@nocrew.org>
4765
4766         * catherine: first working version.
4767
4768 2001-02-06  James Troup  <james@nocrew.org>
4769
4770         * katie (check_files): validate the priority field; i.e. ensure it
4771         doesn't contain a '/' (to catch people prepending the priority
4772         with the component rather than the section).
4773         (check_override): don't warn about source packages; the only check
4774         is on section and we have no GUI tools that would use the Section
4775         field for a Sources file.
4776         (announce): use tags rather than severities for NMUs.  Requested
4777         by Josip Rodin <joy@>. [#78035]
4778
4779 2001-02-04  James Troup  <james@nocrew.org>
4780
4781         * tea (check_override): new function; ensures packages in suites
4782         are also in the override file.  Thanks to bod@ for noticing that
4783         such packages existed.
4784
4785         * katie: move file type compiled regular expressions to utils as
4786         catherine uses them too.
4787         (check_changes): always default maintainer822 to the installer
4788         address so that any bail out won't cause undefs later.
4789         (check_files): update file type re's to match above.
4790         (stable_install): likewise.
4791         (reject): handle any except from moving the changes files.  Fixes
4792         crashes on unreadable changes files.
4793
4794         * melanie (main): add an explanation of why things are not removed
4795         from testing.
4796
4797 2001-01-31  James Troup  <james@nocrew.org>
4798
4799         * melanie (main): ignore a) no message, b) removing from stable or
4800         testing when invoked with -n/--no-action.
4801
4802         * katie (check_override): lower section before checking to see if
4803         we're whining about 'non-US' versus 'non-US/main'.
4804
4805         * sql-aptvc.cpp: new file; wrapper around apt's version comparison
4806         function so that we can use inside of PostgreSQL.
4807
4808 2001-01-28  James Troup  <james@nocrew.org>
4809
4810         * katie: updated to pass new flag to parse_changes() and deal with
4811         the exception raised on invalid .dsc's if appropriate.
4812         * shania (main): likewise.
4813         * melanie (main): likewise.
4814
4815         * tea (check_dscs): new function to validate all .dsc files in
4816         unstable.
4817
4818         * utils.py (parse_changes): if passed an additional flag, validate
4819         the .dsc file to ensure it's extractable by dpkg-source.
4820         Requested by Ben Collins <bcollins@>.
4821
4822 2001-01-27  James Troup  <james@nocrew.org>
4823
4824         * madison (main): connect to the DB as nobody.
4825
4826         * katie (check_files): remove support for -r/--no-version-check
4827         since it makes no sense under katie (jenna will automatically
4828         remove the (new) older version) and was evil in any event.
4829         (check_changes): add missing new line to rejection message.
4830         (check_dsc): likewise.
4831         (process_it): reset reject_message here.
4832         (main): not here.  Also remove support for -r.
4833
4834 2001-01-26  James Troup  <james@nocrew.org>
4835
4836         * katie (check_override): don't whine about 'non-US/main' versus
4837         'non-US'.
4838
4839 2001-01-26  Michael Beattie  <mjb@debian.org>
4840
4841         * natalie.py (usage): new function.
4842         (main): use it.
4843
4844 2001-01-25  Antti-Juhani Kaijanaho  <gaia@iki.fi>
4845
4846         * update-mirrorlists: Update README.non-US too (request from Joy).
4847
4848 2001-01-25  James Troup  <james@nocrew.org>
4849
4850         * katie (reject): catch any exception from utils.move() and just
4851         pass, we previously only caught can't-overwrite errors and not
4852         can't-read ones.
4853
4854         * jenna (generate_src_list): use ORDER BY in selects to avoid
4855         unnecessary changes to Packages files.
4856         (generate_bin_list): likewise.
4857
4858         * utils.py (extract_component_from_section): separated out from
4859         build_file_list() as it's now used by claire too.
4860
4861         * claire.py (find_dislocated_stable): rewrite the query to extract
4862         section information and handle component-less locations properly.
4863         Thanks to ajt@ for the improved queries.
4864         (fix_component_section): new function to fix components and
4865         sections.
4866
4867 2001-01-23  James Troup  <james@nocrew.org>
4868
4869         * katie (check_files): set file type for (u?)debs first thing, so
4870         that if we continue, other functions which rely on file type
4871         existing don't bomb out.  If apt_pkg or apt_inst raise an
4872         exception when parsing the control file, don't try any other
4873         checks, just drop out.
4874         (check_changes): new test to ensure there is actually a target
4875         distribution.
4876
4877 2001-01-22  James Troup  <james@nocrew.org>
4878
4879         * katie (usage): s/dry-run/no-action/.  Noticed by Peter Gervai
4880         <grin@>.
4881         (check_changes): when mapping to unstable, remember to actually
4882         add unstable to the suite list and not just remove the invalid
4883         suite.
4884
4885 2001-01-21  James Troup  <james@nocrew.org>
4886
4887         * katie (check_files): catch exceptions from debExtractControl()
4888         and reject packages which raise any.
4889
4890 2001-01-19  James Troup  <james@nocrew.org>
4891
4892         * katie (check_signature): basename() file name in rejection
4893         message.
4894
4895 2001-01-18  James Troup  <james@nocrew.org>
4896
4897         * katie (in_override_p): remember the section and priority from
4898         the override file so we can check them against the package later.
4899         (check_override): new function; checks section and priority (for
4900         binaries) from the package against the override file and mails the
4901         maintainer about any disparities.
4902         (install): call check_override after announcing the upload.
4903
4904 2001-01-16  James Troup  <james@nocrew.org>
4905
4906         * utils.py (build_file_list): catch ValueError's from splitting up
4907         the files field and translate it into a parse error.
4908
4909         * tea: add support for finding unreferenced files.
4910
4911         * katie (in_override_p): add support for suite-aliasing so that
4912         proposed-updates uploads work again.
4913         (check_changes): catch parses errors from utils.build_file_list().
4914         (check_dsc): likewise.
4915         (check_diff): yet more dpkg breakage so we require even newer a
4916         version.
4917
4918         * jenna (generate_bin_list): don't do nasty path munging that's no
4919         longer needed.
4920
4921         * denise (main): support for non-US; and rename testing's override
4922         files so they're based on testing's codename.
4923
4924 2001-01-16  Martin Michlmayr  <tbm@cyrius.com>
4925
4926         * melanie: add to the bug closing message explaining what happens
4927         (or rather doesn't) with bugs against packages that have been
4928         removed.
4929
4930 2001-01-14  James Troup  <james@nocrew.org>
4931
4932         * charisma (main): fix silly off-by-one error; suite priority
4933         checking was done using "less than" rather than "less than or
4934         equal to" which was causing weird hesienbugs with wrong Maintainer
4935         fields.
4936
4937 2001-01-10  James Troup  <james@nocrew.org>
4938
4939         * katie (in_override_p): adapted to use SQL-based overrides.
4940         read_override_file function disappears.
4941
4942         * db_access.py: add new functions get_section_id, get_priority_id
4943         and get_override_type_id.
4944         (get_architecture_id): return -1 if the architecture is not found.
4945
4946         * heidi: switch %d -> %d in all SQL queries.
4947         (get_list): Use string.join where appropriate.
4948
4949         * rhona (in_override_p): don't die if the override file doesn't
4950         exist.
4951         (main): warn if the override file doesn't exist.
4952
4953         * alyson: new script; will eventually sync the config file and the
4954         SQL database.
4955
4956         * natalie.py: new script; manipulates overrides.
4957
4958         * melanie: new script; removes packages from suites.
4959
4960 2001-01-08  James Troup  <james@nocrew.org>
4961
4962         * katie (re_bad_diff): whee; dpkg 1.8.1.1 didn't actually fix
4963         anything it just changed the symptom.  Recognise the new breakage
4964         and reject them too.
4965
4966 2001-01-07  James Troup  <james@nocrew.org>
4967
4968         * katie (check_dsc): when adding the cwd copy of the .orig.tar.gz
4969         to the .changes file, be sure to set up files[filename]["type"]
4970         too.
4971
4972 2001-01-06  James Troup  <james@nocrew.org>
4973
4974         * katie (check_diff): new function; detects bad diff files
4975         produced by dpkg 1.8.1 and rejects thems.
4976         (process_it): call check_diff().
4977         (check_dsc): gar.  Add support for multiple versions of the
4978         .orig.tar.gz file in the archive from -sa uploads.  Check md5sum
4979         and size against all versions and use one which matches if
4980         possible and exclude any that don't from being poolized to avoid
4981         file overwrites.  Thanks to broonie@ for providing the example.
4982         (install): skip any files marked as excluded as above.
4983
4984 2001-01-05  James Troup  <james@nocrew.org>
4985
4986         * heidi (process_file): add missing argument to error message.
4987
4988 2001-01-04  James Troup  <james@nocrew.org>
4989
4990         * heidi (main): fix handling of multiple files by reading all
4991         files not just the first file n times (where n = the number of
4992         files passed as arguments).
4993
4994 2001-01-04  Anthony Towns  <ajt@debian.org>
4995
4996         * katie (check_dsc): proper fix for the code which locates the
4997         .orig.tar.gz; check for '<filename>$' or '^<filename>$'.
4998
4999 2000-12-20  James Troup  <james@nocrew.org>
5000
5001         * rhona: replace IN's with EXISTS's to make DELETE time for
5002         binaries and source sane on auric.  Add a -n/--no-action flag and
5003         make it stop actions if used.  Fixed a bug in binaries deletion
5004         with no StayOfExecution (s/</<=/).  Add working -h/--help and
5005         -V/--version.  Giving timing info on deletion till I'm sure it's
5006         sane.
5007
5008         * katie (check_changes): map testing to unstable.
5009
5010         * madison: new script; shows versions in different architectures.
5011
5012         * katie (check_dsc): ensure size matches as well as md5sum;
5013         suggested by Ben Collins <bcollins@debian.org> in Debian Bug
5014         #69702.
5015
5016 2000-12-19  James Troup  <james@nocrew.org>
5017
5018         * katie (reject): ignore the "can't overwrite file" exception from
5019         utils.move() and leave the files where they are.
5020         (reject): doh! os.access() test was reversed so we only tried to
5021         move files which didn't exist... replaced with os.path.exists()
5022         test the right way round.
5023
5024         * utils.py (move): raise an exception if we can't overwrite the
5025         destination file.
5026         (copy): likewise.
5027
5028 2000-12-18  James Troup  <james@nocrew.org>
5029
5030         * rhona: first working version.
5031
5032         * db_access.py (get_files_id): force both sizes to be integers.
5033
5034         * katie (main): use size_type().
5035
5036         * utils.py (size_type): new function; pretty prints a file size.
5037
5038 2000-12-17  James Troup  <james@nocrew.org>
5039
5040         * charisma (main): do version compares so that older packages do
5041         not override newer ones and process source first as source wins
5042         over binaries in terms of who we think of as the Maintainer.
5043
5044 2000-12-15  James Troup  <james@nocrew.org>
5045
5046         * katie (install): use the files id for the .orig.tar.gz from
5047         check_dsc().
5048         (install): limit select for legacy source to a) source in legacy
5049         or legacy-mixed type locations and b) distinct on files.id.
5050         (install): rather than the bizarre insert new, delete old method
5051         for moving legacy source into the pool, use a simple update of
5052         files.
5053         (process_it): initalize some globals before each process.
5054
5055 2000-12-14  James Troup  <james@nocrew.org>
5056
5057         * katie (in_override_p): index on binary_type too since .udeb
5058         overrides are in a different file.
5059         (read_override_file): likewise.
5060         (check_files): correct filename passed to get_files_id().
5061         (check_dsc): we _have_ to preprend '/' to the filename to avoid
5062         mismatches like jabber.orig.tar.gz versus libjabber.orig.tar.gz.
5063         (check_dsc): remember the files id of the .orig.tar.gz, not the
5064         location id.
5065
5066 2000-12-13  James Troup  <james@nocrew.org>
5067
5068         * utils.py (poolify): force the component to lower case except for
5069         non-US.
5070
5071         * katie (in_override_p): handle .udeb-specific override files.
5072         (check_files): pass the binary type to in_override_p().
5073         (check_dsc): remember the location id of the old .orig.tar.gz in
5074         case it's not in the pool.
5075         (install): use location id from dsc_files; which is where
5076         check_dsc() puts it for old .orig.tar.gz files.
5077         (install): install files after all DB work is complete.
5078         (reject): basename() the changes filename.
5079         (manual_reject): likewise.
5080
5081         * shania: new progam; replaces incomingcleaner.
5082
5083 2000-12-05  James Troup  <james@nocrew.org>
5084
5085         * katie (check_changes): if inside stable and can't find files
5086         from the .changes; assume it's installed in the pool and chdir()
5087         to there.
5088         (check_files): we are not installing for stable installs, so don't
5089         check for overwriting existing files.
5090         (check_dsc): likewise.
5091         (check_dsc): reorder .orig.tar.gz handling so that we search in
5092         the pool first and only then fall back on any .orig.tar.gz in the
5093         cwd; this avoids false positives on the overwrite check when
5094         people needlessly reupoad the .orig.tar.gz in a non-sa upload.
5095         (install): if this is a stable install, bail out to
5096         stable_install() immediately.
5097         (install): dsc_files handling was horribly broken. a) we need to
5098         add files from the .dsc and not the .changes (duh), b) we need to
5099         add the .dsc file itself to dsc_files (to be consistent with neve
5100         if for no other reason).
5101         (stable_install): new function; handles installs from inside
5102         proposed-updates to stable.
5103         (acknowledge_new): basename changes_filename before doing
5104         anything.
5105         (process_it): absolutize the changes filename to avoid the
5106         requirement of being in the same directory as the .changes file.
5107         (process_it): save and restore the cwd as stable installs can
5108         potentially jump into the pool to find files.
5109
5110         * jenna: dislocated_files support using claire.
5111
5112         * heidi (process_file): select package field from binaries
5113         explicitly.
5114
5115         * db_access.py (get_files_id): fix cache key used.
5116
5117         * utils.py (build_file_list): fix 'non-US/non-free' case in
5118         section/component splitting.
5119         (move): use os.path.isdir() rather than stat.
5120         (copy): likewise.
5121
5122         * claire.py: new file; stable in non-stable munger.
5123
5124         * tea: new file; simply ensures all files in the DB exist.
5125
5126 2000-12-01  James Troup  <james@nocrew.org>
5127
5128         * katie (check_dsc): use regex_safe().
5129         (check_changes): typo in changes{} key:
5130         s/distributions/distribution/.
5131         (install): use changes["source"], not files[file]["source"] as the
5132         latter may not exist and the former is used elsewhere.  Commit the
5133         SQL transaction earlier.
5134
5135         * utils.py (regex_safe): new function; escapes characters which
5136         have meaning to SQL's regex comparison operator ('~').
5137
5138 2000-11-30  James Troup  <james@nocrew.org>
5139
5140         * katie (install): pool_location is based on source package name,
5141         not binary package.
5142
5143         * utils.py (move): if dest is a directory, append the filename
5144         before chmod-ing.
5145         (copy): ditto.
5146
5147         * katie (check_files): don't allow overwriting of existing .debs.
5148         (check_dsc): don't allow overwriting of existing source files.
5149
5150 2000-11-27  James Troup  <james@nocrew.org>
5151
5152         * katie (check_signature): don't try to load rsaref; it's
5153         obsolete.
5154         (in_override_p): don't try to lookup override entries for packages
5155         with an invalid suite name.
5156         (announce): don't assume the suite name is valid; use Find() to
5157         lookup the mailing list name for announcements.
5158
5159         * utils.py (where_am_i): typo; hostname is in the first element,
5160         not second.
5161
5162         * db_access.py (get_suite_id): return -1 on an unknown suite.
5163
5164 2000-11-26  James Troup  <james@nocrew.org>
5165
5166         * katie (install): fix CopyChanges handling; typo in in checking
5167         Cnf for CopyChanges flag and was calling non-existent function
5168         copy_file.
5169
5170         * utils.py (copy): new function; clone of move without the
5171         unlink().
5172
5173 2000-11-25  James Troup  <james@nocrew.org>
5174
5175         * utils.py (build_file_list): handle non-US prefixes properly
5176         (i.e. 'non-US' -> 'non-US/main' and 'non-US/libs' -> 'non-US/main'
5177         + 'libs' not 'non-US/libs').
5178         (send_mail): add '-odq' to sendmail invocation to avoid DNS lookup
5179         delays.  This is possibly(/probably) exim speicifc and (like other
5180         sendmail options) needs to be in the config file.
5181
5182 2000-11-24  James Troup  <james@nocrew.org>
5183
5184         * rhona (check_sources): we need file id from dsc_files; not id.
5185         Handle non .dsc source files being re-referenced in dsc_files.
5186
5187         * katie (in_override_p): strip out any 'non-US' prefix.
5188         (check_files): use utils.where_am_i() rather than hardcoding.
5189         (check_files): validate the component.
5190         (install): use utils.where_am_i() rather than hardcoding.
5191         (install): fix mail to go to actual recepient.
5192         (reject): likewise.
5193         (manual_reject): likewise.
5194         (acknowledge_new): likewise.
5195         (announce): likewise.
5196
5197         * db_access.py (get_component_id): ignore case when searching for
5198         the component and don't crash if the component can't be found, but
5199         return -1.
5200         (get_location_id): handle -1 from get_component_id().
5201
5202         * jenna (generate_src_list): don't bring 'suite' into our big
5203         multi-table-joining select as we already know the 'suite_id'.
5204         (generate_bin_list): likewise.
5205
5206         * neve (main): don't quit if not on ftp-master.
5207         (process_packages): remove unused variable 'suite_codename'.
5208
5209         * utils.py (move): actually move the file.
5210         (build_file_list): handle non-US prefixes in the section.
5211
5212         * catherine (main): use which_conf_file().
5213         * charisma (main): likewise.
5214         * heidi (main): likewise.
5215         * jenna (main): likewise.
5216         * katie (main): likewise.
5217         * neve (main): likewise.
5218         * rhona (main): likewise.
5219
5220         * utils.py (where_am_i): new routine; determines the archive as
5221         understood by other 'dak' programs.
5222         (which_conf_file): new routine; determines the conf file to read.
5223
5224 2000-11-17  James Troup  <james@nocrew.org>
5225
5226         * katie (install): fix where .changes files for proposed-updates
5227         go.
5228
5229 2000-11-04  James Troup  <james@nocrew.org>
5230
5231         * jenna (main): handle architecture properly if no
5232         -a/--architecture argument is given, i.e. reset architecture with
5233         the values for the suite for each suite.
5234
5235         * Add apt_pkg.init() to the start of all scripts as it's now
5236         required by python-apt.
5237
5238 2000-10-29  James Troup  <james@nocrew.org>
5239
5240         * jenna (generate_bin_list): take an additional argument 'type'
5241         and use it in the SELECT.
5242         (main): if processing component 'main', process udebs and debs.
5243
5244         * neve (process_packages): set up 'type' in 'binaries' (by
5245         assuming .deb).
5246
5247         * katie (re_isadeb): accept ".udeb" or ".deb" as a file ending.
5248         (check_files): set up files[file]["dbtype"].
5249         (install): use files[file]["dbtype"] to set up the 'type' field in
5250         the 'binaries' table.
5251
5252         * init_pool.sql: add a 'type' field to the 'binaries' table to
5253         distinguisgh between ".udeb" and ".deb" files.
5254
5255         * utils.py (move): scrap basename() usage; use a "dir_p(dest) :
5256         dest ? dirname(dest)" type check instead.
5257
5258         * katie (check_dsc): handle the case of an .orig.tar.gz not found
5259         in the pool without crashing.  Also handle the case of being asked
5260         to look for something other than an .orig.tar.gz in the pool.
5261
5262 2000-10-26  James Troup  <james@nocrew.org>
5263
5264         * katie (install): fix filenames put into files table during
5265         poolification of legacy source.
5266
5267         * utils.py (move): work around a bug in os.path.basename() which
5268         cunningly returns '' if there is a trailing slash on the path
5269         passed to it.
5270
5271         * katie (check_dsc): Remove more cruft.  If we find the
5272         .orig.tar.gz in the pool and it's in a legacy (or legacy-mixed)
5273         location, make a note of that so we can fix things in install().
5274         (install): as above.  Move any old source out of legacy locations
5275         so that 'apt-get source' will work.
5276         (process_it): reset the flag that indicates to install that the
5277         source needs moved.
5278
5279         * cron.daily: more.  Nowhere near complete yet though.
5280
5281         * katie (install): don't run os.makedirs, a) utils.move() does
5282         this now, b) we weren't removing the user's umask and were
5283         creating dirs with SNAFU permissions.
5284         (check_dsc): rewrite the .orig.tar.gz handling to take into
5285         account, err, package pools.  i.e. look anywhere in the pool
5286         rather than faffing around with two simple paths.
5287
5288         * neve (process_sources): add the .dsc to dsc_files too.
5289
5290 2000-10-25  James Troup  <james@nocrew.org>
5291
5292         * neve (process_sources): don't duplicate .orig.tar.gz's.
5293
5294 2000-10-23  James Troup  <james@nocrew.org>
5295
5296         * utils.py (re_extract_src_version): moved here.
5297
5298         * neve: move re_extract_src_version to utils.
5299         (process_packages): reflect change.
5300
5301         * katie (install): reflect change.
5302
5303 2000-10-19  James Troup  <james@nocrew.org>
5304
5305         * jenna (generate_src_list): handle locations with null
5306         components.
5307         (generate_bin_list): likewise.
5308