blob: 00c989664d884a2ba7a674d226ea1d7888a28978 [file] [log] [blame]
Sapan Bhatia24836f12013-08-27 10:16:05 -04001import os
2import base64
Tony Mackae7f30c2013-09-25 12:46:50 -04003from django.db.models import F, Q
Sapan Bhatia24836f12013-08-27 10:16:05 -04004from planetstack.config import Config
Sapan Bhatia04c94ad2013-09-02 18:00:28 -04005from observer.openstacksyncstep import OpenStackSyncStep
6from core.models.user import User
Sapan Bhatia24836f12013-08-27 10:16:05 -04007
8class SyncUsers(OpenStackSyncStep):
Tony Mackce79de02013-09-24 10:12:33 -04009 provides=[User]
10 requested_interval=0
Tony Mack66646d52013-09-24 21:47:12 -040011
12 def fetch_pending(self):
13 return User.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None))
14
Tony Mackce79de02013-09-24 10:12:33 -040015 def sync_record(self, user):
16 name = user.email[:user.email.find('@')]
17 user_fields = {'name': name,
18 'email': user.email,
19 'password': hashlib.md5(user.password).hexdigest()[:6],
20 'enabled': True}
21 if not user.kuser_id:
22 keystone_user = self.driver.create_user(**user_fields)
23 user.kuser_id = keystone_user.id
24 else:
25 self.driver.update_user(user.kuser_id, user_fields)
Sapan Bhatia24836f12013-08-27 10:16:05 -040026
Tony Mackce79de02013-09-24 10:12:33 -040027 if user.site:
28 self.driver.add_user_role(user.kuser_id, user.site.tenant_id, 'user')
29 if user.is_admin:
30 self.driver.add_user_role(user.kuser_id, user.site.tenant_id, 'admin')
31 else:
32 # may have admin role so attempt to remove it
33 self.driver.delete_user_role(user.kuser_id, user.site.tenant_id, 'admin')
Sapan Bhatia24836f12013-08-27 10:16:05 -040034
Tony Mackce79de02013-09-24 10:12:33 -040035 if user.public_key:
Tony Mack387a73f2013-09-18 07:59:14 -040036 driver = self.driver.client_driver(caller=user, tenant=user.site.login_base)
37 key_fields = {'name': user.keyname,
38 'public_key': user.public_key}
39 driver.create_keypair(**key_fields)
Sapan Bhatia24836f12013-08-27 10:16:05 -040040
Tony Mackce79de02013-09-24 10:12:33 -040041 user.save()