Wide range of debugging changes
[plstackapi.git] / planetstack / observer / steps / sync_users.py
1 import os
2 import base64
3 from planetstack.config import Config
4 from observer.openstacksyncstep import OpenStackSyncStep
5 from core.models.user import User
6
7 class SyncUsers(OpenStackSyncStep):
8         provides=[User]
9         requested_interval=0
10         def sync_record(self, user):
11                 name = user.email[:user.email.find('@')]
12                 user_fields = {'name': name,
13                                            'email': user.email,
14                                            'password': hashlib.md5(user.password).hexdigest()[:6],
15                                            'enabled': True}
16                 if not user.kuser_id:
17                         keystone_user = self.driver.create_user(**user_fields)
18                         user.kuser_id = keystone_user.id
19                 else:
20                         self.driver.update_user(user.kuser_id, user_fields)             
21
22                 if user.site:
23                         self.driver.add_user_role(user.kuser_id, user.site.tenant_id, 'user')
24                         if user.is_admin:
25                                 self.driver.add_user_role(user.kuser_id, user.site.tenant_id, 'admin')
26                         else:
27                                 # may have admin role so attempt to remove it
28                                 self.driver.delete_user_role(user.kuser_id, user.site.tenant_id, 'admin')
29
30                 if user.public_key:
31                         self.init_caller(user, user.site.login_base)
32                         self.save_key(user.public_key, user.keyname)
33                         self.init_admin()
34
35                 user.save()