mirror of
				https://github.com/spantaleev/matrix-docker-ansible-deploy.git
				synced 2025-10-30 23:07:57 +01:00 
			
		
		
		
	This extends the collection with support for seamless authentication at the Jitsi server using Matrix OpenID. 1. New role for installing the [Matrix User Verification Service](https://github.com/matrix-org/matrix-user-verification-service) 2. Changes to Jitsi role: Installing Jitsi Prosody Mods and configuring Jitsi Auth 3. Changes to Jitsi and nginx-proxy roles: Serving .well-known/element/jitsi from jitsi.DOMAIN 4. We updated the Jitsi documentation on authentication and added documentation for the user verification service.
		
			
				
	
	
		
			86 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| ---
 | |
| 
 | |
| - name: Ensure Matrix jitsi-prosody environment exists
 | |
|   ansible.builtin.file:
 | |
|     path: "{{ item.path }}"
 | |
|     state: directory
 | |
|     mode: 0777
 | |
|     owner: "{{ matrix_user_username }}"
 | |
|     group: "{{ matrix_user_groupname }}"
 | |
|   with_items:
 | |
|     - {path: "{{ matrix_jitsi_prosody_base_path }}", when: true}
 | |
|     - {path: "{{ matrix_jitsi_prosody_config_path }}", when: true}
 | |
|     - {path: "{{ matrix_jitsi_prosody_plugins_path }}", when: true}
 | |
|     - {path: "{{ matrix_jitsi_prosody_ext_path }}", when: true}
 | |
|   when: item.when | bool
 | |
| 
 | |
| - name: Ensure jitsi-prosody Docker image is pulled
 | |
|   community.docker.docker_image:
 | |
|     name: "{{ matrix_jitsi_prosody_docker_image }}"
 | |
|     source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}"
 | |
|     force_source: "{{ matrix_jitsi_prosody_docker_image_force_pull if ansible_version.major > 2 or ansible_version.minor >= 8 else omit }}"
 | |
|     force: "{{ omit if ansible_version.major > 2 or ansible_version.minor >= 8 else matrix_jitsi_prosody_docker_image_force_pull }}"
 | |
|   register: result
 | |
|   retries: "{{ devture_playbook_help_container_retries_count }}"
 | |
|   delay: "{{ devture_playbook_help_container_retries_delay }}"
 | |
|   until: result is not failed
 | |
| 
 | |
| - name: Ensure jitsi-prosody environment variables file is created
 | |
|   ansible.builtin.template:
 | |
|     src: "{{ role_path }}/templates/prosody/env.j2"
 | |
|     dest: "{{ matrix_jitsi_prosody_base_path }}/env"
 | |
|     owner: "{{ matrix_user_username }}"
 | |
|     group: "{{ matrix_user_groupname }}"
 | |
|     mode: 0640
 | |
| 
 | |
| # Configure matrix authentication.
 | |
| - name: Install user verification plugin
 | |
|   ansible.builtin.include_tasks:
 | |
|     file: "{{ role_path }}/tasks/util/setup_jitsi_auth_uvs_install.yml"
 | |
|   when: matrix_jitsi_enable_auth | bool and matrix_jitsi_auth_type == "matrix"
 | |
| 
 | |
| - name: Manage Jitsi .well-known
 | |
|   when: matrix_jitsi_require_well_known | bool
 | |
|   block:
 | |
|     - name: Ensure .well-known directories exist
 | |
|       ansible.builtin.file:
 | |
|         path: "{{ item.path }}"
 | |
|         state: directory
 | |
|         mode: 0775
 | |
|         owner: "{{ matrix_user_username }}"
 | |
|         group: "{{ matrix_user_groupname }}"
 | |
|       with_items:
 | |
|         - {path: "{{ matrix_static_files_base_path }}/.well-known/element", when: "{{ matrix_jitsi_enable_auth | bool and matrix_jitsi_auth_type == 'matrix' }}"}
 | |
|       when: item.when | bool
 | |
| 
 | |
|     # Create .well-known/element/jitsi in the static file directory for nginx-proxy.
 | |
|     - name: Ensure Jitsi /.well-known/element/jitsi configured
 | |
|       ansible.builtin.copy:
 | |
|         content: "{{ matrix_jitsi_wellknown_element_jitsi_json }}"
 | |
|         dest: "{{ matrix_static_files_base_path }}/.well-known/element/jitsi"
 | |
|         mode: 0644
 | |
|         owner: "{{ matrix_user_username }}"
 | |
|         group: "{{ matrix_user_groupname }}"
 | |
|       when: matrix_jitsi_enable_auth | bool and matrix_jitsi_auth_type == "matrix"
 | |
| # END Block
 | |
| 
 | |
| # Remove matrix authentication if disabled
 | |
| - name: Ensure user verification plugin is not present if matrix auth is disabled
 | |
|   ansible.builtin.include_tasks:
 | |
|     file: "{{ role_path }}/tasks/util/setup_jitsi_auth_uvs_uninstall.yml"
 | |
|   when: (not matrix_jitsi_enable_auth | bool) or (matrix_jitsi_auth_type != "matrix")
 | |
| 
 | |
| - name: Ensure matrix-jitsi-prosody.service file is installed
 | |
|   ansible.builtin.template:
 | |
|     src: "{{ role_path }}/templates/prosody/matrix-jitsi-prosody.service.j2"
 | |
|     dest: "{{ devture_systemd_docker_base_systemd_path }}/matrix-jitsi-prosody.service"
 | |
|     mode: 0644
 | |
|   register: matrix_jitsi_prosody_systemd_service_result
 | |
| 
 | |
| # Tasks that require a running prosody container are called in this file.
 | |
| - name: Run prosody related tasks, that require a running container.
 | |
|   ansible.builtin.include_tasks:
 | |
|     file: "{{ role_path }}/tasks/util/setup_jitsi_prosody_post_setup_hooks.yml"
 | |
|   when:
 | |
|     - matrix_jitsi_enable_auth | bool and matrix_jitsi_auth_type == "internal"
 |