mirror of
				https://github.com/spantaleev/matrix-docker-ansible-deploy.git
				synced 2025-10-26 04:50:40 +01:00 
			
		
		
		
	sync with previous repo
This commit is contained in:
		
							
								
								
									
										132
									
								
								roles/matrix-bridge-mautrix-telegram/defaults/main.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										132
									
								
								roles/matrix-bridge-mautrix-telegram/defaults/main.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,132 @@ | ||||
| # mautrix-telegram is a Matrix <-> Telegram bridge | ||||
| # See: https://github.com/tulir/mautrix-telegram | ||||
|  | ||||
| matrix_mautrix_telegram_enabled: true | ||||
|  | ||||
| matrix_telegram_lottieconverter_container_self_build: false | ||||
| matrix_telegram_lottieconverter_container_self_build_mask_arch: false | ||||
| matrix_telegram_lottieconverter_docker_repo: "https://mau.dev/tulir/lottieconverter.git" | ||||
| matrix_telegram_lottieconverter_docker_src_files_path: "{{ matrix_base_data_path }}/lotticonverter/docker-src" | ||||
| matrix_telegram_lottieconverter_docker_image: "dock.mau.dev/tulir/lottieconverter:alpine-3.14" # needs to be ajusted according to FROM clause of Dockerfile of mautrix-telegram | ||||
|  | ||||
| matrix_mautrix_telegram_container_self_build: false | ||||
| matrix_mautrix_telegram_docker_repo: "https://mau.dev/tulir/mautrix-telegram.git" | ||||
| matrix_mautrix_telegram_docker_src_files_path: "{{ matrix_base_data_path }}/mautrix-telegram/docker-src" | ||||
|  | ||||
| matrix_mautrix_telegram_version: v0.9.0 | ||||
| # See: https://mau.dev/tulir/mautrix-telegram/container_registry | ||||
| matrix_mautrix_telegram_docker_image: "dock.mau.dev/tulir/mautrix-telegram:{{ matrix_mautrix_telegram_version }}" | ||||
| matrix_mautrix_telegram_docker_image_force_pull: "{{ matrix_mautrix_telegram_docker_image.endswith(':latest') }}" | ||||
|  | ||||
| matrix_mautrix_telegram_base_path: "{{ matrix_base_data_path }}/mautrix-telegram" | ||||
| matrix_mautrix_telegram_config_path: "{{ matrix_mautrix_telegram_base_path }}/config" | ||||
| matrix_mautrix_telegram_data_path: "{{ matrix_mautrix_telegram_base_path }}/data" | ||||
|  | ||||
| # Get your own API keys at https://my.telegram.org/apps | ||||
| matrix_mautrix_telegram_api_id: '' | ||||
| matrix_mautrix_telegram_api_hash: '' | ||||
| matrix_mautrix_telegram_bot_token: disabled | ||||
|  | ||||
| # Mautrix telegram public endpoint to log in to telegram | ||||
| # Use an uuid so it's not easily discoverable. | ||||
| # Example: /741a0483-ba17-4682-9900-30bd7269f1cc | ||||
| matrix_mautrix_telegram_public_endpoint: '' | ||||
|  | ||||
| matrix_mautrix_telegram_homeserver_address: "{{ matrix_homeserver_container_url }}" | ||||
| matrix_mautrix_telegram_homeserver_domain: '{{ matrix_domain }}' | ||||
| matrix_mautrix_telegram_appservice_address: 'http://matrix-mautrix-telegram:8080' | ||||
| matrix_mautrix_telegram_appservice_public_external: 'https://{{ matrix_server_fqn_matrix }}{{ matrix_mautrix_telegram_public_endpoint }}' | ||||
|  | ||||
| matrix_mautrix_telegram_appservice_bot_username: telegrambot | ||||
|  | ||||
| # Controls whether the matrix-mautrix-telegram container exposes its HTTP port (tcp/8080 in the container). | ||||
| # | ||||
| # Takes an "<ip>:<port>" or "<port>" value (e.g. "127.0.0.1:9006"), or empty string to not expose. | ||||
| matrix_mautrix_telegram_container_http_host_bind_port: '' | ||||
|  | ||||
| # A list of extra arguments to pass to the container | ||||
| matrix_mautrix_telegram_container_extra_arguments: [] | ||||
|  | ||||
| # List of systemd services that matrix-mautrix-telegram.service depends on. | ||||
| matrix_mautrix_telegram_systemd_required_services_list: ['docker.service'] | ||||
|  | ||||
| # List of systemd services that matrix-mautrix-telegram.service wants | ||||
| matrix_mautrix_telegram_systemd_wanted_services_list: [] | ||||
|  | ||||
| matrix_mautrix_telegram_appservice_token: '' | ||||
| matrix_mautrix_telegram_homeserver_token: '' | ||||
|  | ||||
|  | ||||
| # Database-related configuration fields. | ||||
| # | ||||
| # To use SQLite, stick to these defaults. | ||||
| # | ||||
| # To use Postgres: | ||||
| # - change the engine (`matrix_mautrix_telegram_database_engine: 'postgres'`) | ||||
| # - adjust your database credentials via the `matrix_mautrix_telegram_postgres_*` variables | ||||
| matrix_mautrix_telegram_database_engine: 'sqlite' | ||||
|  | ||||
| matrix_mautrix_telegram_sqlite_database_path_local: "{{ matrix_mautrix_telegram_data_path }}/mautrix-telegram.db" | ||||
| matrix_mautrix_telegram_sqlite_database_path_in_container: "/data/mautrix-telegram.db" | ||||
|  | ||||
| matrix_mautrix_telegram_database_username: 'matrix_mautrix_telegram' | ||||
| matrix_mautrix_telegram_database_password: 'some-password' | ||||
| matrix_mautrix_telegram_database_hostname: 'matrix-postgres' | ||||
| matrix_mautrix_telegram_database_port: 5432 | ||||
| matrix_mautrix_telegram_database_name: 'matrix_mautrix_telegram' | ||||
|  | ||||
| matrix_mautrix_telegram_database_connection_string: 'postgres://{{ matrix_mautrix_telegram_database_username }}:{{ matrix_mautrix_telegram_database_password }}@{{ matrix_mautrix_telegram_database_hostname }}:{{ matrix_mautrix_telegram_database_port }}/{{ matrix_mautrix_telegram_database_name }}' | ||||
|  | ||||
| matrix_mautrix_telegram_appservice_database: "{{ | ||||
| 	{ | ||||
| 		'sqlite': ('sqlite:///' + matrix_mautrix_telegram_sqlite_database_path_in_container), | ||||
| 		'postgres': matrix_mautrix_telegram_database_connection_string, | ||||
| 	}[matrix_mautrix_telegram_database_engine] | ||||
| }}" | ||||
|  | ||||
|  | ||||
| # Can be set to enable automatic double-puppeting via Shared Secret Auth (https://github.com/devture/matrix-synapse-shared-secret-auth). | ||||
| matrix_mautrix_telegram_login_shared_secret: '' | ||||
|  | ||||
| # Default configuration template which covers the generic use case. | ||||
| # You can customize it by controlling the various variables inside it. | ||||
| # | ||||
| # For a more advanced customization, you can extend the default (see `matrix_mautrix_telegram_configuration_extension_yaml`) | ||||
| # or completely replace this variable with your own template. | ||||
| matrix_mautrix_telegram_configuration_yaml: "{{ lookup('template', 'templates/config.yaml.j2') }}" | ||||
|  | ||||
| matrix_mautrix_telegram_configuration_extension_yaml: | | ||||
|   # Your custom YAML configuration goes here. | ||||
|   # This configuration extends the default starting configuration (`matrix_mautrix_telegram_configuration_yaml`). | ||||
|   # | ||||
|   # You can override individual variables from the default configuration, or introduce new ones. | ||||
|   # | ||||
|   # If you need something more special, you can take full control by | ||||
|   # completely redefining `matrix_mautrix_telegram_configuration_yaml`. | ||||
|  | ||||
| matrix_mautrix_telegram_configuration_extension: "{{ matrix_mautrix_telegram_configuration_extension_yaml|from_yaml if matrix_mautrix_telegram_configuration_extension_yaml|from_yaml is mapping else {} }}" | ||||
|  | ||||
| # Holds the final configuration (a combination of the default and its extension). | ||||
| # You most likely don't need to touch this variable. Instead, see `matrix_mautrix_telegram_configuration_yaml`. | ||||
| matrix_mautrix_telegram_configuration: "{{ matrix_mautrix_telegram_configuration_yaml|from_yaml|combine(matrix_mautrix_telegram_configuration_extension, recursive=True) }}" | ||||
|  | ||||
| matrix_mautrix_telegram_registration_yaml: | | ||||
|   id: telegram | ||||
|   as_token: "{{ matrix_mautrix_telegram_appservice_token }}" | ||||
|   hs_token: "{{ matrix_mautrix_telegram_homeserver_token }}" | ||||
|   namespaces: | ||||
|       users: | ||||
|       - exclusive: true | ||||
|         regex: '^@telegram_.+:{{ matrix_mautrix_telegram_homeserver_domain|regex_escape }}$' | ||||
|       - exclusive: true | ||||
|         regex: '^@{{ matrix_mautrix_telegram_appservice_bot_username|regex_escape }}:{{ matrix_mautrix_telegram_homeserver_domain|regex_escape }}$' | ||||
|       aliases: | ||||
|       - exclusive: true | ||||
|         regex: '^#telegram_.+:{{ matrix_mautrix_telegram_homeserver_domain|regex_escape }}$' | ||||
|   # See https://github.com/tulir/mautrix-signal/issues/43 | ||||
|   sender_localpart: _bot_{{ matrix_mautrix_telegram_appservice_bot_username }} | ||||
|   url: {{ matrix_mautrix_telegram_appservice_address }} | ||||
|   rate_limited: false | ||||
|   de.sorunome.msc2409.push_ephemeral: true | ||||
|  | ||||
| matrix_mautrix_telegram_registration: "{{ matrix_mautrix_telegram_registration_yaml|from_yaml }}" | ||||
							
								
								
									
										70
									
								
								roles/matrix-bridge-mautrix-telegram/tasks/init.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								roles/matrix-bridge-mautrix-telegram/tasks/init.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,70 @@ | ||||
