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”之前工作,但没有进一步......逻辑上有什么问题?
要获取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)
| 归档时间: |
|
| 查看次数: |
5584 次 |
| 最近记录: |