ansible-nginx/tasks/vhost.yml

80 lines
2.9 KiB
YAML
Raw Normal View History

2015-07-15 20:18:51 +07:00
---
2016-01-12 20:40:09 +07:00
- name: FAIL | Check vhost and SSL/TLS support
fail: msg="Missmatch configuration for vhost {{ item.name if item.name is string else item.name[0] }}"
2016-01-12 21:01:01 +07:00
when: >
item.proto is defined and
'https' in item.proto and
item.ssl_name is not defined
2016-01-12 20:40:09 +07:00
with_items: nginx_vhosts
2015-11-04 15:16:59 +07:00
- name: FILE | Create root directory
file: >
path={{ nginx_root }}
state=directory
2015-07-15 20:18:51 +07:00
- name: FILE | Create root folders (foreach nginx_vhosts)
2015-11-05 21:38:18 +07:00
file: >
path={{ nginx_root }}/{{ item.name if item.name is string else item.name[0] }}
state=directory
owner={{ item.owner | default('www-data') }}
group={{ item.group | default('www-data') }}
mode={{ item.mode | default('0755') }}
with_items: nginx_vhosts
2015-11-30 18:16:17 +07:00
when: >
item.root is not defined and
(item.template is defined and item.template != '_proxy') and
2015-12-01 21:46:57 +07:00
(item.delete is not defined or not item.delete) and
item.redirect_to is not defined
2015-11-05 21:38:18 +07:00
- name: FILE | Create root public folders (foreach nginx_vhosts)
2015-07-30 18:02:21 +07:00
file: >
path={{ nginx_root }}/{{ item.name if item.name is string else item.name[0] }}/public
2015-07-30 18:02:21 +07:00
state=directory
owner={{ item.owner | default('www-data') }}
group={{ item.group | default('www-data') }}
mode={{ item.mode | default('0755') }}
2015-07-15 20:18:51 +07:00
with_items: nginx_vhosts
2015-11-30 18:16:17 +07:00
when: >
item.root is not defined and
(item.template is defined and item.template != '_proxy') and
2015-12-01 21:46:57 +07:00
(item.delete is not defined or not item.delete) and
item.redirect_to is not defined
2015-07-15 20:18:51 +07:00
- name: TEMPLATE | Create vhosts
2015-07-30 18:02:21 +07:00
template: >
2015-12-01 21:46:57 +07:00
src=etc/nginx/sites-available/{{ item.template if item.redirect_to is not defined else '_redirect' }}.j2
dest=/etc/nginx/sites-available/{{ item.name if item.name is string else item.name[0] }}
2015-07-15 20:18:51 +07:00
with_items: nginx_vhosts
notify: reload nginx
2015-07-31 06:02:37 +07:00
when: item.delete is not defined or not item.delete
2015-07-15 20:18:51 +07:00
#- name: COPY | Add index.html / index.php
# copy: src={{ item }} dest={{ nginx_root }}/{{ item.name }}/public/{{ item }} owner=www-data group=www-data mode=0666
2015-07-15 20:42:32 +07:00
# with_fileglob: "web/*"
2015-07-15 20:18:51 +07:00
2015-07-30 18:02:21 +07:00
- name: FILE | Delete vhosts
2015-11-30 20:41:35 +07:00
file: path=/etc/nginx/sites-available/{{ item.name if item.name is string else item.name[0] }} state=absent
2015-07-30 18:02:21 +07:00
with_items: nginx_vhosts
notify: reload nginx
when: item.delete is defined and item.delete
- name: FILE | Enable vhosts
file: >
src=/etc/nginx/sites-available/{{ item.name if item.name is string else item.name[0] }}
dest=/etc/nginx/sites-enabled/{{ item.name if item.name is string else item.name[0] }}
2015-07-30 18:02:21 +07:00
state=link
2015-07-15 20:18:51 +07:00
with_items: nginx_vhosts
notify: reload nginx
2015-07-31 06:02:37 +07:00
when: >
((item.enable is not defined) or
(item.enable is defined and item.enable)) and
(item.delete is not defined or not item.delete)
2015-07-15 20:18:51 +07:00
2015-07-30 18:02:21 +07:00
- name: FILE | Disable vhosts
2015-11-30 20:41:35 +07:00
file: path=/etc/nginx/sites-enabled/{{ item.name if item.name is string else item.name[0] }} state=absent
2015-07-15 20:18:51 +07:00
with_items: nginx_vhosts
2015-07-30 18:02:21 +07:00
notify: reload nginx
2015-11-30 20:41:35 +07:00
when: (item.enable is defined and not item.enable) or (item.delete is defined and item.delete)
2015-07-30 18:02:21 +07:00