added theme
[myslice.git] / portal / manageuserview.py
index e5dceb6..cbed7ab 100644 (file)
@@ -1,7 +1,7 @@
 from unfold.loginrequired               import LoginRequiredAutoLogoutView
 #
 from manifold.core.query                import Query
-from manifold.manifoldapi               import execute_query
+from manifold.manifoldapi               import execute_query, execute_admin_query
 from portal.actions                     import manifold_update_user, manifold_update_account, manifold_add_account, manifold_delete_account, sfa_update_user
 #
 from unfold.page                        import Page    
@@ -11,15 +11,15 @@ from django.http                        import HttpResponse, HttpResponseRedirec
 from django.contrib                     import messages
 from django.contrib.auth.decorators     import login_required
 from django.core.mail                   import send_mail
-
+from theme import ThemeView
 #
 import json, os, re, itertools
 
 # requires login
-class UserView(LoginRequiredAutoLogoutView):
+class UserView(LoginRequiredAutoLogoutView, ThemeView):
     template_name = "manageuserview.html"
     def dispatch(self, *args, **kwargs):
-        return super(AccountView, self).dispatch(*args, **kwargs)
+        return super(UserView, self).dispatch(*args, **kwargs)
 
 
     def get_context_data(self, **kwargs):
@@ -29,16 +29,20 @@ class UserView(LoginRequiredAutoLogoutView):
         page.add_css_files ( [ "css/onelab.css", "css/account_view.css","css/plugin.css" ] )
 
         for key, value in kwargs.iteritems():
-            print "%s = %s" % (key, value)
-            #if key == "platformname":
-            #    platformname=value
+            #print "%s = %s" % (key, value)
+            if key == "email":
+                selected_email=value
     
-        user_query  = Query().get('local:user').select('config','email','status')
-        user_details = execute_query(self.request, user_query)
+        user_query  = Query().get('local:user').filter_by('email', '==', selected_email).select('user_id','config','email','status')
+        user_details = execute_admin_query(self.request, user_query)
         
         # not always found in user_details...
         config={}
         for user_detail in user_details:
+            user_id = user_detail['user_id']
+            user_email = user_detail['email'] 
+            print "hello_world"
+            print user_id          
             # different significations of user_status
             if user_detail['status'] == 0: 
                 user_status = 'Disabled'
@@ -53,9 +57,9 @@ class UserView(LoginRequiredAutoLogoutView):
                 config = json.loads(user_detail['config'])
 
         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')
+        account_query  = Query().get('local:account').filter_by('user_id', '==', user_id).select('user_id','platform_id','auth_type','config')
         platform_details = execute_query(self.request, platform_query)
-        account_details = execute_query(self.request, account_query)
+        account_details = execute_admin_query(self.request, account_query)
        
         # initial assignment needed for users having account.config = {} 
         platform_name = ''
@@ -182,7 +186,7 @@ class UserView(LoginRequiredAutoLogoutView):
         platform_list = [{'platform_no_access': t[0]}
             for t in itertools.izip_longest(total_platform_list)]
 
-        context = super(AccountView, self).get_context_data(**kwargs)
+        context = super(UserView, self).get_context_data(**kwargs)
         context['principal_acc'] = principal_acc_list
         context['ref_acc'] = ref_acc_list
         context['platform_list'] = platform_list
@@ -190,7 +194,7 @@ class UserView(LoginRequiredAutoLogoutView):
         context['my_slices'] = my_slices
         context['my_auths'] = my_auths
         context['user_status'] = user_status
-        context['person']   = self.request.user
+        context['user_email']   = user_email
         context['firstname'] = config.get('firstname',"?")
         context['lastname'] = config.get('lastname',"?")
         context['fullname'] = context['firstname'] +' '+ context['lastname']
@@ -204,6 +208,7 @@ class UserView(LoginRequiredAutoLogoutView):
         context['topmenu_items'] = topmenu_items_live('My Account', page)
         # so we can sho who is logged
         context['username'] = the_user(self.request)
+        context['theme'] = self.theme
 #        context ['firstname'] = config['firstname']
         prelude_env = page.prelude_env()
         context.update(prelude_env)