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