mirror of
https://github.com/vmware/vsphere-automation-sdk-python.git
synced 2024-11-23 01:49:59 -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>
138 lines
5.0 KiB
Python
138 lines
5.0 KiB
Python
#!/usr/bin/env python
|
|
|
|
"""
|
|
* *******************************************************
|
|
* Copyright (c) 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.5+'
|
|
|
|
from com.vmware.vcenter.vm.hardware_client import Boot
|
|
from vmware.vapi.vsphere.client import create_vsphere_client
|
|
|
|
from samples.vsphere.common.sample_util import parse_cli_args_vm
|
|
from samples.vsphere.common.sample_util import pp
|
|
from samples.vsphere.vcenter.setup import testbed
|
|
|
|
from samples.vsphere.vcenter.helper.vm_helper import get_vm
|
|
from samples.vsphere.common.ssl_helper import get_unverified_session
|
|
|
|
|
|
"""
|
|
Demonstrates how to configure the settings used when booting a virtual machine.
|
|
|
|
Sample Prerequisites:
|
|
The sample needs an existing VM.
|
|
"""
|
|
|
|
vm = None
|
|
vm_name = None
|
|
client = None
|
|
cleardata = False
|
|
orig_boot_info = None
|
|
|
|
|
|
def setup(context=None):
|
|
global vm, vm_name, client, cleardata
|
|
if context:
|
|
# Run sample suite via setup script
|
|
client = context.client
|
|
vm_name = testbed.config['VM_NAME_DEFAULT']
|
|
else:
|
|
# Run sample in standalone mode
|
|
server, username, password, cleardata, skip_verification, vm_name = \
|
|
parse_cli_args_vm(testbed.config['VM_NAME_DEFAULT'])
|
|
|
|
session = get_unverified_session() if skip_verification else None
|
|
|
|
# Connect to vSphere client
|
|
client = create_vsphere_client(server=server,
|
|
username=username,
|
|
password=password,
|
|
session=session)
|
|
|
|
|
|
def run():
|
|
global vm
|
|
vm = get_vm(client, vm_name)
|
|
if not vm:
|
|
raise Exception('Sample requires an existing vm with name ({}). '
|
|
'Please create the vm first.'.format(vm_name))
|
|
print("Using VM '{}' ({}) for Boot Sample".format(vm_name, vm))
|
|
|
|
print('\n# Example: Get current Boot configuration')
|
|
boot_info = client.vcenter.vm.hardware.Boot.get(vm)
|
|
print('vm.hardware.Boot.get({}) -> {}'.format(vm, pp(boot_info)))
|
|
|
|
# Save current Boot info to verify that we have cleaned up properly
|
|
global orig_boot_info
|
|
orig_boot_info = boot_info
|
|
|
|
print('\n# Example: Update firmware to EFI for Boot configuration')
|
|
update_spec = Boot.UpdateSpec(type=Boot.Type.EFI)
|
|
print('vm.hardware.Boot.update({}, {})'.format(vm, update_spec))
|
|
client.vcenter.vm.hardware.Boot.update(vm, update_spec)
|
|
boot_info = client.vcenter.vm.hardware.Boot.get(vm)
|
|
print('vm.hardware.Boot.get({}) -> {}'.format(vm, pp(boot_info)))
|
|
|
|
print('\n# Example: Update boot firmware to tell it to enter setup mode on '
|
|
'next boot')
|
|
update_spec = Boot.UpdateSpec(enter_setup_mode=True)
|
|
print('vm.hardware.Boot.update({}, {})'.format(vm, update_spec))
|
|
client.vcenter.vm.hardware.Boot.update(vm, update_spec)
|
|
boot_info = client.vcenter.vm.hardware.Boot.get(vm)
|
|
print('vm.hardware.Boot.get({}) -> {}'.format(vm, pp(boot_info)))
|
|
|
|
print('\n# Example: Update boot firmware to introduce a delay in boot'
|
|
' process and to reboot')
|
|
print('# automatically after a failure to boot. '
|
|
'(delay=10000 ms, retry=True,')
|
|
print('# retry_delay=30000 ms')
|
|
update_spec = Boot.UpdateSpec(delay=10000,
|
|
retry=True,
|
|
retry_delay=30000)
|
|
print('vm.hardware.Boot.update({}, {})'.format(vm, update_spec))
|
|
client.vcenter.vm.hardware.Boot.update(vm, update_spec)
|
|
boot_info = client.vcenter.vm.hardware.Boot.get(vm)
|
|
print('vm.hardware.Boot.get({}) -> {}'.format(vm, pp(boot_info)))
|
|
|
|
|
|
def cleanup():
|
|
print('\n# Cleanup: Revert Boot configuration')
|
|
update_spec = \
|
|
Boot.UpdateSpec(type=orig_boot_info.type,
|
|
efi_legacy_boot=orig_boot_info.efi_legacy_boot,
|
|
network_protocol=orig_boot_info.network_protocol,
|
|
delay=orig_boot_info.delay,
|
|
retry=orig_boot_info.retry,
|
|
retry_delay=orig_boot_info.retry_delay,
|
|
enter_setup_mode=orig_boot_info.enter_setup_mode)
|
|
print('vm.hardware.Boot.update({}, {})'.format(vm, update_spec))
|
|
client.vcenter.vm.hardware.Boot.update(vm, update_spec)
|
|
boot_info = client.vcenter.vm.hardware.Boot.get(vm)
|
|
print('vm.hardware.Boot.get({}) -> {}'.format(vm, pp(boot_info)))
|
|
|
|
if boot_info != orig_boot_info:
|
|
print('vm.hardware.Boot WARNING: '
|
|
'Final Boot info does not match original')
|
|
|
|
|
|
def main():
|
|
setup()
|
|
run()
|
|
if cleardata:
|
|
cleanup()
|
|
|
|
|
|
if __name__ == '__main__':
|
|
main()
|