我正在使用Ansible 2.3.0.0并且我在Ansible 2.4.0.0中进行了测试,获得了相同的结果。我的问题很简单。 我有以下列表:
vars:
password_text_to_encrypt:
- { line: "{{truststore_pass }}" , result: }
- { line: "{{ keystore_pass }}" , result: }
- { line: "{{ gp_pass }}" , result: }
- { line: "{{ datasource_password }}" , result: }
- { line: "{{ server_password }}" , result: }
- { line: "{{ sftp_password }}" , result: }
- { line: "{{ db_userpassword }}" , result: }
roles:
- basic_role
我想加密列表中每个项目的行值,并将其保存在results属性中。 我正在尝试使用此Ansible代码,但它在任务分配中失败:
- name: "Encrypt password"
uri:
url: http://122.81.10.1:8910/Cloud/encrypt
method: POST
body: "{{ item.line}}"
return_content: yes
register: "r"
with_items:
- "{{password_text_to_encrypt}}"
- name: "Replace var in result"
set_fact: item['0']['result']="{{ item.1.content}}"
#replace: '{{ item.1.content}}'
with_nested:
- "{{password_text_to_encrypt}}"
- "{{r.results}}"
when: item.1.item.line==item.0.line
- name: "print Results"
debug:
msg: "The Item is :{{item.result}}"
with_items:
- "{{password_text_to_encrypt}}"
输出消息是:
"msg": "The variable name 'item['0']['result']' is not valid. Variables must start with a letter or underscore character, and contain only letters, numbers and underscores."}
我已经测试了其他可能性,但我没有实现每个item.results保存其加密值
答案 0 :(得分:0)
最后,必须以这种方式使用set_fact方法:
我没有使用相同的变量,而是创建了另一个具有相同结构的变量。
- name: "Replace var in result"
set_fact:
encrypted: "{{encrypted|default([]) + [ {'line': item.1.content, 'regexp': item.0.regexp} ]}}"
with_nested:
- "{{password_text_to_encrypt}}"
- "{{r.results}}"
when: item.1.item.line==item.0.line
但我无法重写对象内的字段