
The main difficulty in tracing async requests which are made during the rendering of Angular-based pages is tracking the root request (the one which was made to render the skeleton page which then initiated all other requests) throughout other requests, so they form a cohesive trace. This is solved by capturing the root request id and exposing it as a profiler module constant in the process of interpolating _scripts.html Django template. Then if that constant is not an empty dictionary, profiler module intercepts all Angular requests and adds osprofiler headers to them. This patch also fixes issues which arose after transitioning to the new version of angular-bootstrap. Change-Id: I656028b969289a473f54594681d9313ff8a07fd8
84 lines
3.1 KiB
Python
84 lines
3.1 KiB
Python
# Copyright 2012 United States Government as represented by the
|
|
# Administrator of the National Aeronautics and Space Administration.
|
|
# All Rights Reserved.
|
|
#
|
|
# Copyright 2012 Nebula, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
"""
|
|
Context processors used by Horizon.
|
|
"""
|
|
|
|
import re
|
|
|
|
from django.conf import settings
|
|
|
|
from horizon import conf
|
|
from openstack_dashboard.contrib.developer.profiler import api as profiler
|
|
|
|
|
|
def openstack(request):
|
|
"""Context processor necessary for OpenStack Dashboard functionality.
|
|
|
|
The following variables are added to the request context:
|
|
|
|
``authorized_tenants``
|
|
A list of tenant objects which the current user has access to.
|
|
|
|
``regions``
|
|
|
|
A dictionary containing information about region support, the current
|
|
region, and available regions.
|
|
"""
|
|
context = {}
|
|
|
|
# Auth/Keystone context
|
|
context.setdefault('authorized_tenants', [])
|
|
if request.user.is_authenticated():
|
|
context['authorized_tenants'] = [
|
|
tenant for tenant in
|
|
request.user.authorized_tenants if tenant.enabled]
|
|
|
|
# Region context/support
|
|
available_regions = getattr(settings, 'AVAILABLE_REGIONS', [])
|
|
regions = {'support': len(available_regions) > 1,
|
|
'current': {'endpoint': request.session.get('region_endpoint'),
|
|
'name': request.session.get('region_name')},
|
|
'available': [{'endpoint': region[0], 'name':region[1]} for
|
|
region in available_regions]}
|
|
context['regions'] = regions
|
|
|
|
# Adding webroot access
|
|
context['WEBROOT'] = getattr(settings, "WEBROOT", "/")
|
|
|
|
# Adding profiler support flag
|
|
profiler_settings = getattr(settings, 'OPENSTACK_PROFILER', {})
|
|
profiler_enabled = profiler_settings.get('enabled', False)
|
|
context['profiler_enabled'] = profiler_enabled
|
|
if profiler_enabled and 'profile_page' in request.COOKIES:
|
|
index_view_id = request.META.get(profiler.ROOT_HEADER, '')
|
|
hmac_keys = profiler_settings.get('keys', [])
|
|
context['x_trace_info'] = profiler.update_trace_headers(
|
|
hmac_keys, parent_id=index_view_id)
|
|
|
|
# Search for external plugins and append to javascript message catalog
|
|
# internal plugins are under the openstack_dashboard domain
|
|
# so we exclude them from the js_catalog
|
|
js_catalog = ['horizon', 'openstack_dashboard']
|
|
regex = re.compile(r'^openstack_dashboard')
|
|
all_plugins = conf.HORIZON_CONFIG['plugins']
|
|
js_catalog.extend(p for p in all_plugins if not regex.search(p))
|
|
context['JS_CATALOG'] = '+'.join(js_catalog)
|
|
|
|
return context
|