ansible/roles/nextcloud/tasks/main.yml

65 lines
2.0 KiB
YAML

---
- name: Install packages
apt: name={{ item }}
with_items:
# FIXME currently PHP handled out of ansible
# - php7.0-apcu
# - php7.0-curl
# - php7.0-fpm
# - php7.0-gd
# - php7.0-ldap
# - php7.0-mbstring
# - php7.0-pgsql
# - php7.0-xml
# - php7.0-zip
# - php-redis
- postgresql
- python-psycopg2
- name: Configure PostgreSQL database
postgresql_db: name={{ owncloud_dbname }}
become: true
become_user: postgres
- name: Configure PostgreSQL user
postgresql_user: db={{ owncloud_dbname }} name={{ owncloud_dbuser }} password={{ owncloud_dbpass }} priv=ALL state=present
become: true
become_user: postgres
- name: Ensure certificates are available
command: openssl req -x509 -nodes -newkey rsa:2048 -keyout /etc/nginx/ssl/{{ nextcloud_domain }}.key -out /etc/nginx/ssl/{{ nextcloud_domain }}.crt -days 730 -subj "/CN={{ nextcloud_domain }}" creates=/etc/nginx/ssl/{{ nextcloud_domain }}.crt
notify: Restart nginx
- name: Configure certificate manager for nextcloud
template: src=certs.j2 dest=/etc/acertmgr/{{ nextcloud_domain }}.conf
notify: Run acertmgr
- name: Create vhost directory
file: path=/var/www/nextcloud state=directory owner=www-data group=www-data
- name: Configure vhost
template: src=vhost.j2 dest=/etc/nginx/sites-available/nextcloud
notify: Restart nginx
# FIXME currently PHP handled out of ansible
#- name: Configure php7.0-fpm
# copy: src=www.conf dest=/etc/php/7.0/fpm/pool.d/www.conf
# notify: Restart php7.0-fpm
# FIXME currently PHP handled out of ansible
#- name: Configure php7.0 opcache
# copy: src=opcache.ini dest=/etc/php/7.0/mods-available/opcache.ini
# notify: Restart php7.0-fpm
- name: Enable vhost
file: src=/etc/nginx/sites-available/nextcloud dest=/etc/nginx/sites-enabled/nextcloud state=link
notify: Restart nginx
# FIXME currently PHP handled out of ansible
#- name: Start php7.0-fpm
# service: name=php7.0-fpm state=started enabled=yes
- name: Start PostgreSQL
service: name=postgresql state=started enabled=yes