blob: 1481fb04887fd41d920f5e5e45e7dea1d63a30f3 [file] [log] [blame]
Matteo Scandolof0441032017-08-08 13:05:26 -07001
2# Copyright 2017-present Open Networking Foundation
3#
4# Licensed under the Apache License, Version 2.0 (the "License");
5# you may not use this file except in compliance with the License.
6# You may obtain a copy of the License at
7#
8# http://www.apache.org/licenses/LICENSE-2.0
9#
10# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS,
12# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13# See the License for the specific language governing permissions and
14# limitations under the License.
15
16
Scott Bakerb63ea792016-08-11 10:24:48 -070017import os
18import base64
Scott Bakerc808c672019-02-04 11:38:20 -080019from openstacksyncstep import OpenStackSyncStep
20from xossynchronizer.modelaccessor import *
21from xosconfig import Config
22from multistructlog import create_logger
23
24log = create_logger(Config().get('logging'))
25
Scott Bakerb63ea792016-08-11 10:24:48 -070026
27class SyncControllerSlices(OpenStackSyncStep):
28 provides=[Slice]
29 requested_interval=0
30 observes=ControllerSlice
31 playbook='sync_controller_slices.yaml'
32
33 def map_sync_inputs(self, controller_slice):
Scott Bakerc808c672019-02-04 11:38:20 -080034 log.info("sync'ing slice controller %s" % controller_slice)
Scott Bakerb63ea792016-08-11 10:24:48 -070035
36 if not controller_slice.controller.admin_user:
Scott Bakerc808c672019-02-04 11:38:20 -080037 log.info("controller %r has no admin_user, skipping" % controller_slice.controller)
Scott Bakerb63ea792016-08-11 10:24:48 -070038 return
39
Scott Bakeraf599eb2017-03-21 12:43:26 -070040 controller_users = ControllerUser.objects.filter(user_id=controller_slice.slice.creator.id,
41 controller_id=controller_slice.controller.id)
Scott Bakerb63ea792016-08-11 10:24:48 -070042 if not controller_users:
43 raise Exception("slice createor %s has not accout at controller %s" % (controller_slice.slice.creator, controller_slice.controller.name))
44 else:
45 controller_user = controller_users[0]
Scott Baker04a37f52016-08-11 10:52:21 -070046 driver = self.driver.admin_driver(controller=controller_slice.controller)
Scott Bakerb63ea792016-08-11 10:24:48 -070047 roles = [driver.get_admin_role().name]
48
49 max_instances=int(controller_slice.slice.max_instances)
50 tenant_fields = {'endpoint':controller_slice.controller.auth_url,
51 'endpoint_v3': controller_slice.controller.auth_url_v3,
52 'domain': controller_slice.controller.domain,
53 'admin_user': controller_slice.controller.admin_user,
54 'admin_password': controller_slice.controller.admin_password,
Zack Williams9cb1f3a2017-08-20 19:35:03 -070055 'admin_project': 'admin',
56 'project': controller_slice.slice.name,
57 'project_description': controller_slice.slice.description,
Scott Bakerb63ea792016-08-11 10:24:48 -070058 'roles':roles,
Zack Williams9cb1f3a2017-08-20 19:35:03 -070059 'username':controller_user.user.email,
Scott Bakerb63ea792016-08-11 10:24:48 -070060 'ansible_tag':'%s@%s'%(controller_slice.slice.name,controller_slice.controller.name),
61 'max_instances':max_instances}
62
63 return tenant_fields
64
65 def map_sync_outputs(self, controller_slice, res):
Zack Williams2b1f7f82017-08-28 11:45:55 -070066 tenant_id = res[0]['project']['id']
Scott Bakerb63ea792016-08-11 10:24:48 -070067 if (not controller_slice.tenant_id):
68 try:
Scott Baker04a37f52016-08-11 10:52:21 -070069 driver = self.driver.admin_driver(controller=controller_slice.controller)
Scott Bakerb63ea792016-08-11 10:24:48 -070070 driver.shell.nova.quotas.update(tenant_id=tenant_id, instances=int(controller_slice.slice.max_instances))
71 except:
Scott Bakerc808c672019-02-04 11:38:20 -080072 log.exception('Could not update quota for %s'%controller_slice.slice.name)
Scott Bakerb63ea792016-08-11 10:24:48 -070073 raise Exception('Could not update quota for %s'%controller_slice.slice.name)
74
75 controller_slice.tenant_id = tenant_id
Sapan Bhatiab9e504c2017-08-29 18:39:53 -040076 controller_slice.backend_status = 'OK'
77 controller_slice.backend_code = 1
Scott Bakerb63ea792016-08-11 10:24:48 -070078 controller_slice.save()
79
80
81 def map_delete_inputs(self, controller_slice):
Scott Bakeraf599eb2017-03-21 12:43:26 -070082 controller_users = ControllerUser.objects.filter(user_id=controller_slice.slice.creator.id,
83 controller_id=controller_slice.controller.id)
Scott Bakerb63ea792016-08-11 10:24:48 -070084 if not controller_users:
85 raise Exception("slice createor %s has not accout at controller %s" % (controller_slice.slice.creator, controller_slice.controller.name))
86 else:
87 controller_user = controller_users[0]
88
89 tenant_fields = {'endpoint':controller_slice.controller.auth_url,
Andy Bavier66f9f342018-04-12 16:16:03 -070090 'endpoint_v3': controller_slice.controller.auth_url_v3,
91 'domain': controller_slice.controller.domain,
Scott Bakerb63ea792016-08-11 10:24:48 -070092 'admin_user': controller_slice.controller.admin_user,
93 'admin_password': controller_slice.controller.admin_password,
Sapan Bhatia9d52a3a2017-09-15 00:52:42 -040094 'admin_project': 'admin',
95 'project': controller_slice.slice.name,
96 'project_description': controller_slice.slice.description,
Scott Bakerb63ea792016-08-11 10:24:48 -070097 'name':controller_user.user.email,
98 'ansible_tag':'%s@%s'%(controller_slice.slice.name,controller_slice.controller.name),
99 'delete': True}
100 return tenant_fields