1
0
mirror of https://github.com/vmware/vsphere-automation-sdk-python.git synced 2024-11-22 09:39:58 -05:00

add account linking config when creating sddc

Signed-off-by: Tianhao He <het@vmware.com>
This commit is contained in:
Tianhao He 2018-06-15 13:23:07 +08:00
parent 8957cfad5e
commit 6b344229ce

View File

@ -16,14 +16,12 @@
__author__ = 'VMware, Inc.' __author__ = 'VMware, Inc.'
import argparse import argparse
import atexit
import os import os
import requests
from random import randrange from random import randrange
from tabulate import tabulate
from com.vmware.vmc.model_client import AwsSddcConfig, ErrorResponse
from com.vmware.vapi.std.errors_client import InvalidRequest from com.vmware.vapi.std.errors_client import InvalidRequest
from com.vmware.vmc.model_client import AwsSddcConfig, ErrorResponse, AccountLinkSddcConfig, SddcConfig
from tabulate import tabulate
from vmware.vapi.vmc.client import create_vmc_client from vmware.vapi.vmc.client import create_vmc_client
from samples.vmc.helpers.vmc_task_helper import wait_for_task from samples.vmc.helpers.vmc_task_helper import wait_for_task
@ -38,18 +36,6 @@ class CreateDeleteSDDC(object):
""" """
def __init__(self): def __init__(self):
self.org_id = None
self.vmc_client = None
self.sddc_id = None
self.sddc_name = None
self.listsddc = None
self.createsddc = None
self.deletesddc = None
self.cleanup = None
self.refresh_token = None
self.interval_sec = None
def option(self):
parser = argparse.ArgumentParser() parser = argparse.ArgumentParser()
parser.add_argument('-r', '--refresh-token', parser.add_argument('-r', '--refresh-token',
@ -64,6 +50,10 @@ class CreateDeleteSDDC(object):
help="Name of the SDDC to be created. " help="Name of the SDDC to be created. "
"Default is 'Sample SDDC xx'") "Default is 'Sample SDDC xx'")
parser.add_argument('--region',
default='us-west-2',
help='AWS Region')
parser.add_argument('-i', '--interval-sec', parser.add_argument('-i', '--interval-sec',
default=60, default=60,
help='Task pulling interval in sec') help='Task pulling interval in sec')
@ -88,21 +78,19 @@ class CreateDeleteSDDC(object):
self.refresh_token = args.refresh_token self.refresh_token = args.refresh_token
self.org_id = args.org_id self.org_id = args.org_id
self.region = args.region
self.listsddc = args.listsddc self.listsddc = args.listsddc
self.createsddc = args.createsddc self.createsddc = args.createsddc
self.deletesddc = args.deletesddc self.deletesddc = args.deletesddc
self.cleanup = args.cleardata self.cleanup = args.cleardata
self.sddc_id = None
self.sddc_name = args.sddc_name or \ self.sddc_name = args.sddc_name or 'Sample SDDC {}'.format(randrange(100))
'Sample SDDC {}'.format(randrange(100))
self.interval_sec = int(args.interval_sec) self.interval_sec = int(args.interval_sec)
def setup(self):
# Login to VMware Cloud on AWS # Login to VMware Cloud on AWS
session = requests.Session() self.vmc_client = create_vmc_client(self.refresh_token)
self.vmc_client = create_vmc_client(self.refresh_token, session)
atexit.register(session.close) def setup(self):
# Check if the organization exists # Check if the organization exists
orgs = self.vmc_client.Orgs.list() orgs = self.vmc_client.Orgs.list()
@ -113,10 +101,26 @@ class CreateDeleteSDDC(object):
print('\n# Example: Create a SDDC ({}) in org {}:'. print('\n# Example: Create a SDDC ({}) in org {}:'.
format(self.sddc_name, self.org_id)) format(self.sddc_name, self.org_id))
provider = os.environ.get('VMC_PROVIDER', 'AWS') account_id = self.vmc_client.orgs.account_link.ConnectedAccounts.get(
self.org_id)[0].id
vpc_map = self.vmc_client.orgs.account_link.CompatibleSubnets.get(
org=self.org_id,
linked_account_id=account_id).vpc_map
customer_subnet_id = self.get_subnet_id(vpc_map)
if not customer_subnet_id:
raise ValueError('No available subnet for region {}'.format(self.region))
sddc_config = AwsSddcConfig( sddc_config = AwsSddcConfig(
region='US_WEST_2', num_hosts=1, name=self.sddc_name, region=self.region,
provider=provider) name=self.sddc_name,
account_link_sddc_config=[AccountLinkSddcConfig(
customer_subnet_ids=[customer_subnet_id],
connected_account_id=account_id)],
provider=os.environ.get('VMC_PROVIDER', SddcConfig.PROVIDER_AWS),
num_hosts=1,
deployment_type=SddcConfig.DEPLOYMENT_TYPE_SINGLEAZ)
try: try:
task = self.vmc_client.orgs.Sddcs.create(org=self.org_id, task = self.vmc_client.orgs.Sddcs.create(org=self.org_id,
@ -153,8 +157,7 @@ class CreateDeleteSDDC(object):
task_id=task.id, task_id=task.id,
interval_sec=self.interval_sec) interval_sec=self.interval_sec)
print('\n# Example: Remaining SDDCs:'. print('\n# Example: Remaining SDDCs:'.format(self.org_id))
format(self.org_id))
sddcs = self.vmc_client.orgs.Sddcs.list(self.org_id) sddcs = self.vmc_client.orgs.Sddcs.list(self.org_id)
self.print_output(sddcs) self.print_output(sddcs)
@ -172,9 +175,15 @@ class CreateDeleteSDDC(object):
table.append([sddc.id, sddc.name, sddc.resource_config.region]) table.append([sddc.id, sddc.name, sddc.resource_config.region])
print(tabulate(table, ['ID', 'Name', 'AWS Region'])) print(tabulate(table, ['ID', 'Name', 'AWS Region']))
def get_subnet_id(self, vpc_map):
for v in vpc_map.values():
for subnet in v.subnets:
if subnet.region_name.lower() == self.region.lower():
return subnet.subnet_id
def main(): def main():
sddc_operations = CreateDeleteSDDC() sddc_operations = CreateDeleteSDDC()
sddc_operations.option()
sddc_operations.setup() sddc_operations.setup()
if sddc_operations.listsddc: if sddc_operations.listsddc:
sddc_operations.list_sddc() sddc_operations.list_sddc()