mirror of
https://github.com/vmware/vsphere-automation-sdk-python.git
synced 2024-11-25 02:39:59 -05:00
Merge pull request #206 from kunal-pmj/master
Samples for VMC M9 release
This commit is contained in:
commit
f717051643
111
samples/vmc/draas/activate_srm_ops.py
Normal file
111
samples/vmc/draas/activate_srm_ops.py
Normal file
@ -0,0 +1,111 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
* *******************************************************
|
||||||
|
* Copyright (c) VMware, Inc. 2019. 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.'
|
||||||
|
|
||||||
|
import time
|
||||||
|
from samples.vmc.helpers.sample_cli import parser, optional_args
|
||||||
|
|
||||||
|
from vmware.vapi.vmc.vmc_draas_client import create_vmc_draas_client
|
||||||
|
from vmware.vapi.vmc.client import create_vmc_client
|
||||||
|
|
||||||
|
|
||||||
|
class SrmActivationOperations(object):
|
||||||
|
"""
|
||||||
|
Demonstrates VMware Cloud Disaster Recovery As a Service (DRaaS)
|
||||||
|
Site Recovery Manager (SRM) Activation Operations
|
||||||
|
|
||||||
|
Sample Prerequisites:
|
||||||
|
- An organization associated with the calling user.
|
||||||
|
- A SDDC in the organization with SRM Addon activated.
|
||||||
|
- Refresh Token
|
||||||
|
"""
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
optional_args.add_argument('-c', '--cleardata',
|
||||||
|
action='store_true',
|
||||||
|
help='Clean up after sample run')
|
||||||
|
|
||||||
|
args = parser.parse_args()
|
||||||
|
self.org_id = args.org_id
|
||||||
|
self.sddc_id = args.sddc_id
|
||||||
|
self.query_wait_time = 100
|
||||||
|
self.max_wait_time = 900
|
||||||
|
|
||||||
|
self.cleanup = args.cleardata
|
||||||
|
self.vmc_client = create_vmc_client(refresh_token=args.refresh_token)
|
||||||
|
self.draas_client = create_vmc_draas_client(refresh_token=args.refresh_token)
|
||||||
|
|
||||||
|
def setup(self):
|
||||||
|
# Check if the organization exists
|
||||||
|
orgs = self.vmc_client.Orgs.list()
|
||||||
|
if self.org_id not in [org.id for org in orgs]:
|
||||||
|
raise ValueError("Org with ID {} doesn't exist".format(self.org_id))
|
||||||
|
|
||||||
|
# Check if the SDDC exists
|
||||||
|
sddcs = self.vmc_client.orgs.Sddcs.list(self.org_id)
|
||||||
|
if self.sddc_id not in [sddc.id for sddc in sddcs]:
|
||||||
|
raise ValueError("SDDC with ID {} doesn't exist in org {}".
|
||||||
|
format(self.sddc_id, self.org_id))
|
||||||
|
|
||||||
|
# Activate SRM Addon in a SDDC
|
||||||
|
def activate_srm(self):
|
||||||
|
if self.draas_client.SiteRecovery.get(self.org_id, self.sddc_id).site_recovery_state != "ACTIVATED":
|
||||||
|
srm_activation = self.draas_client.SiteRecovery.post(self.org_id,
|
||||||
|
self.sddc_id,
|
||||||
|
activate_site_recovery_config=None)
|
||||||
|
print("Activation of SRM {} : {}".format(srm_activation.status,
|
||||||
|
srm_activation.start_time))
|
||||||
|
self.query_activation_status()
|
||||||
|
else:
|
||||||
|
print("SRM already activated in {}".format(self.sddc_id))
|
||||||
|
|
||||||
|
'''
|
||||||
|
Note: There is no Task API to query activation status, though there is a task structure
|
||||||
|
Hence querying the SRM activation status with resource_id & state for the status.
|
||||||
|
'''
|
||||||
|
def query_activation_status(self):
|
||||||
|
timeout = time.time() + self.max_wait_time
|
||||||
|
while time.time() < timeout:
|
||||||
|
time.sleep(self.query_wait_time)
|
||||||
|
status = self.draas_client.SiteRecovery.get(self.org_id, self.sddc_id)
|
||||||
|
if status.site_recovery_state in ['ACTIVATED', 'DEACTIVATED', 'CANCELLED', 'FAILED']:
|
||||||
|
print("Site Recovery (DRaaS) Activation Status in {} : {}"
|
||||||
|
.format(status.updated, status.site_recovery_state))
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
print("Site Recovery (DRaaS) Activation Status in {} : {}"
|
||||||
|
.format(status.updated, status.site_recovery_state))
|
||||||
|
continue
|
||||||
|
else:
|
||||||
|
raise Exception("Max time out reached {}".format(self.max_wait_time))
|
||||||
|
|
||||||
|
# De-activate SRM Addon in a SDDC. This is a forceful operation as force=True
|
||||||
|
def deactivate_srm(self):
|
||||||
|
if self.cleanup:
|
||||||
|
print("Deactivating SRM")
|
||||||
|
self.draas_client.SiteRecovery.delete(self.org_id,
|
||||||
|
self.sddc_id,
|
||||||
|
force=True)
|
||||||
|
self.query_activation_status()
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
srm_activation_ops = SrmActivationOperations()
|
||||||
|
srm_activation_ops.activate_srm()
|
||||||
|
srm_activation_ops.deactivate_srm()
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
123
samples/vmc/draas/deploy_additional_node.py
Normal file
123
samples/vmc/draas/deploy_additional_node.py
Normal file
@ -0,0 +1,123 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
"""
|
||||||
|
* *******************************************************
|
||||||
|
* Copyright (c) VMware, Inc. 2019. 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.'
|
||||||
|
|
||||||
|
import time
|
||||||
|
from samples.vmc.helpers.sample_cli import parser, optional_args
|
||||||
|
|
||||||
|
from vmware.vapi.vmc.vmc_draas_client import create_vmc_draas_client
|
||||||
|
from vmware.vapi.vmc.client import create_vmc_client
|
||||||
|
from com.vmware.vmc.draas.model_client import ProvisionSrmConfig
|
||||||
|
|
||||||
|
|
||||||
|
class DeployAdditionalNode(object):
|
||||||
|
"""
|
||||||
|
Demonstrates VMware Cloud Disaster Recovery As a Service (DRaaS)
|
||||||
|
Additional Site Recovery Manager (SRM) Node Deployment operations
|
||||||
|
|
||||||
|
Sample Prerequisites:
|
||||||
|
- An organization associated with the calling user.
|
||||||
|
- A SDDC in the organization with SRM Addon activated
|
||||||
|
"""
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
optional_args.add_argument('-c', '--cleardata',
|
||||||
|
action='store_true',
|
||||||
|
help='Clean up after sample run')
|
||||||
|
|
||||||
|
args = parser.parse_args()
|
||||||
|
self.org_id = args.org_id
|
||||||
|
self.sddc_id = args.sddc_id
|
||||||
|
self.wait_time = 100
|
||||||
|
self.max_wait_time = 900
|
||||||
|
self.node_extension_id = 'com.vcDr1'
|
||||||
|
|
||||||
|
self.cleanup = args.cleardata
|
||||||
|
self.vmc_client = create_vmc_client(refresh_token=args.refresh_token)
|
||||||
|
self.draas_client = create_vmc_draas_client(refresh_token=args.refresh_token)
|
||||||
|
|
||||||
|
def setup(self):
|
||||||
|
# Check if the organization exists
|
||||||
|
orgs = self.vmc_client.Orgs.list()
|
||||||
|
if self.org_id not in [org.id for org in orgs]:
|
||||||
|
raise ValueError("Org with ID {} doesn't exist".format(self.org_id))
|
||||||
|
|
||||||
|
# Check if the SDDC exists
|
||||||
|
sddcs = self.vmc_client.orgs.Sddcs.list(self.org_id)
|
||||||
|
if self.sddc_id not in [sddc.id for sddc in sddcs]:
|
||||||
|
raise ValueError("SDDC with ID {} doesn't exist in org {}".
|
||||||
|
format(self.sddc_id, self.org_id))
|
||||||
|
|
||||||
|
# Check if the SRM Add-on is activated in VMC
|
||||||
|
if "ACTIVATED" != self.draas_client.SiteRecovery.get(self.org_id, self.sddc_id).site_recovery_state:
|
||||||
|
raise ValueError("DRaaS is not activated in SDDC with ID {} & org with ID {}".
|
||||||
|
format(self.sddc_id, self.org_id))
|
||||||
|
|
||||||
|
# Deploy Additional SRM Node
|
||||||
|
def deploy_srm(self):
|
||||||
|
deploy_srm = self.draas_client.SiteRecoverySrmNodes.post(
|
||||||
|
self.org_id,
|
||||||
|
self.sddc_id,
|
||||||
|
ProvisionSrmConfig(srm_extension_key_suffix=self.node_extension_id))
|
||||||
|
print('Srm Additional Node Deployment Started {}'.format(deploy_srm.start_time))
|
||||||
|
return deploy_srm.resource_id
|
||||||
|
|
||||||
|
'''
|
||||||
|
Note: There is no Task API to query activation status, though there is a task structure.
|
||||||
|
Hence querying the SRM activation status with resource_id and state for the status.
|
||||||
|
'''
|
||||||
|
def query_deployment(self, deployed_node_id):
|
||||||
|
srm_node_details = self.draas_client.SiteRecovery.get(self.org_id, self.sddc_id).srm_nodes
|
||||||
|
for node_index in range(len(srm_node_details)):
|
||||||
|
if deployed_node_id == srm_node_details[node_index].id:
|
||||||
|
timeout = time.time() + self.max_wait_time
|
||||||
|
while time.time() < timeout:
|
||||||
|
node_details = self.draas_client.SiteRecovery.get(self.org_id, self.sddc_id)
|
||||||
|
time.sleep(self.wait_time)
|
||||||
|
if node_details.srm_nodes[node_index].state in ['READY', 'DELETING', 'CANCELLED', 'FAILED']:
|
||||||
|
print("Site Recovery (DRaaS) Additonal Node Deployment Status {} : {}"
|
||||||
|
.format(node_details.updated,
|
||||||
|
node_details.srm_nodes[node_index].state))
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
print("Site Recovery (DRaaS) Additonal Node Deployment Status {} : {}"
|
||||||
|
.format(node_details.updated,
|
||||||
|
node_details.srm_nodes[node_index].state))
|
||||||
|
continue
|
||||||
|
else:
|
||||||
|
raise Exception("Max time out reached {}".format(self.max_wait_time))
|
||||||
|
node_index += 1
|
||||||
|
|
||||||
|
# Deleting the additional node if with --cleardata flag
|
||||||
|
def delete_node(self, node_id):
|
||||||
|
if self.cleanup:
|
||||||
|
print("Removing the Additional Node")
|
||||||
|
self.draas_client.SiteRecoverySrmNodes.delete(
|
||||||
|
self.org_id,
|
||||||
|
self.sddc_id,
|
||||||
|
node_id)
|
||||||
|
self.query_deployment(node_id)
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
deploy_addtional_nodes = DeployAdditionalNode()
|
||||||
|
deploy_addtional_nodes.setup()
|
||||||
|
srm_node_id = deploy_addtional_nodes.deploy_srm()
|
||||||
|
deploy_addtional_nodes.query_deployment(srm_node_id)
|
||||||
|
deploy_addtional_nodes.delete_node(srm_node_id)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
30
samples/vmc/draas/get_srm_info.py
Normal file
30
samples/vmc/draas/get_srm_info.py
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
import argparse
|
||||||
|
import requests
|
||||||
|
|
||||||
|
from vmware.vapi.vmc.vmc_draas_client import create_vmc_draas_client
|
||||||
|
|
||||||
|
|
||||||
|
parser = argparse.ArgumentParser()
|
||||||
|
parser.add_argument(
|
||||||
|
'--refresh_token',
|
||||||
|
required=True,
|
||||||
|
help='VMware Cloud API refresh token')
|
||||||
|
|
||||||
|
parser.add_argument(
|
||||||
|
'--org_id',
|
||||||
|
required=True,
|
||||||
|
help='Organization identifier.')
|
||||||
|
|
||||||
|
parser.add_argument(
|
||||||
|
'--sddc_id',
|
||||||
|
required=True,
|
||||||
|
help='Sddc Identifier.')
|
||||||
|
|
||||||
|
args = parser.parse_args()
|
||||||
|
refresh_token = args.refresh_token
|
||||||
|
org_id = args.org_id
|
||||||
|
sddc_id = args.sddc_id
|
||||||
|
|
||||||
|
client = create_vmc_draas_client(refresh_token)
|
||||||
|
site_recovery_activation_task = client.SiteRecovery.get(org_id, sddc_id)
|
||||||
|
print(site_recovery_activation_task)
|
76
samples/vsphere/appliances/get_service.py
Normal file
76
samples/vsphere/appliances/get_service.py
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
"""
|
||||||
|
* *******************************************************
|
||||||
|
* Copyright (c) VMware, Inc. 2019. 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.7+'
|
||||||
|
|
||||||
|
import sys
|
||||||
|
from vmware.vapi.vsphere.client import create_vsphere_client
|
||||||
|
|
||||||
|
from samples.vsphere.common import (sample_cli, sample_util)
|
||||||
|
from samples.vsphere.common.ssl_helper import get_unverified_session
|
||||||
|
|
||||||
|
|
||||||
|
"""
|
||||||
|
Description: Demonstrates services api workflow
|
||||||
|
1.Stop a running service
|
||||||
|
2.Get details of stopped service
|
||||||
|
3.Start the service stopped in step 2
|
||||||
|
4.Get details of service
|
||||||
|
5.Restart the service
|
||||||
|
6.Get details of service
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
parser = sample_cli.build_arg_parser()
|
||||||
|
parser.add_argument(
|
||||||
|
'--service_name',
|
||||||
|
action='store',
|
||||||
|
required=True,
|
||||||
|
help='Specify servicename for all stop/start/restart operations')
|
||||||
|
args = sample_util.process_cli_args(parser.parse_args())
|
||||||
|
service_name = args.service_name
|
||||||
|
session = get_unverified_session() if args.skipverification else None
|
||||||
|
client = create_vsphere_client(server=args.server,
|
||||||
|
username=args.username,
|
||||||
|
password=args.password,
|
||||||
|
session=session)
|
||||||
|
|
||||||
|
appliance_service = client.appliance.Services
|
||||||
|
service_list = appliance_service.list()
|
||||||
|
|
||||||
|
|
||||||
|
def ouput_display(info, service_name):
|
||||||
|
print("Service : {}".format(service_name))
|
||||||
|
print("Description : {}".format(info.description))
|
||||||
|
print("state : {}".format(info.state))
|
||||||
|
print("-----------------------------------")
|
||||||
|
|
||||||
|
|
||||||
|
if service_name not in service_list:
|
||||||
|
raise ValueError('Service with service name {} does not exists'.format(service_name))
|
||||||
|
|
||||||
|
print("Example: Stopping service : {}\n".format(service_name))
|
||||||
|
appliance_service.stop(service_name)
|
||||||
|
service_state = appliance_service.get(service_name)
|
||||||
|
ouput_display(service_state, service_name)
|
||||||
|
print("Example: Starting service : {}\n".format(service_name))
|
||||||
|
appliance_service.start(service_name)
|
||||||
|
service_state = appliance_service.get(service_name)
|
||||||
|
ouput_display(service_state, service_name)
|
||||||
|
print("Example: Restarting service : {}\n" .format(service_name))
|
||||||
|
appliance_service.restart(service_name)
|
||||||
|
print("Example: Getting service : {}\n".format(service_name))
|
||||||
|
service_state = appliance_service.get(service_name)
|
||||||
|
ouput_display(service_state, service_name)
|
45
samples/vsphere/appliances/list_service.py
Normal file
45
samples/vsphere/appliances/list_service.py
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
"""
|
||||||
|
* *******************************************************
|
||||||
|
* Copyright (c) VMware, Inc. 2019. 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.7+'
|
||||||
|
|
||||||
|
from vmware.vapi.vsphere.client import create_vsphere_client
|
||||||
|
|
||||||
|
from samples.vsphere.common import (sample_cli, sample_util)
|
||||||
|
from samples.vsphere.common.ssl_helper import get_unverified_session
|
||||||
|
|
||||||
|
|
||||||
|
"""
|
||||||
|
Description: Demonstrates services api workflow
|
||||||
|
1.List all services
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
parser = sample_cli.build_arg_parser()
|
||||||
|
args = sample_util.process_cli_args(parser.parse_args())
|
||||||
|
session = get_unverified_session() if args.skipverification else None
|
||||||
|
client = create_vsphere_client(server=args.server,
|
||||||
|
username=args.username,
|
||||||
|
password=args.password,
|
||||||
|
session=session)
|
||||||
|
|
||||||
|
service_list = client.appliance.Services.list()
|
||||||
|
|
||||||
|
print("Example: List Appliance Services:")
|
||||||
|
print("-------------------\n")
|
||||||
|
for key, values in service_list.items():
|
||||||
|
print("Service Name : {} ".format(key))
|
||||||
|
print("value : {}".format(values.description))
|
||||||
|
print("State: {} \n".format(values.state))
|
Loading…
Reference in New Issue
Block a user