In your case, you have just set the splat expression [1] in a wrong place, i.e., instead of setting aws_network_interface.vm_a_eni_lan_a.private_ips[*]
you set it to aws_network_interface.vm_a_eni_lan_a.*.private_ips
. So you only need to change the output value:
output "foo" {
value = {
name = "xyz"
all_ips = aws_network_interface.vm_a_eni_lan_a.private_ips[*]
}
}
EDIT: The above applies when only a single instance of an aws_network_interface
resource is created. For situations where there are multiple instance of this resource created with count
meta-argument, the following can be used to get a list of IPs:
output "foo" {
value = {
name = "xyz"
all_ips = flatten([for i in aws_network_interface.test[*] : i.private_ips[*]])
}
}
Here, the for
[2] loop is used to iterate over all the instances of a resource, hence the splat expression when referencing them aws_network_interface.test[*]
. Additionally, since this will create a list of lists (as private_ips[*]
returns a list), flatten
[3] built-in function can be used to create a single list of IP addresses.
[1] https://www.terraform.io/language/expressions/splat
[2] https://www.terraform.io/language/expressions/for
[3] https://www.terraform.io/language/functions/flatten