From b4fcd4005bcebbafc988a2e6bc0d2da2b7ffc908 Mon Sep 17 00:00:00 2001 From: Scott Baker Date: Sun, 18 Jan 2015 17:04:35 -0800 Subject: [PATCH] make tenantview method reslient of users with no site, catch users with no site in sanity check --- planetstack/core/xoslib/methods/tenantview.py | 21 ++++++++++++------- .../core/xoslib/static/js/xosTenant.js | 3 +++ 2 files changed, 17 insertions(+), 7 deletions(-) diff --git a/planetstack/core/xoslib/methods/tenantview.py b/planetstack/core/xoslib/methods/tenantview.py index 3fa98f6..6c84b3e 100644 --- a/planetstack/core/xoslib/methods/tenantview.py +++ b/planetstack/core/xoslib/methods/tenantview.py @@ -47,12 +47,19 @@ def getTenantViewDict(user): volumes.append(volume) site_users=[] - for auser in user.site.users.all(): - site_users.append(auser) - user_site_roles=[] - for priv in user.site.siteprivileges.filter(user=user): - user_site_roles.append(priv.role.role) + user_site_id=None + user_site_login_base=None + if not user.site: + pass # this is probably an error + else: + user_site_id = user.site.id + user_site_login_base = user.site.login_base + for auser in user.site.users.all(): + site_users.append(auser) + + for priv in user.site.siteprivileges.filter(user=user): + user_site_roles.append(priv.role.role) blessed_service_classes = [ServiceClass.objects.get(name="Best Effort")] @@ -68,8 +75,8 @@ def getTenantViewDict(user): "blessed_service_classes": [serviceclass.id for serviceclass in blessed_service_classes], "public_volume_names": [volume.name for volume in volumes], "public_volumes": [volume.id for volume in volumes], - "current_user_site_id": user.site.id, - "current_user_login_base": user.site.login_base, + "current_user_site_id": user_site_id, + "current_user_login_base": user_site_login_base, "current_user_site_users": [auser.id for auser in site_users], "current_user_site_user_names": [auser.email for auser in site_users], "current_user_can_create_slice": user.is_admin or ("pi" in user_site_roles) or ("admin" in user_site_roles), diff --git a/planetstack/core/xoslib/static/js/xosTenant.js b/planetstack/core/xoslib/static/js/xosTenant.js index 96465d3..9c45460 100644 --- a/planetstack/core/xoslib/static/js/xosTenant.js +++ b/planetstack/core/xoslib/static/js/xosTenant.js @@ -299,6 +299,9 @@ XOSTenantApp.sanityCheck = function() { if (xos.tenant().blessed_sites.length == 0) { errors.push("no blessed sites"); } + if (xos.tenant().current_user_site_id == null) { + errors.push("current user does not have a site"); + } if (errors.length > 0) { $("#tenantSummary").html("Tenant view sanity check failed
" + errors.join("
")); -- 2.43.0