# Copyright (c) 2008 Mikeal Rogers # # 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. import threading from django.conf import settings from django.template import RequestContext from django.template.context import _builtin_context_processors from django.utils.module_loading import import_string from util.request import safe_get_host from request_cache.middleware import RequestCache REQUEST_CONTEXT = threading.local() class MakoMiddleware(object): def process_request(self, request): """ Process the middleware request. """ REQUEST_CONTEXT.request = request def process_response(self, __, response): """ Process the middleware response. """ REQUEST_CONTEXT.request = None return response def get_template_context_processors(): """ Returns the context processors defined in settings.TEMPLATES. """ context_processors = _builtin_context_processors context_processors += tuple(settings.DEFAULT_TEMPLATE_ENGINE['OPTIONS']['context_processors']) return tuple(import_string(path) for path in context_processors) def get_template_request_context(): """ Returns the template processing context to use for the current request, or returns None if there is not a current request. """ request = getattr(REQUEST_CONTEXT, "request", None) if not request: return None request_cache_dict = RequestCache.get_request_cache().data cache_key = "edxmako_request_context" if cache_key in request_cache_dict: return request_cache_dict[cache_key] context = RequestContext(request) context['is_secure'] = request.is_secure() context['site'] = safe_get_host(request) # This used to happen when a RequestContext object was initialized but was # moved to a different part of the logic when template engines were introduced. # Since we are not using template engines we do this here. # https://github.com/django/django/commit/37505b6397058bcc3460f23d48a7de9641cd6ef0 for processor in get_template_context_processors(): context.update(processor(request)) request_cache_dict[cache_key] = context return context