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