mirror of
https://github.com/ansible-collections/community.general.git
synced 2025-07-22 12:50:22 -07:00
azure_rm_virtualmachine: Add 'accept_terms' for accepting terms when deploying paid marketplace images (#44701)
azure_rm_storageaccount: Add 'StandardSSD_LRS', and choices to correct unrelated sanity error
This commit is contained in:
parent
5bdcaff921
commit
2541a8c494
6 changed files with 140 additions and 9 deletions
|
@ -51,6 +51,7 @@ options:
|
|||
- Premium_LRS
|
||||
- Standard_GRS
|
||||
- Standard_LRS
|
||||
- StandardSSD_LRS
|
||||
- Standard_RAGRS
|
||||
- Standard_ZRS
|
||||
aliases:
|
||||
|
@ -158,7 +159,8 @@ class AzureRMStorageAccount(AzureRMModuleBase):
|
|||
def __init__(self):
|
||||
|
||||
self.module_arg_spec = dict(
|
||||
account_type=dict(type='str', choices=[], aliases=['type']),
|
||||
account_type=dict(type='str', choices=['Premium_LRS', 'Standard_GRS', 'Standard_LRS', 'StandardSSD_LRS', 'Standard_RAGRS', 'Standard_ZRS'],
|
||||
aliases=['type']),
|
||||
custom_domain=dict(type='dict'),
|
||||
location=dict(type='str'),
|
||||
name=dict(type='str', required=True),
|
||||
|
|
|
@ -284,6 +284,13 @@ options:
|
|||
promotion_code:
|
||||
description:
|
||||
- optional promotion code
|
||||
accept_terms:
|
||||
description:
|
||||
- Accept terms for marketplace images that require it
|
||||
- Only Azure service admin/account admin users can purchase images from the marketplace
|
||||
type: bool
|
||||
default: false
|
||||
version_added: "2.7"
|
||||
|
||||
extends_documentation_fragment:
|
||||
- azure
|
||||
|
@ -292,7 +299,6 @@ extends_documentation_fragment:
|
|||
author:
|
||||
- "Chris Houseknecht (@chouseknecht)"
|
||||
- "Matt Davis (@nitzmahone)"
|
||||
|
||||
'''
|
||||
EXAMPLES = '''
|
||||
|
||||
|
@ -308,21 +314,27 @@ EXAMPLES = '''
|
|||
sku: '7.1'
|
||||
version: latest
|
||||
|
||||
- name: Create an availability set for managed disk vm
|
||||
azure_rm_availabilityset:
|
||||
name: avs-managed-disk
|
||||
resource_group: Testing
|
||||
platform_update_domain_count: 5
|
||||
platform_fault_domain_count: 2
|
||||
sku: Aligned
|
||||
|
||||
- name: Create a VM with managed disk
|
||||
azure_rm_virtualmachine:
|
||||
resource_group: Testing
|
||||
name: testvm001
|
||||
vm_size: Standard_D4
|
||||
managed_disk_type: Standard_LRS
|
||||
name: vm-managed-disk
|
||||
admin_username: adminUser
|
||||
ssh_public_keys:
|
||||
- path: /home/adminUser/.ssh/authorized_keys
|
||||
key_data: < insert yor ssh public key here... >
|
||||
availability_set: avs-managed-disk
|
||||
managed_disk_type: Standard_LRS
|
||||
image:
|
||||
offer: CoreOS
|
||||
publisher: CoreOS
|
||||
sku: Stable
|
||||
version: latest
|
||||
vm_size: Standard_D4
|
||||
|
||||
- name: Create a VM with existing storage account and NIC
|
||||
azure_rm_virtualmachine:
|
||||
|
@ -412,6 +424,35 @@ EXAMPLES = '''
|
|||
name: customimage001
|
||||
resource_group: Testing
|
||||
|
||||
- name: Create VM with spcified OS disk size
|
||||
azure_rm_virtualmachine:
|
||||
resource_group: Testing
|
||||
name: big-os-disk
|
||||
admin_username: chouseknecht
|
||||
admin_password: <your password here>
|
||||
os_disk_size_gb: 512
|
||||
image:
|
||||
offer: CentOS
|
||||
publisher: OpenLogic
|
||||
sku: '7.1'
|
||||
version: latest
|
||||
|
||||
- name: Create VM with OS and Plan, accepting the terms
|
||||
azure_rm_virtualmachine:
|
||||
resource_group: Testing
|
||||
name: f5-nva
|
||||
admin_username: chouseknecht
|
||||
admin_password: <your password here>
|
||||
image:
|
||||
publisher: f5-networks
|
||||
offer: f5-big-ip-best
|
||||
sku: f5-bigip-virtual-edition-200m-best-hourly
|
||||
version: latest
|
||||
plan:
|
||||
name: f5-bigip-virtual-edition-200m-best-hourly
|
||||
product: f5-big-ip-best
|
||||
publisher: f5-networks
|
||||
|
||||
- name: Power Off
|
||||
azure_rm_virtualmachine:
|
||||
resource_group: Testing
|
||||
|
@ -678,7 +719,8 @@ class AzureRMVirtualMachine(AzureRMModuleBase):
|
|||
restarted=dict(type='bool', default=False),
|
||||
started=dict(type='bool', default=True),
|
||||
data_disks=dict(type='list'),
|
||||
plan=dict(type='dict')
|
||||
plan=dict(type='dict'),
|
||||
accept_terms=dict(type='bool', default=False)
|
||||
)
|
||||
|
||||
self.resource_group = None
|
||||
|
@ -716,6 +758,7 @@ class AzureRMVirtualMachine(AzureRMModuleBase):
|
|||
self.differences = None
|
||||
self.data_disks = None
|
||||
self.plan = None
|
||||
self.accept_terms = None
|
||||
|
||||
self.results = dict(
|
||||
changed=False,
|
||||
|
@ -1079,6 +1122,24 @@ class AzureRMVirtualMachine(AzureRMModuleBase):
|
|||
|
||||
vm_resource.storage_profile.data_disks = data_disks
|
||||
|
||||
# Before creating VM accept terms of plan if `accept_terms` is True
|
||||
if self.accept_terms is True:
|
||||
if not all([self.plan.get('name'), self.plan.get('product'), self.plan.get('publisher')]):
|
||||
self.fail("parameter error: plan must be specified and include name, product, and publisher")
|
||||
try:
|
||||
plan_name = self.plan.get('name')
|
||||
plan_product = self.plan.get('product')
|
||||
plan_publisher = self.plan.get('publisher')
|
||||
term = self.marketplace_client.marketplace_agreements.get(
|
||||
publisher_id=plan_publisher, offer_id=plan_product, plan_id=plan_name)
|
||||
term.accepted = True
|
||||
agreement = self.marketplace_client.marketplace_agreements.create(
|
||||
publisher_id=plan_publisher, offer_id=plan_product, plan_id=plan_name, parameters=term)
|
||||
except Exception as exc:
|
||||
self.fail(("Error accepting terms for virtual machine {0} with plan {1}. " +
|
||||
"Only service admin/account admin users can purchase images " +
|
||||
"from the marketplace. - {2}").format(self.name, self.plan, str(exc)))
|
||||
|
||||
self.log("Create virtual machine with parameters:")
|
||||
self.create_or_update_vm(vm_resource)
|
||||
|
||||
|
@ -1483,6 +1544,7 @@ class AzureRMVirtualMachine(AzureRMModuleBase):
|
|||
self.image['offer'],
|
||||
self.image['sku'],
|
||||
self.image['version']))
|
||||
return None
|
||||
|
||||
def get_custom_image_reference(self, name, resource_group=None):
|
||||
try:
|
||||
|
@ -1499,6 +1561,7 @@ class AzureRMVirtualMachine(AzureRMModuleBase):
|
|||
return self.compute_models.ImageReference(id=vm_image.id)
|
||||
|
||||
self.fail("Error could not find image with name {0}".format(name))
|
||||
return None
|
||||
|
||||
def get_availability_set(self, resource_group, name):
|
||||
try:
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue