From: Ansgar Burchardt Date: Wed, 12 Aug 2015 13:30:03 +0000 (+0200) Subject: HashedFile: Allow to use a different filename for input X-Git-Url: https://git.decadent.org.uk/gitweb/?a=commitdiff_plain;h=64292a3e28c69cb7a816830c858f8503d6995a98;p=dak.git HashedFile: Allow to use a different filename for input This allows retrieving files using a temporary name, but to install them into the archive using their proper name. --- diff --git a/daklib/archive.py b/daklib/archive.py index 3b55b3f7..0891922d 100644 --- a/daklib/archive.py +++ b/daklib/archive.py @@ -110,7 +110,7 @@ class ArchiveTransaction(object): session.flush() path = os.path.join(archive.path, 'pool', component.component_name, poolname) - hashed_file_path = os.path.join(directory, hashed_file.filename) + hashed_file_path = os.path.join(directory, hashed_file.input_filename) self.fs.copy(hashed_file_path, path, link=False, mode=archive.mode) return poolfile diff --git a/daklib/upload.py b/daklib/upload.py index 2cc70743..b78d100f 100644 --- a/daklib/upload.py +++ b/daklib/upload.py @@ -73,12 +73,21 @@ class FileDoesNotExist(UploadException): class HashedFile(object): """file with checksums """ - def __init__(self, filename, size, md5sum, sha1sum, sha256sum, section=None, priority=None): + def __init__(self, filename, size, md5sum, sha1sum, sha256sum, section=None, priority=None, input_filename=None): self.filename = filename """name of the file @type: str """ + if input_filename is None: + input_filename = filename + self.input_filename = input_filename + """name of the file on disk + + Used for temporary files that should not be installed using their on-disk name. + @type: str + """ + self.size = size """size in bytes @type: long @@ -146,13 +155,13 @@ class HashedFile(object): @raise InvalidHashException: hash mismatch """ - path = os.path.join(directory, self.filename) + path = os.path.join(directory, self.input_filename) try: with open(path) as fh: self.check_fh(fh) except IOError as e: if e.errno == errno.ENOENT: - raise FileDoesNotExist(self.filename) + raise FileDoesNotExist(self.input_filename) raise def check_fh(self, fh): @@ -445,7 +454,7 @@ class Binary(object): @type: HashedFile """ - path = os.path.join(directory, hashed_file.filename) + path = os.path.join(directory, hashed_file.input_filename) data = apt_inst.DebFile(path).control.extractdata("control") self.control = apt_pkg.TagSection(data) @@ -518,7 +527,7 @@ class Source(object): # make sure the hash for the dsc is valid before we use it self._dsc_file.check(directory) - dsc_file_path = os.path.join(directory, self._dsc_file.filename) + dsc_file_path = os.path.join(directory, self._dsc_file.input_filename) data = open(dsc_file_path, 'r').read() self._signed_file = SignedFile(data, keyrings, require_signature) self.dsc = apt_pkg.TagSection(self._signed_file.contents)