Ansible/Jinja2 - 在列表中映射嵌套键

Cry*_*pto 0 yaml filter jinja2 ansible

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

我想从以下强调的文本变量中检索“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
Run Code Online (Sandbox Code Playgroud)

调试任务:

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

输出:

ok: [test] => {
    "msg": ""
}
Run Code Online (Sandbox Code Playgroud)

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

Kon*_*rov 5

要获取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
Run Code Online (Sandbox Code Playgroud)

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

PS 为什么将可能的(?)多个路径加入字符串?

PPS 你的数据结构看起来很奇怪。为什么要定义像列表这样的 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
Run Code Online (Sandbox Code Playgroud)