mirror of
https://github.com/vmware/vsphere-automation-sdk-python.git
synced 2024-11-24 02:19:58 -05:00
aae89a9af0
* Support VMware Cloud on AWS Networking APIs and add a few samples. * Added vsphere_client module to simplify login and API invocation. * Modified existing samples to use vsphere_client. * Update on vm template APIs. Signed-off-by: Tianhao He <het@vmware.com>
163 lines
6.3 KiB
Python
163 lines
6.3 KiB
Python
#!/usr/bin/env python
|
|
|
|
"""
|
|
* *******************************************************
|
|
* Copyright VMware, Inc. 2016-2018. All Rights Reserved.
|
|
* SPDX-License-Identifier: MIT
|
|
* *******************************************************
|
|
*
|
|
* DISCLAIMER. THIS PROGRAM IS PROVIDED TO YOU "AS IS" WITHOUT
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, WHETHER ORAL OR WRITTEN,
|
|
* EXPRESS OR IMPLIED. THE AUTHOR SPECIFICALLY DISCLAIMS ANY IMPLIED
|
|
* WARRANTIES OR CONDITIONS OF MERCHANTABILITY, SATISFACTORY QUALITY,
|
|
* NON-INFRINGEMENT AND FITNESS FOR A PARTICULAR PURPOSE.
|
|
"""
|
|
|
|
__author__ = 'VMware, Inc.'
|
|
__vcenter_version__ = '6.0+'
|
|
|
|
try:
|
|
import urllib2
|
|
except ImportError:
|
|
import urllib.request as urllib2
|
|
|
|
import atexit
|
|
|
|
from com.vmware.vcenter.ovf_client import LibraryItem
|
|
from pyVmomi import vim
|
|
|
|
from samples.vsphere.common import sample_cli
|
|
from samples.vsphere.common import sample_util
|
|
from samples.vsphere.common.id_generator import generate_random_uuid
|
|
from samples.vsphere.common.service_manager import ServiceManager
|
|
from samples.vsphere.common.vim.helpers.vim_utils import (
|
|
get_obj, get_obj_by_moId, poweron_vm, poweroff_vm, delete_object)
|
|
from samples.vsphere.contentlibrary.lib.cls_api_client import ClsApiClient
|
|
from samples.vsphere.contentlibrary.lib.cls_api_helper import ClsApiHelper
|
|
|
|
|
|
class DeployOvfTemplate:
|
|
"""
|
|
Demonstrates the workflow to deploy an OVF library item to a resource pool.
|
|
Note: the sample needs an existing library item with an OVF template
|
|
and an existing cluster with resources for deploying the VM.
|
|
"""
|
|
|
|
def __init__(self):
|
|
self.servicemanager = None
|
|
self.client = None
|
|
self.helper = None
|
|
self.cluster_name = None
|
|
self.lib_item_name = None
|
|
self.vm_obj = None
|
|
self.vm_name = None
|
|
|
|
def setup(self):
|
|
parser = sample_cli.build_arg_parser()
|
|
parser.add_argument('-n', '--vm_name',
|
|
action='store',
|
|
help='Name of the testing vm')
|
|
parser.add_argument('-clustername',
|
|
'--clustername',
|
|
help='The name of the cluster to be used.')
|
|
parser.add_argument('-libitemname',
|
|
'--libitemname',
|
|
help='The name of the library item to deploy.'
|
|
'The library item should contain an OVF package.')
|
|
args = sample_util.process_cli_args(parser.parse_args())
|
|
self.lib_item_name = args.libitemname
|
|
self.cluster_name = args.clustername
|
|
self.vm_name = args.vm_name
|
|
|
|
self.servicemanager = ServiceManager(args.server,
|
|
args.username,
|
|
args.password,
|
|
args.skipverification)
|
|
self.servicemanager.connect()
|
|
atexit.register(self.servicemanager.disconnect)
|
|
|
|
self.client = ClsApiClient(self.servicemanager)
|
|
self.helper = ClsApiHelper(self.client, args.skipverification)
|
|
|
|
# Default VM name
|
|
self.vm_name = 'vm-' + str(generate_random_uuid())
|
|
|
|
def execute(self):
|
|
|
|
# Find the cluster's resource pool moid
|
|
cluster_obj = get_obj(self.servicemanager.content,
|
|
[vim.ClusterComputeResource], self.cluster_name)
|
|
assert cluster_obj is not None
|
|
print("Cluster Moref: {0}".format(cluster_obj))
|
|
|
|
deployment_target = LibraryItem.DeploymentTarget(
|
|
resource_pool_id=cluster_obj.resourcePool._GetMoId())
|
|
lib_item_id = self.helper.get_item_id_by_name(self.lib_item_name)
|
|
assert lib_item_id
|
|
ovf_summary = self.client.ovf_lib_item_service.filter(ovf_library_item_id=lib_item_id,
|
|
target=deployment_target)
|
|
print('Found an OVF template :{0} to deploy.'.format(ovf_summary.name))
|
|
|
|
# Deploy the ovf template
|
|
self.deploy_ovf_template(lib_item_id, ovf_summary, deployment_target)
|
|
|
|
def deploy_ovf_template(self, lib_item_id, ovf_summary, deployment_target):
|
|
# Build the deployment spec
|
|
deployment_spec = LibraryItem.ResourcePoolDeploymentSpec(
|
|
name=self.vm_name,
|
|
annotation=ovf_summary.annotation,
|
|
accept_all_eula=True,
|
|
network_mappings=None,
|
|
storage_mappings=None,
|
|
storage_provisioning=None,
|
|
storage_profile_id=None,
|
|
locale=None,
|
|
flags=None,
|
|
additional_parameters=None,
|
|
default_datastore_id=None)
|
|
|
|
# Deploy the ovf template
|
|
result = self.client.ovf_lib_item_service.deploy(lib_item_id,
|
|
deployment_target,
|
|
deployment_spec,
|
|
client_token=generate_random_uuid())
|
|
|
|
# The type and ID of the target deployment is available in the deployment result.
|
|
if result.succeeded:
|
|
print('Deployment successful. Result resource: {0}, ID: {1}'
|
|
.format(result.resource_id.type, result.resource_id.id))
|
|
self.vm_id = result.resource_id.id
|
|
error = result.error
|
|
if error is not None:
|
|
for warning in error.warnings:
|
|
print('OVF warning: {}'.format(warning.message))
|
|
|
|
# Power on the VM and wait for the power on operation to be completed
|
|
self.vm_obj = get_obj_by_moId(self.servicemanager.content,
|
|
[vim.VirtualMachine], self.vm_id)
|
|
assert self.vm_obj is not None
|
|
poweron_vm(self.servicemanager.content, self.vm_obj)
|
|
|
|
else:
|
|
print('Deployment failed.')
|
|
for error in result.error.errors:
|
|
print('OVF error: {}'.format(error.message))
|
|
|
|
def cleanup(self):
|
|
if self.vm_obj is not None:
|
|
# Power off the VM and wait for the power off operation to complete
|
|
poweroff_vm(self.servicemanager.content, self.vm_obj)
|
|
# Delete the VM
|
|
delete_object(self.servicemanager.content, self.vm_obj)
|
|
|
|
|
|
def main():
|
|
deploy_ovf_sample = DeployOvfTemplate()
|
|
deploy_ovf_sample.setup()
|
|
deploy_ovf_sample.execute()
|
|
deploy_ovf_sample.cleanup()
|
|
|
|
|
|
if __name__ == '__main__':
|
|
main()
|