From 4477af7f9000302d8dfba1c47fdbffc143c10d72 Mon Sep 17 00:00:00 2001 From: Ondra Machacek Date: Mon, 3 Jun 2019 11:00:31 +0200 Subject: [PATCH] ovirt: Resolve also list of hrefs --- .../ovirt_fetch_also_list_of_hrefs.yaml | 3 ++ lib/ansible/module_utils/ovirt.py | 31 +++++++++++-------- 2 files changed, 21 insertions(+), 13 deletions(-) create mode 100644 changelogs/fragments/ovirt_fetch_also_list_of_hrefs.yaml diff --git a/changelogs/fragments/ovirt_fetch_also_list_of_hrefs.yaml b/changelogs/fragments/ovirt_fetch_also_list_of_hrefs.yaml new file mode 100644 index 00000000000..52194652455 --- /dev/null +++ b/changelogs/fragments/ovirt_fetch_also_list_of_hrefs.yaml @@ -0,0 +1,3 @@ +--- +minor_changes: + - When using `fetch_nested` fetch also list of href, instead only single object hrefs. diff --git a/lib/ansible/module_utils/ovirt.py b/lib/ansible/module_utils/ovirt.py index 711ecf0e466..4b2b48526c5 100644 --- a/lib/ansible/module_utils/ovirt.py +++ b/lib/ansible/module_utils/ovirt.py @@ -61,6 +61,20 @@ def get_dict_of_struct(struct, connection=None, fetch_nested=False, attributes=N """ res = {} + def resolve_href(value): + # Fetch nested values of struct: + try: + value = connection.follow_link(value) + except sdk.Error: + value = None + nested_obj = dict( + (attr, convert_value(getattr(value, attr))) + for attr in attributes if getattr(value, attr, None) + ) + nested_obj['id'] = getattr(value, 'id', None) + nested_obj['href'] = getattr(value, 'href', None) + return nested_obj + def remove_underscore(val): if val.startswith('_'): val = val[1:] @@ -73,19 +87,8 @@ def get_dict_of_struct(struct, connection=None, fetch_nested=False, attributes=N if isinstance(value, sdk.Struct): if not fetch_nested or not value.href: return get_dict_of_struct(value) + return resolve_href(value) - # Fetch nested values of struct: - try: - value = connection.follow_link(value) - except sdk.Error: - value = None - nested_obj = dict( - (attr, convert_value(getattr(value, attr))) - for attr in attributes if getattr(value, attr, None) - ) - nested_obj['id'] = getattr(value, 'id', None) - nested_obj['href'] = getattr(value, 'href', None) - return nested_obj elif isinstance(value, Enum) or isinstance(value, datetime): return str(value) elif isinstance(value, list) or isinstance(value, sdk.List): @@ -99,7 +102,9 @@ def get_dict_of_struct(struct, connection=None, fetch_nested=False, attributes=N ret = [] for i in value: if isinstance(i, sdk.Struct): - if not nested: + if fetch_nested and i.href: + ret.append(resolve_href(i)) + elif not nested: ret.append(get_dict_of_struct(i)) else: nested_obj = dict(