blob: b4e5049a90711576c317d1a02076f45e9d6217b9 [file] [log] [blame]
Matteo Scandolof5e10332017-08-08 13:05:25 -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
Andy Bavier89a95422016-11-02 14:38:39 -040017import os
18import base64
19from collections import defaultdict
20from netaddr import IPAddress, IPNetwork
21from django.db.models import F, Q
22from xos.config import Config
23from synchronizers.base.syncstep import *
24from core.models import *
Sapan Bhatiab8e981d2017-01-24 19:32:59 +010025from synchronizers.base.ansible_helper import *
Andy Bavier89a95422016-11-02 14:38:39 -040026from xos.logger import observer_logger as logger
27import json
28
29class SyncControllerSlices(SyncStep):
30 provides=[Slice]
31 requested_interval=0
32 observes=ControllerSlice
33 playbook='sync_controller_slices.yaml'
34
35 def map_sync_inputs(self, controller_slice):
36 logger.info("sync'ing slice controller %s" % controller_slice)
37
38 if not controller_slice.controller.admin_user:
39 logger.info("controller %r has no admin_user, skipping" % controller_slice.controller)
40 return
41
42 controller_users = ControllerUser.objects.filter(user=controller_slice.slice.creator,
43 controller=controller_slice.controller)
44 if not controller_users:
45 raise Exception("slice creator %s has not account at controller %s" % (controller_slice.slice.creator, controller_slice.controller.name))
46 else:
47 controller_user = controller_users[0]
48
49 max_instances=int(controller_slice.slice.max_instances)
50 slice_fields = {
51 'endpoint': controller_slice.controller.auth_url,
52 'admin_user': controller_slice.controller.admin_user,
53 'admin_password': controller_slice.controller.admin_password,
54 'slice_name': controller_slice.slice.name,
55 'slice_description': controller_slice.slice.description,
56 'name': controller_user.user.email,
57 'ansible_tag': '%s@%s'%(controller_slice.slice.name,controller_slice.controller.name),
58 'image': controller_slice.slice.default_image.name,
59 'addresses': '10.168.2.0/24', # FIXME
60 'gateway_ip': '10.168.2.1', # FIXME
61 'gateway_mac': '02:42:0a:a8:02:01', # FIXME
62 'max_instances': max_instances
63 }
64
65 return slice_fields
66
67 def map_sync_outputs(self, controller_slice, res):
68 if (not controller_slice.tenant_id):
69 controller_slice.tenant_id = "Not implemented"
70 controller_slice.backend_status = '1 - OK'
71 controller_slice.save()
72
73
74 def map_delete_inputs(self, controller_slice):
75 controller_users = ControllerUser.objects.filter(user=controller_slice.slice.creator,
76 controller=controller_slice.controller)
77 if not controller_users:
78 raise Exception("slice creator %s has not account at controller %s" % (controller_slice.slice.creator, controller_slice.controller.name))
79 else:
80 controller_user = controller_users[0]
81
82 slice_fields = {
83 'endpoint': controller_slice.controller.auth_url,
84 'admin_user': controller_slice.controller.admin_user,
85 'admin_password': controller_slice.controller.admin_password,
86 'slice': controller_slice.slice.name,
87 'slice_description': controller_slice.slice.description,
88 'name': controller_user.user.email,
89 'ansible_tag': '%s@%s'%(controller_slice.slice.name,controller_slice.controller.name),
90 'delete': True
91 }
92 return slice_fields