X-Git-Url: http://git.onelab.eu/?p=plstackapi.git;a=blobdiff_plain;f=planetstack%2Fcore%2Fxoslib%2Fmethods%2Ftenantview.py;h=44db514c957f10671de95d32033fe5a8a06b1aa6;hp=3fa98f639a9add4ac89d06b688fffcde4ed98ed4;hb=1236fe63b898e1d11d2307268cc7ab21fceafbbb;hpb=8f725a8919153ce7b4d0b9d418df22922410aa4c diff --git a/planetstack/core/xoslib/methods/tenantview.py b/planetstack/core/xoslib/methods/tenantview.py index 3fa98f6..44db514 100644 --- a/planetstack/core/xoslib/methods/tenantview.py +++ b/planetstack/core/xoslib/methods/tenantview.py @@ -19,7 +19,11 @@ def getTenantViewDict(user): good=False for deployment in site.deployments.all(): if deployment.name in BLESSED_DEPLOYMENTS: - good=True + # only bless sites that have at least one node in the deployment + sitedeployments = SiteDeployment.objects.filter(site=site, deployment=deployment) + for sd in sitedeployments.all(): + if sd.nodes.count()>0: + good=True if good: blessed_sites.append(site) @@ -47,12 +51,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,11 +79,12 @@ 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), + "current_user_id": user.id, } class TenantList(APIView):