X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=planetstack%2Fcore%2Fmodels%2Fsite.py;h=af57ed24c87840ca63395b0722030d9a51e69d2d;hb=9d8fc9ee70f829785442ecaf94589ef2c631766d;hp=282368f2b5c69b02994840bf5ea137be40fd0daa;hpb=ea6d8be825120aa2f73c5cc041c54d80b91284c9;p=plstackapi.git diff --git a/planetstack/core/models/site.py b/planetstack/core/models/site.py index 282368f..af57ed2 100644 --- a/planetstack/core/models/site.py +++ b/planetstack/core/models/site.py @@ -1,18 +1,49 @@ import os from django.db import models +from django.db.models import Q from core.models import PlCoreBase,PlCoreBaseManager,PlCoreBaseDeletionManager from core.models import Tag from django.contrib.contenttypes import generic from geoposition.fields import GeopositionField from core.acl import AccessControlList +from planetstack.config import Config + +config = Config() + +class DeploymentLinkDeletionManager(PlCoreBaseDeletionManager): + def get_queryset(self): + parent=super(DeploymentLinkDeletionManager, self) + try: + backend_type = config.observer_backend_type + except AttributeError: + backend_type = None + + parent_queryset = parent.get_queryset() if hasattr(parent, "get_queryset") else parent.get_query_set() + if (backend_type): + return parent_queryset.filter(Q(deployment__backend_type=config.observer_backend_type)|Q(backend_type=None)) + else: + return parent_queryset + + # deprecated in django 1.7 in favor of get_queryset(). + def get_query_set(self): + return self.get_queryset() + class DeploymentDeletionManager(PlCoreBaseDeletionManager): def get_queryset(self): parent=super(DeploymentDeletionManager, self) - if hasattr(parent, "get_queryset"): - return parent.get_queryset().filter(Q(backend_type=config.observer_backend_type)|Q(backend_type=None)) + + try: + backend_type = config.observer_backend_type + except AttributeError: + backend_type = None + + parent_queryset = parent.get_queryset() if hasattr(parent, "get_queryset") else parent.get_query_set() + + if backend_type: + return parent_queryset.filter(Q(backend_type=config.observer_backend_type)|Q(backend_type=None)) else: - return parent.get_queryset().filter(Q(backend_type=config.observer_backend_type)|Q(backend_type=None)) + return parent_queryset # deprecated in django 1.7 in favor of get_queryset(). def get_query_set(self): @@ -21,10 +52,18 @@ class DeploymentDeletionManager(PlCoreBaseDeletionManager): class DeploymentLinkManager(PlCoreBaseManager): def get_queryset(self): parent=super(DeploymentLinkManager, self) - if hasattr(parent, "get_queryset"): - return parent.get_queryset().filter(Q(deployment__backend_type=config.observer_backend_type)|Q(backend_type=None)) + + try: + backend_type = config.observer_backend_type + except AttributeError: + backend_type = None + + parent_queryset = parent.get_queryset() if hasattr(parent, "get_queryset") else parent.get_query_set() + + if backend_type: + return parent_queryset.filter(Q(deployment__backend_type=config.observer_backend_type)|Q(backend_type=None)) else: - return parent.get_queryset().filter(Q(deployment__backend_type=config.observer_backend_type)|Q(backend_type=None)) + return parent_queryset # deprecated in django 1.7 in favor of get_queryset(). def get_query_set(self): @@ -34,10 +73,18 @@ class DeploymentLinkManager(PlCoreBaseManager): class DeploymentManager(PlCoreBaseManager): def get_queryset(self): parent=super(DeploymentManager, self) - if hasattr(parent, "get_queryset"): - return parent.get_queryset().filter(Q(backend_type=config.observer_backend_type)|Q(backend_type=None)) + + try: + backend_type = config.observer_backend_type + except AttributeError: + backend_type = None + + parent_queryset = parent.get_queryset() if hasattr(parent, "get_queryset") else parent.get_query_set() + + if backend_type: + return parent_queryset.filter(Q(backend_type=config.observer_backend_type)|Q(backend_type=None)) else: - return parent.get_queryset().filter(Q(backend_type=config.observer_backend_type)|Q(backend_type=None)) + return parent_queryset.filter(Q(backend_type=config.observer_backend_type)|Q(backend_type=None)) # deprecated in django 1.7 in favor of get_queryset(). def get_query_set(self): @@ -119,6 +166,8 @@ class SitePrivilege(PlCoreBase): return qs class Deployment(PlCoreBase): + objects = DeploymentManager() + deleted_objects = DeploymentDeletionManager() name = models.CharField(max_length=200, unique=True, help_text="Name of the Deployment") admin_user = models.CharField(max_length=200, null=True, blank=True, help_text="Username of an admin user at this deployment") admin_password = models.CharField(max_length=200, null=True, blank=True, help_text="Password of theadmin user at this deployment") @@ -171,6 +220,8 @@ class Deployment(PlCoreBase): return Deployment.objects.all() class DeploymentRole(PlCoreBase): + objects = DeploymentLinkManager() + deleted_objects = DeploymentLinkDeletionManager() ROLE_CHOICES = (('admin','Admin'),) role = models.CharField(choices=ROLE_CHOICES, unique=True, max_length=30) @@ -178,6 +229,8 @@ class DeploymentRole(PlCoreBase): def __unicode__(self): return u'%s' % (self.role) class DeploymentPrivilege(PlCoreBase): + objects = DeploymentLinkManager() + deleted_objects = DeploymentLinkDeletionManager() user = models.ForeignKey('User', related_name='deployment_privileges') deployment = models.ForeignKey('Deployment', related_name='deployment_privileges') @@ -206,6 +259,9 @@ class DeploymentPrivilege(PlCoreBase): return qs class SiteDeployments(PlCoreBase): + objects = DeploymentLinkManager() + deleted_objects = DeploymentLinkDeletionManager() + site = models.ForeignKey(Site) deployment = models.ForeignKey(Deployment) tenant_id = models.CharField(null=True, blank=True, max_length=200, help_text="Keystone tenant id")