
Я пытаюсь создать файлы из разных ключей в массиве, в зависимости от того, установлен ключ в массиве или нет:
##################################################
#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
##################################################
Однако я получаю сообщение об ошибке
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"}
Судя по сообщениям журнала в плейбуке, Ansible передает весь массив элементов в «when», мне же нужно перебрать каждый элемент и сделать что-то, когда условие будет истинным.
Как мне этого добиться?
решение1
with_items:
- "{{joomla_web...}}”
Вы создали массив с одним элементом. Вместо этого вам нужно передать результаты ваших переменных. Попробуйте это вместо этого:
with_items: |
"{{joomla_web...}}”