]> git.decadent.org.uk Git - dak.git/blobdiff - ziyi
sync
[dak.git] / ziyi
diff --git a/ziyi b/ziyi
index 95eb1fd64532952b0779d63e27f03f7ee5c20265..97131540b5532f5887586cdc9e8b37e2281db408 100755 (executable)
--- a/ziyi
+++ b/ziyi
@@ -3,7 +3,7 @@
 # Create all the Release files
 
 # Copyright (C) 2001  Anthony Towns <ajt@debian.org>
-# $Id: ziyi,v 1.1 2001-03-02 02:25:15 troup Exp $
+# $Id: ziyi,v 1.7 2001-08-21 15:40:10 troup Exp $
 
 # This program is free software; you can redistribute it and/or modify
 # it under the terms of the GNU General Public License as published by
@@ -46,19 +46,33 @@ def compressnames (tree,type,file):
            result.append(file + ".bz2")
     return result
 
-def print_file (tree, name):
+def print_md5_files (tree, files):
     path = Cnf["Dir::RootDir"] + tree + "/"
-    try:
-        file_handle = utils.open_file(path + name, "r")
-    except utils.cant_open.exc:
-       print "ALERT: Couldn't open " + path + name
-    else:
-       md5 = apt_pkg.md5sum(file_handle)
-       file_handle.close()
-
-    size = os.stat(path + name)[stat.ST_SIZE]
-
-    out.write(" %s %8d %s\n" % (md5, size, name))
+    for name in files:
+        try:
+            file_handle = utils.open_file(path + name, "r")
+        except utils.cant_open_exc:
+            print "ALERT: Couldn't open " + path + name
+        else:
+           md5 = apt_pkg.md5sum(file_handle)
+           file_handle.close()
+
+        size = os.stat(path + name)[stat.ST_SIZE]
+        out.write(" %s         %8d %s\n" % (md5, size, name))
+
+def print_sha1_files (tree, files):
+    path = Cnf["Dir::RootDir"] + tree + "/"
+    for name in files:
+        try:
+            file_handle = utils.open_file(path + name, "r")
+        except utils.cant_open_exc:
+            print "ALERT: Couldn't open " + path + name
+        else:
+           sha1 = apt_pkg.sha1sum(file_handle)
+           file_handle.close()
+
+        size = os.stat(path + name)[stat.ST_SIZE]
+        out.write(" %s %8d %s\n" % (sha1, size, name))
 
 ################################################################################
 
@@ -68,13 +82,12 @@ def main ():
 
 
     apt_pkg.init()
-    
+
     Cnf = apt_pkg.newConfiguration()
     apt_pkg.ReadConfigFileISC(Cnf,utils.which_conf_file())
 
     AptCnf = apt_pkg.newConfiguration()
     apt_pkg.ReadConfigFileISC(AptCnf,utils.which_apt_conf_file())
