Add idempotence to ec2_eni when private_ip_address is supplied (#2172)

reviewable/pr18780/r1
Rob 8 years ago committed by René Moser
parent 76dee3d872
commit 8fb8ec2e98

@ -274,9 +274,12 @@ def create_eni(connection, vpc_id, module):
module.exit_json(changed=changed, interface=get_eni_info(eni)) module.exit_json(changed=changed, interface=get_eni_info(eni))
def modify_eni(connection, vpc_id, module): def modify_eni(connection, vpc_id, module, looked_up_eni_id):
eni_id = module.params.get("eni_id") if looked_up_eni_id is None:
eni_id = module.params.get("eni_id")
else:
eni_id = looked_up_eni_id
instance_id = module.params.get("instance_id") instance_id = module.params.get("instance_id")
if instance_id == 'None': if instance_id == 'None':
instance_id = None instance_id = None
@ -413,39 +416,58 @@ def get_sec_group_list(groups):
return remote_security_groups return remote_security_groups
def _get_vpc_id(conn, subnet_id): def _get_vpc_id(connection, module, subnet_id):
try: try:
return conn.get_all_subnets(subnet_ids=[subnet_id])[0].vpc_id return connection.get_all_subnets(subnet_ids=[subnet_id])[0].vpc_id
except BotoServerError as e: except BotoServerError as e:
module.fail_json(msg=e.message) module.fail_json(msg=e.message)
def get_eni_id_by_ip(connection, module):
subnet_id = module.params.get('subnet_id')
private_ip_address = module.params.get('private_ip_address')
try:
all_eni = connection.get_all_network_interfaces(filters={'private-ip-address': private_ip_address, 'subnet-id': subnet_id})
except BotoServerError as e:
module.fail_json(msg=e.message)
if all_eni:
return all_eni[0].id
else:
return None
def main(): def main():
argument_spec = ec2_argument_spec() argument_spec = ec2_argument_spec()
argument_spec.update( argument_spec.update(
dict( dict(
eni_id = dict(default=None), eni_id=dict(default=None, type='str'),
instance_id = dict(default=None), instance_id=dict(default=None, type='str'),
private_ip_address = dict(), private_ip_address=dict(type='str'),
subnet_id = dict(), subnet_id=dict(type='str'),
description = dict(), description=dict(type='str'),
security_groups = dict(type='list'), security_groups=dict(default=[], type='list'),
device_index = dict(default=0, type='int'), device_index=dict(default=0, type='int'),
state = dict(default='present', choices=['present', 'absent']), state=dict(default='present', choices=['present', 'absent']),
force_detach = dict(default='no', type='bool'), force_detach=dict(default='no', type='bool'),
source_dest_check = dict(default=None, type='bool'), source_dest_check=dict(default=None, type='bool'),
delete_on_termination = dict(default=None, type='bool'), delete_on_termination=dict(default=None, type='bool'),
secondary_private_ip_addresses = dict(default=None, type='list'), secondary_private_ip_addresses=dict(default=None, type='list'),
secondary_private_ip_address_count = dict(default=None, type='int') secondary_private_ip_address_count=dict(default=None, type='int')
) )
) )
module = AnsibleModule(argument_spec=argument_spec, module = AnsibleModule(argument_spec=argument_spec,
required_if = ([ mutually_exclusive=[
['secondary_private_ip_addresses', 'secondary_private_ip_address_count']
],
required_if=([
('state', 'present', ['subnet_id']), ('state', 'present', ['subnet_id']),
('state', 'absent', ['eni_id']), ('state', 'absent', ['eni_id']),
]) ])
) )
if not HAS_BOTO: if not HAS_BOTO:
@ -464,22 +486,23 @@ def main():
state = module.params.get("state") state = module.params.get("state")
eni_id = module.params.get("eni_id") eni_id = module.params.get("eni_id")
private_ip_address = module.params.get('private_ip_address')
if state == 'present': if state == 'present':
subnet_id = module.params.get("subnet_id") subnet_id = module.params.get("subnet_id")
vpc_id = _get_vpc_id(vpc_connection, subnet_id) vpc_id = _get_vpc_id(vpc_connection, module, subnet_id)
# If private_ip_address is not None, look up to see if an ENI already exists with that IP
if eni_id is None and private_ip_address is not None:
eni_id = get_eni_id_by_ip(connection, module)
if eni_id is None: if eni_id is None:
create_eni(connection, vpc_id, module) create_eni(connection, vpc_id, module)
else: else:
modify_eni(connection, vpc_id, module) modify_eni(connection, vpc_id, module, eni_id)
elif state == 'absent': elif state == 'absent':
delete_eni(connection, module) delete_eni(connection, module)
from ansible.module_utils.basic import * from ansible.module_utils.basic import *
from ansible.module_utils.ec2 import * from ansible.module_utils.ec2 import *
# this is magic, see lib/ansible/module_common.py
#<<INCLUDE_ANSIBLE_MODULE_COMMON>>
if __name__ == '__main__': if __name__ == '__main__':
main() main()

Loading…
Cancel
Save