Merge branch 'fibre' of ssh://git.onelab.eu/git/myslice into fibre
[unfold.git] / portal / managementtababout.py
1 # this somehow is not used anymore - should it not be ?
2 from django.core.context_processors import csrf
3 from django.http import HttpResponseRedirect
4 from django.contrib.auth import authenticate, login, logout
5 from django.template import RequestContext
6 from django.shortcuts import render_to_response
7 from django.shortcuts import render
8
9 from unfold.loginrequired import FreeAccessView
10
11 from manifold.core.query            import Query
12 from manifoldapi.manifoldapi        import execute_query
13 from manifoldapi.manifoldresult import ManifoldResult
14 from myslice.configengine import ConfigEngine
15
16 from myslice.theme import ThemeView
17 import json
18
19 class ManagementAboutView (FreeAccessView, ThemeView):
20     template_name = 'management-tab-about.html'
21
22     def get (self, request):
23         
24         if request.user.is_authenticated(): 
25             user_query  = Query().get('user').select('user_hrn','parent_authority').filter_by('user_hrn','==','$user_hrn')
26             user_details = execute_query(self.request, user_query)
27             
28             user_local_query  = Query().get('local:user').select('config').filter_by('email','==',str(self.request.user))
29             user_local_details = execute_query(self.request, user_local_query)
30             user_authority = json.loads(user_local_details[0]['config']).get('authority')
31             # XXX Should be done using Metadata
32             # select column.name from local:object where table=='authority'
33             authority_query = Query().get('authority').select('authority_hrn', 'name', 'address', 'enabled','description', 
34                                                               'scientific', 'city', 'name', 'url', 'country', 'enabled', 'longitude', 
35                                                               'tech', 'latitude', 'pi_users', 'parent_authority', 'onelab_membership', 
36                                                               'postcode').filter_by('authority_hrn','==',user_authority)
37             authority_details = execute_query(self.request, authority_query)
38             
39             if authority_details :
40                 authority_contacts = {}
41                 authority = authority_details[0]
42                 if 'scientific' in authority and authority['scientific'] is not None:
43                     authority_contacts['scientific'] = [ x.strip()[1:-1] for x in authority['scientific'][1:-1].split(',') ]
44                 if 'technical' in authority and authority['technical'] is not None:
45                     authority_contacts['technical'] = [ x.strip()[1:-1] for x in authority['tech'][1:-1].split(',') ]
46                 if 'legal' in authority and authority['legal'] is not None:
47                     authority_contacts['legal'] = [ x.strip().replace('"','') for x in authority['legal'][1:-1].split(',') ]
48             else :
49                 authority_contacts = None
50                 authority = None
51             
52         return render_to_response(self.template, { 'theme' : self.theme, 'authority' : authority, 'authority_contacts' : authority_contacts }, context_instance=RequestContext(request))
53