X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=planetstack%2Fcore%2Fmodels%2Fslice.py;h=52a5dd6821d95ef870175e0366cf5ee4d052afdd;hb=ea4943318822a4b79dff051a65315c36ce6b8e86;hp=d438bdfde3c6f0227de07f67f9ae603c712f4735;hpb=8a70eb925a6bcbba56ac4b0b02383c2bb6371d67;p=plstackapi.git diff --git a/planetstack/core/models/slice.py b/planetstack/core/models/slice.py index d438bdf..52a5dd6 100644 --- a/planetstack/core/models/slice.py +++ b/planetstack/core/models/slice.py @@ -5,13 +5,13 @@ from core.models import Site from core.models.site import SitePrivilege from core.models import User from core.models import Role -from core.models import Deployment,DeploymentLinkManager,DeploymentLinkDeletionManager +from core.models import Controller,ControllerLinkManager,ControllerLinkDeletionManager from core.models import ServiceClass from core.models.serviceclass import get_default_serviceclass from core.models import Tag from django.contrib.contenttypes import generic from core.models import Service -from core.models import Deployment +from core.models import Controller from django.core.exceptions import ValidationError # Create your models here. @@ -24,15 +24,16 @@ class Slice(PlCoreBase): slice_url = models.URLField(blank=True, max_length=512) site = models.ForeignKey(Site, related_name='slices', help_text="The Site this Slice belongs to") max_slivers = models.IntegerField(default=10) - imagePreference = models.CharField(default="Ubuntu 12.04 LTS", null=True, blank=True, max_length=256) service = models.ForeignKey(Service, related_name='service', null=True, blank=True) network = models.CharField(default="Private Only",null=True, blank=True, max_length=256) - mountDataSets = models.CharField(default="GenBank",null=True, blank=True, max_length=256) tags = generic.GenericRelation(Tag) - serviceClass = models.ForeignKey(ServiceClass, related_name = "slices", null=True, default=get_default_serviceclass) creator = models.ForeignKey(User, related_name='slices', blank=True, null=True) + # for tenant view + image_preference = models.CharField(default="Ubuntu 12.04 LTS", null=True, blank=True, max_length=256) + mount_data_sets = models.CharField(default="GenBank",null=True, blank=True, max_length=256) + def __unicode__(self): return u'%s' % (self.name) @property @@ -92,7 +93,15 @@ class Slice(PlCoreBase): from core.models.network import Network nets = Network.objects.filter(slices=self) nets.delete() - super(SliceAdmin, self).delete(*args, **kwds) + # delete slice controllers + slice_controllers = ControllerSlices.objects.filter(slice=self) + slice_controllers.delete() + # delete slice privilege + slice_privileges = SlicePrivilege.objects.filter(slice=self) + slice_privileges.delete() + # continue with normal delete + super(Slice, self).delete(*args, **kwds) + class SliceRole(PlCoreBase): ROLE_CHOICES = (('admin','Admin'),('default','Default')) @@ -120,24 +129,32 @@ class SlicePrivilege(PlCoreBase): qs = SlicePrivilege.objects.filter(id__in=sp_ids) return qs -class SliceDeployment(PlCoreBase): - objects = DeploymentLinkManager() - deleted_objects = DeploymentLinkDeletionManager() +class ControllerSlices(PlCoreBase): + objects = ControllerLinkManager() + deleted_objects = ControllerLinkDeletionManager() - slice = models.ForeignKey(Slice, related_name='slicedeployments') - deployment = models.ForeignKey(Deployment, related_name='slicedeployments') + controller = models.ForeignKey(Controller, related_name='controllerslices') + slice = models.ForeignKey(Slice, related_name='controllerslices') tenant_id = models.CharField(null=True, blank=True, max_length=200, help_text="Keystone tenant id") - network_id = models.CharField(null=True, blank=True, max_length=256, help_text="Quantum network") - router_id = models.CharField(null=True, blank=True, max_length=256, help_text="Quantum router id") - subnet_id = models.CharField(null=True, blank=True, max_length=256, help_text="Quantum subnet id") - def __unicode__(self): return u'%s %s' % (self.slice, self.deployment) + def __unicode__(self): return u'%s %s' % (self.slice, self.controller) @staticmethod def select_by_user(user): if user.is_admin: - qs = SliceDeployment.objects.all() + qs = ControllerSlices.objects.all() else: slices = Slice.select_by_user(user) - qs = SliceDeployment.objects.filter(slice__in=slices) + qs = ControllerSlices.objects.filter(slice__in=slices) return qs + + def get_cpu_stats(self): + filter = 'project_id=%s'%self.tenant_id + return monitor.get_meter('cpu',filter,None) + + def get_bw_stats(self): + filter = 'project_id=%s'%self.tenant_id + return monitor.get_meter('network.outgoing.bytes',filter,None) + + def get_node_stats(self): + return len(self.slice.slivers)