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 %}
dá
grouped: |-
read:
groups: [1, 2]
policy: ['data']
Você pode obter apenas os valores
grouped_vals: "{{ grouped|from_yaml|dict2items|map(attribute='value')|list }}"
dá
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 }}"
dá
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