X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=planetstack%2Fcore%2Fmodels%2Fsite.py;h=8a6d7c4dc1d210523f722c013b67b5744a48e91e;hb=567e3e6b85c3d78449ca17a406e09abd488755e3;hp=ebf2ab93f25f8ec712a85204e9a5d348e6be902f;hpb=30fd4291ad7fdb809bb8ebbf738c3195436c2455;p=plstackapi.git diff --git a/planetstack/core/models/site.py b/planetstack/core/models/site.py index ebf2ab9..8a6d7c4 100644 --- a/planetstack/core/models/site.py +++ b/planetstack/core/models/site.py @@ -1,35 +1,29 @@ import os from django.db import models from core.models import PlCoreBase -from core.models import DeploymentNetwork - +from core.models import Deployment +from core.models import Tag +from django.contrib.contenttypes import generic +from geoposition.fields import GeopositionField class Site(PlCoreBase): - tenant_id = models.CharField(max_length=200, help_text="Keystone tenant id") + tenant_id = models.CharField(null=True, blank=True, max_length=200, help_text="Keystone tenant id") name = models.CharField(max_length=200, help_text="Name for this Site") site_url = models.URLField(null=True, blank=True, max_length=512, help_text="Site's Home URL Page") enabled = models.BooleanField(default=True, help_text="Status for this Site") + location = GeopositionField() longitude = models.FloatField(null=True, blank=True) latitude = models.FloatField(null=True, blank=True) login_base = models.CharField(max_length=50, unique=True, help_text="Prefix for Slices associated with this Site") is_public = models.BooleanField(default=True, help_text="Indicates the visibility of this site to other members") abbreviated_name = models.CharField(max_length=80) - deployments = models.ManyToManyField(DeploymentNetwork, blank=True, related_name='sites') + deployments = models.ManyToManyField(Deployment, blank=True, related_name='sites') + tags = generic.GenericRelation(Tag) def __unicode__(self): return u'%s' % (self.name) - def save(self, *args, **kwds): - self.os_manager.save_site(self) - super(Site, self).save(*args, **kwds) - - - def delete(self, *args, **kwds): - self.os_manager.delete_site(self) - super(Site, self).delete(*args, **kwds) - - class SitePrivilege(PlCoreBase): user = models.ForeignKey('User', related_name='site_privileges') @@ -39,11 +33,9 @@ class SitePrivilege(PlCoreBase): def __unicode__(self): return u'%s %s %s' % (self.site, self.user, self.role) def save(self, *args, **kwds): - self.os_manager.driver.add_user_role(self.user.kuser_id, self.site.tenant_id, self.role.role_type) super(SitePrivilege, self).save(*args, **kwds) def delete(self, *args, **kwds): - self.os_manager.driver.delete_user_role(self.user.kuser_id, self.site.tenant_id, self.role.role_type) super(SitePrivilege, self).delete(*args, **kwds)