1
0
Fork 0
mirror of https://github.com/iiab/iiab.git synced 2025-03-09 15:40:17 +00:00

implement nextcloud_force_install on trigger

This commit is contained in:
A Holt 2017-12-04 10:00:27 -05:00 committed by GitHub
parent ee735fa1e2
commit 6ae4d9dcf5
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -1,31 +1,43 @@
# we need to install the rpm in order to get the dependencies - name: See if Nextcloud version page exists
# but we only need to do this the first time stat:
path: "{{ nextcloud_prefix }}/nextcloud/version.php"
- name: See if the Nextcloud startup page exists # path: "{{ nextcloud_prefix }}/nextcloud/index.php"
stat: path={{ nextcloud_prefix }}/nextcloud/index.php
register: nextcloud_page register: nextcloud_page
- name: FORCE UPGRADE OR INSTALL IF /opt/nextcloud/version.php DOESN'T EXIST
set_fact:
nextcloud_force_install: True
when: not nextcloud_page.stat.exists
# but we use the tar file to get the latest version # - debug:
# msg: "nextcloud_force_install: {{ nextcloud_force_install }}"
- name: Get the Nextcloud software
get_url: url={{ nextcloud_dl_url }}/{{ nextcloud_src_file }} dest={{ downloads_dir }}/{{ nextcloud_src_file }} - name: Download latest Nextcloud software to /opt/iiab/download/{{ nextcloud_src_file }}
when: internet_available get_url:
url: "{{ nextcloud_dl_url }}/{{ nextcloud_orig_src_file }}"
dest: "{{ downloads_dir }}/{{ nextcloud_src_file }}"
force: yes
when: internet_available and nextcloud_force_install
async: 900 async: 900
poll: 15 poll: 15
tags: tags:
- download - download
- name: Ubuntu and Debian treat names differently (Debian) - name: Ubuntu and Debian treat names differently (Debian)
package: name={{ item }} state=present package:
name: "{{ item }}"
state: present
with_items: with_items:
- libapache2-mod-php{{ php_version }} - "libapache2-mod-php{{ php_version }}"
- php{{ php_version }}-mbstring - "php{{ php_version }}-mbstring"
- php{{ php_version }}-zip - "php{{ php_version }}-zip"
when: is_debian when: is_debian
- name: Ubuntu and Debian treat names differently (Ubuntu) - name: Ubuntu and Debian treat names differently (Ubuntu)
package: name={{ item }} state=present package:
name: "{{ item }}"
state: present
with_items: with_items:
- libapache2-mod-php - libapache2-mod-php
- php-imagick - php-imagick
@ -34,18 +46,25 @@
when: is_ubuntu when: is_ubuntu
- name: Install list of packages (debuntu) - name: Install list of packages (debuntu)
package: name={{ item }} state=present package:
name: "{{ item }}"
state: present
with_items: with_items:
- php{{ php_version }}-gd - "php{{ php_version }}-gd"
- php{{ php_version }}-json - "php{{ php_version }}-json"
- php{{ php_version }}-mysql - "php{{ php_version }}-mysql"
- php{{ php_version }}-curl - "php{{ php_version }}-curl"
- php{{ php_version }}-intl - "php{{ php_version }}-intl"
- php{{ php_version }}-mcrypt - "php{{ php_version }}-mcrypt"
when: is_debuntu when: is_debuntu
# we need to install the rpm in order to get the dependencies
# but we only need to do this the first time
- name: Install list of packages (redhat) - name: Install list of packages (redhat)
package: name={{ item }} state=present package:
name: "{{ item }}"
state: present
with_items: with_items:
- php - php
- php-gd - php-gd
@ -59,52 +78,63 @@
when: is_redhat when: is_redhat
- name: Copy it to permanent location /opt (OS's other than Fedora 18) - name: Copy it to permanent location /opt (OS's other than Fedora 18)
unarchive: src={{ downloads_dir }}/{{ nextcloud_src_file }} unarchive:
dest={{ nextcloud_prefix }} src: "{{ downloads_dir }}/{{ nextcloud_src_file }}"
creates={{ nextcloud_prefix }}/nextcloud/version.php dest: "{{ nextcloud_prefix }}"
when: not is_F18 # creates: "{{ nextcloud_prefix }}/nextcloud/version.php"
when: not is_F18 and nextcloud_force_install
# ansible 1.4.1 does not have "creates" # Ansible 1.4.1 does not have "creates" (but hopefully has "when")
- name: Copy it to permanent location /opt (Fedora 18) - name: Copy it to permanent location /opt (Fedora 18)
unarchive: src={{ downloads_dir }}/{{ nextcloud_src_file }} unarchive:
dest={{ nextcloud_prefix }} src: "{{ downloads_dir }}/{{ nextcloud_src_file }}"
when: is_F18 dest: "{{ nextcloud_prefix }}"
when: is_F18 and nextcloud_force_install
- name: In CentOS, the following config dir is symlink to /etc/nextcloud - name: In CentOS, the following config dir is symlink to /etc/nextcloud
file: path=/etc/nextcloud file:
state=directory path: /etc/nextcloud
state: directory
when: is_centos when: is_centos
- name: Add autoconfig file (CentOS) - name: Add autoconfig file (CentOS)
template: src=autoconfig.php.j2 template:
dest={{ nextcloud_prefix }}/nextcloud/config/autoconfig.php src: autoconfig.php.j2
owner={{ apache_user }} dest: "{{ nextcloud_prefix }}/nextcloud/config/autoconfig.php"
group={{ apache_user }} owner: "{{ apache_user }}"
mode=0640 group: "{{ apache_user }}"
mode: 0640
when: is_centos when: is_centos
- name: Make Apache owner - name: Make Apache owner
file: path={{ nextcloud_prefix }}/nextcloud file:
owner={{ apache_user }} path: "{{ nextcloud_prefix }}/nextcloud"
group={{ apache_user }} owner: "{{ apache_user }}"
recurse=yes group: "{{ apache_user }}"
state=directory recurse: yes
state: directory
- name: Create data directory library - name: Create data directory library
file: path={{ item }} file:
mode=0750 path: "{{ item }}"
owner={{ apache_user }} owner: "{{ apache_user }}"
group={{ apache_user }} group: "{{ apache_user }}"
state=directory mode: 0750
state: directory
with_items: with_items:
- "{{ nextcloud_data_dir }}" - "{{ nextcloud_data_dir }}"
- name: Create a MySQL database for Nextcloud - name: Create a MySQL database for Nextcloud
mysql_db: name={{ nextcloud_dbname }} mysql_db:
name: "{{ nextcloud_dbname }}"
when: mysql_enabled and nextcloud_enabled when: mysql_enabled and nextcloud_enabled
- name: Create a user to access the Nextcloud database - name: Create a user to access the Nextcloud database
mysql_user: name={{ nextcloud_dbuser }} host={{ item }} password={{ nextcloud_dbpassword }} priv={{ nextcloud_dbname }}.*:ALL,GRANT mysql_user:
name: "{{ nextcloud_dbuser }}"
host: "{{ item }}"
password: "{{ nextcloud_dbpassword }}"
priv: "{{ nextcloud_dbname }}.*:ALL,GRANT"
with_items: with_items:
- "{{ nextcloud_dbhost }}" - "{{ nextcloud_dbhost }}"
- 127.0.0.1 - 127.0.0.1
@ -114,8 +144,11 @@
- name: Restart Apache, so it picks up the new aliases - name: Restart Apache, so it picks up the new aliases
service: name={{ apache_service }} state=restarted service:
when: not nextcloud_enabled name: "{{ apache_service }}"
state: restarted
when: nextcloud_enabled
# when: not nextcloud_enabled
# Enable nextcloud by copying template to httpd config # Enable nextcloud by copying template to httpd config