Сложный синтаксис JSON и Ansible JSON_QUERY - PullRequest
1 голос
/ 07 августа 2020

У меня сложный результат в формате JSON, и я пытаюсь извлечь из него значения. Я протестировал онлайн-оценщик JSONpath https://jsonpath.com/, где я могу просто набрать

$.[*].toPort

и получить список запрошенных переменных.

Я пытался использовать тот же синтаксис в Ansible, но получение пустого списка.

- name: JSON test
  hosts: localhost
  gather_facts: no

  vars:
    jsoncontent:
                {
                        "infraAccPortP": {
                            "attributes": {
                                "annotation": "",
                                "childAction": "",
                                "descr": "",
                                "nameAlias": "",
                                "ownerKey": "",
                                "ownerTag": "",
                                "status": "",
                                "uid": "15374"
                            },
                            "children": [
                                {
                                    "infraHPortS": {
                                        "attributes": {
                                            "annotation": "",
                                            "uid": "8927"
                                        },
                                        "children": [
                                            {
                                                "infraPortBlk": {
                                                    "attributes": {                                                  
                                                        "fromPort": "41",
                                                        "toPort": "41",
                                                        "uid": "8927"
                                                    }
                                                }
                                            }
                                        ]
                                    }
                                },
                                {
                                    "infraHPortS": {
                                        "attributes": {
                                            "annotation": "",
                                            "uid": "8927"
                                        },
                                        "children": [
                                            {
                                                "infraPortBlk": {
                                                    "attributes": {
                                                        "fromPort": "42",
                                                        "toPort": "42",
                                                        "uid": "8927"
                                                    }
                                                }
                                            }
                                        ]
                                    }
                                }
                            ]
                        }
                    }

  tasks:
    - name: show jsoncontent
      debug:
        var: jsoncontent

    - name: Show just toPort values
      debug: 
        msg: "{{ jsoncontent | json_query(jmesquery)    }}"
      vars:
        jmesquery: "[*].toPort"

Любая помощь, как настроить запрос, чтобы получить ожидаемый результат? Это немного расстраивает, поскольку не так много документации о том, как json_query реализован в Ansible

1 Ответ

1 голос
/ 07 августа 2020

Приведенная ниже задача выполняет свою работу.

    - name: Show just toPort values
      debug: 
        msg: "{{ jsoncontent.infraAccPortP.children | json_query(jmesquery) }}"
      vars:
        jmesquery: "[].infraHPortS.children[].infraPortBlk.attributes.toPort"

дает

  msg:
  - '41'
  - '42'

Q: "Реализация Ansible не допускает поиск по шаблонам ? "

A: Кажется, нет ничего особенного в реализации . (Этот фильтр перемещен в ansible -collections / community.general с 2.10.)


Q: « Просто запутался, почему я получил такой же результат с гораздо более коротким синтаксисом в этой онлайн-проверке."

A: Я думаю, вопрос в том, как реализована проверка. jq тоже не работает. Например,

shell> cat data.json | jq .jsoncontent.infraAccPortP.children[].infraHPortS.children[].infraPortBlk.attributes.toPort
"41"
"42"

Запрос «проверки» завершается с ошибкой

shell> cat data.json | jq .[*].toPort
jq: error: syntax error, unexpected '*' (Unix shell quoting issues?) at <top-level>, line 1:
.[*].toPort  
jq: 1 compile error

или дает пустой результат

shell> cat data.json | jq .[].toPort
null
...