| import os |
| import base64 |
| from collections import defaultdict |
| from django.db.models import F, Q |
| from xos.config import Config |
| from observer.openstacksyncstep import OpenStackSyncStep |
| from observer.syncstep import * |
| from core.models import Controller |
| from core.models import Image, ControllerImages |
| from util.logger import observer_logger as logger |
| from observer.ansible import * |
| import json |
| |
| class SyncControllerImages(OpenStackSyncStep): |
| provides=[ControllerImages] |
| observes = ControllerImages |
| requested_interval=0 |
| |
| def fetch_pending(self, deleted): |
| if (deleted): |
| return [] |
| |
| # now we return all images that need to be enacted |
| return ControllerImages.objects.filter(Q(enacted__lt=F('updated')) | Q(enacted=None)) |
| |
| def sync_record(self, controller_image): |
| logger.info("Working on image %s on controller %s" % (controller_image.image.name, controller_image.controller)) |
| |
| controller_register = json.loads(controller_image.controller.backend_register) |
| if (controller_register.get('disabled',False)): |
| raise InnocuousException('Controller %s is disabled'%controller_image.controller.name) |
| |
| image_fields = {'endpoint':controller_image.controller.auth_url, |
| 'admin_user':controller_image.controller.admin_user, |
| 'admin_password':controller_image.controller.admin_password, |
| 'name':controller_image.image.name, |
| 'filepath':controller_image.image.path, |
| 'ansible_tag': '%s@%s'%(controller_image.image.name,controller_image.controller.name), # name of ansible playbook |
| } |
| |
| |
| res = run_template('sync_controller_images.yaml', image_fields, path='controller_images', expected_num=1) |
| |
| image_id = res[0]['id'] |
| controller_image.glance_image_id = image_id |
| controller_image.backend_status = '1 - OK' |
| controller_image.save() |