
Estou tentando criar arquivos a partir de chaves diferentes em um array, com base em uma chave do array sendo definida ou não:
##################################################
#main site, same ftp user
- name: copy deploy keys private
template: src=deploy_key dest=/root/.ssh/id_rsa-{{item.user}} owner=root group=root mode=0600
with_items:
- "{{joomla_websites + joomla_tls_websites + wordpress_websites + wordpress_h2_websites + phpbb_sites + symfony_websites + phpbb_sites}}"
ignore_errors: true
when: item.ftp_user is not defined
tags:
- sshd
- newsite
#staging site, different ftp user, use same key
- name: copy deploy keys private
template: src=deploy_key dest=/root/.ssh/id_rsa-{{item.ftp_user}} owner=root group=root mode=0600
with_items:
- "{{joomla_websites + joomla_tls_websites + wordpress_websites + wordpress_h2_websites + phpbb_sites + symfony_websites + phpbb_sites}}"
ignore_errors: true
when: item.ftp_user is defined
tags:
- sshd
- newsite
##################################################
No entanto, estou recebendo um erro
fatal: [1.2.3.4]: FAILED! => {"failed": true, "msg": "The conditional check 'item.ftp_user is not defined' failed. The error was: error while evaluating conditional (item.ftp_user is not defined): 'item' is undefined\n\nThe error appears to have been in '/home/jochen/projects/automatem/ansible/roles/accounts/tasks/main.yml': line 14, column 3, but may\nbe elsewhere in the file depending on the exact syntax problem.\n\nThe offending line appears to be:\n\n\n- name: copy deploy keys private, main site\n ^ here\n"}
Com base nas mensagens de log do playbook, Ansible está passando todo o array de itens para "quando", o que eu quero é percorrer cada item e fazer algo quando uma condição for verdadeira
Como posso conseguir isso?
Responder1
with_items:
- "{{joomla_web...}}”
Você criou um array com um único item. Em vez disso, você precisa passar os resultados das suas variáveis. Em vez disso, tente isto:
with_items: |
"{{joomla_web...}}”