cloudcafe/cloudcafe/compute/hypervisors/xenserver/client.py

116 lines
3.4 KiB
Python

"""
Copyright 2013 Rackspace
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
"""
import XenAPI
from cafe.common.reporting import cclogging
from cafe.engine.clients.base import BaseClient
from cloudcafe.compute.hypervisors.xenserver.models.virtual_machine \
import VirtualMachine, VirtualBlockDevice, VirtualDiskImage
def _log_failure(log):
def _decorator(func):
def _wrapper(*args, **kwargs):
try:
response = func(*args, **kwargs)
except XenAPI.Failure as exception:
log.error(exception)
raise exception
return response
return _wrapper
return _decorator
class XenAPIClient(BaseClient):
_log = cclogging.getLogger(__name__)
def __init__(self, url=None, username=None, password=None):
"""
Initialization
@param url: URL for the target XenServer instance
@type url: string
@param username: Username used to connect to XenServer
@type username: string
@param password: Password for the provided username
@type password: string
"""
self.session = XenAPI.Session(url)
self.session.xenapi.login_with_password(username, password)
@_log_failure(log=_log)
def get_vm_record(self, server_id):
"""
Retrieves a VM Record for the given Compute uuid
@param server_id: The uuid of the Compute instance
@type server_id: string
@rtype: VirtualMachine
"""
vm = self._get_vm_by_compute_id(server_id)
record = self.session.xenapi.VM.get_record(vm)
virtual_machine = VirtualMachine._dict_to_obj(**record)
return virtual_machine
@_log_failure(log=_log)
def get_vbd_record(self, vbd):
"""
Retrieves a VBD Record
@param vbd: The OpaqueRef of the VBD
@type vbd: string
@rtype: VirtualBlockDevice
"""
record = self.session.xenapi.VBD.get_record(vbd)
block_device = VirtualBlockDevice._dict_to_obj(record)
return block_device
@_log_failure(log=_log)
def get_vdi_record(self, vdi):
"""
Retrieves a VDI Record
@param vdi: The OpaqueRef of the VDI
@type vdi: string
@rtype: VirtualDiskImage
"""
record = self.session.xenapi.VDI.get_record(vdi)
vdi = VirtualDiskImage._dict_to_obj(record)
return vdi
@_log_failure(log=_log)
def _get_vm_by_compute_id(self, server_id):
"""
Retrieves VM given a Compute uuid
@param server_id: The Compute uuid of an instance
@type server_id: string
@rtype: VM
"""
expected_vm_name = 'instance-{uuid}'.format(uuid=server_id)
virtual_machines = self.session.xenapi.VM.get_all()
for vm in virtual_machines:
vm_name = self.session.xenapi.VM.get_name_label(vm)
if expected_vm_name == vm_name:
return vm
return None