- name: Create Linux user '{{ kolibri_user }}' and add it to groups '{{ apache_user }}', 'disk' user: name: "{{ kolibri_user }}" groups: - "{{ apache_user }}" - disk state: present shell: /bin/false system: yes create_home: no - name: Create {{ kolibri_home }} (for Kolibri content, configuration, sqlite3 databases) file: path: "{{ kolibri_home }}" # /library/kolibri owner: "{{ kolibri_user }}" # kolibri group: "{{ apache_user }}" # www-data (on Debian/Ubuntu/Raspbian) mode: 0755 state: directory - name: Create /etc/kolibri file: name: /etc/kolibri state: directory owner: root group: root mode: 0755 - name: Save kolibri_user ({{ kolibri_user }}) to /etc/kolibri/username copy: content: "{{ kolibri_user }}" dest: /etc/kolibri/username owner: root group: root mode: 0644 - name: Save kolibri_home (KOLIBRI_HOME="{{ kolibri_home }}") to /etc/kolibri/daemon.conf copy: content: 'KOLIBRI_HOME="{{ kolibri_home }}"' dest: /etc/kolibri/daemon.conf owner: root group: root mode: 0644 - name: apt install latest Kolibri .deb from {{ kolibri_deb_url }} apt: deb: "{{ kolibri_deb_url }}" # https://learningequality.org/r/kolibri-deb-latest environment: KOLIBRI_HOME: "{{ kolibri_home }}" # these don't do a thing for now but KOLIBRI_USER: "{{ kolibri_user }}" # both can't hurt & Might Help Later when: internet_available | bool - name: 'Install from templates: kolibri.service unit file for systemd & sites-available/kolibri.conf for Apache' template: src: "{{ item.src }}" dest: "{{ item.dest }}" owner: root group: root mode: 0644 with_items: - { src: 'kolibri.service.j2', dest: '/etc/systemd/system/kolibri.service' } - { src: 'kolibri.conf.j2', dest: '/etc/apache2/sites-available/kolibri.conf' } - name: Enable 'kolibri' systemd service (for reboots) but ensure it's stopped for Kolibri provisioning systemd: name: kolibri daemon_reload: yes enabled: yes state: stopped # 2019-10-01: Should no longer be nec, thanks to /etc/kolibri/daemon.conf # containing KOLIBRI_HOME="/library/kolibri" (above) #- name: Run Kolibri migrations to begin populating {{ kolibri_home }} # i.e. /library/kolibri # shell: export KOLIBRI_HOME="{{ kolibri_home }}" && "{{ kolibri_exec_path }}" manage migrate # ignore_errors: yes # become: yes # become_user: "{{ kolibri_user }}" # when: kolibri_provision | bool - name: Set Kolibri default language ({{ kolibri_language }}) shell: export KOLIBRI_HOME="{{ kolibri_home }}" && "{{ kolibri_exec_path }}" language setdefault "{{ kolibri_language }}" ignore_errors: yes become: yes become_user: "{{ kolibri_user }}" when: kolibri_provision | bool - name: 'Provision Kolibri, while setting: facility name, admin acnt / password, preset type, and language' shell: > export KOLIBRI_HOME="{{ kolibri_home }}" && "{{ kolibri_exec_path }}" manage provisiondevice --facility "{{ kolibri_facility }}" --superusername "{{ kolibri_admin_user }}" --superuserpassword "{{ kolibri_admin_password }}" --preset "{{ kolibri_preset }}" --language_id "{{ kolibri_language }}" #--preset "{{ kolibri_preset }}" --language_id "{{ kolibri_language }}" --verbosity 0 --noinput ignore_errors: yes become: yes become_user: "{{ kolibri_user }}" when: kolibri_provision | bool - name: chown -R {{ kolibri_user }}:{{ apache_user }} {{ kolibri_home }} for good measure? file: path: "{{ kolibri_home }}" # /library/kolibri owner: "{{ kolibri_user }}" # kolibri group: "{{ apache_user }}" # www-data (on Debian/Ubuntu/Raspbian) recurse: yes when: kolibri_provision | bool # 2019-09-29: roles/kiwix/tasks/kiwix_install.yml installs 4 Apache modules # for similar purposes (not all nec?) Only 1 (proxy_http) is needed here. - name: Enable Apache module proxy_http for http://box{{ kolibri_url }} # i.e. http://box/kolibri apache2_module: name: proxy_http - name: Start 'kolibri' systemd service, if kolibri_enabled systemd: name: kolibri state: started when: kolibri_enabled | bool - name: Enable http://box{{ kolibri_url }} with Apache (a2ensite) if kolibri_enabled # i.e. http://box/kolibri command: a2ensite kolibri.conf when: kolibri_enabled | bool - name: Disable & Stop 'kolibri' systemd service if not kolibri_enabled systemd: name: kolibri enabled: no state: stopped when: not kolibri_enabled - name: Disable http://box{{ kolibri_url }} with Apache (a2dissite) if not kolibri_enabled command: a2dissite kolibri.conf when: not kolibri_enabled - name: Restart Apache service ({{ apache_service }}) # e.g. apache2 systemd: name: "{{ apache_service }}" state: restarted - name: Add 'kolibri' variable values to {{ iiab_ini_file }} # /etc/iiab/iiab.ini ini_file: path: "{{ iiab_ini_file }}" section: kolibri option: "{{ item.option }}" value: "{{ item.value }}" with_items: - option: name value: kolibri - option: description value: '"Kolibri is an open-source educational platform specially designed to provide offline access to a wide range of quality, openly licensed educational contents in low-resource contexts like rural schools, refugee camps, orphanages, and also in non-formal school programs."' - option: kolibri_url value: "{{ kolibri_url }}" - option: kolibri_exec_path value: "{{ kolibri_exec_path }}" - option: kolibri_http_port value: "{{ kolibri_http_port }}" - option: kolibri_enabled value: "{{ kolibri_enabled }}"