2017-07-26 17:52:02 +00:00
|
|
|
from django.core.management.base import BaseCommand
|
|
|
|
from opennebula_api.models import OpenNebulaManager
|
|
|
|
from datacenterlight.models import VMTemplate
|
|
|
|
import logging
|
|
|
|
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
class Command(BaseCommand):
|
2018-03-16 08:32:13 +00:00
|
|
|
help = '''Fetches the VM templates from OpenNebula and populates the dcl
|
|
|
|
VMTemplate model'''
|
2017-07-26 17:52:02 +00:00
|
|
|
|
2018-05-23 22:44:53 +00:00
|
|
|
def get_templates(self, manager, prefix):
|
|
|
|
templates = manager.get_templates('%s-' % prefix)
|
|
|
|
dcl_vm_templates = []
|
|
|
|
for template in templates:
|
|
|
|
template_name = template.name.lstrip('%s-' % prefix)
|
|
|
|
template_id = template.id
|
|
|
|
dcl_vm_template = VMTemplate.create(
|
|
|
|
template_name, template_id, prefix
|
|
|
|
)
|
|
|
|
dcl_vm_templates.append(dcl_vm_template)
|
|
|
|
return dcl_vm_templates
|
|
|
|
|
2017-07-26 17:52:02 +00:00
|
|
|
def handle(self, *args, **options):
|
|
|
|
try:
|
|
|
|
manager = OpenNebulaManager()
|
|
|
|
dcl_vm_templates = []
|
2018-05-23 22:44:53 +00:00
|
|
|
dcl_vm_templates.extend(
|
|
|
|
self.get_templates(manager, VMTemplate.PUBLIC)
|
|
|
|
)
|
|
|
|
dcl_vm_templates.extend(
|
|
|
|
self.get_templates(manager, VMTemplate.IPV6)
|
|
|
|
)
|
2017-07-26 17:52:02 +00:00
|
|
|
|
|
|
|
old_vm_templates = VMTemplate.objects.all()
|
|
|
|
old_vm_templates.delete()
|
|
|
|
|
|
|
|
for dcl_vm_template in dcl_vm_templates:
|
|
|
|
dcl_vm_template.save()
|
|
|
|
except Exception as e:
|
2018-03-16 08:32:13 +00:00
|
|
|
logger.error('Error connecting to OpenNebula. Error Details: '
|
|
|
|
'{err}'.format(err=str(e)))
|