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:
David Lyle 2014-04-11 16:26:35 -06:00
parent 5ed79c9435
commit 0c1a0a7015

View File

@ -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