Fix default get_user_home with dynamic dashboards
The existing get_user_home implementation expects both the 'admin' and 'project' dashboards to exist and throws an exception if they are missing. With the inclusion of configurable dashboard loading, we can no longer count on certain dashboards being loaded. Closes-Bug: #1293727 Change-Id: I4ee0b7b313f4e1b27c0daea829c8b38282fa78d9
This commit is contained in:
parent
5ed79c9435
commit
0c1a0a7015
@ -18,14 +18,23 @@ from django import shortcuts
|
|||||||
from django.views.decorators import vary
|
from django.views.decorators import vary
|
||||||
|
|
||||||
import horizon
|
import horizon
|
||||||
|
from horizon import base
|
||||||
|
|
||||||
from openstack_auth import views
|
from openstack_auth import views
|
||||||
|
|
||||||
|
|
||||||
def get_user_home(user):
|
def get_user_home(user):
|
||||||
|
dashboard = None
|
||||||
if user.is_superuser:
|
if user.is_superuser:
|
||||||
return horizon.get_dashboard('admin').get_absolute_url()
|
try:
|
||||||
return horizon.get_dashboard('project').get_absolute_url()
|
dashboard = horizon.get_dashboard('admin')
|
||||||
|
except base.NotRegistered:
|
||||||
|
pass
|
||||||
|
|
||||||
|
if dashboard is None:
|
||||||
|
dashboard = horizon.get_default_dashboard()
|
||||||
|
|
||||||
|
return dashboard.get_absolute_url()
|
||||||
|
|
||||||
|
|
||||||
@vary.vary_on_cookie
|
@vary.vary_on_cookie
|
||||||
|
Loading…
Reference in New Issue
Block a user