Sapan Bhatia | 24836f1 | 2013-08-27 10:16:05 -0400 | [diff] [blame] | 1 | import os |
| 2 | import base64 |
Sapan Bhatia | 3346abe | 2015-01-23 16:26:46 +0000 | [diff] [blame] | 3 | import socket |
Tony Mack | ae7f30c | 2013-09-25 12:46:50 -0400 | [diff] [blame] | 4 | from django.db.models import F, Q |
Scott Baker | 86e132c | 2015-02-11 21:38:09 -0800 | [diff] [blame] | 5 | from xos.config import Config |
Scott Baker | 107b3e2 | 2015-03-09 16:24:45 -0700 | [diff] [blame^] | 6 | from xos.settings import RESTAPI_HOSTNAME, RESTAPI_PORT |
Sapan Bhatia | 04c94ad | 2013-09-02 18:00:28 -0400 | [diff] [blame] | 7 | from observer.openstacksyncstep import OpenStackSyncStep |
| 8 | from core.models.sliver import Sliver |
Tony Mack | 3066a95 | 2015-01-05 22:48:11 -0500 | [diff] [blame] | 9 | from core.models.slice import Slice, SlicePrivilege, ControllerSlice |
| 10 | from core.models.network import Network, NetworkSlice, ControllerNetwork |
Tony Mack | fe9d9bd | 2014-04-07 19:46:15 -0400 | [diff] [blame] | 11 | from util.logger import Logger, logging |
Sapan Bhatia | 14356b7 | 2014-11-05 10:32:41 -0500 | [diff] [blame] | 12 | from observer.ansible import * |
Tony Mack | fe9d9bd | 2014-04-07 19:46:15 -0400 | [diff] [blame] | 13 | |
| 14 | logger = Logger(level=logging.INFO) |
Sapan Bhatia | 24836f1 | 2013-08-27 10:16:05 -0400 | [diff] [blame] | 15 | |
Sapan Bhatia | 14356b7 | 2014-11-05 10:32:41 -0500 | [diff] [blame] | 16 | def escape(s): |
| 17 | s = s.replace('\n',r'\n').replace('"',r'\"') |
| 18 | return s |
Sapan | 6a97562 | 2014-12-03 00:01:23 -0500 | [diff] [blame] | 19 | |
Sapan Bhatia | 24836f1 | 2013-08-27 10:16:05 -0400 | [diff] [blame] | 20 | class SyncSlivers(OpenStackSyncStep): |
Tony Mack | dacfb98 | 2013-09-24 21:57:16 -0400 | [diff] [blame] | 21 | provides=[Sliver] |
| 22 | requested_interval=0 |
Sapan Bhatia | 39a775f | 2015-01-29 20:58:25 +0000 | [diff] [blame] | 23 | observes=Sliver |
Tony Mack | 66646d5 | 2013-09-24 21:47:12 -0400 | [diff] [blame] | 24 | |
Scott Baker | db0a110 | 2014-08-08 09:57:28 -0700 | [diff] [blame] | 25 | def get_userdata(self, sliver): |
Scott Baker | 107b3e2 | 2015-03-09 16:24:45 -0700 | [diff] [blame^] | 26 | userdata = 'opencloud:\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)) |
Scott Baker | db0a110 | 2014-08-08 09:57:28 -0700 | [diff] [blame] | 27 | return userdata |
| 28 | |
Tony Mack | 27ec0f5 | 2013-10-16 13:13:32 -0400 | [diff] [blame] | 29 | def sync_record(self, sliver): |
Sapan Bhatia | 6bc4328 | 2014-12-22 13:01:18 -0500 | [diff] [blame] | 30 | logger.info("sync'ing sliver:%s slice:%s controller:%s " % (sliver, sliver.slice.name, sliver.node.site_deployment.controller)) |
Sapan Bhatia | 14356b7 | 2014-11-05 10:32:41 -0500 | [diff] [blame] | 31 | |
Tony Mack | 6fd3ef8 | 2013-10-08 22:17:54 -0400 | [diff] [blame] | 32 | metadata_update = {} |
Sapan | 6a97562 | 2014-12-03 00:01:23 -0500 | [diff] [blame] | 33 | if (sliver.numberCores): |
Tony Mack | 6fd3ef8 | 2013-10-08 22:17:54 -0400 | [diff] [blame] | 34 | metadata_update["cpu_cores"] = str(sliver.numberCores) |
| 35 | |
| 36 | for tag in sliver.slice.tags.all(): |
| 37 | if tag.name.startswith("sysctl-"): |
| 38 | metadata_update[tag.name] = tag.value |
| 39 | |
Sapan Bhatia | 14356b7 | 2014-11-05 10:32:41 -0500 | [diff] [blame] | 40 | # public keys |
| 41 | slice_memberships = SlicePrivilege.objects.filter(slice=sliver.slice) |
| 42 | pubkeys = set([sm.user.public_key for sm in slice_memberships if sm.user.public_key]) |
Sapan | 6a97562 | 2014-12-03 00:01:23 -0500 | [diff] [blame] | 43 | if sliver.creator.public_key: |
| 44 | pubkeys.add(sliver.creator.public_key) |
Tony Mack | ed9925a | 2014-04-14 22:15:02 -0400 | [diff] [blame] | 45 | |
Sapan Bhatia | 14356b7 | 2014-11-05 10:32:41 -0500 | [diff] [blame] | 46 | if sliver.slice.creator.public_key: |
Sapan | 6a97562 | 2014-12-03 00:01:23 -0500 | [diff] [blame] | 47 | pubkeys.add(sliver.slice.creator.public_key) |
Scott Baker | 9c7a1e1 | 2014-05-30 14:42:42 -0700 | [diff] [blame] | 48 | |
Sapan Bhatia | eeaf5fd | 2014-12-22 11:50:47 -0500 | [diff] [blame] | 49 | nics = [] |
| 50 | networks = [ns.network for ns in NetworkSlice.objects.filter(slice=sliver.slice)] |
Tony Mack | 3066a95 | 2015-01-05 22:48:11 -0500 | [diff] [blame] | 51 | controller_networks = ControllerNetwork.objects.filter(network__in=networks, |
Sapan Bhatia | 6bc4328 | 2014-12-22 13:01:18 -0500 | [diff] [blame] | 52 | controller=sliver.node.site_deployment.controller) |
Scott Baker | db0a110 | 2014-08-08 09:57:28 -0700 | [diff] [blame] | 53 | |
Sapan Bhatia | eeaf5fd | 2014-12-22 11:50:47 -0500 | [diff] [blame] | 54 | for controller_network in controller_networks: |
| 55 | if controller_network.network.template.visibility == 'private' and \ |
| 56 | controller_network.network.template.translation == 'none' and controller_network.net_id: |
| 57 | nics.append(controller_network.net_id) |
Sapan Bhatia | 14356b7 | 2014-11-05 10:32:41 -0500 | [diff] [blame] | 58 | |
Sapan | 6a97562 | 2014-12-03 00:01:23 -0500 | [diff] [blame] | 59 | # now include network template |
Scott Baker | 369f9b9 | 2015-01-03 12:03:38 -0800 | [diff] [blame] | 60 | network_templates = [network.template.shared_network_name for network in networks \ |
| 61 | if network.template.shared_network_name] |
Sapan Bhatia | 14356b7 | 2014-11-05 10:32:41 -0500 | [diff] [blame] | 62 | |
Tony Mack | 06c8e47 | 2014-11-30 15:53:08 -0500 | [diff] [blame] | 63 | #driver = self.driver.client_driver(caller=sliver.creator, tenant=sliver.slice.name, controller=sliver.controllerNetwork) |
Tony Mack | 80c4254 | 2015-01-07 12:48:37 -0500 | [diff] [blame] | 64 | driver = self.driver.admin_driver(tenant='admin', controller=sliver.node.site_deployment.controller) |
Sapan Bhatia | eeaf5fd | 2014-12-22 11:50:47 -0500 | [diff] [blame] | 65 | nets = driver.shell.quantum.list_networks()['networks'] |
| 66 | for net in nets: |
| 67 | if net['name'] in network_templates: |
| 68 | nics.append(net['id']) |
Sapan Bhatia | 14356b7 | 2014-11-05 10:32:41 -0500 | [diff] [blame] | 69 | |
Sapan Bhatia | eeaf5fd | 2014-12-22 11:50:47 -0500 | [diff] [blame] | 70 | if (not nics): |
| 71 | for net in nets: |
| 72 | if net['name']=='public': |
| 73 | nics.append(net['id']) |
Sapan Bhatia | 14356b7 | 2014-11-05 10:32:41 -0500 | [diff] [blame] | 74 | |
Sapan Bhatia | eeaf5fd | 2014-12-22 11:50:47 -0500 | [diff] [blame] | 75 | # look up image id |
Tony Mack | 80c4254 | 2015-01-07 12:48:37 -0500 | [diff] [blame] | 76 | controller_driver = self.driver.admin_driver(controller=sliver.node.site_deployment.controller) |
Sapan Bhatia | eeaf5fd | 2014-12-22 11:50:47 -0500 | [diff] [blame] | 77 | image_id = None |
| 78 | images = controller_driver.shell.glanceclient.images.list() |
| 79 | for image in images: |
| 80 | if image.name == sliver.image.name or not image_id: |
| 81 | image_id = image.id |
Sapan Bhatia | 14356b7 | 2014-11-05 10:32:41 -0500 | [diff] [blame] | 82 | |
Sapan Bhatia | eeaf5fd | 2014-12-22 11:50:47 -0500 | [diff] [blame] | 83 | # look up key name at the controller |
| 84 | # create/fetch keypair |
| 85 | keyname = None |
| 86 | keyname = sliver.creator.email.lower().replace('@', 'AT').replace('.', '') +\ |
| 87 | sliver.slice.name |
| 88 | key_fields = {'name': keyname, |
| 89 | 'public_key': sliver.creator.public_key} |
Sapan Bhatia | 14356b7 | 2014-11-05 10:32:41 -0500 | [diff] [blame] | 90 | |
Sapan Bhatia | eeaf5fd | 2014-12-22 11:50:47 -0500 | [diff] [blame] | 91 | try: |
| 92 | legacy = Config().observer_legacy |
| 93 | except: |
| 94 | legacy = False |
| 95 | |
| 96 | if (legacy): |
| 97 | host_filter = sliver.node.name.split('.',1)[0] |
| 98 | else: |
Tony Mack | 7da8d8f | 2015-01-15 13:32:54 -0500 | [diff] [blame] | 99 | host_filter = sliver.node.name.strip() |
Sapan Bhatia | eeaf5fd | 2014-12-22 11:50:47 -0500 | [diff] [blame] | 100 | |
| 101 | availability_zone_filter = 'nova:%s'%host_filter |
| 102 | sliver_name = '%s-%d'%(sliver.slice.name,sliver.id) |
| 103 | |
| 104 | userData = self.get_userdata(sliver) |
| 105 | if sliver.userData: |
| 106 | userData = sliver.userData |
| 107 | |
Tony Mack | 80c4254 | 2015-01-07 12:48:37 -0500 | [diff] [blame] | 108 | controller = sliver.node.site_deployment.controller |
Sapan Bhatia | 6bc4328 | 2014-12-22 13:01:18 -0500 | [diff] [blame] | 109 | tenant_fields = {'endpoint':controller.auth_url, |
Tony Mack | d1275ea | 2015-01-10 22:31:26 -0500 | [diff] [blame] | 110 | 'admin_user': sliver.creator.email, |
Sapan Bhatia | d7750cf | 2015-01-16 22:16:10 +0000 | [diff] [blame] | 111 | 'admin_password': sliver.creator.remote_password, |
Sapan Bhatia | eeaf5fd | 2014-12-22 11:50:47 -0500 | [diff] [blame] | 112 | 'admin_tenant': sliver.slice.name, |
| 113 | 'tenant': sliver.slice.name, |
| 114 | 'tenant_description': sliver.slice.description, |
| 115 | 'name':sliver_name, |
| 116 | 'ansible_tag':sliver_name, |
| 117 | 'availability_zone': availability_zone_filter, |
| 118 | 'image_id':image_id, |
| 119 | 'key_name':keyname, |
Tony Mack | 3f126ae | 2015-01-19 15:19:24 -0500 | [diff] [blame] | 120 | 'flavor_id':sliver.flavor.id, |
Sapan Bhatia | eeaf5fd | 2014-12-22 11:50:47 -0500 | [diff] [blame] | 121 | 'nics':nics, |
| 122 | 'meta':metadata_update, |
| 123 | 'key':key_fields, |
| 124 | 'user_data':r'%s'%escape(userData)} |
| 125 | |
Sapan Bhatia | 3b3e1e1 | 2015-01-23 16:21:57 +0000 | [diff] [blame] | 126 | res = run_template('sync_slivers.yaml', tenant_fields,path='slivers', expected_num=2) |
| 127 | sliver_id = res[1]['info']['OS-EXT-SRV-ATTR:instance_name'] # 0 is for the key |
| 128 | sliver_uuid = res[1]['id'] # 0 is for the key |
Sapan Bhatia | 68b9c1c | 2015-01-20 20:59:24 +0000 | [diff] [blame] | 129 | |
Sapan Bhatia | 3b3e1e1 | 2015-01-23 16:21:57 +0000 | [diff] [blame] | 130 | try: |
| 131 | hostname = res[1]['info']['OS-EXT-SRV-ATTR:hypervisor_hostname'] |
| 132 | ip = socket.gethostbyname(hostname) |
| 133 | sliver.ip = ip |
| 134 | except: |
| 135 | pass |
Sapan Bhatia | 14356b7 | 2014-11-05 10:32:41 -0500 | [diff] [blame] | 136 | |
Sapan Bhatia | 3b3e1e1 | 2015-01-23 16:21:57 +0000 | [diff] [blame] | 137 | sliver.instance_id = sliver_id |
| 138 | sliver.instance_uuid = sliver_uuid |
| 139 | sliver.instance_name = sliver_name |
| 140 | sliver.save() |
Sapan Bhatia | 24836f1 | 2013-08-27 10:16:05 -0400 | [diff] [blame] | 141 | |
Sapan Bhatia | 9650004 | 2014-07-23 09:37:19 -0400 | [diff] [blame] | 142 | def delete_record(self, sliver): |
Sapan Bhatia | 3b3e1e1 | 2015-01-23 16:21:57 +0000 | [diff] [blame] | 143 | sliver_name = '%s-%d'%(sliver.slice.name,sliver.id) |
| 144 | controller = sliver.node.site_deployment.controller |
| 145 | tenant_fields = {'endpoint':controller.auth_url, |
| 146 | 'admin_user': sliver.creator.email, |
| 147 | 'admin_password': sliver.creator.remote_password, |
| 148 | 'admin_tenant': sliver.slice.name, |
| 149 | 'tenant': sliver.slice.name, |
| 150 | 'tenant_description': sliver.slice.description, |
| 151 | 'name':sliver_name, |
| 152 | 'ansible_tag':sliver_name, |
| 153 | 'delete': True} |
| 154 | |
Scott Baker | 107b3e2 | 2015-03-09 16:24:45 -0700 | [diff] [blame^] | 155 | try: |
| 156 | res = run_template('sync_slivers.yaml', tenant_fields,path='slivers', expected_num=1)
|
| 157 | except Exception,e:
|
| 158 | print "Could not sync %s"%sliver_name
|
| 159 | #import traceback
|
| 160 | #traceback.print_exc()
|
| 161 | raise e
|
| 162 | |
Sapan Bhatia | 3b3e1e1 | 2015-01-23 16:21:57 +0000 | [diff] [blame] | 163 | if (len(res)!=1): |
| 164 | raise Exception('Could not delete sliver %s'%sliver.slice.name) |