Ansible: Como mesclar uma lista de objetos de dicionário com a mesma chave, obtendo um elemento de dicionário com uma lista de milhares de valores diferentes agrupados?

Ansible: Como mesclar uma lista de objetos de dicionário com a mesma chave, obtendo um elemento de dicionário com uma lista de milhares de valores diferentes agrupados?

Tenho lutado com o Ansible por um tempo e finalmente solicito qualquer ajuda, se possível,

Ter um conjunto de políticas 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"
    }
]

Tenho a necessidade de agrupá-los para obter:

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

Mas até agora ainda não consegui agrupar por chave "ação" + "recurso" obtendo uma lista de "grupos" relacionados em um novo campo "grupos". Consegui obter apenas uma lista de dicionários no formato { "action"+"resource" : "group1" }, ..., { "action"+"resource" : "groupN" }

Código de tarefa ansible relacionado:

- 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

Depois de várias tentativas usandocombinar,União,agrupar porfiltros ansible sem sucesso. qualquer informação seria muito apreciada.

Atenciosamente,

Responder1

Crie a estrutura de Jinja. Por exemplo, dada amaisdados simplificados

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

declare o dicionário como renomear as chaves

    keys:
      group: groups
      resource: policy

e declare a estrutura

  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']

Você pode obter apenas os valores

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

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

O primeiro item da lista é o que você está procurando. Ou você pode obtê-lo no dicionário

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

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

Exemplo de um manual completo para teste

- 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

informação relacionada