X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=planetstack%2Fcore%2Fmodels%2Fsliver.py;h=d2f794f4c9cbf34adedd937ca052e76effc8008c;hb=ac5578b11e845c752b83f44371c8e1dd58f7e22b;hp=601afbb8512526a34a7362331d04762b18913919;hpb=8af38d6d6d4993bce2199aa13ee48873b97ea84f;p=plstackapi.git diff --git a/planetstack/core/models/sliver.py b/planetstack/core/models/sliver.py index 601afbb..d2f794f 100644 --- a/planetstack/core/models/sliver.py +++ b/planetstack/core/models/sliver.py @@ -8,6 +8,7 @@ from core.models import Slice from core.models import Node from core.models import Site from core.models import Deployment +from core.models import Controller from core.models import User from core.models import Tag from core.models import Flavor @@ -17,13 +18,13 @@ from monitor import driver as monitor config = Config() -def get_default_flavor(deployment = None): +def get_default_flavor(controller = None): # Find a default flavor that can be used for a sliver. This is particularly # useful in evolution. It's also intended this helper function can be used # for admin.py when users - if deployment: - flavors = deployment.flavors.all() + if controller: + flavors = controller.flavors.all() else: flavors = Flavor.objects.all() @@ -46,7 +47,7 @@ class SliverDeletionManager(PlCoreBaseDeletionManager): parent_queryset = parent.get_queryset() if hasattr(parent, "get_queryset") else parent.get_query_set() if (backend_type): - return parent_queryset.filter(Q(node__deployment__backend_type=backend_type)) + return parent_queryset.filter(Q(node__controller__backend_type=backend_type)) else: return parent_queryset @@ -67,7 +68,7 @@ class SliverManager(PlCoreBaseManager): parent_queryset = parent.get_queryset() if hasattr(parent, "get_queryset") else parent.get_query_set() if backend_type: - return parent_queryset.filter(Q(node__deployment__backend_type=backend_type)) + return parent_queryset.filter(Q(node__controller__backend_type=backend_type)) else: return parent_queryset @@ -80,6 +81,7 @@ class Sliver(PlCoreBase): objects = SliverManager() deleted_objects = SliverDeletionManager() instance_id = models.CharField(null=True, blank=True, max_length=200, help_text="Nova instance id") + instance_uuid = models.CharField(null=True, blank=True, max_length=200, help_text="Nova instance uuid") name = models.CharField(max_length=200, help_text="Sliver name") instance_name = models.CharField(blank=True, null=True, max_length=200, help_text="OpenStack generated name") ip = models.GenericIPAddressField(help_text="Sliver ip address", blank=True, null=True) @@ -87,8 +89,8 @@ class Sliver(PlCoreBase): #key = models.ForeignKey(Key, related_name='slivers') creator = models.ForeignKey(User, related_name='slivers', blank=True, null=True) slice = models.ForeignKey(Slice, related_name='slivers') + deployment = models.ForeignKey(Deployment, verbose_name='deployment', related_name='sliver_deployment') node = models.ForeignKey(Node, related_name='slivers') - deploymentNetwork = models.ForeignKey(Deployment, verbose_name='deployment', related_name='sliver_deploymentNetwork') numberCores = models.IntegerField(verbose_name="Number of Cores", help_text="Number of cores for sliver", default=0) flavor = models.ForeignKey(Flavor, help_text="Flavor of this instance", default=get_default_flavor) tags = generic.GenericRelation(Tag) @@ -105,14 +107,13 @@ class Sliver(PlCoreBase): return u'unsaved-sliver' def save(self, *args, **kwds): - self.name = self.slice.slicename + self.name = self.slice.name if not self.creator and hasattr(self, 'caller'): self.creator = self.caller - self.deploymentNetwork = self.node.deployment # XXX smbaker - disabled for now, was causing fault in tenant view create slice -# if not self.deploymentNetwork.test_acl(slice=self.slice): -# raise exceptions.ValidationError("Deployment %s's ACL does not allow any of this slice %s's users" % (self.deploymentNetwork.name, self.slice.name)) +# if not self.controllerNetwork.test_acl(slice=self.slice): +# raise exceptions.ValidationError("Deployment %s's ACL does not allow any of this slice %s's users" % (self.controllerNetwork.name, self.slice.name)) super(Sliver, self).save(*args, **kwds)