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