view data_manager/data_manager.py @ 2:2b4526fdf7fb draft default tip

planemo upload for repository https://github.com/galaxyproject/tools-iuc/tree/master/data_managers/data_manager_fetch_busco/ commit 2d2c72dc464b938bfa4def2511ce0938f3a1ea7d
author iuc
date Mon, 24 Apr 2023 12:26:46 +0000
parents 15b97817550a
children
line wrap: on
line source

#!/usr/bin/env python
#
# Data manager for reference data for the 'BUSCO' Galaxy tools
import argparse
import datetime
import json
import os
import shutil
import subprocess
from pathlib import Path


def main(args):
    workdir = os.path.join(os.getcwd(), "busco_downloads")
    cmd = "busco --download %s" % args.database
    subprocess.check_call(cmd, shell=True)
    with open(args.json) as fh:
        params = json.load(fh)
    target_directory = params["output_data"][0]["extra_files_path"]
    data_manager_entry = {}
    data_manager_entry["value"] = args.name.lower()
    data_manager_entry["name"] = args.name
    data_manager_entry["version"] = args.version
    data_manager_entry["path"] = str(Path(target_directory))
    data_manager_json = dict(data_tables=dict(busco_database=data_manager_entry))

    os.mkdir(target_directory)
    output_path = os.path.abspath(os.path.join(os.getcwd(), "busco_downloads"))
    for filename in os.listdir(workdir):
        shutil.move(os.path.join(output_path, filename), target_directory)
    with open(args.json, "w") as fh:
        json.dump(data_manager_json, fh, sort_keys=True)


if __name__ == "__main__":

    # Read command line
    parser = argparse.ArgumentParser(description="Download BUSCO database")
    parser.add_argument("--database", help="Database name")
    parser.add_argument(
        "--name", default=str(datetime.date.today()), help="Data table entry unique ID"
    )
    parser.add_argument("--version", help="BUSCO version")
    parser.add_argument("--json", help="Path to JSON file")
    args = parser.parse_args()

    main(args)