--- - name: Configure https vhosts template: src=vhost.conf.j2 dest={{ nginx_confd_path }}/{{ item.nginx_domain_name }}.conf mode=0644 owner=root group=root with_items: nginx_tls_vhosts notify: - reload nginx # concatenated key + cert, can live in the same file # See: http://nginx.org/en/docs/http/configuring_https_servers.html - name: Copy TLS certs copy: { dest: "{{ tls_key_dir }}/{{ item.nginx_domain_name }}.crt.pem", content: "{{ item.tls_cert }}", mode: 0700, owner: 'root', group: 'root' } with_items: nginx_tls_vhosts when: item.tls_cert is defined notify: - reload nginx - name: Generate self-signed TLS cert command: openssl req -x509 -nodes -sha256 -days 365 -subj "/C=SO/ST=SO/L=snakeoil/O=snakeoil/CN=snakeoil" -newkey rsa:2048 -keyout /etc/ssl/private/nginx-snakeoil.key -out /etc/ssl/certs/nginx-snakeoil.crt -extensions v3_ca creates=/etc/ssl/certs/nginx-snakeoil.crt notify: - reload nginx - name: Generate 2048-bit dhparam command: openssl dhparam -out dhparam.pem 2048 chdir=/etc/ssl/certs creates=dhparam.pem notify: - reload nginx - name: Create vhost document roots file: path={{ nginx_root_prefix }}/{{ item.nginx_domain_name }} state=directory mode=0755 owner=nginx group=nginx with_items: nginx_tls_vhosts - name: Install WordPress git: repo=https://github.com/WordPress/WordPress.git dest={{ nginx_root_prefix }}/{{ item.nginx_domain_name }}/wordpress version={{ item.wordpress_version }} depth=1 when: item.has_wordpress == 'yes' with_items: nginx_tls_vhosts tags: wordpress # vim: set ts=2 sw=2: