Matrix Docker Ansible eploy
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

158 lines
5.5 KiB

  1. ---
  2. # Ensure Required Directories Exist
  3. - name: Ensure matrix-element-call paths exist
  4. ansible.builtin.file:
  5. path: "{{ item.path }}"
  6. state: directory
  7. mode: 0750
  8. owner: "{{ matrix_user_username }}"
  9. group: "{{ matrix_user_groupname }}"
  10. loop:
  11. - path: "{{ matrix_element_call_base_path }}"
  12. - path: "{{ matrix_element_call_base_path }}/data"
  13. - path: "{{ matrix_element_call_base_path }}/config"
  14. - path: "{{ matrix_element_call_base_path }}/backend" # For LiveKit and Redis config
  15. # Ensure Configuration Files are in Place
  16. - name: Ensure Element Call config.json is in place
  17. ansible.builtin.template:
  18. src: "{{ role_path }}/templates/config.json.j2"
  19. dest: "{{ matrix_element_call_base_path }}/config/config.json"
  20. mode: 0640
  21. owner: "{{ matrix_user_username }}"
  22. group: "{{ matrix_user_groupname }}"
  23. - name: Ensure LiveKit livekit.yaml is in place
  24. ansible.builtin.template:
  25. src: "{{ role_path }}/templates/livekit.yaml.j2"
  26. dest: "{{ matrix_element_call_base_path }}/backend/livekit.yaml"
  27. mode: 0640
  28. owner: "{{ matrix_user_username }}"
  29. group: "{{ matrix_user_groupname }}"
  30. - name: Ensure Redis redis.conf is in place
  31. ansible.builtin.template:
  32. src: "{{ role_path }}/templates/redis.conf.j2"
  33. dest: "{{ matrix_element_call_base_path }}/backend/redis.conf"
  34. mode: 0640
  35. owner: "{{ matrix_user_username }}"
  36. group: "{{ matrix_user_groupname }}"
  37. - name: Ensure matrix-element-call environment file is in place
  38. ansible.builtin.template:
  39. src: "{{ role_path }}/templates/env.j2"
  40. dest: "{{ matrix_element_call_base_path }}/config/env"
  41. mode: 0640
  42. owner: "{{ matrix_user_username }}"
  43. group: "{{ matrix_user_groupname }}"
  44. - name: Ensure matrix-element-call Docker labels file is in place
  45. ansible.builtin.template:
  46. src: "{{ role_path }}/templates/labels.j2"
  47. dest: "{{ matrix_element_call_base_path }}/config/labels"
  48. mode: 0640
  49. owner: "{{ matrix_user_username }}"
  50. group: "{{ matrix_user_groupname }}"
  51. # Ensure Docker Images are Pulled
  52. - name: Ensure matrix-element-call Docker image is pulled
  53. community.docker.docker_image:
  54. name: "{{ matrix_element_call_image }}"
  55. source: pull
  56. force_source: "{{ matrix_element_call_container_image_force_pull }}"
  57. register: element_call_image_result
  58. retries: "{{ devture_playbook_help_container_retries_count }}"
  59. delay: "{{ devture_playbook_help_container_retries_delay }}"
  60. until: element_call_image_result is not failed
  61. - name: Ensure jwt-service Docker image is pulled
  62. community.docker.docker_image:
  63. name: "ghcr.io/element-hq/lk-jwt-service:latest-ci"
  64. source: pull
  65. register: jwt_image_result
  66. retries: 3
  67. delay: 10
  68. until: jwt_image_result is not failed
  69. - name: Ensure livekit Docker image is pulled
  70. community.docker.docker_image:
  71. name: "livekit/livekit-server:latest"
  72. source: pull
  73. register: livekit_image_result
  74. retries: 3
  75. delay: 10
  76. until: livekit_image_result is not failed
  77. - name: Ensure redis Docker image is pulled
  78. community.docker.docker_image:
  79. name: "redis:6-alpine"
  80. source: pull
  81. register: redis_image_result
  82. retries: 3
  83. delay: 10
  84. until: redis_image_result is not failed
  85. # Ensure Docker Containers are Running
  86. - name: Run matrix-element-call Docker container
  87. community.docker.docker_container:
  88. name: "matrix-element-call"
  89. image: "{{ matrix_element_call_image }}"
  90. state: started
  91. restart_policy: unless-stopped
  92. env_file: "{{ matrix_element_call_base_path }}/config/env"
  93. labels: "{{ lookup('file', matrix_element_call_base_path ~ '/config/labels') | from_yaml }}"
  94. networks:
  95. - name: "{{ matrix_element_call_container_network }}"
  96. volumes:
  97. - "{{ matrix_element_call_base_path }}/config/config.json:/app/config.json"
  98. - "{{ matrix_element_call_base_path }}/data:/data"
  99. - name: Run jwt-service Docker container
  100. community.docker.docker_container:
  101. name: "matrix-jwt-service"
  102. image: "ghcr.io/element-hq/lk-jwt-service:latest-ci"
  103. state: started
  104. restart_policy: unless-stopped
  105. environment:
  106. LIVEKIT_SECRET: "{{ matrix_element_call_livekit_dev_key }}" # User-specified key
  107. LIVEKIT_URL: "{{ matrix_element_call_livekit_service_url }}"
  108. LIVEKIT_KEY: "devkey"
  109. networks:
  110. - name: "{{ matrix_element_call_container_network }}"
  111. - name: Run livekit Docker container
  112. community.docker.docker_container:
  113. name: "matrix-livekit"
  114. image: "livekit/livekit-server:latest"
  115. state: started
  116. restart_policy: unless-stopped
  117. command: "--dev --config /etc/livekit.yaml"
  118. volumes:
  119. - "{{ matrix_element_call_base_path }}/backend/livekit.yaml:/etc/livekit.yaml"
  120. network_mode: "host"
  121. - name: Run redis Docker container
  122. community.docker.docker_container:
  123. name: "matrix-redis"
  124. image: "redis:6-alpine"
  125. state: started
  126. restart_policy: unless-stopped
  127. command: redis-server /etc/redis.conf
  128. volumes:
  129. - "{{ matrix_element_call_base_path }}/backend/redis.conf:/etc/redis.conf"
  130. networks:
  131. - name: "{{ matrix_element_call_container_network }}"
  132. # Ensure Systemd Services are Set Up
  133. - name: Ensure matrix-element-call systemd service is installed
  134. ansible.builtin.template:
  135. src: "{{ role_path }}/templates/element-call.service.j2"
  136. dest: "{{ devture_systemd_docker_base_systemd_path }}/matrix-element-call.service"
  137. mode: 0644
  138. - name: Ensure matrix-element-call systemd service is enabled and started
  139. ansible.builtin.systemd:
  140. name: matrix-element-call
  141. enabled: true
  142. state: started
  143. daemon_reload: true