Ansible: Как объединить список объектов словаря с одинаковым ключом, получив один элемент словаря со списком из этих разных сгруппированных значений?

Ansible: Как объединить список объектов словаря с одинаковым ключом, получив один элемент словаря со списком из этих разных сгруппированных значений?

Я уже некоторое время борюсь с Ansible и, наконец, прошу любой помощи, если это возможно,

Наличие набора политик Nifi:

"nifi_raw_policies": [
    {
        "action": "read",
        "group": "8c052e6c-0184-1000-0000-000072a0bb44",
        "resource": "/data/process-groups/8b6b5c9f-0184-1000-57e3-f27fc56dd4aa"
    },
    {
        "action": "read",
        "group": "8c0536d8-0184-1000-0000-000018ba98a9",
        "resource": "/data/process-groups/8b6b5c9f-0184-1000-57e3-f27fc56dd4aa"
    }
]

Мне необходимо сгруппировать их, чтобы получить:

"nifi_grouped_policies": [
    {
        "policy": "read/data/process-groups/8b6b5c9f-0184-1000-57e3-f27fc56dd4aa",
        "groups": [ "8c052e6c-0184-1000-0000-000072a0bb44","8c0536d8-0184-1000-0000-000018ba98a9" ]
    }
]

Но до сих пор я не могу сгруппировать по ключу "action"+"resource", получив список связанных "group" в новом поле "groups". Мне удалось получить только список словарей в виде { "action"+"resource" : "group1" }, ..., { "action"+"resource" : "groupN" }

Сопутствующий код задачи ansible:

- name: Declare policies (simplest)
  set_fact:
    nifi_raw_policies: [
        {
            "action": "read",
            "group": "8c052e6c-0184-1000-0000-000072a0bb44",
            "resource": "/data/process-groups/8b6b5c9f-0184-1000-57e3-f27fc56dd4aa"
        },
        {
            "action": "read",
            "group": "8c0536d8-0184-1000-0000-000018ba98a9",
            "resource": "/data/process-groups/8b6b5c9f-0184-1000-57e3-f27fc56dd4aa"
        }
    ]

- name: Declare policies - debug
  debug: var=nifi_raw_policies

- name: Combine action and resource
  set_fact:
    nifi_policies: >-
      {{ nifi_policies|default([])
        | union([{
            item.action + item.resource : item.group
            }])
      }}
  with_items: "{{ nifi_raw_policies }}"

- name: Combine action and resource - debug
  debug: var=nifi_policies

После нескольких попыток использованияобъединить,союз,группа пофильтры ansible безуспешно... любые идеи были бы высоко оценены.

С наилучшими пожеланиями,

решение1

Создайте структуру Jinja. Например, учитываямрэупрощенные данные

  raw:
    - action: read
      group: 1
      resource: data
    - action: read
      group: 2
      resource: data

объявить словарь как переименовать ключи

    keys:
      group: groups
      resource: policy

и объявить структуру

  grouped: |
    {% for i in raw|groupby('action') %}
    {{ i.0 }}:
    {% for k in i.1|json_query('[].keys(@)|[]')|unique %}
    {% if k != 'action' %}
      {{ keys[k] }}: {{ i.1|map(attribute=k)|unique }}
    {% endif %}
    {% endfor %}
    {% endfor %}

дает

  grouped: |-
    read:
      groups: [1, 2]
      policy: ['data']

Вы можете получить только значения

  grouped_vals: "{{ grouped|from_yaml|dict2items|map(attribute='value')|list }}"

дает

  grouped_vals:
    - groups: [1, 2]
      policy: [data]

Первый пункт в списке — это то, что вы ищете. Или вы можете получить это из словаря

  nifi_grouped_policies: "{{ (grouped|from_yaml).read }}"

дает

  nifi_grouped_policies:
    groups: [1, 2]
    policy: [data]

Пример полной схемы тестирования

- hosts: localhost

  vars:

    raw:
      - action: read
        group: 1
        resource: data
      - action: read
        group: 2
        resource: data

    keys:
      group: groups
      resource: policy
    grouped: |
      {% for i in raw|groupby('action') %}
      {{ i.0 }}:
      {% for k in i.1|json_query('[].keys(@)|[]')|unique %}
      {% if k != 'action' %}
        {{ keys[k] }}: {{ i.1|map(attribute=k)|unique }}
      {% endif %}
      {% endfor %}
      {% endfor %}
    grouped_vals: "{{ grouped|from_yaml|dict2items|map(attribute='value')|list }}"
    nifi_grouped_policies: "{{ (grouped|from_yaml).read }}"

  tasks:

    - debug:
        var: grouped
    - debug:
        var: grouped_vals|to_yaml
    - debug:
        var: nifi_grouped_policies|to_yaml

Связанный контент