X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=planetstack%2Fcore%2Fmodels%2Fsite.py;h=cc2ad0314871a8450e1572a090b5d8dc4da1fc19;hb=a354d644f199bcebd5ec8d16c40ab42cec43d3e5;hp=69863eb17ebcbe95965e7ef0cc98f2d77aa83fc6;hpb=bc065c0814ab8d5cca3aae3ba25e65d08d79fc1e;p=plstackapi.git diff --git a/planetstack/core/models/site.py b/planetstack/core/models/site.py index 69863eb..cc2ad03 100644 --- a/planetstack/core/models/site.py +++ b/planetstack/core/models/site.py @@ -105,7 +105,7 @@ class Site(PlCoreBase): abbreviated_name = models.CharField(max_length=80) #deployments = models.ManyToManyField('Deployment', blank=True, related_name='sites') - deployments = models.ManyToManyField('Deployment', through='SiteDeployments', blank=True, help_text="Select which sites are allowed to host nodes in this deployment", related_name='sites') + deployments = models.ManyToManyField('Deployment', through='SiteDeployment', blank=True, help_text="Select which sites are allowed to host nodes in this deployment", related_name='sites') tags = generic.GenericRelation(Tag) def __unicode__(self): return u'%s' % (self.name) @@ -263,44 +263,14 @@ class ControllerRole(PlCoreBase): def __unicode__(self): return u'%s' % (self.role) -class ControllerPrivilege(PlCoreBase): - objects = ControllerLinkManager() - deleted_objects = ControllerLinkDeletionManager() - - user = models.ForeignKey('User', related_name='controllerprivileges') - controller = models.ForeignKey('Controller', related_name='controllerprivileges') - role = models.ForeignKey('ControllerRole',related_name='controllerprivileges') - - def __unicode__(self): return u'%s %s %s' % (self.controller, self.user, self.role) - - def can_update(self, user): - if user.is_readonly: - return False - if user.is_admin: - return True - cprivs = ControllerPrivilege.objects.filter(user=user) - for cpriv in dprivs: - if cpriv.role.role == 'admin': - return True - return False - - @staticmethod - def select_by_user(user): - if user.is_admin: - qs = ControllerPrivilege.objects.all() - else: - cpriv_ids = [cp.id for cp in ControllerPrivilege.objects.filter(user=user)] - qs = ControllerPrivilege.objects.filter(id__in=cpriv_ids) - return qs - class Controller(PlCoreBase): objects = ControllerManager() deleted_objects = ControllerDeletionManager() name = models.CharField(max_length=200, unique=True, help_text="Name of the Controller") - version = models.CharField(max_length=200, unique=True, help_text="Controller version") - backend_type = models.CharField(max_length=200, null=True, blank=True, help_text="Type of compute controller, e.g. EC2, OpenStack, or OpenStack version") + backend_type = models.CharField(max_length=200, help_text="Type of compute controller, e.g. EC2, OpenStack, or OpenStack version") + version = models.CharField(max_length=200, help_text="Controller version") auth_url = models.CharField(max_length=200, null=True, blank=True, help_text="Auth url for the compute controller") admin_user = models.CharField(max_length=200, null=True, blank=True, help_text="Username of an admin user at this controller") admin_password = models.CharField(max_length=200, null=True, blank=True, help_text="Password of theadmin user at this controller") @@ -308,7 +278,14 @@ class Controller(PlCoreBase): def __unicode__(self): return u'%s %s %s' % (self.name, self.backend_type, self.version) -class SiteDeployments(PlCoreBase): + def can_update(self, user): + if user.is_readonly: + return False + if user.is_admin: + return True + return False + +class SiteDeployment(PlCoreBase): objects = ControllerLinkManager() deleted_objects = ControllerLinkDeletionManager() @@ -316,6 +293,11 @@ class SiteDeployments(PlCoreBase): deployment = models.ForeignKey(Deployment,related_name='sitedeployments') controller = models.ForeignKey(Controller, null=True, blank=True, related_name='sitedeployments') availability_zone = models.CharField(max_length=200, null=True, blank=True, help_text="OpenStack availability zone") - tenant_id = models.CharField(null=True, blank=True, max_length=200, db_index=True, help_text="Keystone tenant id") def __unicode__(self): return u'%s %s' % (self.deployment, self.site) + +class ControllerSite(PlCoreBase): + + site = models.ForeignKey(Site,related_name='controllersite') + controller = models.ForeignKey(Controller, null=True, blank=True, related_name='controllersite') + tenant_id = models.CharField(null=True, blank=True, max_length=200, db_index=True, help_text="Keystone tenant id")