# -*- coding: utf-8 -*- # Copyright (C) 2012-2015 by the Free Software Foundation, Inc. # # This file is part of Postorius. # # Postorius is free software: you can redistribute it and/or modify it under # the terms of the GNU General Public License as published by the Free # Software Foundation, either version 3 of the License, or (at your option) # any later version. # # Postorius is distributed in the hope that it will be useful, but WITHOUT # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or # FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for # more details. # # You should have received a copy of the GNU General Public License along with # Postorius. If not, see <http://www.gnu.org/licenses/>. import logging from django.conf import settings from django.core.urlresolvers import reverse, NoReverseMatch from django.shortcuts import resolve_url logger = logging.getLogger(__name__) def postorius(request): """Add template variables to context. """ # Use a template so that the page header/footer is suppressed when # requested via AJAX if request.is_ajax(): template_to_extend = "postorius/base_ajax.html" else: template_to_extend = "postorius/base.html" # Find the HyperKitty URL if installed hyperkitty_url = False if "hyperkitty" in settings.INSTALLED_APPS: try: hyperkitty_url = reverse("hk_root") except NoReverseMatch: pass return { 'postorius_base_template': template_to_extend, 'request': request, 'hyperkitty_url': hyperkitty_url, # Resolve the login and logout URLs from the settings (they can be # either URLs or view names since Django 1.6) 'login_url': resolve_url(settings.LOGIN_URL), 'logout_url': resolve_url(settings.LOGOUT_URL), }