# HG changeset patch # User blankenberglab # Date 1648828952 0 # Node ID 0445344b7c3fe183d80921c531dde1b29fe60608 # Parent c60d0cbdc01afb3ded292c7d680c9a3a987aedf2 "planemo upload for repository https://github.com/blankenberglab/galaxy-tools-blankenberg/tree/main/data_managers/data_manager_refgenie_pull commit 793d970b919fcfd5f21a2d6e03e825b05dd56b69" diff -r c60d0cbdc01a -r 0445344b7c3f data_manager/data_manager_refgenie_pull.py --- a/data_manager/data_manager_refgenie_pull.py Fri Oct 01 14:24:12 2021 +0000 +++ b/data_manager/data_manager_refgenie_pull.py Fri Apr 01 16:02:32 2022 +0000 @@ -4,6 +4,7 @@ import argparse import logging from base64 import urlsafe_b64encode +from html import escape from urllib.parse import urljoin import refgenconf @@ -15,20 +16,21 @@ def galaxy_code_get_refgenie_assets(refgenie_config_file): try: + rval = [] rgc = refgenconf.RefGenConf(refgenie_config_file, writable=False, skip_read_lock=True) - except refgenconf.exceptions.RefgenconfError as e: - return[{'name': str(e), 'value': 'ERROR', 'options': [], 'selected': False}] - rval = [] - for urlname, genomes in rgc.listr().items(): - urlname_64 = urlsafe_b64encode(bytes(urlname, 'utf8')).decode('utf8') - ul = [] - for genome, assets in genomes.items(): - al = [] - for name in assets: - al.append({'name': name, 'value': '%s/%s/%s' % (urlname_64, genome, name), 'options': [], 'selected': False}) - ul.append({'name': genome, 'value': genome, 'options': al, 'selected': False}) - rval.append({'name': urlname, 'value': urlname_64, 'options': ul, 'selected': False}) - return rval + for urlname, genomes in rgc.listr().items(): + urlname_64 = urlsafe_b64encode(bytes(urlname, 'utf8')).decode('utf8') + ul = [] + for genome, assets in genomes.items(): + al = [] + for name in assets: + al.append({'name': name, 'value': '%s/%s/%s' % (urlname_64, genome, name), 'options': [], 'selected': False}) + ul.append({'name': genome, 'value': genome, 'options': al, 'selected': False}) + rval.append({'name': urlname, 'value': urlname_64, 'options': ul, 'selected': False}) + return rval + except Exception as e: + log.debug("Failed to access refgenie server: %s", e) + return[{'name': escape(str(e)), 'value': 'ERROR', 'options': [], 'selected': False}] if __name__ == '__main__': @@ -36,10 +38,17 @@ parser.add_argument('-n', '--names', dest='names', action='store', default=None, help='Table names to reload') parser.add_argument('-u', '--url', dest='url', action='store', default=None, help='Base url for reload') parser.add_argument('-k', '--key', dest='key', action='store', default=None, help='Galaxy API Key') + parser.add_argument('-g', '--graceful', dest='graceful', action='store_true', help='Fail gracefully') args = parser.parse_args() - if not args.names: - tables = requests.get(urljoin(args.url, "api/tool_data"), params={'key': args.key}).json() - args.names = [d.get('name') for d in tables] - for name in args.names: - print(requests.get(urljoin(args.url, "api/tool_data/%s/reload" % (name)), params={'key': args.key}).json()) + try: + if not args.names: + tables = requests.get(urljoin(args.url, "api/tool_data"), params={'key': args.key}).json() + args.names = [d.get('name') for d in tables] + for name in args.names: + print(requests.get(urljoin(args.url, "api/tool_data/%s/reload" % (name)), params={'key': args.key}).json()) + except Exception as e: + if args.graceful: + print("Failed to reload data tables:\n%s" % (e)) + else: + raise e diff -r c60d0cbdc01a -r 0445344b7c3f data_manager/data_manager_refgenie_pull.xml --- a/data_manager/data_manager_refgenie_pull.xml Fri Oct 01 14:24:12 2021 +0000 +++ b/data_manager/data_manager_refgenie_pull.xml Fri Apr 01 16:02:32 2022 +0000 @@ -1,4 +1,4 @@ - + from remote resource macros.xml @@ -18,8 +18,12 @@ && #end for echo '{}' > '${out_file}' - #if $api_refresh: - && python '${__tool_directory__}/data_manager_refgenie_pull.py' -k "\$API_KEY" -u '${__galaxy_url__}' >> '${out_log}' + #if "refresh" in $str($api_refresh): + && python '${__tool_directory__}/data_manager_refgenie_pull.py' -k "\$API_KEY" -u '${__galaxy_url__}' + #if "graceful" in $str($api_refresh): + --graceful + #end if + >> '${out_log}' #end if ]]> @@ -27,17 +31,21 @@ .+/.+/.+ - + + + + + - - + + - + @@ -57,7 +65,7 @@ .. class:: infomark -**Notice:** Galaxy data tables will be refreshed using API calls. +**Notice:** Galaxy data tables will be refreshed using API calls. You must have configured Galaxy to work with refgenie, see https://galaxyproject.org/admin/refgenie/. .. class:: warning