X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=portal%2Fhomeview.py;h=6e0fba88c3d0842e9a4ee4a78a45000e07bb78bb;hb=690cbb6c4847ded7833a0c5f05c4e767522ff0e5;hp=c71481ad46390011e78ff7f0f5935e1c166f191f;hpb=b57d73b52870350b8150f00126394fd0df6d09f1;p=unfold.git diff --git a/portal/homeview.py b/portal/homeview.py index c71481ad..6e0fba88 100644 --- a/portal/homeview.py +++ b/portal/homeview.py @@ -1,18 +1,32 @@ # this somehow is not used anymore - should it not be ? -from django.core.context_processors import csrf -from django.http import HttpResponseRedirect -from django.contrib.auth import authenticate, login, logout -from django.template import RequestContext -from django.shortcuts import render_to_response +from django.core.context_processors import csrf +from django.http import HttpResponseRedirect +from django.contrib.auth import authenticate, login, logout +from django.template import RequestContext +from django.shortcuts import render_to_response +from django.shortcuts import render -from unfold.loginrequired import FreeAccessView -from manifold.manifoldresult import ManifoldResult -from ui.topmenu import topmenu_items, the_user -from myslice.configengine import ConfigEngine +from unfold.loginrequired import FreeAccessView -class HomeView (FreeAccessView): +from manifold.core.query import Query +from manifoldapi.manifoldapi import execute_query +from manifoldapi.manifoldresult import ManifoldResult +from ui.topmenu import topmenu_items, the_user +from myslice.configengine import ConfigEngine + +from myslice.theme import ThemeView +from portal.account import Account, get_expiration +from portal.models import PendingSlice +from portal.actions import authority_check_pis, get_jfed_identity + +import json, time +import activity.user + +class HomeView (FreeAccessView, ThemeView): + template_name = 'home-view.html' + # expose this so we can mention the backend URL on the welcome page def default_env (self): return { @@ -21,6 +35,9 @@ class HomeView (FreeAccessView): def post (self,request): env = self.default_env() + env['theme'] = self.theme + env['section'] = "Dashboard" + username = request.POST.get('username') password = request.POST.get('password') @@ -38,33 +55,159 @@ class HomeView (FreeAccessView): manifoldresult = auth_result # let's use ManifoldResult.__repr__ env['state']="%s"%manifoldresult - env['layout_1_or_2']="layout-unfold2.html" - return render_to_response('home-view.html',env, context_instance=RequestContext(request)) + # user was authenticated at the backend elif auth_result is not None: user=auth_result if user.is_active: - print "LOGGING IN" login(request, user) - return HttpResponseRedirect ('/login-ok') + + if request.user.is_authenticated(): + env['person'] = self.request.user + env['username'] = self.request.user + + # log user activity + activity.user.login(self.request) + + ## check user is pi or not + platform_details = {} + account_details = {} + acc_auth_cred = {} + acc_user_cred = {} + platform_query = Query().get('local:platform').select('platform_id','platform','gateway_type','disabled') + account_query = Query().get('local:account').select('user_id','platform_id','auth_type','config') + platform_details = execute_query(self.request, platform_query) + account_details = execute_query(self.request, account_query) + if platform_details is not None and platform_details != {}: + for platform_detail in platform_details: + for account_detail in account_details: + if platform_detail['platform_id'] == account_detail['platform_id']: + if 'config' in account_detail and account_detail['config'] is not '': + account_config = json.loads(account_detail['config']) + if 'myslice' in platform_detail['platform']: + acc_auth_cred = account_config.get('delegated_authority_credentials','N/A') + acc_user_cred = account_config.get('delegated_user_credential','N/A') + # assigning values + #if acc_auth_cred=={} or acc_auth_cred=='N/A': + # pi = "is_not_pi" + #else: + # pi = "is_pi" + user_email = str(self.request.user) + pi = authority_check_pis(self.request, user_email) + + # check if the user has creds or not + if acc_user_cred == {} or acc_user_cred == 'N/A': + user_cred = 'no_creds' + else: + exp_date = get_expiration(acc_user_cred, 'timestamp') + if exp_date < time.time(): + user_cred = 'creds_expired' + else: + user_cred = 'has_creds' + + # list the pending slices of this user + pending_slices = [] + for slices in PendingSlice.objects.filter(type_of_nodes__iexact=self.request.user).all(): + pending_slices.append(slices.slice_name) + + env['pending_slices'] = pending_slices + env['pi'] = pi + env['user_cred'] = user_cred + else: + env['person'] = None else: + # log user activity + activity.user.login(self.request, "notactive") env['state'] = "Your account is not active, please contact the site admin." env['layout_1_or_2']="layout-unfold2.html" - return render_to_response('home-view.html',env, context_instance=RequestContext(request)) + + jfed_identity = get_jfed_identity(request) + if jfed_identity is not None: + import base64 + encoded_jfed_identity = base64.b64encode(jfed_identity) + env['jfed_identity'] = encoded_jfed_identity + else: + env['jfed_identity'] = None + # otherwise else: + # log user activity + activity.user.login(self.request, "error") env['state'] = "Your username and/or password were incorrect." - env['layout_1_or_2']="layout-unfold2.html" - return render_to_response('home-view.html',env, context_instance=RequestContext(request)) + + return render_to_response(self.template,env, context_instance=RequestContext(request)) - # login-ok sets state="Welcome to MySlice" in urls.py def get (self, request, state=None): env = self.default_env() + acc_auth_cred={} + + jfed_identity = get_jfed_identity(request) + if jfed_identity is not None: + import base64 + encoded_jfed_identity = base64.b64encode(jfed_identity) + env['jfed_identity'] = encoded_jfed_identity + else: + env['jfed_identity'] = None + + if request.user.is_authenticated(): + + ## check user is pi or not + platform_details = {} + account_details = {} + acc_auth_cred = {} + acc_user_cred = {} + platform_query = Query().get('local:platform').select('platform_id','platform','gateway_type','disabled') + account_query = Query().get('local:account').select('user_id','platform_id','auth_type','config') + # XXX Something like an invalid session seems to make the execute fail sometimes, and thus gives an error on the main page + platform_details = execute_query(self.request, platform_query) + account_details = execute_query(self.request, account_query) + if platform_details is not None and platform_details != {}: + for platform_detail in platform_details: + for account_detail in account_details: + if 'platform_id' in platform_detail: + if platform_detail['platform_id'] == account_detail['platform_id']: + if 'config' in account_detail and account_detail['config'] is not '': + account_config = json.loads(account_detail['config']) + if 'myslice' in platform_detail['platform']: + acc_auth_cred = account_config.get('delegated_authority_credentials','N/A') + acc_user_cred = account_config.get('delegated_user_credential','N/A') + # assigning values + #if acc_auth_cred=={} or acc_auth_cred=='N/A': + # pi = "is_not_pi" + #else: + # pi = "is_pi" + user_email = str(self.request.user) + pi = authority_check_pis(self.request, user_email) + # check if the user has creds or not + if acc_user_cred == {} or acc_user_cred == 'N/A': + user_cred = 'no_creds' + else: + exp_date = get_expiration(acc_user_cred, 'timestamp') + if exp_date < time.time(): + user_cred = 'creds_expired' + else: + user_cred = 'has_creds' + + # list the pending slices of this user + pending_slices = [] + for slices in PendingSlice.objects.filter(type_of_nodes__iexact=self.request.user).all(): + pending_slices.append(slices.slice_name) + + env['pending_slices'] = pending_slices + env['pi'] = pi + env['user_cred'] = user_cred + env['person'] = self.request.user + else: + env['person'] = None + + env['theme'] = self.theme + env['section'] = "Dashboard" + + env['username']=the_user(request) env['topmenu_items'] = topmenu_items(None, request) if state: env['state'] = state - elif not env['username']: env['state'] = "Please sign in" + elif not env['username']: env['state'] = None # use one or two columns for the layout - not logged in users will see the login prompt - env['layout_1_or_2']="layout-unfold2.html" if not env['username'] else "layout-unfold1.html" - return render_to_response('home-view.html',env, context_instance=RequestContext(request)) + return render_to_response(self.template, env, context_instance=RequestContext(request))