mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
ec2_vpc_route_table - Support route propagation through VGW.
Based on work by Bret Martin via pull request #356
This commit is contained in:
parent
b76f9a7eca
commit
dce995e196
1 changed files with 34 additions and 2 deletions
|
@ -54,6 +54,11 @@ options:
|
||||||
''' be specified by subnet ID or by a CIDR such as '10.0.0.0/24'.
|
''' be specified by subnet ID or by a CIDR such as '10.0.0.0/24'.
|
||||||
required: true
|
required: true
|
||||||
aliases: []
|
aliases: []
|
||||||
|
propagating_vgw_ids:
|
||||||
|
description:
|
||||||
|
- Enables route propagation from virtual gateways specified by ID.
|
||||||
|
required: false
|
||||||
|
aliases: []
|
||||||
wait:
|
wait:
|
||||||
description:
|
description:
|
||||||
- wait for the VPC to be in state 'available' before returning
|
- wait for the VPC to be in state 'available' before returning
|
||||||
|
@ -329,6 +334,24 @@ def ensure_subnet_associations(vpc_conn, vpc_id, route_table, subnets,
|
||||||
return {'changed': changed}
|
return {'changed': changed}
|
||||||
|
|
||||||
|
|
||||||
|
def ensure_propagation(vpc_conn, route_table_id, propagating_vgw_ids,
|
||||||
|
check_mode):
|
||||||
|
|
||||||
|
# NOTE: As of boto==2.15.0, it is not yet possible to query the existing
|
||||||
|
# propagating gateways. However, EC2 does support this as evidenced by
|
||||||
|
# the describe-route-tables tool. For now, just enable the given VGWs
|
||||||
|
# and do not disable any others.
|
||||||
|
changed = False
|
||||||
|
for vgw_id in propagating_vgw_ids:
|
||||||
|
if vgw_id not in original_association_ids:
|
||||||
|
changed = True
|
||||||
|
vpc_conn.enable_vgw_route_propagation(route_table_id,
|
||||||
|
vgw_id,
|
||||||
|
test_run=check_mode)
|
||||||
|
|
||||||
|
return {'changed': changed}
|
||||||
|
|
||||||
|
|
||||||
def ensure_route_table_absent(vpc_conn, vpc_id, route_table_id, resource_tags,
|
def ensure_route_table_absent(vpc_conn, vpc_id, route_table_id, resource_tags,
|
||||||
check_mode):
|
check_mode):
|
||||||
if route_table_id:
|
if route_table_id:
|
||||||
|
@ -347,7 +370,8 @@ def ensure_route_table_absent(vpc_conn, vpc_id, route_table_id, resource_tags,
|
||||||
|
|
||||||
|
|
||||||
def ensure_route_table_present(vpc_conn, vpc_id, route_table_id, resource_tags,
|
def ensure_route_table_present(vpc_conn, vpc_id, route_table_id, resource_tags,
|
||||||
routes, subnets, check_mode):
|
routes, subnets, propagating_vgw_ids,
|
||||||
|
check_mode):
|
||||||
changed = False
|
changed = False
|
||||||
tags_valid = False
|
tags_valid = False
|
||||||
if route_table_id:
|
if route_table_id:
|
||||||
|
@ -371,6 +395,12 @@ def ensure_route_table_present(vpc_conn, vpc_id, route_table_id, resource_tags,
|
||||||
.format(route_table_id or resource_tags, e)
|
.format(route_table_id or resource_tags, e)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if propagating_vgw_ids is not None:
|
||||||
|
result = ensure_propagation(vpc_conn, route_table_id,
|
||||||
|
propagating_vgw_ids,
|
||||||
|
check_mode=check_mode)
|
||||||
|
changed = changed or result['changed']
|
||||||
|
|
||||||
if not tags_valid and resource_tags is not None:
|
if not tags_valid and resource_tags is not None:
|
||||||
result = ensure_tags(vpc_conn, route_table.id, resource_tags,
|
result = ensure_tags(vpc_conn, route_table.id, resource_tags,
|
||||||
add_only=True, check_mode=check_mode)
|
add_only=True, check_mode=check_mode)
|
||||||
|
@ -422,6 +452,7 @@ def main():
|
||||||
argument_spec.update({
|
argument_spec.update({
|
||||||
'vpc_id': {'required': True},
|
'vpc_id': {'required': True},
|
||||||
'route_table_id': {'required': False},
|
'route_table_id': {'required': False},
|
||||||
|
'propagating_vgw_ids': {'type': 'list', 'required': False},
|
||||||
'resource_tags': {'type': 'dict', 'required': False},
|
'resource_tags': {'type': 'dict', 'required': False},
|
||||||
'routes': {'type': 'list', 'required': False},
|
'routes': {'type': 'list', 'required': False},
|
||||||
'subnets': {'type': 'list', 'required': False},
|
'subnets': {'type': 'list', 'required': False},
|
||||||
|
@ -450,6 +481,7 @@ def main():
|
||||||
vpc_id = module.params.get('vpc_id')
|
vpc_id = module.params.get('vpc_id')
|
||||||
route_table_id = module.params.get('route_table_id')
|
route_table_id = module.params.get('route_table_id')
|
||||||
resource_tags = module.params.get('resource_tags')
|
resource_tags = module.params.get('resource_tags')
|
||||||
|
propagating_vgw_ids = module.params.get('propagating_vgw_ids', [])
|
||||||
|
|
||||||
routes = module.params.get('routes')
|
routes = module.params.get('routes')
|
||||||
for route_spec in routes:
|
for route_spec in routes:
|
||||||
|
@ -462,7 +494,7 @@ def main():
|
||||||
if state == 'present':
|
if state == 'present':
|
||||||
result = ensure_route_table_present(
|
result = ensure_route_table_present(
|
||||||
vpc_conn, vpc_id, route_table_id, resource_tags,
|
vpc_conn, vpc_id, route_table_id, resource_tags,
|
||||||
routes, subnets, module.check_mode
|
routes, subnets, propagating_vgw_ids, module.check_mode
|
||||||
)
|
)
|
||||||
elif state == 'absent':
|
elif state == 'absent':
|
||||||
result = ensure_route_table_absent(
|
result = ensure_route_table_absent(
|
||||||
|
|
Loading…
Reference in a new issue