X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=portal%2Fslicetabexperiment.py;h=ab2fee2ee966ea1cb5c4f5d03cbd55eeec6be017;hb=refs%2Fheads%2Ff4f-review;hp=023c2060464ea77b287ed37db6ac0c0705d360a2;hpb=558fe659b62f98ccc7f4e64cab68dee712a9be30;p=myslice.git diff --git a/portal/slicetabexperiment.py b/portal/slicetabexperiment.py index 023c2060..ab2fee2e 100644 --- a/portal/slicetabexperiment.py +++ b/portal/slicetabexperiment.py @@ -15,6 +15,11 @@ from ui.topmenu import topmenu_items, the_user from myslice.configengine import ConfigEngine from myslice.theme import ThemeView +from myslice.configengine import ConfigEngine + +from sfa.planetlab.plxrn import hash_loginbase + +import urllib2,json class ExperimentView (FreeAccessView, ThemeView): template_name = 'slice-tab-experiment.html' @@ -23,26 +28,80 @@ class ExperimentView (FreeAccessView, ThemeView): username = self.request.user - split_slicename = slicename.split('.') - ple_slicename = split_slicename[0] + '8' + split_slicename[1] + '_' + split_slicename[2] - - query_current_resources = Query.get('slice').select('resource').filter_by('slice_hrn','==',slicename) + query_current_resources = Query.get('slice').select('resource','parent_authority').filter_by('slice_hrn','==',slicename) current_resources = execute_query(request, query_current_resources) - formatted_resource_list=[] + parent_authority = current_resources[0]['parent_authority'] + + split_slicename = slicename.split('.') + ple_slicename = hash_loginbase(parent_authority) + '_' + split_slicename[-1] + + ple_resource_list=[] + nitos_resource_list=[] + nitos_paris_resource_list=[] + iotlab_resource_list=[] try: for resources in current_resources: list_res = resources['resource'] + #print "list_b4" + #print list_res for res in list_res: split_list = res.split('+') # split the resource urn - if [s for s in split_list if 'ple' in s]: # search only ple resources + #print "list_after" + #print split_list + if [s for s in split_list if 'ple' in s]: # find ple resources res_hrn = split_list[-1] # last element is resource hrn - formatted_resource_list.append(res_hrn) + ple_resource_list.append(res_hrn) + if [s for s in split_list if 'omf:paris.fit-nitos.fr' in s]: # find nitos_paris resources + res_hrn = split_list[-1] # last element is resource hrn + nitos_paris_resource_list.append(res_hrn) + if [s for s in split_list if 'iotlab' in s]: # find iotlab resources + res_hrn = split_list[-1] # last element is resource hrn + iotlab_resource_list.append(res_hrn) + if [s for s in split_list if 'omf:nitos.indoor' in s]: # find nitos_indoor resources + res_hrn = split_list[-1] # last element is resource hrn + nitos_resource_list.append(res_hrn) + if [s for s in split_list if 'omf:nitos.outdoor' in s]: # find nitos_outdoor resources + res_hrn = split_list[-1] # last element is resource hrn + nitos_resource_list.append(res_hrn) + + except Exception,e: - print "Exception in slicetabexperiment.py in ple resource search %s" % e + print "Exception in slicetabexperiment.py in OneLab resource search %s" % e - print "list of ple resource hrns" - print formatted_resource_list + #print "list of ple res hrns" + #print ple_resource_list + #print "list of nit_paris res hrns" + #print nitos_paris_resource_list + #print "list of iotLab res hrns" + #print iotlab_resource_list + #print "list of nitos res hrns" + #print nitos_resource_list + + all_users = list() + #get all iotlab users + all_users = list() + try: + engine = ConfigEngine() + userData = "Basic " + (engine.iotlab_admin_user() + ":" + engine.iotlab_admin_password()).encode("base64").rstrip() + req = urllib2.Request(engine.iotlab_url()) + req.add_header('Accept', 'application/json') + req.add_header("Content-type", "application/x-www-form-urlencoded") + req.add_header('Authorization', userData) + # make the request and print the results + res = urllib2.urlopen(req) + all_users = json.load(res) + except urllib2.URLError as e: + print "There is a problem in getting iotlab users %s" % e.reason + - return render_to_response(self.template, { 'theme' : self.theme,'slicename':slicename, 'ple_slicename':ple_slicename, 'username':username, 'ple_resources':formatted_resource_list }, context_instance=RequestContext(request)) + #getting the login from email + #initial value no-account == contact_admin + iot_login = 'contact_admin' + username = str(username) + for user in all_users: + if user['email'] == username: + iot_login = user['login'] + + return render_to_response(self.template, { 'theme' : self.theme,'slicename':slicename, 'ple_slicename':ple_slicename, 'username':username, 'ple_resources':ple_resource_list, 'nitos_resources': nitos_resource_list, 'nitos_paris_resources':nitos_paris_resource_list, 'iotlab_resources':iotlab_resource_list, 'iot_login':iot_login }, context_instance=RequestContext(request))