ec2_vpc_route_table - Support route propagation through VGW.

Based on work by Bret Martin via pull request #356
This commit is contained in:
Robert Estelle 2014-12-01 15:56:04 -05:00 committed by Matt Clay
parent b76f9a7eca
commit dce995e196

View file

@ -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(