slices, slice memberships and site privileges work when openstack is disabled or...
[plstackapi.git] / plstackapi / core / models / site.py
1 import os
2 from django.db import models
3 from plstackapi.core.models import PlCoreBase
4 from plstackapi.core.models import DeploymentNetwork
5
6
7 class Site(PlCoreBase):
8
9     tenant_id = models.CharField(max_length=200, help_text="Keystone tenant id")
10     name = models.CharField(max_length=200, help_text="Name for this Site")
11     site_url = models.URLField(null=True, blank=True, max_length=512, help_text="Site's Home URL Page")
12     enabled = models.BooleanField(default=True, help_text="Status for this Site")
13     longitude = models.FloatField(null=True, blank=True)
14     latitude = models.FloatField(null=True, blank=True)
15     login_base = models.CharField(max_length=50, unique=True, help_text="Prefix for Slices associated with this Site")
16     is_public = models.BooleanField(default=True, help_text="Indicates the visibility of this site to other members")
17     abbreviated_name = models.CharField(max_length=80)
18
19     deployments = models.ManyToManyField(DeploymentNetwork, blank=True, related_name='sites')
20
21     def __unicode__(self):  return u'%s' % (self.name)
22
23     def save(self, *args, **kwds):
24         self.os_manager.save_site(self)
25         super(Site, self).save(*args, **kwds)               
26
27
28     def delete(self, *args, **kwds):
29         self.os_manager.delete_site(self)
30         super(Site, self).delete(*args, **kwds)         
31         
32
33 class SitePrivilege(PlCoreBase):
34
35     user = models.ForeignKey('PLUser', related_name='site_privileges')
36     site = models.ForeignKey('Site', related_name='site_privileges')
37     role = models.ForeignKey('Role')
38
39     def __unicode__(self):  return u'%s %s %s' % (self.site, self.user, self.role)
40
41     def save(self, *args, **kwds):
42         self.os_manager.driver.add_user_role(self.user.user_id, self.site.tenant_id, self.role.role_type)
43         super(SitePrivilege, self).save(*args, **kwds)
44
45     def delete(self, *args, **kwds):
46         self.os_manager.driver.delete_user_role(self.user.user_id, self.site.tenant_id, self.role.role_type)
47         super(SitePrivilege, self).delete(*args, **kwds)
48
49