blob: ca0c52ceba3bc423f4fd9baf157797328ab0acc6 [file] [log] [blame]
Sapan Bhatia24836f12013-08-27 10:16:05 -04001import os
2import base64
Sapan Bhatia1e5d3442015-01-23 16:26:46 +00003import socket
Tony Mackae7f30c2013-09-25 12:46:50 -04004from django.db.models import F, Q
Scott Baker76a840e2015-02-11 21:38:09 -08005from xos.config import Config
Scott Baker6861c1f2015-03-09 16:24:45 -07006from xos.settings import RESTAPI_HOSTNAME, RESTAPI_PORT
Sapan Bhatia04c94ad2013-09-02 18:00:28 -04007from observer.openstacksyncstep import OpenStackSyncStep
8from core.models.sliver import Sliver
Tony Macka7dbd422015-01-05 22:48:11 -05009from core.models.slice import Slice, SlicePrivilege, ControllerSlice
10from core.models.network import Network, NetworkSlice, ControllerNetwork
Sapan Bhatia475c5972014-11-05 10:32:41 -050011from observer.ansible import *
Tony Mack08f82882015-03-29 08:32:21 -040012from util.logger import observer_logger as logger
Sapan Bhatia24836f12013-08-27 10:16:05 -040013
Sapan Bhatia475c5972014-11-05 10:32:41 -050014def escape(s):
15 s = s.replace('\n',r'\n').replace('"',r'\"')
16 return s
Sapand1a582d2014-12-03 00:01:23 -050017
Sapan Bhatia24836f12013-08-27 10:16:05 -040018class SyncSlivers(OpenStackSyncStep):
Tony Mackdacfb982013-09-24 21:57:16 -040019 provides=[Sliver]
20 requested_interval=0
Sapan Bhatia99f49682015-01-29 20:58:25 +000021 observes=Sliver
Tony Mack66646d52013-09-24 21:47:12 -040022
Andy Bavierfd0669c2015-03-18 15:59:19 -040023 def get_userdata(self, sliver, pubkeys):
Andy Bavier03d25602015-04-16 13:41:50 -040024 userdata = '#cloud-config\n\nopencloud:\n slicename: "%s"\n hostname: "%s"\n restapi_hostname: "%s"\n restapi_port: "%s"\n' % (sliver.slice.name, sliver.node.name, RESTAPI_HOSTNAME, str(RESTAPI_PORT))
25 userdata += 'ssh_authorized_keys:\n'
Andy Bavierfd0669c2015-03-18 15:59:19 -040026 for key in pubkeys:
27 userdata += ' - %s\n' % key
Scott Bakerdb0a1102014-08-08 09:57:28 -070028 return userdata
29
Tony Mack27ec0f52013-10-16 13:13:32 -040030 def sync_record(self, sliver):
Sapan Bhatia2471d252014-12-22 13:01:18 -050031 logger.info("sync'ing sliver:%s slice:%s controller:%s " % (sliver, sliver.slice.name, sliver.node.site_deployment.controller))
Sapan Bhatia475c5972014-11-05 10:32:41 -050032
Tony Mack6fd3ef82013-10-08 22:17:54 -040033 metadata_update = {}
Sapand1a582d2014-12-03 00:01:23 -050034 if (sliver.numberCores):
Tony Mack6fd3ef82013-10-08 22:17:54 -040035 metadata_update["cpu_cores"] = str(sliver.numberCores)
36
37 for tag in sliver.slice.tags.all():
38 if tag.name.startswith("sysctl-"):
39 metadata_update[tag.name] = tag.value
40
Sapan Bhatia475c5972014-11-05 10:32:41 -050041 # public keys
42 slice_memberships = SlicePrivilege.objects.filter(slice=sliver.slice)
43 pubkeys = set([sm.user.public_key for sm in slice_memberships if sm.user.public_key])
Sapand1a582d2014-12-03 00:01:23 -050044 if sliver.creator.public_key:
45 pubkeys.add(sliver.creator.public_key)
Tony Macked9925a2014-04-14 22:15:02 -040046
Sapan Bhatia475c5972014-11-05 10:32:41 -050047 if sliver.slice.creator.public_key:
Sapand1a582d2014-12-03 00:01:23 -050048 pubkeys.add(sliver.slice.creator.public_key)
Scott Baker9c7a1e12014-05-30 14:42:42 -070049
Scott Baker68944742015-04-30 14:30:56 -070050 if sliver.slice.service and sliver.slice.service.public_key:
51 pubkeys.add(sliver.slice.service.public_key)
52
Sapan Bhatiaf3d21322014-12-22 11:50:47 -050053 nics = []
54 networks = [ns.network for ns in NetworkSlice.objects.filter(slice=sliver.slice)]
Tony Macka7dbd422015-01-05 22:48:11 -050055 controller_networks = ControllerNetwork.objects.filter(network__in=networks,
Sapan Bhatia2471d252014-12-22 13:01:18 -050056 controller=sliver.node.site_deployment.controller)
Scott Bakerdb0a1102014-08-08 09:57:28 -070057
Sapan Bhatiaf3d21322014-12-22 11:50:47 -050058 for controller_network in controller_networks:
59 if controller_network.network.template.visibility == 'private' and \
60 controller_network.network.template.translation == 'none' and controller_network.net_id:
61 nics.append(controller_network.net_id)
Sapan Bhatia475c5972014-11-05 10:32:41 -050062
Sapand1a582d2014-12-03 00:01:23 -050063 # now include network template
Scott Baker81fa17f2015-01-03 12:03:38 -080064 network_templates = [network.template.shared_network_name for network in networks \
65 if network.template.shared_network_name]
Sapan Bhatia475c5972014-11-05 10:32:41 -050066
Tony Mack336e0f92014-11-30 15:53:08 -050067 #driver = self.driver.client_driver(caller=sliver.creator, tenant=sliver.slice.name, controller=sliver.controllerNetwork)
Tony Mackdd8746b2015-01-07 12:48:37 -050068 driver = self.driver.admin_driver(tenant='admin', controller=sliver.node.site_deployment.controller)
Sapan Bhatiaf3d21322014-12-22 11:50:47 -050069 nets = driver.shell.quantum.list_networks()['networks']
70 for net in nets:
71 if net['name'] in network_templates:
72 nics.append(net['id'])
Sapan Bhatia475c5972014-11-05 10:32:41 -050073
Sapan Bhatiaf3d21322014-12-22 11:50:47 -050074 if (not nics):
75 for net in nets:
76 if net['name']=='public':
77 nics.append(net['id'])
Sapan Bhatia475c5972014-11-05 10:32:41 -050078
Scott Baker68944742015-04-30 14:30:56 -070079 image_id = None
80 controller_images = sliver.image.controllerimages.filter(controller=sliver.node.site_deployment.controller)
81 if controller_images:
82 image_id = controller_images[0].glance_image_id
83 logger.info("using image_id from ControllerImage object: " + str(image_id))
84
85 if image_id is None:
Sapan Bhatia84ed9d62015-03-16 12:55:23 -040086 controller_driver = self.driver.admin_driver(controller=sliver.node.site_deployment.controller)
87 image_id = None
88 images = controller_driver.shell.glanceclient.images.list()
89 for image in images:
90 if image.name == sliver.image.name or not image_id:
91 image_id = image.id
Scott Baker68944742015-04-30 14:30:56 -070092 logger.info("using image_id from glance: " + str(image_id))
Sapan Bhatia475c5972014-11-05 10:32:41 -050093
Sapan Bhatiaf3d21322014-12-22 11:50:47 -050094 try:
95 legacy = Config().observer_legacy
96 except:
97 legacy = False
98
99 if (legacy):
100 host_filter = sliver.node.name.split('.',1)[0]
101 else:
Tony Mack95f8e672015-01-15 13:32:54 -0500102 host_filter = sliver.node.name.strip()
Sapan Bhatiaf3d21322014-12-22 11:50:47 -0500103
104 availability_zone_filter = 'nova:%s'%host_filter
105 sliver_name = '%s-%d'%(sliver.slice.name,sliver.id)
106
Andy Bavierfd0669c2015-03-18 15:59:19 -0400107 userData = self.get_userdata(sliver, pubkeys)
Sapan Bhatiaf3d21322014-12-22 11:50:47 -0500108 if sliver.userData:
109 userData = sliver.userData
110
Tony Mackdd8746b2015-01-07 12:48:37 -0500111 controller = sliver.node.site_deployment.controller
Sapan Bhatia2471d252014-12-22 13:01:18 -0500112 tenant_fields = {'endpoint':controller.auth_url,
Tony Mackbf0a90e2015-01-10 22:31:26 -0500113 'admin_user': sliver.creator.email,
Sapan Bhatia740f7ef2015-01-16 22:16:10 +0000114 'admin_password': sliver.creator.remote_password,
Sapan Bhatiaf3d21322014-12-22 11:50:47 -0500115 'admin_tenant': sliver.slice.name,
116 'tenant': sliver.slice.name,
117 'tenant_description': sliver.slice.description,
118 'name':sliver_name,
119 'ansible_tag':sliver_name,
120 'availability_zone': availability_zone_filter,
121 'image_id':image_id,
Tony Mackf210e3d2015-01-19 15:19:24 -0500122 'flavor_id':sliver.flavor.id,
Sapan Bhatiaf3d21322014-12-22 11:50:47 -0500123 'nics':nics,
124 'meta':metadata_update,
Sapan Bhatiaf3d21322014-12-22 11:50:47 -0500125 'user_data':r'%s'%escape(userData)}
126
Andy Bavier87e7a922015-04-17 14:40:57 -0400127 res = run_template('sync_slivers.yaml', tenant_fields,path='slivers', expected_num=1)
128 sliver_id = res[0]['info']['OS-EXT-SRV-ATTR:instance_name']
129 sliver_uuid = res[0]['id']
Sapan Bhatiacb5c24a2015-01-20 20:59:24 +0000130
Sapan Bhatiab0464ba2015-01-23 16:21:57 +0000131 try:
Andy Bavier87e7a922015-04-17 14:40:57 -0400132 hostname = res[0]['info']['OS-EXT-SRV-ATTR:hypervisor_hostname']
Sapan Bhatiab0464ba2015-01-23 16:21:57 +0000133 ip = socket.gethostbyname(hostname)
134 sliver.ip = ip
135 except:
136 pass
Sapan Bhatia475c5972014-11-05 10:32:41 -0500137
Sapan Bhatiab0464ba2015-01-23 16:21:57 +0000138 sliver.instance_id = sliver_id
139 sliver.instance_uuid = sliver_uuid
140 sliver.instance_name = sliver_name
141 sliver.save()
Sapan Bhatia24836f12013-08-27 10:16:05 -0400142
Sapan Bhatia96500042014-07-23 09:37:19 -0400143 def delete_record(self, sliver):
Sapan Bhatiab0464ba2015-01-23 16:21:57 +0000144 sliver_name = '%s-%d'%(sliver.slice.name,sliver.id)
145 controller = sliver.node.site_deployment.controller
146 tenant_fields = {'endpoint':controller.auth_url,
147 'admin_user': sliver.creator.email,
148 'admin_password': sliver.creator.remote_password,
149 'admin_tenant': sliver.slice.name,
150 'tenant': sliver.slice.name,
151 'tenant_description': sliver.slice.description,
152 'name':sliver_name,
153 'ansible_tag':sliver_name,
154 'delete': True}
155
Scott Baker6861c1f2015-03-09 16:24:45 -0700156 try:
157 res = run_template('sync_slivers.yaml', tenant_fields,path='slivers', expected_num=1)
158 except Exception,e:
159 print "Could not sync %s"%sliver_name
160 #import traceback
161 #traceback.print_exc()
162 raise e
163
Sapan Bhatiab0464ba2015-01-23 16:21:57 +0000164 if (len(res)!=1):
165 raise Exception('Could not delete sliver %s'%sliver.slice.name)