From 3c91f5701ed3118f8d88d874d8e64cccb4bad6fd Mon Sep 17 00:00:00 2001 From: Miguel Caballer Date: Tue, 12 Mar 2024 12:40:08 +0100 Subject: [PATCH 1/2] Do not get appdb vos --- app/appdb.py | 22 +++++++++------------- app/utils.py | 33 ++++----------------------------- 2 files changed, 13 insertions(+), 42 deletions(-) diff --git a/app/appdb.py b/app/appdb.py index dd8b25a51..2fd2984ef 100644 --- a/app/appdb.py +++ b/app/appdb.py @@ -24,7 +24,6 @@ from urllib.parse import urlparse APPDB_URL = "https://appdb.egi.eu" -VO_LIST = [] APPDB_TIMEOUT = 10 @@ -45,18 +44,15 @@ def appdb_call(path, retries=3, url=APPDB_URL, timeout=APPDB_TIMEOUT): def get_vo_list(): - global VO_LIST - if not VO_LIST: - vos = [] - data = appdb_call('/rest/1.0/vos') - if data: - if isinstance(data['vo:vo'], list): - for vo in data['vo:vo']: - vos.append(vo['@name']) - else: - vos.append(data['vo:vo']['@name']) - VO_LIST = vos - return VO_LIST + vos = [] + data = appdb_call('/rest/1.0/vos') + if data: + if isinstance(data['vo:vo'], list): + for vo in data['vo:vo']: + vos.append(vo['@name']) + else: + vos.append(data['vo:vo']['@name']) + return vos def _get_services(vo=None): diff --git a/app/utils.py b/app/utils.py index f191ddfd5..12ed7fd39 100644 --- a/app/utils.py +++ b/app/utils.py @@ -47,9 +47,6 @@ LAST_UPDATE = 0 PORT_SPECT_TYPES = ["PortSpec", "tosca.datatypes.network.PortSpec", "tosca.datatypes.indigo.network.PortSpec"] -VO_LIST = [] -VO_LAST_UPDATE = 0 - def _getStaticSitesInfo(force=False): # Remove cache if force is True @@ -152,7 +149,9 @@ def getCachedSiteList(force=False): now = int(time.time()) if force or not SITE_LIST or now - LAST_UPDATE > g.settings.appdb_cache_timeout: try: - SITE_LIST = appdb.get_sites() + sites = appdb.get_sites() + if sites: + SITE_LIST = appdb.get_sites() # in case of error do not update time LAST_UPDATE = now except Exception as ex: @@ -790,32 +789,8 @@ def get_project_ids(creds): return creds -def getCachedVOList(): - global VO_LIST - global VO_LAST_UPDATE - - now = int(time.time()) - if not VO_LIST or now - VO_LAST_UPDATE > g.settings.appdb_cache_timeout: - try: - VO_LIST = appdb.get_vo_list() - # in case of error do not update time - VO_LAST_UPDATE = now - except Exception as ex: - flash("Error retrieving VO list from AppDB: %s" % ex, 'warning') - - return VO_LIST - - def getVOs(session): - vos = getStaticVOs() - vos.extend(getCachedVOList()) - vos = list(set(vos)) - vos.sort() - if "vos" in session and session["vos"]: - vos = [vo for vo in vos if vo in session["vos"]] - elif not g.settings.debug_oidc_token: - vos = [] - return vos + return session["vos"] if "vos" in session and session["vos"] else [] def get_site_info_from_radl(radl, creds): From 7aaa3ede729a454f1ad0495709ba4a53179e5267 Mon Sep 17 00:00:00 2001 From: Miguel Caballer Date: Tue, 12 Mar 2024 12:42:20 +0100 Subject: [PATCH 2/2] Do not get appdb vos --- app/utils.py | 9 --------- 1 file changed, 9 deletions(-) diff --git a/app/utils.py b/app/utils.py index 12ed7fd39..1c244a403 100644 --- a/app/utils.py +++ b/app/utils.py @@ -101,15 +101,6 @@ def getStaticSites(vo=None, force=False): return res -def getStaticVOs(): - res = [] - for site in _getStaticSitesInfo(): - if "vos" in site and site["vos"]: - res.extend(list(site["vos"].keys())) - - return list(set(res)) - - def get_site_info(cred_id, cred, userid): domain = None res_site = {}