Sapan Bhatia | 24836f1 | 2013-08-27 10:16:05 -0400 | [diff] [blame] | 1 | import os |
| 2 | import base64 |
Tony Mack | ae7f30c | 2013-09-25 12:46:50 -0400 | [diff] [blame] | 3 | from django.db.models import F, Q |
Sapan Bhatia | 24836f1 | 2013-08-27 10:16:05 -0400 | [diff] [blame] | 4 | from planetstack.config import Config |
Sapan Bhatia | 04c94ad | 2013-09-02 18:00:28 -0400 | [diff] [blame] | 5 | from observer.openstacksyncstep import OpenStackSyncStep |
Tony Mack | 91463d9 | 2014-06-19 20:42:03 -0400 | [diff] [blame] | 6 | from core.models import User, UserDeployments, SitePrivilege, SiteDeployments |
Sapan Bhatia | 24836f1 | 2013-08-27 10:16:05 -0400 | [diff] [blame] | 7 | |
| 8 | class SyncSitePrivileges(OpenStackSyncStep): |
Tony Mack | dacfb98 | 2013-09-24 21:57:16 -0400 | [diff] [blame] | 9 | requested_interval=0 |
| 10 | provides=[SitePrivilege] |
Tony Mack | 66646d5 | 2013-09-24 21:47:12 -0400 | [diff] [blame] | 11 | |
| 12 | def fetch_pending(self): |
Tony Mack | 31078dd | 2013-10-02 12:46:21 -0400 | [diff] [blame] | 13 | return SitePrivilege.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None)) |
Tony Mack | 66646d5 | 2013-09-24 21:47:12 -0400 | [diff] [blame] | 14 | |
Tony Mack | 37146d2 | 2013-10-21 11:02:51 -0400 | [diff] [blame] | 15 | def sync_record(self, site_priv): |
Tony Mack | dacfb98 | 2013-09-24 21:57:16 -0400 | [diff] [blame] | 16 | if site_priv.user.kuser_id and site_priv.site.tenant_id: |
| 17 | self.driver.add_user_role(site_priv.user.kuser_id, |
| 18 | site_priv.site.tenant_id, |
Tony Mack | 0036707 | 2013-10-08 18:09:30 -0400 | [diff] [blame] | 19 | site_priv.role.role) |
Tony Mack | e4be32f | 2014-03-11 20:45:25 -0400 | [diff] [blame] | 20 | |
| 21 | # sync site privileges at all site deployments |
| 22 | site_deployments = SiteDeployments.objects.filter(site=site_priv.site) |
| 23 | for site_deployment in site_deployments: |
| 24 | user_deployments = UserDeployments.objects.filter(deployment=site_deployment.deployment) |
| 25 | if user_deployments: |
| 26 | kuser_id = user_deployments[0].kuser_id |
Tony Mack | f77f140 | 2014-04-02 07:06:53 -0400 | [diff] [blame] | 27 | driver = self.driver.admin_driver(deployment=site_deployment.deployment.name) |
Tony Mack | e4be32f | 2014-03-11 20:45:25 -0400 | [diff] [blame] | 28 | driver.add_user_role(kuser_id, |
| 29 | site_deployment.tenant_id, |
Tony Mack | f77f140 | 2014-04-02 07:06:53 -0400 | [diff] [blame] | 30 | site_priv.role.role) |