]> err.no Git - dak/commitdiff
reject on presence/absence of un/expected checksums-* fields
authorAnthony Towns <aj@azure.humbug.org.au>
Fri, 11 Apr 2008 11:48:35 +0000 (11:48 +0000)
committerAnthony Towns <aj@azure.humbug.org.au>
Fri, 11 Apr 2008 11:48:35 +0000 (11:48 +0000)
ChangeLog
dak/process_unchecked.py

index 90475c4fc033ff872605915a8a888aac90f8d234..002339e623f7070bd97716d7ffc871cea3f02084 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -7,7 +7,8 @@
 
        * dak/process_unchecked.py: check_md5sum becomes check_hashes
        and check_hash. If changes format is 1.8 or later, also check
-       checksums-sha1 and checksums-sha256 for both .changes and .dsc.
+       checksums-sha1 and checksums-sha256 for both .changes and .dsc,
+       and reject on presence/absence of un/expected checksums-* fields.
 
 2008-04-07  Joerg Jaspert  <joerg@debian.org>
 
index c4fcf4b7e63065e91080cb5f90006404a6417eb1..30737ed1252fb7d7996d1612541798ad76d87db4 100755 (executable)
@@ -916,14 +916,32 @@ def check_hashes ():
     else:
         hashes = []
 
+    for x in changes:
+        if x.startswith("checksum-"):
+           h = x.split("-",1)[1] 
+           if h not in dict(hashes):
+               reject("Unsupported checksum field in .changes" % (h))
+
+    for x in dsc:
+        if x.startswith("checksum-"):
+           h = x.split("-",1)[1] 
+           if h not in dict(hashes):
+               reject("Unsupported checksum field in .dsc" % (h))
+
     for h,f in hashes:
-        fs = daklib.utils.build_file_list(changes, 0, "checksums-%s" % h, h)
-        check_hash( ".changes %s" % (h), fs, h, f, files)
+        try:
+            fs = daklib.utils.build_file_list(changes, 0, "checksums-%s" % h, h)
+            check_hash(".changes %s" % (h), fs, h, f, files)
+       except daklib.utils.no_files_exc:
+           reject("No Checksums-%s: field in .changes file" % (h))
 
         if "source" not in changes["architecture"]: continue
 
-        fs = daklib.utils.build_file_list(dsc, 1, "checksums-%s" % h, h)
-        check_hash( ".dsc %s" % (h), fs, h, f, dsc_files)
+        try:
+            fs = daklib.utils.build_file_list(dsc, 1, "checksums-%s" % h, h)
+            check_hash(".dsc %s" % (h), fs, h, f, dsc_files)
+       except daklib.utils.no_files_exc:
+           reject("No Checksums-%s: field in .changes file" % (h))
 
 ################################################################################