fixing bug where if both private_ip and assign_public_p are set ansible fails out

This commit is contained in:
evanccopengeo 2014-04-15 17:55:26 -04:00
parent f547733b1f
commit 88b30a74d2

View file

@ -813,6 +813,15 @@ def create_instances(module, ec2, override_count=None):
module.fail_json( module.fail_json(
msg="assign_public_ip only available with vpc_subnet_id") msg="assign_public_ip only available with vpc_subnet_id")
else:
if private_ip:
interface = boto.ec2.networkinterface.NetworkInterfaceSpecification(
subnet_id=vpc_subnet_id,
private_ip_address=private_ip,
groups=group_id,
associate_public_ip_address=assign_public_ip)
interfaces = boto.ec2.networkinterface.NetworkInterfaceCollection(interface)
params['network_interfaces'] = interfaces
else: else:
interface = boto.ec2.networkinterface.NetworkInterfaceSpecification( interface = boto.ec2.networkinterface.NetworkInterfaceSpecification(
subnet_id=vpc_subnet_id, subnet_id=vpc_subnet_id,
@ -820,7 +829,6 @@ def create_instances(module, ec2, override_count=None):
associate_public_ip_address=assign_public_ip) associate_public_ip_address=assign_public_ip)
interfaces = boto.ec2.networkinterface.NetworkInterfaceCollection(interface) interfaces = boto.ec2.networkinterface.NetworkInterfaceCollection(interface)
params['network_interfaces'] = interfaces params['network_interfaces'] = interfaces
else: else:
params['subnet_id'] = vpc_subnet_id params['subnet_id'] = vpc_subnet_id
if vpc_subnet_id: if vpc_subnet_id:
@ -842,6 +850,14 @@ def create_instances(module, ec2, override_count=None):
# check to see if we're using spot pricing first before starting instances # check to see if we're using spot pricing first before starting instances
if not spot_price: if not spot_price:
if assign_public_ip and private_ip:
params.update(dict(
min_count = count_remaining,
max_count = count_remaining,
client_token = id,
placement_group = placement_group,
))
else:
params.update(dict( params.update(dict(
min_count = count_remaining, min_count = count_remaining,
max_count = count_remaining, max_count = count_remaining,
@ -849,6 +865,7 @@ def create_instances(module, ec2, override_count=None):
placement_group = placement_group, placement_group = placement_group,
private_ip_address = private_ip, private_ip_address = private_ip,
)) ))
res = ec2.run_instances(**params) res = ec2.run_instances(**params)
instids = [ i.id for i in res.instances ] instids = [ i.id for i in res.instances ]
while True: while True: