slice = models.ForeignKey(Slice, related_name='slivers')
node = models.ForeignKey(Node, related_name='slivers')
deploymentNetwork = models.ForeignKey(DeploymentNetwork, verbose_name='deployment', related_name='sliver_deploymentNetwork')
- numberCores = models.IntegerField(verbose_name="Number of Cores", help_text="Number of cores for sliver", default=2)
+ numberCores = models.IntegerField(verbose_name="Number of Cores", help_text="Number of cores for sliver", default=0)
- def __unicode__(self): return u'%s::%s' % (self.slice, self.deploymentNetwork)
+ def __unicode__(self): return u'%s::%s::%s' % (self.deploymentNetwork, self.slice, self.node.name)
def save(self, *args, **kwds):
- if not self.slice.subnet.exists():
- raise exceptions.ValidationError, "Slice %s has no subnet" % self.slice.name
-
- if not self.instance_id:
- instance = self.driver.spawn_instance(name=self.name,
- key_name = self.key.name,
- image_id = self.image.image_id,
- hostname = self.node.name )
- self.instance_id = instance.id
- self.instance_name = getattr(instance, 'OS-EXT-SRV-ATTR:instance_name')
-
+ if not self.name:
+ self.name = self.slice.name
+ self.os_manager.save_sliver(self)
super(Sliver, self).save(*args, **kwds)
def delete(self, *args, **kwds):
- if self.instance_id:
- self.driver.destroy_instance(self.instance_id)
-
+ self.os_manager.delete_sliver(self)
super(Sliver, self).delete(*args, **kwds)