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