Skip to content

Commit

Permalink
aws_ec2: fix populating SSM inventory for multiple hosts (#2227)
Browse files Browse the repository at this point in the history
SUMMARY

The function _get_ssm_information() returns dicts with one object. Multiple results cannot be concatenated/merged using d.update() since it will keep overwriting one object.
Concatenate the nested lists instead.
Fixes #2226

ISSUE TYPE

Bugfix Pull Request

COMPONENT NAME

aws_ec2

Reviewed-by: Bikouo Aubin
Reviewed-by: GomathiselviS
(cherry picked from commit f97c56b)
  • Loading branch information
r2bit authored and patchback[bot] committed Jan 8, 2025
1 parent b1b6678 commit 48c9d23
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 4 deletions.
3 changes: 3 additions & 0 deletions changelogs/fragments/2227-fix-ssm-inventory.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
---
bugfixes:
- aws_ec2 - fix SSM inventory collection for multiple (>40) hosts (https://github.com/ansible-collections/amazon.aws/pull/2227).
8 changes: 4 additions & 4 deletions plugins/inventory/aws_ec2.py
Original file line number Diff line number Diff line change
Expand Up @@ -670,17 +670,17 @@ def _add_ssm_information(self, connection, instances):
break

def _get_multiple_ssm_inventories(self, connection, instance_ids):
result = {}
result = []
# SSM inventory filters Values list can contain a maximum of 40 items so we need to retrieve 40 at a time
# https://docs.aws.amazon.com/systems-manager/latest/APIReference/API_InventoryFilter.html
while len(instance_ids) > 40:
filters = [{"Key": "AWS:InstanceInformation.InstanceId", "Values": instance_ids[:40]}]
result.update(_get_ssm_information(connection, filters))
result.extend(_get_ssm_information(connection, filters).get("Entities", []))
instance_ids = instance_ids[40:]
if instance_ids:
filters = [{"Key": "AWS:InstanceInformation.InstanceId", "Values": instance_ids}]
result.update(_get_ssm_information(connection, filters))
return result
result.extend(_get_ssm_information(connection, filters).get("Entities", []))
return {"Entities": result}

def _populate(
self,
Expand Down

0 comments on commit 48c9d23

Please sign in to comment.