-#do_query_leases=True
-do_query_leases=False
-
-insert_grid=False
-#insert_grid=True
-
-insert_messages=False
-#insert_messages=True
-
-class SliceView (LoginRequiredAutoLogoutView, ThemeView):
-
- def get (self,request, slicename=tmp_default_slice):
-
- page = Page(request)
- page.add_css_files ('css/slice-view.css')
- page.add_js_files ( [ "js/common.functions.js" ] )
- page.add_js_chunks ('$(function() { messages.debug("sliceview: jQuery version " + $.fn.jquery); });')
- page.add_js_chunks ('$(function() { messages.debug("sliceview: users turned %s"); });'%("on" if do_query_users else "off"))
- page.add_js_chunks ('$(function() { messages.debug("sliceview: leases turned %s"); });'%("on" if do_query_leases else "off"))
- page.add_js_chunks ('$(function() { messages.debug("manifold URL %s"); });'%(ConfigEngine().manifold_url()))
-
- metadata = page.get_metadata()
- resource_md = metadata.details_by_object('resource')
- resource_fields = [column['name'] for column in resource_md['column']]
-
- user_md = metadata.details_by_object('user')
- user_fields = ['user_hrn'] # [column['name'] for column in user_md['column']]
-
- # TODO The query to run is embedded in the URL
- main_query = Query.get('slice').filter_by('slice_hrn', '=', slicename)
- main_query.select(
- 'slice_hrn',
- #'resource.hrn', 'resource.urn',
- 'resource.hostname', 'resource.type',
- 'resource.network_hrn',
- 'lease.urn',
- 'user.user_hrn',
- #'application.measurement_point.counter'
- )
- # for internal use in the querytable plugin;
- # needs to be a unique column present for each returned record
- main_query_init_key = 'hostname'
-
- query_resource_all = Query.get('resource').select(resource_fields)
-
- aq = AnalyzedQuery(main_query, metadata=metadata)
- page.enqueue_query(main_query, analyzed_query=aq)
- page.enqueue_query(query_resource_all)
- if do_query_users:
- # Required: the user must have an authority in its user.config
- # XXX Temporary solution
- user_query = Query().get('local:user').select('config','email')
- user_details = execute_query(self.request, user_query)
-
- # not always found in user_details...
- config={}
-# 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")
-#
-# if user_detail['authority'] is not None:
-# sub_authority = user_detail['authority'].split('.')
-# root_authority = sub_authority[0]
-# query_user_all = Query.get(root_authority+':user').select(user_fields)
-#
-# # XXX TODO this filter doesn't work - to be improved in Manifold
-# #.filter_by('authority.authority_hrn', '=', user_detail['authority'])
-#
-# page.enqueue_query(query_user_all)
-# else:
-# print "authority of the user is not in local:user db"
- query_user_all = Query.get('user').select(user_fields).filter_by('parent_authority','==','ple.upmc')
- page.enqueue_query(query_user_all)
- # query_user_all = None
-
- # ... and for the relations
- # XXX Let's hardcode resources for now
- sq_resource = aq.subquery('resource')
- sq_user = aq.subquery('user')
- sq_lease = aq.subquery('lease')
- sq_measurement = aq.subquery('measurement')
-
-
- # Prepare the display according to all metadata
- # (some parts will be pending, others can be triggered by users).
- #
- # For example slice measurements will not be requested by default...
-
- # Create the base layout (Stack)...
- main_stack = Stack (
- page=page,
- title="Slice %s"%slicename,
- sons=[],
- )
-
- # ... responsible for the slice properties...
-
- # a nice header
- main_stack.insert (
- Raw (page=page,
- togglable=False,
- toggled=True,
- html="<h2 class='well well-lg'> Slice %s</h2>"%slicename)
- )
-
- # --------------------------------------------------------------------------
- # QueryUpdater (Pending Operations)
-
- main_stack.insert(QueryUpdater(
- page = page,
- title = 'Pending operations',
- query = main_query,
- togglable = True,
- # start turned off, it will open up itself when stuff comes in
- toggled = False,
- domid = 'pending',
- outline_complete = True,
- ))
-
- # --------------------------------------------------------------------------
- # Filter Resources
-
-# turn off for now -- see above
- filter_query_editor = QueryEditor(
- page = page,
- query = sq_resource,
- query_all = query_resource_all,
- title = "Select Columns",
- domid = 'select-columns',
- )
- filter_active_filters = ActiveFilters(
- page = page,
- query = sq_resource,
- title = "Active Filters",
- )
- filters_area = Stack(
- page = page,
- title = 'Filter Resources',
- domid = 'filters',
- sons = [filter_query_editor,
- filter_active_filters],
- togglable = True,
- toggled = 'persistent',
- outline_complete = True,
- )
- main_stack.insert (filters_area)
-
- # --------------------------------------------------------------------------
- # RESOURCES
- # the resources part is made of a Tabs (Geographic, List),
-
- resources_as_gmap = GoogleMap(
- page = page,
- title = 'Geographic view',
- domid = 'resources-map',
- # tab's sons preferably turn this off
- togglable = False,
- query = sq_resource,
- query_all = query_resource_all,
- # this key is the one issued by google
- googlemap_api_key = ConfigEngine().googlemap_api_key(),
- # the key to use at init-time
- init_key = main_query_init_key,
- checkboxes = True,
- # center on Paris
- latitude = 49.,
- longitude = 9,
- zoom = 4,
- )
-
- resources_as_3dmap = SensLabMap(
- page = page,
- title = '3D Map',
- domid = 'senslabmap',
- query = sq_resource,
- query_all = query_resource_all,
- )
-
- resources_as_list = QueryTable(
- page = page,
- domid = 'resources-list',
- title = 'List view',
- # this is the query at the core of the slice list
- query = sq_resource,
- query_all = query_resource_all,
- init_key = main_query_init_key,
- checkboxes = True,
- datatables_options = {
- 'iDisplayLength': 25,
- 'bLengthChange' : True,
- 'bAutoWidth' : True,
- },
- )
-
- if insert_grid:
- resources_as_grid = QueryGrid(
- page = page,
- domid = 'resources-grid',
- title = 'Grid view',
- # this is the query at the core of the slice list
- query = sq_resource,
- query_all = query_resource_all,
- init_key = main_query_init_key,
- checkboxes = True,
- )
-
- if do_query_leases:
- resources_as_scheduler = Scheduler(
- page = page,
- title = 'Scheduler',
- domid = 'scheduler',
- query = sq_resource,
- query_all_resources = query_resource_all,
- query_lease = sq_lease,
- )
-
- # with the new 'Filter' stuff on top, no need for anything but the querytable
- resources_as_list_area = resources_as_list
-
- resources_sons = [
- resources_as_gmap,
- resources_as_3dmap,
- resources_as_scheduler,
- resources_as_list_area,
- ] if do_query_leases else [
- resources_as_gmap,
- resources_as_3dmap,
- resources_as_list_area,
- ]
- if insert_grid:
- resources_sons.append(resources_as_grid)
-
- resources_area = Tabs ( page=page,
- domid="resources",
- togglable=True,
- title="Resources",
- outline_complete=True,
- sons= resources_sons,
- active_domid = 'resources-map',
- persistent_active=True,
- )
- main_stack.insert (resources_area)
-
- # --------------------------------------------------------------------------
- # USERS
-
- if do_query_users and query_user_all is not None:
- tab_users = Tabs(
- page = page,
- domid = 'users',
- outline_complete = True,
- togglable = True,
- title = 'Users',
- active_domid = 'users-list',
- )
- main_stack.insert(tab_users)
-
- tab_users.insert(QueryTable(
- page = page,
- title = 'Users List',
- domid = 'users-list',
- # tab's sons preferably turn this off
- togglable = False,
- # this is the query at the core of the slice list
- query = sq_user,
- query_all = query_user_all,
- init_key = 'user_hrn',
- checkboxes = True,
- datatables_options = {
- 'iDisplayLength' : 25,
- 'bLengthChange' : True,
- 'bAutoWidth' : True,
- },
- ))