| # See https://github.com/spantaleev/matrix-docker-ansible-deploy/issues/1070 | ||||
| # and https://github.com/spantaleev/matrix-docker-ansible-deploy/commit/1ab507349c752042d26def3e95884f6df8886b74#commitcomment-51108407 | ||||
| - name: Fail if trying to self-build on Ansible < 2.8 | ||||
|   fail: | ||||
|     msg: "To self-build the Element image, you should use Ansible 2.8 or higher. See docs/ansible.md" | ||||
|   when: "ansible_version.major == 2 and ansible_version.minor < 8 and matrix_mautrix_telegram_container_self_build and matrix_mautrix_telegram_enabled" | ||||
|  | ||||
| - set_fact: | ||||
|     matrix_systemd_services_list: "{{ matrix_systemd_services_list + ['matrix-mautrix-telegram.service'] }}" | ||||
|   when: matrix_mautrix_telegram_enabled|bool | ||||
|  | ||||
| # If the matrix-synapse role is not used, these variables may not exist. | ||||
| - set_fact: | ||||
|     matrix_synapse_container_extra_arguments: > | ||||
|       {{ matrix_synapse_container_extra_arguments|default([]) }} | ||||
|       + | ||||
|       ["--mount type=bind,src={{ matrix_mautrix_telegram_config_path }}/registration.yaml,dst=/matrix-mautrix-telegram-registration.yaml,ro"] | ||||
|  | ||||
|     matrix_synapse_app_service_config_files: > | ||||
|       {{ matrix_synapse_app_service_config_files|default([]) }} | ||||
|       + | ||||
|       {{ ["/matrix-mautrix-telegram-registration.yaml"] }} | ||||
|   when: matrix_mautrix_telegram_enabled|bool | ||||
|  | ||||
| - block: | ||||
|   - name: Fail if matrix-nginx-proxy role already executed | ||||
|     fail: | ||||
|       msg: >- | ||||
|         Trying to append Mautrix Telegram's reverse-proxying configuration to matrix-nginx-proxy, | ||||
|         but it's pointless since the matrix-nginx-proxy role had already executed. | ||||
|         To fix this, please change the order of roles in your plabook, | ||||
|         so that the matrix-nginx-proxy role would run after the matrix-bridge-mautrix-telegram role. | ||||
|     when: matrix_nginx_proxy_role_executed|default(False)|bool | ||||
|  | ||||
|   - name: Generate Mautrix Telegram proxying configuration for matrix-nginx-proxy | ||||
|     set_fact: | ||||
|       matrix_mautrix_telegram_matrix_nginx_proxy_configuration: | | ||||
|         location {{ matrix_mautrix_telegram_public_endpoint }} { | ||||
|         {% if matrix_nginx_proxy_enabled|default(False) %} | ||||
|         	{# Use the embedded DNS resolver in Docker containers to discover the service #} | ||||
|         	resolver 127.0.0.11 valid=5s; | ||||
|         	set $backend "matrix-mautrix-telegram:8080"; | ||||
|         	proxy_pass http://$backend; | ||||
|         {% else %} | ||||
|         	{# Generic configuration for use outside of our container setup #} | ||||
|         	proxy_pass http://127.0.0.1:9006; | ||||
|         {% endif %} | ||||
|         } | ||||
|  | ||||
|   - name: Register Mautrix Telegram proxying configuration with matrix-nginx-proxy | ||||
|     set_fact: | ||||
|       matrix_nginx_proxy_proxy_matrix_additional_server_configuration_blocks: | | ||||
|         {{ | ||||
|           matrix_nginx_proxy_proxy_matrix_additional_server_configuration_blocks|default([]) | ||||
|           + | ||||
|           [matrix_mautrix_telegram_matrix_nginx_proxy_configuration] | ||||
|         }} | ||||
|   tags: | ||||
|    - always | ||||
|   when: matrix_mautrix_telegram_enabled|bool | ||||
|  | ||||
| - name: Warn about reverse-proxying if matrix-nginx-proxy not used | ||||
|   debug: | ||||
|     msg: >- | ||||
|       NOTE: You've enabled the Mautrix Telegram bridge but are not using the matrix-nginx-proxy | ||||
|       reverse proxy. | ||||
|       Please make sure that you're proxying the `{{ matrix_mautrix_telegram_public_endpoint }}` | ||||
|       URL endpoint to the matrix-mautrix-telegram container. | ||||
|       You can expose the container's port using the `matrix_mautrix_telegram_container_http_host_bind_port` variable. | ||||
|   when: "matrix_mautrix_telegram_enabled|bool and matrix_nginx_proxy_enabled is not defined" | ||||
							
								
								
									
										21
									
								
								roles/matrix-bridge-mautrix-telegram/tasks/main.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								roles/matrix-bridge-mautrix-telegram/tasks/main.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | ||||
| - import_tasks: "{{ role_path }}/tasks/init.yml" | ||||
|   tags: | ||||
|     - always | ||||
|  | ||||
| - import_tasks: "{{ role_path }}/tasks/validate_config.yml" | ||||
|   when: "run_setup|bool and matrix_mautrix_telegram_enabled|bool" | ||||
|   tags: | ||||
|     - setup-all | ||||
|     - setup-mautrix-telegram | ||||
|  | ||||
| - import_tasks: "{{ role_path }}/tasks/setup_install.yml" | ||||
|   when: "run_setup|bool and matrix_mautrix_telegram_enabled|bool" | ||||
|   tags: | ||||
|     - setup-all | ||||
|     - setup-mautrix-telegram | ||||
|  | ||||
| - import_tasks: "{{ role_path }}/tasks/setup_uninstall.yml" | ||||
|   when: "run_setup|bool and not matrix_mautrix_telegram_enabled|bool" | ||||
|   tags: | ||||
|     - setup-all | ||||
|     - setup-mautrix-telegram | ||||
							
								
								
									
										150
									
								
								roles/matrix-bridge-mautrix-telegram/tasks/setup_install.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										150
									
								
								roles/matrix-bridge-mautrix-telegram/tasks/setup_install.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,150 @@ | ||||
| --- | ||||
|  | ||||
| # If the matrix-synapse role is not used, `matrix_synapse_role_executed` won't exist. | ||||
| # We don't want to fail in such cases. | ||||
| - name: Fail if matrix-synapse role already executed | ||||
|   fail: | ||||
|     msg: >- | ||||
|       The matrix-bridge-mautrix-telegram role needs to execute before the matrix-synapse role. | ||||
|   when: "matrix_synapse_role_executed|default(False)" | ||||
|  | ||||
| - set_fact: | ||||
|     matrix_mautrix_telegram_requires_restart: false | ||||
|  | ||||
| - block: | ||||
|     - name: Check if an SQLite database already exists | ||||
|       stat: | ||||
|         path: "{{ matrix_mautrix_telegram_sqlite_database_path_local }}" | ||||
|       register: matrix_mautrix_telegram_sqlite_database_path_local_stat_result | ||||
|  | ||||
|     - block: | ||||
|         - set_fact: | ||||
|             matrix_postgres_db_migration_request: | ||||
|               src: "{{ matrix_mautrix_telegram_sqlite_database_path_local }}" | ||||
|               dst: "{{ matrix_mautrix_telegram_database_connection_string }}" | ||||
|               caller: "{{ role_path|basename }}" | ||||
|               engine_variable_name: 'matrix_mautrix_telegram_database_engine' | ||||
|               engine_old: 'sqlite' | ||||
|               systemd_services_to_stop: ['matrix-mautrix-telegram.service'] | ||||
|  | ||||
|         - import_tasks: "{{ role_path }}/../matrix-postgres/tasks/util/migrate_db_to_postgres.yml" | ||||
|  | ||||
|         - set_fact: | ||||
|             matrix_mautrix_telegram_requires_restart: true | ||||
|       when: "matrix_mautrix_telegram_sqlite_database_path_local_stat_result.stat.exists|bool" | ||||
|   when: "matrix_mautrix_telegram_database_engine == 'postgres'" | ||||
|  | ||||
| - name: Ensure Mautrix Telegram paths exist | ||||
|   file: | ||||
|     path: "{{ item.path }}" | ||||
|     state: directory | ||||
|     mode: 0750 | ||||
|     owner: "{{ matrix_user_username }}" | ||||
|     group: "{{ matrix_user_groupname }}" | ||||
|   with_items: | ||||
|     - { path: "{{ matrix_mautrix_telegram_base_path }}", when: true } | ||||
|     - { path: "{{ matrix_mautrix_telegram_config_path }}", when: true } | ||||
|     - { path: "{{ matrix_mautrix_telegram_data_path }}", when: true } | ||||
|     - { path: "{{ matrix_mautrix_telegram_docker_src_files_path }}", when: "{{ matrix_mautrix_telegram_container_self_build }}" } | ||||
|   when: item.when|bool | ||||
|  | ||||
| - name: Ensure Mautrix Telegram image is pulled | ||||
|   docker_image: | ||||
|     name: "{{ matrix_mautrix_telegram_docker_image }}" | ||||
|     source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}" | ||||
|     force_source: "{{ matrix_mautrix_telegram_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_mautrix_telegram_docker_image_force_pull }}" | ||||
|   when: "not matrix_mautrix_telegram_container_self_build|bool" | ||||
|  | ||||
| - name: Ensure lottieconverter is present when self-building | ||||
|   git: | ||||
|     repo: "{{ matrix_telegram_lottieconverter_docker_repo }}" | ||||
|     dest: "{{ matrix_telegram_lottieconverter_docker_src_files_path }}" | ||||
|     force: "yes" | ||||
|   register: matrix_telegram_lottieconverter_git_pull_results | ||||
|   when: "matrix_telegram_lottieconverter_container_self_build|bool and matrix_mautrix_telegram_container_self_build|bool" | ||||
|  | ||||
| - name: Ensure lottieconverter Docker image is built | ||||
|   docker_image: | ||||
|     name: "{{ matrix_telegram_lottieconverter_docker_image }}" | ||||
|     source: build | ||||
|     force_source: "{{ matrix_telegram_lottieconverter_git_pull_results.changed 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_telegram_lottieconverter_git_pull_results.changed }}" | ||||
|     build: | ||||
|       dockerfile: Dockerfile | ||||
|       path: "{{ matrix_telegram_lottieconverter_docker_src_files_path }}" | ||||
|       pull: yes | ||||
|   when: "matrix_telegram_lottieconverter_container_self_build|bool and matrix_telegram_lottieconverter_git_pull_results.changed and matrix_mautrix_telegram_container_self_build|bool" | ||||
|  | ||||
| - name: Ensure matrix-mautrix-telegram repository is present when self-building | ||||
|   git: | ||||
|     repo: "{{ matrix_mautrix_telegram_docker_repo }}" | ||||
|     dest: "{{ matrix_mautrix_telegram_docker_src_files_path }}" | ||||
|     force: "yes" | ||||
|   register: matrix_mautrix_telegram_git_pull_results | ||||
|   when: "matrix_mautrix_telegram_container_self_build|bool" | ||||
|  | ||||
| - name: Ensure matrix-mautrix-telegram Docker image is built | ||||
|   docker_image: | ||||
|     name: "{{ matrix_mautrix_telegram_docker_image }}" | ||||
|     source: build | ||||
|     force_source: "{{ matrix_mautrix_telegram_git_pull_results.changed 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_mautrix_telegram_git_pull_results.changed }}" | ||||
|     build: | ||||
|       dockerfile: Dockerfile | ||||
|       path: "{{ matrix_mautrix_telegram_docker_src_files_path }}" | ||||
|       pull: "{{ not matrix_telegram_lottieconverter_container_self_build_mask_arch|bool }}" | ||||
|       args: | ||||
|         TARGETARCH: "" | ||||
|   when: "matrix_mautrix_telegram_container_self_build|bool and matrix_mautrix_telegram_git_pull_results.changed" | ||||
|  | ||||
| - name: Check if an old database file already exists | ||||
|   stat: | ||||
|     path: "{{ matrix_mautrix_telegram_base_path }}/mautrix-telegram.db" | ||||
|   register: matrix_mautrix_telegram_stat_database | ||||
|  | ||||
| - name: (Data relocation) Ensure matrix-mautrix-telegram.service is stopped | ||||
|   service: | ||||
|     name: matrix-mautrix-telegram | ||||
|     state: stopped | ||||
|     daemon_reload: yes | ||||
|   failed_when: false | ||||
|   when: "matrix_mautrix_telegram_stat_database.stat.exists" | ||||
|  | ||||
| - name: (Data relocation) Move mautrix-telegram database file to ./data directory | ||||
|   command: "mv {{ matrix_mautrix_telegram_base_path }}/mautrix-telegram.db {{ matrix_mautrix_telegram_data_path }}/mautrix-telegram.db" | ||||
|   when: "matrix_mautrix_telegram_stat_database.stat.exists" | ||||
|  | ||||
| - name: Ensure mautrix-telegram config.yaml installed | ||||
|   copy: | ||||
|     content: "{{ matrix_mautrix_telegram_configuration|to_nice_yaml }}" | ||||
|     dest: "{{ matrix_mautrix_telegram_config_path }}/config.yaml" | ||||
|     mode: 0644 | ||||
|     owner: "{{ matrix_user_username }}" | ||||
|     group: "{{ matrix_user_groupname }}" | ||||
|  | ||||
| - name: Ensure mautrix-telegram registration.yaml installed | ||||
|   copy: | ||||
|     content: "{{ matrix_mautrix_telegram_registration|to_nice_yaml }}" | ||||
|     dest: "{{ matrix_mautrix_telegram_config_path }}/registration.yaml" | ||||
|     mode: 0644 | ||||
|     owner: "{{ matrix_user_username }}" | ||||
|     group: "{{ matrix_user_groupname }}" | ||||
|  | ||||
| - name: Ensure matrix-mautrix-telegram.service installed | ||||
|   template: | ||||
|     src: "{{ role_path }}/templates/systemd/matrix-mautrix-telegram.service.j2" | ||||
|     dest: "{{ matrix_systemd_path }}/matrix-mautrix-telegram.service" | ||||
|     mode: 0644 | ||||
|   register: matrix_mautrix_telegram_systemd_service_result | ||||
|  | ||||
| - name: Ensure systemd reloaded after matrix-mautrix-telegram.service installation | ||||
|   service: | ||||
|     daemon_reload: yes | ||||
|   when: "matrix_mautrix_telegram_systemd_service_result.changed" | ||||
|  | ||||
| - name: Ensure matrix-mautrix-telegram.service restarted, if necessary | ||||
|   service: | ||||
|     name: "matrix-mautrix-telegram.service" | ||||
|     state: restarted | ||||
|   when: "matrix_mautrix_telegram_requires_restart|bool" | ||||
| @@ -0,0 +1,24 @@ | ||||
| --- | ||||
|  | ||||
| - name: Check existence of matrix-mautrix-telegram service | ||||
|   stat: | ||||
|     path: "{{ matrix_systemd_path }}/matrix-mautrix-telegram.service" | ||||
|   register: matrix_mautrix_telegram_service_stat | ||||
|  | ||||
| - name: Ensure matrix-mautrix-telegram is stopped | ||||
|   service: | ||||
|     name: matrix-mautrix-telegram | ||||
|     state: stopped | ||||
|     daemon_reload: yes | ||||
|   when: "matrix_mautrix_telegram_service_stat.stat.exists" | ||||
|  | ||||
| - name: Ensure matrix-mautrix-telegram.service doesn't exist | ||||
|   file: | ||||
|     path: "{{ matrix_systemd_path }}/matrix-mautrix-telegram.service" | ||||
|     state: absent | ||||
|   when: "matrix_mautrix_telegram_service_stat.stat.exists" | ||||
|  | ||||
| - name: Ensure systemd reloaded after matrix-mautrix-telegram.service removal | ||||
|   service: | ||||
|     daemon_reload: yes | ||||
|   when: "matrix_mautrix_telegram_service_stat.stat.exists" | ||||
| @@ -0,0 +1,22 @@ | ||||
| --- | ||||
|  | ||||
| - name: Fail if required settings not defined | ||||
|   fail: | ||||
|     msg: >- | ||||
|       You need to define a required configuration setting (`{{ item }}`). | ||||
|   when: "vars[item] == ''" | ||||
|   with_items: | ||||
|     - "matrix_mautrix_telegram_api_id" | ||||
|     - "matrix_mautrix_telegram_api_hash" | ||||
|     - "matrix_mautrix_telegram_public_endpoint" | ||||
|     - "matrix_mautrix_telegram_appservice_token" | ||||
|     - "matrix_mautrix_telegram_homeserver_token" | ||||
|  | ||||
| - name: (Deprecation) Catch and report renamed Telegram variables | ||||
|   fail: | ||||
|     msg: >- | ||||
|       Your configuration contains a variable, which now has a different name. | ||||
|       Please change your configuration to rename the variable (`{{ item.old }}` -> `{{ item.new }}`). | ||||
|   when: "item.old in vars" | ||||
|   with_items: | ||||
|     - {'old': 'matrix_mautrix_telegram_container_exposed_port_number', 'new': '<superseded by matrix_mautrix_telegram_container_http_host_bind_port>'} | ||||
							
								
								
									
										419
									
								
								roles/matrix-bridge-mautrix-telegram/templates/config.yaml.j2
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										419
									
								
								roles/matrix-bridge-mautrix-telegram/templates/config.yaml.j2
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,419 @@ | ||||
| #jinja2: lstrip_blocks: "True" | ||||
| # Homeserver details | ||||
| homeserver: | ||||
|     # The address that this appservice can use to connect to the homeserver. | ||||
|     address: {{ matrix_mautrix_telegram_homeserver_address }} | ||||
|     # The domain of the homeserver (for MXIDs, etc). | ||||
|     domain: {{ matrix_mautrix_telegram_homeserver_domain }} | ||||
|     # Whether or not to verify the SSL certificate of the homeserver. | ||||
|     # Only applies if address starts with https:// | ||||
|     verify_ssl: true | ||||
|  | ||||
| # Application service host/registration related details | ||||
| # Changing these values requires regeneration of the registration. | ||||
| appservice: | ||||
|     # The address that the homeserver can use to connect to this appservice. | ||||
|     address: {{ matrix_mautrix_telegram_appservice_address|to_json }} | ||||
|  | ||||
|     # The hostname and port where this appservice should listen. | ||||
|     hostname: 0.0.0.0 | ||||
|     port: 8080 | ||||
|     # The maximum body size of appservice API requests (from the homeserver) in mebibytes | ||||
|     # Usually 1 is enough, but on high-traffic bridges you might need to increase this to avoid 413s | ||||
|     max_body_size: 1 | ||||
|  | ||||
|     # The full URI to the database. SQLite and Postgres are fully supported. | ||||
|     # Other DBMSes supported by SQLAlchemy may or may not work. | ||||
|     # Format examples: | ||||
|     #   SQLite:   sqlite:///filename.db | ||||
|     #   Postgres: postgres://username:password@hostname/dbname | ||||
|     database: {{ matrix_mautrix_telegram_appservice_database|to_json }} | ||||
|  | ||||
|     # Public part of web server for out-of-Matrix interaction with the bridge. | ||||
|     # Used for things like login if the user wants to make sure the 2FA password isn't stored in | ||||
|     # the HS database. | ||||
|     public: | ||||
|         # Whether or not the public-facing endpoints should be enabled. | ||||
|         enabled: true | ||||
|         # The prefix to use in the public-facing endpoints. | ||||
|         prefix: {{ matrix_mautrix_telegram_public_endpoint|to_json }} | ||||
|         # The base URL where the public-facing endpoints are available. The prefix is not added | ||||
|         # implicitly. | ||||
|         external: {{ matrix_mautrix_telegram_appservice_public_external|to_json }} | ||||
|  | ||||
|     # Provisioning API part of the web server for automated portal creation and fetching information. | ||||
|     # Used by things like Dimension (https://dimension.t2bot.io/). | ||||
|     provisioning: | ||||
|         # Whether or not the provisioning API should be enabled. | ||||
|         enabled: false | ||||
|         # The prefix to use in the provisioning API endpoints. | ||||
|         prefix: /_matrix/provision/v1 | ||||
|         # The shared secret to authorize users of the API. | ||||
|         # Set to "generate" to generate and save a new token. | ||||
|         shared_secret: generate | ||||
|  | ||||
|     # The unique ID of this appservice. | ||||
|     id: telegram | ||||
|     # Username of the appservice bot. | ||||
|     bot_username: {{ matrix_mautrix_telegram_appservice_bot_username|to_json }} | ||||
|     # Display name and avatar for bot. Set to "remove" to remove display name/avatar, leave empty | ||||
|     # to leave display name/avatar as-is. | ||||
|     bot_displayname: Telegram bridge bot | ||||
|     bot_avatar: mxc://maunium.net/tJCRmUyJDsgRNgqhOgoiHWbX | ||||
|  | ||||
|     # Authentication tokens for AS <-> HS communication. | ||||
|     as_token: {{ matrix_mautrix_telegram_appservice_token|to_json }} | ||||
|     hs_token: {{ matrix_mautrix_telegram_homeserver_token|to_json }} | ||||
|  | ||||
| # Bridge config | ||||
| bridge: | ||||
|     # Localpart template of MXIDs for Telegram users. | ||||
|     # {userid} is replaced with the user ID of the Telegram user. | ||||
|     username_template: "telegram_{userid}" | ||||
|     # Localpart template of room aliases for Telegram portal rooms. | ||||
|     # {groupname} is replaced with the name part of the public channel/group invite link ( https://t.me/{} ) | ||||
|     alias_template: "telegram_{groupname}" | ||||
|     # Displayname template for Telegram users. | ||||
|     # {displayname} is replaced with the display name of the Telegram user. | ||||
|     displayname_template: "{displayname} (Telegram)" | ||||
|  | ||||
|     # Set the preferred order of user identifiers which to use in the Matrix puppet display name. | ||||
|     # In the (hopefully unlikely) scenario that none of the given keys are found, the numeric user | ||||
|     # ID is used. | ||||
|     # | ||||
|     # If the bridge is working properly, a phone number or an username should always be known, but | ||||
|     # the other one can very well be empty. | ||||
|     # | ||||
|     # Valid keys: | ||||
|     #   "full name"          (First and/or last name) | ||||
|     #   "full name reversed" (Last and/or first name) | ||||
|     #   "first name" | ||||
|     #   "last name" | ||||
|     #   "username" | ||||
|     #   "phone number" | ||||
|     displayname_preference: | ||||
|     - full name | ||||
|     - username | ||||
|     - phone number | ||||
|     # Maximum length of displayname | ||||
|     displayname_max_length: 100 | ||||
|  | ||||
|     # Maximum number of members to sync per portal when starting up. Other members will be | ||||
|     # synced when they send messages. The maximum is 10000, after which the Telegram server | ||||
|     # will not send any more members. | ||||
|     # Defaults to no local limit (-> limited to 10000 by server) | ||||
|     max_initial_member_sync: -1 | ||||
|     # Whether or not to sync the member list in channels. | ||||
|     # If no channel admins have logged into the bridge, the bridge won't be able to sync the member | ||||
|     # list regardless of this setting. | ||||
|     sync_channel_members: true | ||||
|     # Whether or not to skip deleted members when syncing members. | ||||
|     skip_deleted_members: true | ||||
|     # Whether or not to automatically synchronize contacts and chats of Matrix users logged into | ||||
|     # their Telegram account at startup. | ||||
|     startup_sync: true | ||||
|     # Number of most recently active dialogs to check when syncing chats. | ||||
|     # Dialogs include groups and private chats, but only groups are synced. | ||||
|     # Set to 0 to remove limit. | ||||
|     sync_dialog_limit: 30 | ||||
|     # Whether or not to sync and create portals for direct chats at startup. | ||||
|     sync_direct_chats: false | ||||
|     # The maximum number of simultaneous Telegram deletions to handle. | ||||
|     # A large number of simultaneous redactions could put strain on your homeserver. | ||||
|     max_telegram_delete: 10 | ||||
|     # Whether or not to automatically sync the Matrix room state (mostly unpuppeted displaynames) | ||||
|     # at startup and when creating a bridge. | ||||
|     sync_matrix_state: true | ||||
|     # Allow logging in within Matrix. If false, users can only log in using login-qr or the | ||||
|     # out-of-Matrix login website (see appservice.public config section) | ||||
|     allow_matrix_login: true | ||||
|     # Whether or not to bridge plaintext highlights. | ||||
|     # Only enable this if your displayname_template has some static part that the bridge can use to | ||||
|     # reliably identify what is a plaintext highlight. | ||||
|     plaintext_highlights: false | ||||
|     # Whether or not to make portals of publicly joinable channels/supergroups publicly joinable on Matrix. | ||||
|     public_portals: true | ||||
|     # Whether or not to use /sync to get presence, read receipts and typing notifications when using | ||||
|     # your own Matrix account as the Matrix puppet for your Telegram account. | ||||
|     sync_with_custom_puppets: true | ||||
|     # Shared secret for https://github.com/devture/matrix-synapse-shared-secret-auth | ||||
|     # | ||||
|     # If set, custom puppets will be enabled automatically for local users | ||||
|     # instead of users having to find an access token and run `login-matrix` | ||||
|     # manually. | ||||
|     login_shared_secret: {{ matrix_mautrix_telegram_login_shared_secret|to_json }} | ||||
|     # Set to false to disable link previews in messages sent to Telegram. | ||||
|     telegram_link_preview: true | ||||
|     # Use inline images instead of a separate message for the caption. | ||||
|     # N.B. Inline images are not supported on all clients (e.g. Element iOS). | ||||
|     inline_images: false | ||||
|     # Maximum size of image in megabytes before sending to Telegram as a document. | ||||
|     image_as_file_size: 10 | ||||
|     # Maximum size of Telegram documents in megabytes to bridge. | ||||
|     max_document_size: 100 | ||||
|     # Enable experimental parallel file transfer, which makes uploads/downloads much faster by | ||||
|     # streaming from/to Matrix and using many connections for Telegram. | ||||
|     # Note that generating HQ thumbnails for videos is not possible with streamed transfers. | ||||
|     parallel_file_transfer: false | ||||
|     # Whether or not created rooms should have federation enabled. | ||||
|     # If false, created portal rooms will never be federated. | ||||
|     federate_rooms: true | ||||
|     # Settings for converting animated stickers. | ||||
|     animated_sticker: | ||||
|         # Format to which animated stickers should be converted. | ||||
|         # disable - No conversion, send as-is (gzipped lottie) | ||||
|         # png - converts to non-animated png (fastest), | ||||
|         # gif - converts to animated gif, but loses transparency | ||||
|         # webm - converts to webm video, requires ffmpeg executable with vp9 codec and webm container support | ||||
|         target: gif | ||||
|         # Arguments for converter. All converters take width and height. | ||||
|         # GIF converter takes background as a hex color. | ||||
|         args: | ||||
|             width: 256 | ||||
|             height: 256 | ||||
|             background: "020202"  # only for gif | ||||
|             fps: 30               # only for webm | ||||
|     # End-to-bridge encryption support options. These require matrix-nio to be installed with pip | ||||
|     # and login_shared_secret to be configured in order to get a device for the bridge bot. | ||||
|     # | ||||
|     # Additionally, https://github.com/matrix-org/synapse/pull/5758 is required if using a normal | ||||
|     # application service. | ||||
|     encryption: | ||||
|         # Allow encryption, work in group chat rooms with e2ee enabled | ||||
|         allow: false | ||||
|         # Default to encryption, force-enable encryption in all portals the bridge creates | ||||
|         # This will cause the bridge bot to be in private chats for the encryption to work properly. | ||||
|         default: false | ||||
|         # Database for the encryption data. Currently only supports Postgres and an in-memory | ||||
|         # store that's persisted as a pickle. | ||||
|         # If set to `default`, will use the appservice postgres database | ||||
|         # or a pickle file if the appservice database is sqlite. | ||||
|         # | ||||
|         # Format examples: | ||||
|         #   Pickle:   pickle:///filename.pickle | ||||
|         #   Postgres: postgres://username:password@hostname/dbname | ||||
|         database: default | ||||
|  | ||||
|     # Whether or not to explicitly set the avatar and room name for private | ||||
|     # chat portal rooms. This will be implicitly enabled if encryption.default is true. | ||||
|     private_chat_portal_meta: false | ||||
|     # Whether or not the bridge should send a read receipt from the bridge bot when a message has | ||||
|     # been sent to Telegram. | ||||
|     delivery_receipts: false | ||||
|     # Whether or not delivery errors should be reported as messages in the Matrix room. | ||||
|     delivery_error_reports: false | ||||
|     # Set this to true to tell the bridge to re-send m.bridge events to all rooms on the next run. | ||||
|     # This field will automatically be changed back to false after it, | ||||
|     # except if the config file is not writable. | ||||
|     resend_bridge_info: false | ||||
|  | ||||
|     # Overrides for base power levels. | ||||
|     initial_power_level_overrides: | ||||
|         user: {} | ||||
|         group: {} | ||||
|  | ||||
|     # Whether to bridge Telegram bot messages as m.notices or m.texts. | ||||
|     bot_messages_as_notices: true | ||||
|     bridge_notices: | ||||
|         # Whether or not Matrix bot messages (type m.notice) should be bridged. | ||||
|         default: false | ||||
|         # List of user IDs for whom the previous flag is flipped. | ||||
|         # e.g. if bridge_notices.default is false, notices from other users will not be bridged, but | ||||
|         #      notices from users listed here will be bridged. | ||||
|         exceptions: [] | ||||
|  | ||||
|     # Some config options related to Telegram message deduplication. | ||||
|     # The default values are usually fine, but some debug messages/warnings might recommend you | ||||
|     # change these. | ||||
|     deduplication: | ||||
|         # Whether or not to check the database if the message about to be sent is a duplicate. | ||||
|         pre_db_check: false | ||||
|         # The number of latest events to keep when checking for duplicates. | ||||
|         # You might need to increase this on high-traffic bridge instances. | ||||
|         cache_queue_length: 20 | ||||
|  | ||||
|  | ||||
|     # The formats to use when sending messages to Telegram via the relay bot. | ||||
|     # | ||||
|     # Telegram doesn't have built-in emotes, so the m.emote format is also used for non-relaybot users. | ||||
|     # | ||||
|     # Available variables: | ||||
|     #   $sender_displayname    - The display name of the sender (e.g. Example User) | ||||
|     #   $sender_username       - The username (Matrix ID localpart) of the sender (e.g. exampleuser) | ||||
|     #   $sender_mxid           - The Matrix ID of the sender (e.g. @exampleuser:example.com) | ||||
|     #   $message               - The message content as HTML | ||||
|     message_formats: | ||||
|         m.text: "<b>$sender_displayname</b>: $message" | ||||
|         m.notice: "<b>$sender_displayname</b>: $message" | ||||
|         m.emote: "* <b>$sender_displayname</b> $message" | ||||
|         m.file: "<b>$sender_displayname</b> sent a file: $message" | ||||
|         m.image: "<b>$sender_displayname</b> sent an image: $message" | ||||
|         m.audio: "<b>$sender_displayname</b> sent an audio file: $message" | ||||
|         m.video: "<b>$sender_displayname</b> sent a video: $message" | ||||
|         m.location: "<b>$sender_displayname</b> sent a location: $message" | ||||
|     # Telegram doesn't have built-in emotes, this field specifies how m.emote's from authenticated | ||||
|     # users are sent to telegram. All fields in message_formats are supported. Additionally, the | ||||
|     # Telegram user info is available in the following variables: | ||||
|     #    $displayname - Telegram displayname | ||||
|     #    $username    - Telegram username (may not exist) | ||||
|     #    $mention     - Telegram @username or displayname mention (depending on which exists) | ||||
|     emote_format: "* $mention $formatted_body" | ||||
|  | ||||
|     # The formats to use when sending state events to Telegram via the relay bot. | ||||
|     # | ||||
|     # Variables from `message_formats` that have the `sender_` prefix are available without the prefix. | ||||
|     # In name_change events, `$prev_displayname` is the previous displayname. | ||||
|     # | ||||
|     # Set format to an empty string to disable the messages for that event. | ||||
|     state_event_formats: | ||||
|         join: "<b>$displayname</b> joined the room." | ||||
|         leave: "<b>$displayname</b> left the room." | ||||
|         name_change: "<b>$prev_displayname</b> changed their name to <b>$displayname</b>" | ||||
|  | ||||
|     # Filter rooms that can/can't be bridged. Can also be managed using the `filter` and | ||||
|     # `filter-mode` management commands. | ||||
|     # | ||||
|     # Filters do not affect direct chats. | ||||
|     # An empty blacklist will essentially disable the filter. | ||||
|     filter: | ||||
|         # Filter mode to use. Either "blacklist" or "whitelist". | ||||
|         # If the mode is "blacklist", the listed chats will never be bridged. | ||||
|         # If the mode is "whitelist", only the listed chats can be bridged. | ||||
|         mode: blacklist | ||||
|         # The list of group/channel IDs to filter. | ||||
|         list: [] | ||||
|  | ||||
|     # The prefix for commands. Only required in non-management rooms. | ||||
|     command_prefix: "!tg" | ||||
|  | ||||
|     # Permissions for using the bridge. | ||||
|     # Permitted values: | ||||
|     #   relaybot - Only use the bridge via the relaybot, no access to commands. | ||||
|     #       user - Relaybot level + access to commands to create bridges. | ||||
|     #  puppeting - User level + logging in with a Telegram account. | ||||
|     #       full - Full access to use the bridge, i.e. previous levels + Matrix login. | ||||
|     #      admin - Full access to use the bridge and some extra administration commands. | ||||
|     # Permitted keys: | ||||
|     #        * - All Matrix users | ||||
|     #   domain - All users on that homeserver | ||||
|     #     mxid - Specific user | ||||
|     permissions: | ||||
|       '{{ matrix_mautrix_telegram_homeserver_domain }}': full | ||||
|  | ||||
|     # Options related to the message relay Telegram bot. | ||||
|     relaybot: | ||||
|         private_chat: | ||||
|             # List of users to invite to the portal when someone starts a private chat with the bot. | ||||
|             # If empty, private chats with the bot won't create a portal. | ||||
|             invite: [] | ||||
|             # Whether or not to bridge state change messages in relaybot private chats. | ||||
|             state_changes: true | ||||
|             # When private_chat_invite is empty, this message is sent to users /starting the | ||||
|             # relaybot. Telegram's "markdown" is supported. | ||||
|             message: This is a Matrix bridge relaybot and does not support direct chats | ||||
|         # List of users to invite to all group chat portals created by the bridge. | ||||
|         group_chat_invite: [] | ||||
|         # Whether or not the relaybot should not bridge events in unbridged group chats. | ||||
|         # If false, portals will be created when the relaybot receives messages, just like normal | ||||
|         # users. This behavior is usually not desirable, as it interferes with manually bridging | ||||
|         # the chat to another room. | ||||
|         ignore_unbridged_group_chat: true | ||||
|         # Whether or not to allow creating portals from Telegram. | ||||
|         authless_portals: true | ||||
|         # Whether or not to allow Telegram group admins to use the bot commands. | ||||
|         whitelist_group_admins: true | ||||
|         # Whether or not to ignore incoming events sent by the relay bot. | ||||
|         ignore_own_incoming_events: true | ||||
|         # List of usernames/user IDs who are also allowed to use the bot commands. | ||||
|         whitelist: [] | ||||
|  | ||||
| # Telegram config | ||||
| telegram: | ||||
|     # Get your own API keys at https://my.telegram.org/apps | ||||
|     api_id: {{ matrix_mautrix_telegram_api_id|to_json }} | ||||
|     api_hash: {{ matrix_mautrix_telegram_api_hash|to_json }} | ||||
|     # (Optional) Create your own bot at https://t.me/BotFather | ||||
|     bot_token: {{ matrix_mautrix_telegram_bot_token|to_json }} | ||||
|  | ||||
|     # Telethon connection options. | ||||
|     connection: | ||||
|         # The timeout in seconds to be used when connecting. | ||||
|         timeout: 120 | ||||
|         # How many times the reconnection should retry, either on the initial connection or when | ||||
|         # Telegram disconnects us. May be set to a negative or null value for infinite retries, but | ||||
|         # this is not recommended, since the program can get stuck in an infinite loop. | ||||
|         retries: 5 | ||||
|         # The delay in seconds to sleep between automatic reconnections. | ||||
|         retry_delay: 1 | ||||
|         # The threshold below which the library should automatically sleep on flood wait errors | ||||
|         # (inclusive). For instance, if a FloodWaitError for 17s occurs and flood_sleep_threshold | ||||
|         # is 20s, the library will sleep automatically. If the error was for 21s, it would raise | ||||
|         # the error instead. Values larger than a day (86400) will be changed to a day. | ||||
|         flood_sleep_threshold: 60 | ||||
|         # How many times a request should be retried. Request are retried when Telegram is having | ||||
|         # internal issues, when there is a FloodWaitError less than flood_sleep_threshold, or when | ||||
|         # there's a migrate error. May take a negative or null value for infinite retries, but this | ||||
|         # is not recommended, since some requests can always trigger a call fail (such as searching | ||||
|         # for messages). | ||||
|         request_retries: 5 | ||||
|  | ||||
|     # Device info sent to Telegram. | ||||
|     device_info: | ||||
|         # "auto" = OS name+version. | ||||
|         device_model: auto | ||||
|         # "auto" = Telethon version. | ||||
|         system_version: auto | ||||
|         # "auto" = mautrix-telegram version. | ||||
|         app_version: auto | ||||
|         lang_code: en | ||||
|         system_lang_code: en | ||||
|  | ||||
|     # Custom server to connect to. | ||||
|     server: | ||||
|         # Set to true to use these server settings. If false, will automatically | ||||
|         # use production server assigned by Telegram. Set to false in production. | ||||
|         enabled: false | ||||
|         # The DC ID to connect to. | ||||
|         dc: 2 | ||||
|         # The IP to connect to. | ||||
|         ip: 149.154.167.40 | ||||
|         # The port to connect to. 443 may not work, 80 is better and both are equally secure. | ||||
|         port: 80 | ||||
|  | ||||
|     # Telethon proxy configuration. | ||||
|     # You must install PySocks from pip for proxies to work. | ||||
|     proxy: | ||||
|         # Allowed types: disabled, socks4, socks5, http | ||||
|         type: disabled | ||||
|         # Proxy IP address and port. | ||||
|         address: 127.0.0.1 | ||||
|         port: 1080 | ||||
|         # Whether or not to perform DNS resolving remotely. | ||||
|         rdns: true | ||||
|         # Proxy authentication (optional). | ||||
|         username: "" | ||||
|         password: "" | ||||
|  | ||||
| # Python logging configuration. | ||||
| # | ||||
| # See section 16.7.2 of the Python documentation for more info: | ||||
| # https://docs.python.org/3.6/library/logging.config.html#configuration-dictionary-schema | ||||
| logging: | ||||
|     version: 1 | ||||
|     formatters: | ||||
|         precise: | ||||
|             format: "[%(asctime)s] [%(levelname)s@%(name)s] %(message)s" | ||||
|     handlers: | ||||
|         console: | ||||
|             class: logging.StreamHandler | ||||
|             formatter: precise | ||||
|     loggers: | ||||
|         mau: | ||||
|             level: DEBUG | ||||
|         telethon: | ||||
|             level: DEBUG | ||||
|         aiohttp: | ||||
|             level: INFO | ||||
|     root: | ||||
|         level: DEBUG | ||||
|         handlers: [console] | ||||
| @@ -0,0 +1,54 @@ | ||||
| #jinja2: lstrip_blocks: "True" | ||||
| [Unit] | ||||
| Description=Matrix Mautrix Telegram bridge | ||||
| {% for service in matrix_mautrix_telegram_systemd_required_services_list %} | ||||
| Requires={{ service }} | ||||
| After={{ service }} | ||||
| {% endfor %} | ||||
| {% for service in matrix_mautrix_telegram_systemd_wanted_services_list %} | ||||
| Wants={{ service }} | ||||
| {% endfor %} | ||||
| DefaultDependencies=no | ||||
|  | ||||
| [Service] | ||||
| Type=simple | ||||
| Environment="HOME={{ matrix_systemd_unit_home_path }}" | ||||
| ExecStartPre=-{{ matrix_host_command_sh }} -c '{{ matrix_host_command_docker }} kill matrix-mautrix-telegram 2>/dev/null' | ||||
| ExecStartPre=-{{ matrix_host_command_sh }} -c '{{ matrix_host_command_docker }} rm matrix-mautrix-telegram 2>/dev/null' | ||||
| ExecStartPre={{ matrix_host_command_docker }} run --rm --name matrix-mautrix-telegram-db \ | ||||
| 			--log-driver=none \ | ||||
| 			--user={{ matrix_user_uid }}:{{ matrix_user_gid }} \ | ||||
| 			--cap-drop=ALL \ | ||||
| 			--network={{ matrix_docker_network }} \ | ||||
| 			-v {{ matrix_mautrix_telegram_config_path }}:/config:z \ | ||||
| 			-v {{ matrix_mautrix_telegram_data_path }}:/data:z \ | ||||
| 			{{ matrix_mautrix_telegram_docker_image }} \ | ||||
| 			alembic -x config=/config/config.yaml upgrade head | ||||
|  | ||||
| # Intentional delay, so that the homeserver (we likely depend on) can manage to start. | ||||
| ExecStartPre={{ matrix_host_command_sleep }} 5 | ||||
|  | ||||
| ExecStart={{ matrix_host_command_docker }} run --rm --name matrix-mautrix-telegram \ | ||||
| 			--log-driver=none \ | ||||
| 			--user={{ matrix_user_uid }}:{{ matrix_user_gid }} \ | ||||
| 			--cap-drop=ALL \ | ||||
| 			--network={{ matrix_docker_network }} \ | ||||
| 			{% if matrix_mautrix_telegram_container_http_host_bind_port %} | ||||
| 			-p {{ matrix_mautrix_telegram_container_http_host_bind_port }}:8080 \ | ||||
| 			{% endif %} | ||||
| 			-v {{ matrix_mautrix_telegram_config_path }}:/config:z \ | ||||
| 			-v {{ matrix_mautrix_telegram_data_path }}:/data:z \ | ||||
| 			{% for arg in matrix_mautrix_telegram_container_extra_arguments %} | ||||
| 			{{ arg }} \ | ||||
| 			{% endfor %} | ||||
| 			{{ matrix_mautrix_telegram_docker_image }} \ | ||||
| 			python3 -m mautrix_telegram -c /config/config.yaml --no-update | ||||
|  | ||||
| ExecStop=-{{ matrix_host_command_sh }} -c '{{ matrix_host_command_docker }} kill matrix-mautrix-telegram 2>/dev/null' | ||||
| ExecStop=-{{ matrix_host_command_sh }} -c '{{ matrix_host_command_docker }} rm matrix-mautrix-telegram 2>/dev/null' | ||||
| Restart=always | ||||
| RestartSec=30 | ||||
| SyslogIdentifier=matrix-mautrix-telegram | ||||
|  | ||||
| [Install] | ||||
| WantedBy=multi-user.target | ||||
		Reference in New Issue
	
	Block a user