3 from collections import defaultdict
4 from django.db import models
5 from django.db.models import F, Q
6 from core.models import PlCoreBase,User,Controller
7 from core.models import Controller,ControllerLinkManager,ControllerLinkDeletionManager
9 class ControllerUser(PlCoreBase):
10 objects = ControllerLinkManager()
11 deleted_objects = ControllerLinkDeletionManager()
13 user = models.ForeignKey(User,related_name='controllerusers')
14 controller = models.ForeignKey(Controller,related_name='controllersusers')
15 kuser_id = models.CharField(null=True, blank=True, max_length=200, help_text="Keystone user id")
17 def __unicode__(self): return u'%s %s' % (self.controller, self.user)
20 def select_by_user(user):
22 qs = ControllerUser.objects.all()
24 users = Users.select_by_user(user)
25 qs = ControllerUser.objects.filter(user__in=users)
29 class ControllerSitePrivilege(PlCoreBase):
30 objects = ControllerLinkManager()
31 deleted_objects = ControllerLinkDeletionManager()
33 controller = models.ForeignKey('Controller', related_name='controllersiteprivileges')
34 site_privilege = models.ForeignKey('SitePrivilege', related_name='controllersiteprivileges')
35 role_id = models.CharField(null=True, blank=True, max_length=200, db_index=True, help_text="Keystone id")
37 def __unicode__(self): return u'%s %s' % (self.controller, self.site_privilege)
39 def can_update(self, user):
44 cprivs = ControllerSitePrivilege.objects.filter(site_privilege__user=user)
46 if cpriv.site_privilege.role.role == ['admin', 'Admin']:
51 def select_by_user(user):
53 qs = ControllerSitePrivilege.objects.all()
55 cpriv_ids = [cp.id for cp in ControllerSitePrivilege.objects.filter(site_privilege__user=user)]
56 qs = ControllerSitePrivilege.objects.filter(id__in=cpriv_ids)
60 class ControllerSlicePrivilege(PlCoreBase):
61 objects = ControllerLinkManager()
62 deleted_objects = ControllerLinkDeletionManager()
64 controller = models.ForeignKey('Controller', related_name='controllersliceprivileges')
65 slice_privilege = models.ForeignKey('SlicePrivilege', related_name='controllersliceprivileges')
66 role_id = models.CharField(null=True, blank=True, max_length=200, db_index=True, help_text="Keystone id")
68 def __unicode__(self): return u'%s %s' % (self.controller, self.slice_privilege)
70 def can_update(self, user):
75 cprivs = ControllerSlicePrivilege.objects.filter(slice_privilege__user=user)
77 if cpriv.role.role == ['admin', 'Admin']:
82 def select_by_user(user):
84 qs = ControllerSlicePrivilege.objects.all()
86 cpriv_ids = [cp.id for cp in ControllerSlicePrivilege.objects.filter(slice_privilege__user=user)]
87 qs = ControllerSlicePrivilege.objects.filter(id__in=cpriv_ids)