2012-02-04 17:40:31 -06:00
|
|
|
# Copyright 2012 Nebula, Inc.
|
2011-07-03 20:55:00 -07:00
|
|
|
#
|
2011-01-12 13:43:31 -08:00
|
|
|
# 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.
|
2011-07-03 20:55:00 -07:00
|
|
|
|
2017-07-18 13:48:12 -04:00
|
|
|
from importlib import import_module
|
|
|
|
import logging
|
2020-01-09 16:49:18 +02:00
|
|
|
import urllib
|
2017-07-18 13:48:12 -04:00
|
|
|
|
2015-12-03 12:34:01 -08:00
|
|
|
from django.conf import settings
|
2018-01-17 14:11:59 +13:00
|
|
|
from django import http
|
2012-10-04 15:43:40 -07:00
|
|
|
from django import shortcuts
|
2017-12-12 13:30:33 +09:00
|
|
|
from django import urls
|
2018-08-06 14:14:24 +03:00
|
|
|
from django.utils.encoding import smart_text
|
2018-01-17 14:11:59 +13:00
|
|
|
from django.utils.translation import ugettext as _
|
2014-07-29 16:57:39 +02:00
|
|
|
import django.views.decorators.vary
|
2017-07-18 13:48:12 -04:00
|
|
|
from django.views.generic import TemplateView
|
2011-10-31 11:31:05 -07:00
|
|
|
|
|
|
|
import horizon
|
2015-02-05 09:25:24 +00:00
|
|
|
from horizon import exceptions
|
2015-12-03 12:34:01 -08:00
|
|
|
from horizon import notifications
|
|
|
|
|
2017-07-18 13:48:12 -04:00
|
|
|
LOG = logging.getLogger(__name__)
|
|
|
|
|
2015-12-03 12:34:01 -08:00
|
|
|
|
2019-04-11 09:51:31 +09:00
|
|
|
MESSAGES_PATH = settings.MESSAGES_PATH
|
2011-01-15 01:16:25 -08:00
|
|
|
|
2012-03-26 18:08:48 -07:00
|
|
|
|
2012-10-04 15:43:40 -07:00
|
|
|
def get_user_home(user):
|
2018-06-21 11:19:33 +03:00
|
|
|
dashboard = horizon.get_default_dashboard()
|
2014-04-11 16:26:35 -06:00
|
|
|
return dashboard.get_absolute_url()
|
2012-03-26 18:08:48 -07:00
|
|
|
|
2011-01-12 13:43:31 -08:00
|
|
|
|
2019-08-26 14:26:26 +01:00
|
|
|
# TODO(stephenfin): Migrate to CBV
|
2014-07-29 16:57:39 +02:00
|
|
|
@django.views.decorators.vary.vary_on_cookie
|
2012-10-04 15:43:40 -07:00
|
|
|
def splash(request):
|
2017-12-12 13:48:55 +09:00
|
|
|
if not request.user.is_authenticated:
|
2015-02-05 09:25:24 +00:00
|
|
|
raise exceptions.NotAuthenticated()
|
|
|
|
|
|
|
|
response = shortcuts.redirect(horizon.get_user_home(request.user))
|
2014-11-20 08:49:09 -07:00
|
|
|
if 'logout_reason' in request.COOKIES:
|
|
|
|
response.delete_cookie('logout_reason')
|
2016-09-12 15:22:20 +05:30
|
|
|
if 'logout_status' in request.COOKIES:
|
|
|
|
response.delete_cookie('logout_status')
|
2015-12-03 12:34:01 -08:00
|
|
|
# Display Message of the Day message from the message files
|
|
|
|
# located in MESSAGES_PATH
|
|
|
|
if MESSAGES_PATH:
|
|
|
|
notifications.process_message_notification(request, MESSAGES_PATH)
|
2014-06-18 16:34:59 +05:30
|
|
|
return response
|
2016-03-08 17:03:32 +03:00
|
|
|
|
|
|
|
|
|
|
|
def get_url_with_pagination(request, marker_name, prev_marker_name, url_string,
|
|
|
|
object_id=None):
|
|
|
|
if object_id:
|
2017-12-12 13:30:33 +09:00
|
|
|
url = urls.reverse(url_string, args=(object_id,))
|
2016-03-08 17:03:32 +03:00
|
|
|
else:
|
2017-12-12 13:30:33 +09:00
|
|
|
url = urls.reverse(url_string)
|
2016-03-08 17:03:32 +03:00
|
|
|
marker = request.GET.get(marker_name, None)
|
|
|
|
if marker:
|
|
|
|
return "{}?{}".format(url,
|
|
|
|
urllib.parse.urlencode({marker_name: marker}))
|
|
|
|
|
|
|
|
prev_marker = request.GET.get(prev_marker_name, None)
|
|
|
|
if prev_marker:
|
|
|
|
return "{}?{}".format(url,
|
|
|
|
urllib.parse.urlencode({prev_marker_name:
|
|
|
|
prev_marker}))
|
|
|
|
return url
|
2017-07-18 13:48:12 -04:00
|
|
|
|
|
|
|
|
|
|
|
class ExtensibleHeaderView(TemplateView):
|
|
|
|
template_name = 'header/_header_sections.html'
|
|
|
|
|
|
|
|
def get_context_data(self, **kwargs):
|
|
|
|
context = super(ExtensibleHeaderView, self).get_context_data(**kwargs)
|
|
|
|
header_sections = []
|
|
|
|
config = getattr(settings, 'HORIZON_CONFIG', {})
|
|
|
|
for view_path in config.get("header_sections", []):
|
|
|
|
mod_path, view_cls = view_path.rsplit(".", 1)
|
|
|
|
try:
|
|
|
|
mod = import_module(mod_path)
|
|
|
|
except ImportError:
|
|
|
|
LOG.warning("Could not load header view: %s", mod_path)
|
|
|
|
continue
|
|
|
|
|
|
|
|
try:
|
|
|
|
view = getattr(mod, view_cls)(request=self.request)
|
|
|
|
response = view.get(self.request)
|
|
|
|
rendered_response = response.render()
|
|
|
|
packed_response = [view_path.replace('.', '-'),
|
2018-08-06 14:14:24 +03:00
|
|
|
smart_text(rendered_response.content)]
|
2017-07-18 13:48:12 -04:00
|
|
|
header_sections.append(packed_response)
|
|
|
|
|
|
|
|
except Exception as e:
|
|
|
|
LOG.warning("Could not render header %(path)s, exception: "
|
|
|
|
"%(exc)s", {'path': view_path, 'exc': e})
|
|
|
|
continue
|
|
|
|
|
|
|
|
context['header_sections'] = header_sections
|
|
|
|
return context
|
2018-01-17 14:11:59 +13:00
|
|
|
|
|
|
|
|
|
|
|
def csrf_failure(request, reason=""):
|
|
|
|
if reason:
|
|
|
|
reason += " "
|
|
|
|
reason += _("Cookies may be turned off. "
|
|
|
|
"Make sure cookies are enabled and try again.")
|
|
|
|
|
|
|
|
url = settings.LOGIN_URL + "?csrf_failure=%s" % urllib.parse.quote(reason)
|
|
|
|
response = http.HttpResponseRedirect(url)
|
|
|
|
return response
|