
Estoy intentando crear archivos a partir de diferentes claves en una matriz, en función de que una clave en la matriz esté configurada o no:
##################################################
#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
##################################################
Sin embargo me sale un error
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"}
Según los mensajes de registro del libro de jugadas, Ansible está pasando toda la matriz de elementos a "cuándo", lo que quiero es recorrer cada elemento y hacer algo cuando una condición sea verdadera.
¿Cómo puedo conseguir esto?
Respuesta1
with_items:
- "{{joomla_web...}}”
Ha creado una matriz con un solo elemento. En su lugar, debe pasar los resultados de sus variables. Pruebe esto en su lugar:
with_items: |
"{{joomla_web...}}”