From c8c35ed0d987d0ad6b903c74d4688dbe19d1cd78 Mon Sep 17 00:00:00 2001 From: Thierry Parmentelat Date: Mon, 16 Dec 2013 12:19:16 +0100 Subject: [PATCH] =?utf8?q?move=20commented=20code=20about=20the=20?= =?utf8?q?=E2=80=98where=20am=20I=20a=20PI=E2=80=99=20question=20into=20to?= =?utf8?q?pmenuvalidation=20plugin?= MIME-Version: 1.0 Content-Type: text/plain; charset=utf8 Content-Transfer-Encoding: 8bit --- plugins/topmenuvalidation/__init__.py | 37 +++++++++++++++++++++++++++ ui/topmenu.py | 35 ------------------------- 2 files changed, 37 insertions(+), 35 deletions(-) diff --git a/plugins/topmenuvalidation/__init__.py b/plugins/topmenuvalidation/__init__.py index ef7a7334..6eafaf8c 100644 --- a/plugins/topmenuvalidation/__init__.py +++ b/plugins/topmenuvalidation/__init__.py @@ -33,3 +33,40 @@ Query.get('ple:user').filter_by('user_hrn', '==', '$user_hrn').select('pi_author def json_settings_list (self): return [ 'query_uuid', 'button_domid', ] + +#################### here is an extract previously in topmenu.py +### # ** Where am I a PI ** +### # For this we need to ask SFA (of all authorities) = PI function +### user_query = Query().get('local:user').select('config','email') +### user_details = execute_query(request, user_query) +### +### # Required: the user must have an authority in its user.config +### # XXX Temporary solution +### # not always found in user_details... +### config={} +#### Deactivated until fixed +#### if user_details is not None: +#### for user_detail in user_details: +#### #email = user_detail['email'] +#### if user_detail['config']: +#### config = json.loads(user_detail['config']) +#### user_detail['authority'] = config.get('authority',"Unknown Authority") +#### print "topmenu: %s", (user_detail['authority']) +#### if user_detail['authority'] is not None: +#### sub_authority = user_detail['authority'].split('.') +#### root_authority = sub_authority[0] +#### pi_authorities_query = Query.get(root_authority+':user').filter_by('user_hrn', '==', '$user_hrn').select('pi_authorities') +#### else: +#### pi_authorities_query = Query.get('user').filter_by('user_hrn', '==', '$user_hrn').select('pi_authorities') +#### try: +#### pi_authorities_tmp = execute_query(request, pi_authorities_query) +#### except: +#### pi_authorities_tmp = set() +#### pi_authorities = set() +#### for pa in pi_authorities_tmp: +#### if 'pi_authorities' in pa: +#### pi_authorities |= set(pa['pi_authorities']) +#### print "pi_authorities =", pi_authorities +#### if len(pi_authorities) > 0: +#### result.append({'label':'Validation', 'href': '/portal/validate/'}) +### result.append({'label':'Validation', 'href': '/portal/validate/'}) diff --git a/ui/topmenu.py b/ui/topmenu.py index c23adf7b..82979d55 100644 --- a/ui/topmenu.py +++ b/ui/topmenu.py @@ -23,41 +23,6 @@ def topmenu_items (current,request=None): if has_user: result.append({'label':'Dashboard', 'href': '/portal/dashboard/'}) result.append({'label':'Request a slice', 'href': '/portal/slice_request/'}) -### # ** Where am I a PI ** -### # For this we need to ask SFA (of all authorities) = PI function -### user_query = Query().get('local:user').select('config','email') -### user_details = execute_query(request, user_query) -### -### # Required: the user must have an authority in its user.config -### # XXX Temporary solution -### # not always found in user_details... -### config={} -#### Deactivated until fixed -#### if user_details is not None: -#### for user_detail in user_details: -#### #email = user_detail['email'] -#### if user_detail['config']: -#### config = json.loads(user_detail['config']) -#### user_detail['authority'] = config.get('authority',"Unknown Authority") -#### print "topmenu: %s", (user_detail['authority']) -#### if user_detail['authority'] is not None: -#### sub_authority = user_detail['authority'].split('.') -#### root_authority = sub_authority[0] -#### pi_authorities_query = Query.get(root_authority+':user').filter_by('user_hrn', '==', '$user_hrn').select('pi_authorities') -#### else: -#### pi_authorities_query = Query.get('user').filter_by('user_hrn', '==', '$user_hrn').select('pi_authorities') -#### try: -#### pi_authorities_tmp = execute_query(request, pi_authorities_query) -#### except: -#### pi_authorities_tmp = set() -#### pi_authorities = set() -#### for pa in pi_authorities_tmp: -#### if 'pi_authorities' in pa: -#### pi_authorities |= set(pa['pi_authorities']) -#### print "pi_authorities =", pi_authorities -#### if len(pi_authorities) > 0: -#### result.append({'label':'Validation', 'href': '/portal/validate/'}) -### result.append({'label':'Validation', 'href': '/portal/validate/'}) # always create a disabled button for validation, and let the # topmenuvalidation plugin handle that asynchroneously, based on this domid result.append({'label':'Validation', 'href': '/portal/validate/', 'domid':'topmenu-validation', 'disabled':True}) -- 2.43.0