Mercurial > repos > cathywise > truststore_import
view TrustStoreGalaxyImport.py @ 20:b94a8f55b1da
Un-gzip.
author | Catherine Wise <catherine.wise@csiro.au> |
---|---|
date | Mon, 13 Jan 2014 08:51:17 +1100 |
parents | 159d2159e745 |
children | 8cf18ca6f13f |
line wrap: on
line source
import sys import shutil import gzip from py_ts import TrustStoreClient, ts_utils from galaxy.datatypes.checkers import * def printNice(elem, f, depth): try: f.write('\t'*depth + elem.name + " (" + str(len(elem.fragments)) + " parts)\n") except AttributeError: f.write('\t'*depth + elem.name + "\n") for child in elem.children: printNice(child, f, depth+1) if __name__ == '__main__': kms_url = sys.argv[1] ims_url = sys.argv[2] username = sys.argv[3] password = sys.argv[4] client_key = sys.argv[5] client_secret = sys.argv[6] storename = sys.argv[7] path = sys.argv[8] filename = "" outputFile = "" if len(sys.argv) > 10: filename = sys.argv[9] outputFile = sys.argv[10] else: outputFile = sys.argv[9] config = TrustStoreClient.Config(ims_url, kms_url, client_key, client_secret) ts = TrustStoreClient.TrustStoreClient(headless=True, config=config) try: ts.authenticate(username, password) except TrustStoreClient.TrustStoreClientAuthenticationException as e: print e sys.exit(5) ts.getPrivateKey('privkey.pem') listing = ts.listStores() found = False for store in listing: if store.friendly_name == storename: found = True root = ts.listDirectory(store) location = None if path != "/": location = ts_utils.ts_utils.dirAtPath(root, path) if not location: print "Path not found" sys.exit(3) else: location = root if filename and filename != "": downloadMe = ts_utils.ts_utils.recurseToChildNamed(location, filename) if downloadMe: download = ts.getFile(store, downloadMe) is_gzipped, is_valid = check_gzip(download) if is_gzipped and not is_valid: print "File is compressed (gzip) but not valid." sys.exit(4) elif is_gzipped and is_valid: if link_data_only == 'copy_files': # We need to uncompress the temp_name file, but BAM files must remain compressed in the BGZF format CHUNK_SIZE = 2**20 # 1Mb fd, uncompressed = tempfile.mkstemp(prefix='data_id_%s_upload_gunzip_' % dataset.dataset_id, dir=os.path.dirname(outputFile), text=False ) gzipped_file = gzip.GzipFile(download, 'rb') while 1: try: chunk = gzipped_file.read(CHUNK_SIZE) except IOError: os.close(fd) os.remove(uncompressed) print 'Problem decompressing gzipped data', dataset, json_file sys.exit(4) if not chunk: break os.write(fd, chunk) os.close(fd) gzipped_file.close() shutil.copy(uncompressed, outputFile) else: shutil.copy(download, outputFile) else: print "File not found" sys.exit(4) else: with open(outputFile, 'w+') as f: try: for child in root.children: printNice(child, f, 0) except AttributeError as e: print e print root if not found: print "Store not found" sys.exit(2)