Ansible / Jinja2 - 在列表

时间:2017-08-14 16:24:10

标签: filter ansible yaml jinja2

在嵌套变量列表中映射属性时,我无法检索其密钥。

我想从以下强调文本变量中检索“tls_cert_file”的键:

vault_config_listener:
  - tcp:
    - address: "0.0.0.0:8200"
    - tls_cert_file: "/etc/ssl/wildcard.crt"
    - tls_key_file: "/etc/ssl/private/wildcard.key"
    - tls_require_and_verify_client_cert: "false"
  - tcp:
    - address: "127.0.0.1:8200"
    - tls_disable: true

调试任务:

- debug:
    msg: "{{ (vault_config_listener | selectattr('tcp', 'defined') | map(attribute='tcp')) | selectattr('tls_cert_file','defined') | map(attribute='tls_cert_file') | join('') | dirname }}"

输出:

ok: [test] => {
    "msg": ""
}

我让地图工作到“tcp”,但没有进一步......逻辑有什么问题?

1 个答案:

答案 0 :(得分:2)

要获取tls_cert_file的列表,您可以使用

vault_config_listener | selectattr('tcp', 'defined') | map(attribute='tcp') | sum(start=[]) | selectattr('tls_cert_file','defined') | map(attribute='tls_cert_file') | list

note sum(start=[]) - 它用于展平列表列表。

P.S。为什么将可能的(?)多个路径加入到字符串中?

P.P.S您的数据结构似乎很奇怪。为什么要定义像list这样的tcp属性,而不仅仅是:

tcp:
  address: 0.0.0.0:8200
  tls_cert_file: /etc/ssl/wildcard.crt
  tls_key_file: /etc/ssl/private/wildcard.key
  tls_require_and_verify_client_cert: false