blob: 8d4a5e08783b3136a85a2706868b10680102f3f8 [file] [log] [blame]
Tony Mack06c8e472014-11-30 15:53:08 -05001import os
2import base64
3from collections import defaultdict
4from netaddr import IPAddress, IPNetwork
5from django.db.models import F, Q
Scott Baker86e132c2015-02-11 21:38:09 -08006from xos.config import Config
Tony Mack06c8e472014-11-30 15:53:08 -05007from observer.openstacksyncstep import OpenStackSyncStep
Sapan Bhatia06b1a882015-05-09 18:14:40 +02008from core.models import *
Tony Mack06c8e472014-11-30 15:53:08 -05009from observer.ansible import *
Tony Mackd96353e2015-01-06 18:27:48 -050010from openstack.driver import OpenStackDriver
Tony Mack4d0d75c2015-03-29 08:32:21 -040011from util.logger import observer_logger as logger
Sapan Bhatia06b1a882015-05-09 18:14:40 +020012import json
Tony Mack06c8e472014-11-30 15:53:08 -050013
Tony Mack74364932015-01-06 17:49:25 -050014class SyncControllerSlices(OpenStackSyncStep):
Sapan Bhatia5d662c72015-01-27 03:52:19 +000015 provides=[Slice]
Tony Mack06c8e472014-11-30 15:53:08 -050016 requested_interval=0
Sapan Bhatia39a775f2015-01-29 20:58:25 +000017 observes=ControllerSlice
Tony Mack06c8e472014-11-30 15:53:08 -050018
19 def fetch_pending(self, deleted):
20 if (deleted):
Tony Mack3066a952015-01-05 22:48:11 -050021 return ControllerSlice.deleted_objects.all()
Tony Mack06c8e472014-11-30 15:53:08 -050022 else:
Tony Mack3066a952015-01-05 22:48:11 -050023 return ControllerSlice.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None))
Tony Mack06c8e472014-11-30 15:53:08 -050024
Tony Mack06c8e472014-11-30 15:53:08 -050025 def sync_record(self, controller_slice):
26 logger.info("sync'ing slice controller %s" % controller_slice)
27
Sapan Bhatia06b1a882015-05-09 18:14:40 +020028 controller_register = json.loads(controller_slice.controller.backend_register)
29 if (controller_register.get('disabled',False)):
30 raise Exception('Controller %s is disabled'%controller_slice.controller.name)
31
Tony Mack06c8e472014-11-30 15:53:08 -050032 if not controller_slice.controller.admin_user:
33 logger.info("controller %r has no admin_user, skipping" % controller_slice.controller)
34 return
35
Tony Mack3066a952015-01-05 22:48:11 -050036 controller_users = ControllerUser.objects.filter(user=controller_slice.slice.creator,
Sapan Bhatia1941de12014-12-22 11:25:31 -050037 controller=controller_slice.controller)
38 if not controller_users:
39 raise Exception("slice createor %s has not accout at controller %s" % (controller_slice.slice.creator, controller_slice.controller.name))
40 else:
41 controller_user = controller_users[0]
Tony Mackd96353e2015-01-06 18:27:48 -050042 roles = ['Admin']
Tony Mack06c8e472014-11-30 15:53:08 -050043
Sapan Bhatia1941de12014-12-22 11:25:31 -050044 max_instances=int(controller_slice.slice.max_slivers)
45 tenant_fields = {'endpoint':controller_slice.controller.auth_url,
46 'admin_user': controller_slice.controller.admin_user,
47 'admin_password': controller_slice.controller.admin_password,
48 'admin_tenant': 'admin',
49 'tenant': controller_slice.slice.name,
50 'tenant_description': controller_slice.slice.description,
51 'roles':roles,
52 'name':controller_user.user.email,
53 'ansible_tag':'%s@%s'%(controller_slice.slice.name,controller_slice.controller.name),
54 'max_instances':max_instances}
55
Sapan Bhatia1941de12014-12-22 11:25:31 -050056 expected_num = len(roles)+1
Sapan Bhatia3b3e1e12015-01-23 16:21:57 +000057 res = run_template('sync_controller_slices.yaml', tenant_fields, path='controller_slices', expected_num=expected_num)
58 tenant_id = res[0]['id']
59 if (not controller_slice.tenant_id):
60 try:
Sapan Bhatiae8d50192015-05-09 18:17:39 +020061 driver = OpenStackDriver().admin_driver(controller=controller_slice.controller)
62 driver.shell.nova.quotas.update(tenant_id=controller_slice.tenant_id, instances=int(controller_slice.slice.max_slivers))
Sapan Bhatia3b3e1e12015-01-23 16:21:57 +000063 except:
Sapan Bhatiae8d50192015-05-09 18:17:39 +020064 logger.log_exc('Could not update quota for %s'%controller_slice.slice.name)
65 raise Exception('Could not update quota for %s'%controller_slice.slice.name)
66
Sapan Bhatia3b3e1e12015-01-23 16:21:57 +000067 controller_slice.tenant_id = tenant_id
Sapan Bhatiac88c9a82015-01-27 03:52:43 +000068 controller_slice.backend_status = '1 - OK'
Sapan Bhatia3b3e1e12015-01-23 16:21:57 +000069 controller_slice.save()
Sapan Bhatia1941de12014-12-22 11:25:31 -050070
Tony Mack06c8e472014-11-30 15:53:08 -050071
Tony Mack06c8e472014-11-30 15:53:08 -050072 def delete_record(self, controller_slice):
Sapan Bhatiae8d50192015-05-09 18:17:39 +020073 controller_register = json.loads(controller_slice.controller.backend_register)
74 if (controller_register.get('disabled',False)):
75 raise Exception('Controller %s is disabled'%controller_slice.controller.name)
Tony Mack06c8e472014-11-30 15:53:08 -050076
Sapan Bhatiae8d50192015-05-09 18:17:39 +020077 controller_users = ControllerUser.objects.filter(user=controller_slice.slice.creator,
78 controller=controller_slice.controller)
79 if not controller_users:
80 raise Exception("slice createor %s has not accout at controller %s" % (controller_slice.slice.creator, controller_slice.controller.name))
81 else:
82 controller_user = controller_users[0]
83
84 tenant_fields = {'endpoint':controller_slice.controller.auth_url,
85 'admin_user': controller_slice.controller.admin_user,
86 'admin_password': controller_slice.controller.admin_password,
87 'admin_tenant': 'admin',
88 'tenant': controller_slice.slice.name,
89 'tenant_description': controller_slice.slice.description,
90 'name':controller_user.user.email,
91 'ansible_tag':'%s@%s'%(controller_slice.slice.name,controller_slice.controller.name),
92 'delete': True}
93
94 expected_num = 1
95 run_template('sync_controller_slices.yaml', tenant_fields, path='controller_slices', expected_num=expected_num)