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