X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=planetstack%2Fcore%2Fmodels%2Fsliver.py;h=4d89d9fac5479b20e4f3ac77621668dce1dc5e02;hb=bfb2b549ada86ce85fc0d87b1e00fdfc7ecb9fa4;hp=c4789d6839d920d0ea645d1fcbd6bfb4101ab090;hpb=284d284866cf41070e866436f3693f9e749d1952;p=plstackapi.git diff --git a/planetstack/core/models/sliver.py b/planetstack/core/models/sliver.py index c4789d6..4d89d9f 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() @@ -87,8 +88,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 +106,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)