X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=planetstack%2Fcore%2Fmodels%2Fsite.py;h=9f183b5e796954771d59082411bb00fa586e3b49;hb=4df786ffd7b10707a21667dfb4494b1d05ff4eae;hp=04d10737c47305bbf8da4d7a02b7da5defe67007;hpb=cc750d5a502b2c6b1be2939b8d96f5faf6674779;p=plstackapi.git diff --git a/planetstack/core/models/site.py b/planetstack/core/models/site.py index 04d1073..9f183b5 100644 --- a/planetstack/core/models/site.py +++ b/planetstack/core/models/site.py @@ -1,18 +1,28 @@ 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) - 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=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): @@ -22,10 +32,18 @@ class DeploymentLinkDeletionManager(PlCoreBaseDeletionManager): 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=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): @@ -34,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=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): @@ -47,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=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): @@ -140,6 +174,7 @@ class Deployment(PlCoreBase): admin_tenant = models.CharField(max_length=200, null=True, blank=True, help_text="Name of the tenant the admin user belongs to") auth_url = models.CharField(max_length=200, null=True, blank=True, help_text="Auth url for the deployment") backend_type = models.CharField(max_length=200, null=True, blank=True, help_text="Type of deployment, e.g. EC2, OpenStack, or OpenStack version") + availability_zone = models.CharField(max_length=200, null=True, blank=True, help_text="OpenStack availability zone") # smbaker: the default of 'allow all' is intended for evolutions of existing # deployments. When new deployments are created via the GUI, they are @@ -181,13 +216,9 @@ class Deployment(PlCoreBase): def __unicode__(self): return u'%s' % (self.name) - @staticmethod - def select_by_user(user): - return Deployment.objects.all() - class DeploymentRole(PlCoreBase): - objects = DeploymentLinkManager() - deleted_objects = DeploymentLinkDeletionManager() + #objects = DeploymentLinkManager() + #deleted_objects = DeploymentLinkDeletionManager() ROLE_CHOICES = (('admin','Admin'),) role = models.CharField(choices=ROLE_CHOICES, unique=True, max_length=30) @@ -232,10 +263,6 @@ class SiteDeployments(PlCoreBase): deployment = models.ForeignKey(Deployment) tenant_id = models.CharField(null=True, blank=True, max_length=200, help_text="Keystone tenant id") - @staticmethod - def select_by_user(user): - return SiteDeployments.objects.all() - #class Meta: # db_table = 'core_site_deployments' # #auto_created = Site