-    print "APT.CONF IS: " + utils.which_apt_conf_file()
 
     Arguments = [('d',"debug","Ziyi::Options::Debug", "IntVal"),
                  ('h',"help","Ziyi::Options::Help"),
@@ -102,6 +115,12 @@ def main ():
        label = SuiteBlock.get("Label", origin)
        version = SuiteBlock.get("Version", "")
        codename = SuiteBlock.get("CodeName", "")
+
+       if SuiteBlock.has_key("NotAutomatic"):
+           notautomatic = "yes"
+       else:
+           notautomatic = ""
+
        if SuiteBlock.has_key("Components"):
            components = SuiteBlock.SubTree("Components").List()
        else:
@@ -132,18 +151,22 @@ def main ():
        if codename != "":
            out.write("Codename: %s\n" % (codename))
        out.write("Date: %s\n" % (time.strftime("%a, %d %b %Y %H:%M:%S UTC", time.gmtime(time.time()))))
+       if notautomatic != "":
+           out.write("NotAutomatic: %s\n" % (notautomatic))
        out.write("Architectures: %s\n" % (string.join(filter(real_arch, SuiteBlock.SubTree("Architectures").List()))))
        if components != []:
             out.write("Components: %s\n" % (string.join(components)))
 
        out.write("Description: %s\n" % (SuiteBlock["Description"]))
-       out.write("MD5Sum:\n")
+
+       files = []
+
        if AptCnf.has_key("tree::%s" % (tree)):
            for sec in string.split(AptCnf["tree::%s::Sections" % (tree)]):
                for arch in string.split(AptCnf["tree::%s::Architectures" % (tree)]):
                    if arch == "source":
                        for file in compressnames("tree::%s" % (tree), "Sources", "%s/%s/Sources" % (sec, arch)):
-                           print_file(tree,file)
+                           files.append(file)
                    else:
                        rel = "%s/binary-%s/Release" % (sec, arch)
                        relpath = Cnf["Dir::RootDir"]+tree+"/"+rel
@@ -163,19 +186,53 @@ def main ():
                                    release.write("Component: %s\n" % (sec))
                                release.write("Origin: %s\n" % (origin))
                                release.write("Label: %s\n" % (label))
+                               if notautomatic != "":
+                                   release.write("NotAutomatic: %s\n" % (notautomatic))
                                release.write("Architecture: %s\n" % (arch))
                                release.close()
-                           print_file(tree,"%s/binary-%s/Release" % (sec,arch))
+                           files.append("%s/binary-%s/Release" % (sec,arch))
+
+                       disks = "%s/disks-%s" % (sec, arch)
+                       diskspath = Cnf["Dir::RootDir"]+tree+"/"+disks
+                       if os.path.exists(diskspath):
+                           for dir in os.listdir(diskspath):
+                               if os.path.exists("%s/%s/md5sum.txt" % (diskspath, dir)):
+                                   files.append("%s/%s/md5sum.txt" % (disks, dir))
+
                        for file in compressnames("tree::%s" % (tree), "Packages", "%s/binary-%s/Packages" % (sec, arch)):
-                           print_file(tree,file)
+                           files.append(file)
+
+           if AptCnf.has_key("tree::%s/main" % (tree)):
+               sec = string.split(AptCnf["tree::%s/main::Sections" % (tree)])[0]
+               if sec != "debian-installer":
+                   print "ALERT: weird non debian-installer section in %s" % (tree)
+
+               for arch in string.split(AptCnf["tree::%s/main::Architectures" % (tree)]):
+                   if arch != "source":  # always true
+                       for file in compressnames("tree::%s/main" % (tree), "Packages", "main/%s/binary-%s/Packages" % (sec, arch)):
+                           files.append(file)
+
        elif AptCnf.has_key("bindirectory::%s" % (tree)):
            for file in compressnames("bindirectory::%s" % (tree), "Packages", AptCnf["bindirectory::%s::Packages" % (tree)]):
-               print_file(tree,string.replace(file,tree+"/","",1))
+               files.append(string.replace(file,tree+"/","",1))
            for file in compressnames("bindirectory::%s" % (tree), "Sources", AptCnf["bindirectory::%s::Sources" % (tree)]):
-               print_file(tree,string.replace(file,tree+"/","",1))
+               files.append(string.replace(file,tree+"/","",1))
        else:
            print "ALERT: no tree/bindirectory for %s" % (tree)
 
+       out.write("MD5Sum:\n")
+       print_md5_files(tree, files)
+       out.write("SHA1:\n")
+       print_sha1_files(tree, files)
+
+       out.close()
+       if Cnf.has_key("Dinstall::SigningKeyring"):
+           dest = Cnf["Dir::RootDir"] + tree + "/Release.gpg"
+           if os.path.exists(dest):
+                os.unlink(dest)
+           os.system("gpg --secret-keyring \"%s\" --no-options --batch --no-tty --armour --detach-sign <%s --output=%s" % (Cnf["Dinstall::SigningKeyring"],
+               Cnf["Dir::RootDir"] + tree + "/Release", dest))
+
 #######################################################################################
 
 if __name__ == '__main__':