move commented code about the ‘where am I a PI’ question into topmenuvalidation plugin
authorThierry Parmentelat <thierry.parmentelat@inria.fr>
Mon, 16 Dec 2013 11:19:16 +0000 (12:19 +0100)
committerThierry Parmentelat <thierry.parmentelat@inria.fr>
Mon, 16 Dec 2013 11:19:16 +0000 (12:19 +0100)
plugins/topmenuvalidation/__init__.py
ui/topmenu.py

index ef7a733..6eafaf8 100644 (file)
@@ -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/'})
index c23adf7..82979d5 100644 (file)
@@ -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})