mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
parent
411c7e22b6
commit
657d9d1f25
1 changed files with 13 additions and 2 deletions
|
@ -98,6 +98,12 @@ options:
|
||||||
required: false
|
required: false
|
||||||
default: 500
|
default: 500
|
||||||
aliases: []
|
aliases: []
|
||||||
|
private_zone:
|
||||||
|
description:
|
||||||
|
- If set to true, the private zone matching the requested name within the domain will be used if there are both public and private zones. The default is to use the public zone.
|
||||||
|
required: false
|
||||||
|
default: false
|
||||||
|
version_added: "1.9"
|
||||||
requirements: [ "boto" ]
|
requirements: [ "boto" ]
|
||||||
author: Bruce Pennypacker
|
author: Bruce Pennypacker
|
||||||
'''
|
'''
|
||||||
|
@ -202,6 +208,7 @@ def main():
|
||||||
value = dict(required=False),
|
value = dict(required=False),
|
||||||
overwrite = dict(required=False, type='bool'),
|
overwrite = dict(required=False, type='bool'),
|
||||||
retry_interval = dict(required=False, default=500)
|
retry_interval = dict(required=False, default=500)
|
||||||
|
private_zone = dict(required=False, type='bool', default=False),
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
module = AnsibleModule(argument_spec=argument_spec)
|
module = AnsibleModule(argument_spec=argument_spec)
|
||||||
|
@ -214,6 +221,7 @@ def main():
|
||||||
value_in = module.params.get('value')
|
value_in = module.params.get('value')
|
||||||
alias_hosted_zone_id_in = module.params.get('alias_hosted_zone_id')
|
alias_hosted_zone_id_in = module.params.get('alias_hosted_zone_id')
|
||||||
retry_interval_in = module.params.get('retry_interval')
|
retry_interval_in = module.params.get('retry_interval')
|
||||||
|
private_zone_in = module.params.get('private_zone')
|
||||||
|
|
||||||
ec2_url, aws_access_key, aws_secret_key, region = get_ec2_creds(module)
|
ec2_url, aws_access_key, aws_secret_key, region = get_ec2_creds(module)
|
||||||
|
|
||||||
|
@ -250,8 +258,11 @@ def main():
|
||||||
zones = {}
|
zones = {}
|
||||||
results = conn.get_all_hosted_zones()
|
results = conn.get_all_hosted_zones()
|
||||||
for r53zone in results['ListHostedZonesResponse']['HostedZones']:
|
for r53zone in results['ListHostedZonesResponse']['HostedZones']:
|
||||||
zone_id = r53zone['Id'].replace('/hostedzone/', '')
|
# only save this zone id if the private status of the zone matches
|
||||||
zones[r53zone['Name']] = zone_id
|
# the private_zone_in boolean specified in the params
|
||||||
|
if module.boolean(r53zone['Config']['PrivateZone']) == private_zone_in:
|
||||||
|
zone_id = r53zone['Id'].replace('/hostedzone/', '')
|
||||||
|
zones[r53zone['Name']] = zone_id
|
||||||
|
|
||||||
# Verify that the requested zone is already defined in Route53
|
# Verify that the requested zone is already defined in Route53
|
||||||
if not zone_in in zones:
|
if not zone_in in zones:
|
||||||
|
|
Loading…
Reference in a new issue