]> git.pld-linux.org Git - projects/pld-ftp-admin.git/commitdiff
- signpkg: allow signing whole tree if no pkgname given
authorElan Ruusamäe <glen@pld-linux.org>
Sat, 13 Aug 2011 05:29:58 +0000 (05:29 +0000)
committerElan Ruusamäe <glen@pld-linux.org>
Sat, 13 Aug 2011 05:29:58 +0000 (05:29 +0000)
Changed files:
    bin/pfa-signpkg -> 1.10
    modules/sign.py -> 1.6

bin/pfa-signpkg
modules/sign.py

index 8b861821366659ac6f079672f14b758fc6cb1d46..1da726207c70013ba1291bb7aab2cbb1088e9cbf 100644 (file)
@@ -2,6 +2,7 @@
 # vi: encoding=utf-8 ts=8 sts=4 sw=4 et
 
 import sys, os
+import getopt
 sys.path.insert(0, os.environ['HOME']+'/pld-ftp-admin/modules')
 import ftptree
 import getpass
@@ -10,8 +11,15 @@ import ftpio
 from config import sign_key
 from sign import is_signed, signpkgs
 
-if len(sys.argv) < 3:
-    print >>sys.stderr, "ERR: not enough parameters given"
+try:
+    opts, args = getopt.getopt(sys.argv[1:], '')
+except getopt.GetoptError:
+    print >>sys.stderr, "ERR: options error"
+    print >>sys.stderr, "sign.py tree package1 [package2...]"
+    sys.exit(1)
+
+if len(args) < 1:
+    print >>sys.stderr, "ERR: missing tree name"
     print >>sys.stderr, "sign.py tree package1 [package2...]"
     sys.exit(1)
 
@@ -19,26 +27,39 @@ if sign_key == None:
     print >>sys.stderr, "ERR: sign_key not defined in config"
     sys.exit(1)
 
-checkdir(sys.argv[1])
+treename = args[0]
+packages = args[1:]
+
+checkdir(treename)
 
 ftpio.connect('sign')
 
-if not ftpio.lock(sys.argv[1], True):
-    print >>sys.stderr, "ERR: %s tree already locked" % sys.argv[1]
+if not ftpio.lock(treename, True):
+    print >>sys.stderr, "ERR: %s tree already locked" % treename
     sys.exit(1)
 
 files = []
 try:
-    tree = ftptree.FtpTree(sys.argv[1])
-    tree.mark4moving(sys.argv[2:])
+    if len(packages) < 1:
+        loadall = True
+    else:
+        loadall = False
+
+    # if no files specified, grab whole tree contents
+    tree = ftptree.FtpTree(treename, loadall = loadall)
+    if loadall:
+        # this is hack, should be a param, not access private .loadedpkgs element
+        tree.mark4moving(tree.loadedpkgs)
+    else:
+        tree.mark4moving(packages)
     files = tree.rpmfiles()
 
 except ftptree.SomeError:
     # In case of problems we need to unlock the tree before exiting
-    ftpio.unlock(sys.argv[1])
+    ftpio.unlock(treename)
     sys.exit(1)
 
-ftpio.unlock(sys.argv[1])
+ftpio.unlock(treename)
 
 print "Checking signatures of %d files from %d packages" % (len(files), len(tree.loadedpkgs))
 sign = []
index 69e1492c8e8f975d0ca823bbd355422c06496587..2a23e9c1678d95edbafe3f77eae2241f8c468031 100644 (file)
@@ -16,7 +16,7 @@ def getSigInfo(hdr):
     siginfo = hdr.sprintf(string)
     if siginfo == '(none)':
         return None
-   
+
     return siginfo.split(',')[2].lstrip()
 
 def is_signed(rpm_file):
This page took 0.092626 seconds and 4 git commands to generate.