Bug fixes for GCP modules (#60995)

This commit is contained in:
The Magician 2019-08-21 12:31:48 -07:00 committed by ansibot
parent 76cc8e9fc3
commit 21b14d95db
2 changed files with 59 additions and 0 deletions

View file

@ -49,6 +49,13 @@ options:
- absent - absent
default: present default: present
type: str type: str
admin_enabled:
description:
- Whether the VLAN attachment is enabled or disabled. When using PARTNER type
this will Pre-Activate the interconnect attachment .
required: false
type: bool
version_added: 2.9
interconnect: interconnect:
description: description:
- URL of the underlying Interconnect object that this attachment's traffic will - URL of the underlying Interconnect object that this attachment's traffic will
@ -61,6 +68,20 @@ options:
- An optional description of this resource. - An optional description of this resource.
required: false required: false
type: str type: str
bandwidth:
description:
- Provisioned bandwidth capacity for the interconnect attachment.
- For attachments of type DEDICATED, the user can set the bandwidth.
- For attachments of type PARTNER, the Google Partner that is operating the interconnect
must set the bandwidth.
- Output only for PARTNER type, mutable for PARTNER_PROVIDER and DEDICATED, Defaults
to BPS_10G .
- 'Some valid choices include: "BPS_50M", "BPS_100M", "BPS_200M", "BPS_300M",
"BPS_400M", "BPS_500M", "BPS_1G", "BPS_2G", "BPS_5G", "BPS_10G", "BPS_20G",
"BPS_50G"'
required: false
type: str
version_added: 2.9
edge_availability_domain: edge_availability_domain:
description: description:
- Desired availability domain for the attachment. Only available for type PARTNER, - Desired availability domain for the attachment. Only available for type PARTNER,
@ -140,6 +161,12 @@ EXAMPLES = '''
''' '''
RETURN = ''' RETURN = '''
adminEnabled:
description:
- Whether the VLAN attachment is enabled or disabled. When using PARTNER type this
will Pre-Activate the interconnect attachment .
returned: success
type: bool
cloudRouterIpAddress: cloudRouterIpAddress:
description: description:
- IPv4 address + prefix length to be configured on Cloud Router Interface for this - IPv4 address + prefix length to be configured on Cloud Router Interface for this
@ -163,6 +190,16 @@ description:
- An optional description of this resource. - An optional description of this resource.
returned: success returned: success
type: str type: str
bandwidth:
description:
- Provisioned bandwidth capacity for the interconnect attachment.
- For attachments of type DEDICATED, the user can set the bandwidth.
- For attachments of type PARTNER, the Google Partner that is operating the interconnect
must set the bandwidth.
- Output only for PARTNER type, mutable for PARTNER_PROVIDER and DEDICATED, Defaults
to BPS_10G .
returned: success
type: str
edgeAvailabilityDomain: edgeAvailabilityDomain:
description: description:
- Desired availability domain for the attachment. Only available for type PARTNER, - Desired availability domain for the attachment. Only available for type PARTNER,
@ -288,8 +325,10 @@ def main():
module = GcpModule( module = GcpModule(
argument_spec=dict( argument_spec=dict(
state=dict(default='present', choices=['present', 'absent'], type='str'), state=dict(default='present', choices=['present', 'absent'], type='str'),
admin_enabled=dict(type='bool'),
interconnect=dict(type='str'), interconnect=dict(type='str'),
description=dict(type='str'), description=dict(type='str'),
bandwidth=dict(type='str'),
edge_availability_domain=dict(type='str'), edge_availability_domain=dict(type='str'),
type=dict(type='str'), type=dict(type='str'),
router=dict(required=True, type='dict'), router=dict(required=True, type='dict'),
@ -349,8 +388,10 @@ def delete(module, link, kind):
def resource_to_request(module): def resource_to_request(module):
request = { request = {
u'kind': 'compute#interconnectAttachment', u'kind': 'compute#interconnectAttachment',
u'adminEnabled': module.params.get('admin_enabled'),
u'interconnect': module.params.get('interconnect'), u'interconnect': module.params.get('interconnect'),
u'description': module.params.get('description'), u'description': module.params.get('description'),
u'bandwidth': module.params.get('bandwidth'),
u'edgeAvailabilityDomain': module.params.get('edge_availability_domain'), u'edgeAvailabilityDomain': module.params.get('edge_availability_domain'),
u'type': module.params.get('type'), u'type': module.params.get('type'),
u'router': replace_resource_dict(module.params.get(u'router', {}), 'selfLink'), u'router': replace_resource_dict(module.params.get(u'router', {}), 'selfLink'),
@ -422,10 +463,12 @@ def is_different(module, response):
# This is for doing comparisons with Ansible's current parameters. # This is for doing comparisons with Ansible's current parameters.
def response_to_hash(module, response): def response_to_hash(module, response):
return { return {
u'adminEnabled': response.get(u'adminEnabled'),
u'cloudRouterIpAddress': response.get(u'cloudRouterIpAddress'), u'cloudRouterIpAddress': response.get(u'cloudRouterIpAddress'),
u'customerRouterIpAddress': response.get(u'customerRouterIpAddress'), u'customerRouterIpAddress': response.get(u'customerRouterIpAddress'),
u'interconnect': response.get(u'interconnect'), u'interconnect': response.get(u'interconnect'),
u'description': response.get(u'description'), u'description': response.get(u'description'),
u'bandwidth': response.get(u'bandwidth'),
u'edgeAvailabilityDomain': response.get(u'edgeAvailabilityDomain'), u'edgeAvailabilityDomain': response.get(u'edgeAvailabilityDomain'),
u'pairingKey': response.get(u'pairingKey'), u'pairingKey': response.get(u'pairingKey'),
u'partnerAsn': response.get(u'partnerAsn'), u'partnerAsn': response.get(u'partnerAsn'),

View file

@ -73,6 +73,12 @@ resources:
returned: always returned: always
type: complex type: complex
contains: contains:
adminEnabled:
description:
- Whether the VLAN attachment is enabled or disabled. When using PARTNER type
this will Pre-Activate the interconnect attachment .
returned: success
type: bool
cloudRouterIpAddress: cloudRouterIpAddress:
description: description:
- IPv4 address + prefix length to be configured on Cloud Router Interface for - IPv4 address + prefix length to be configured on Cloud Router Interface for
@ -97,6 +103,16 @@ resources:
- An optional description of this resource. - An optional description of this resource.
returned: success returned: success
type: str type: str
bandwidth:
description:
- Provisioned bandwidth capacity for the interconnect attachment.
- For attachments of type DEDICATED, the user can set the bandwidth.
- For attachments of type PARTNER, the Google Partner that is operating the
interconnect must set the bandwidth.
- Output only for PARTNER type, mutable for PARTNER_PROVIDER and DEDICATED,
Defaults to BPS_10G .
returned: success
type: str
edgeAvailabilityDomain: edgeAvailabilityDomain:
description: description:
- Desired availability domain for the attachment. Only available for type PARTNER, - Desired availability domain for the attachment. Only available for type PARTNER,