Я уже некоторое время борюсь с 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