e940196a43
1) This patch fixes the session timeout string problem which occurs when users clicks on the UI and Ui redirects the user to the login page but without session timeout message. 2) This patch also fixes other cases of unnecessary logout messages. Closes-Bug: #1231355 Change-Id: I9824db44382247d64cc8c399eb5e855e818e8781
49 lines
1.5 KiB
Python
49 lines
1.5 KiB
Python
# 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.
|
|
|
|
from django import shortcuts
|
|
import django.views.decorators.vary
|
|
|
|
import horizon
|
|
from horizon import base
|
|
|
|
from openstack_auth import forms
|
|
|
|
|
|
def get_user_home(user):
|
|
dashboard = None
|
|
if user.is_superuser:
|
|
try:
|
|
dashboard = horizon.get_dashboard('admin')
|
|
except base.NotRegistered:
|
|
pass
|
|
|
|
if dashboard is None:
|
|
dashboard = horizon.get_default_dashboard()
|
|
|
|
return dashboard.get_absolute_url()
|
|
|
|
|
|
@django.views.decorators.vary.vary_on_cookie
|
|
def splash(request):
|
|
if request.user.is_authenticated():
|
|
response = shortcuts.redirect(horizon.get_user_home(request.user))
|
|
else:
|
|
form = forms.Login(request)
|
|
request.session.clear()
|
|
request.session.set_test_cookie()
|
|
response = shortcuts.render(request, 'splash.html', {'form': form})
|
|
response.delete_cookie('logout_reason')
|
|
return response
|