181 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			181 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| # SPDX-FileCopyrightText: 2023 Johan Swetzén
 | |
| # SPDX-FileCopyrightText: 2023 Samuel Meenzen
 | |
| # SPDX-FileCopyrightText: 2024 - 2025 Slavi Pantaleev
 | |
| # SPDX-FileCopyrightText: 2024 Suguru Hirahara
 | |
| #
 | |
| # SPDX-License-Identifier: AGPL-3.0-or-later
 | |
| 
 | |
| ---
 | |
| # mautrix-wsproxy is a Matrix <-> websocket bridge
 | |
| # See: https://github.com/mautrix/wsproxy
 | |
| 
 | |
| matrix_mautrix_wsproxy_enabled: true
 | |
| 
 | |
| matrix_mautrix_wsproxy_version: latest
 | |
| # See: https://mau.dev/mautrix/wsproxy/container_registry
 | |
| matrix_mautrix_wsproxy_docker_image: "{{ matrix_mautrix_wsproxy_docker_image_registry_prefix }}mautrix/wsproxy:{{ matrix_mautrix_wsproxy_version }}"
 | |
| matrix_mautrix_wsproxy_docker_image_registry_prefix: "{{ matrix_mautrix_wsproxy_docker_image_registry_prefix_upstream }}"
 | |
| matrix_mautrix_wsproxy_docker_image_registry_prefix_upstream: "{{ matrix_mautrix_wsproxy_docker_image_registry_prefix_upstream_default }}"
 | |
| matrix_mautrix_wsproxy_docker_image_registry_prefix_upstream_default: "dock.mau.dev/"
 | |
| matrix_mautrix_wsproxy_docker_image_force_pull: "{{ matrix_mautrix_wsproxy_docker_image.endswith(':latest') }}"
 | |
| 
 | |
| matrix_mautrix_wsproxy_base_path: "{{ matrix_base_data_path }}/wsproxy"
 | |
| matrix_mautrix_wsproxy_config_path: "{{ matrix_mautrix_wsproxy_base_path }}/config"
 | |
| 
 | |
| matrix_mautrix_wsproxy_homeserver_address: ""
 | |
| matrix_mautrix_wsproxy_homeserver_domain: "{{ matrix_domain }}"
 | |
| 
 | |
| matrix_mautrix_wsproxy_bind_port: false
 | |
| matrix_mautrix_wsproxy_port: 29331
 | |
| 
 | |
| matrix_mautrix_wsproxy_appservice_address: "http://matrix-mautrix-wsproxy:{{ matrix_mautrix_wsproxy_port }}"
 | |
| 
 | |
| matrix_mautrix_wsproxy_hostname: ""
 | |
| 
 | |
| # The base container network. It will be auto-created by this role if it doesn't exist already.
 | |
| matrix_mautrix_wsproxy_container_network: matrix-mautrix-wsproxy
 | |
| 
 | |
| matrix_mautrix_wsproxy_twitter_container_additional_networks: "{{ matrix_mautrix_wsproxy_twitter_container_additional_networks_auto + matrix_mautrix_wsproxy_twitter_container_additional_networks_custom }}"
 | |
| matrix_mautrix_wsproxy_twitter_container_additional_networks_auto: []
 | |
| matrix_mautrix_wsproxy_twitter_container_additional_networks_custom: []
 | |
| 
 | |
| # matrix_mautrix_wsproxy_container_labels_traefik_enabled controls whether labels to assist a Traefik reverse-proxy will be attached to the container.
 | |
| # See `../templates/labels.j2` for details.
 | |
| #
 | |
| # To inject your own other container labels, see `matrix_mautrix_wsproxy_container_labels_additional_labels`.
 | |
| matrix_mautrix_wsproxy_container_labels_traefik_enabled: true
 | |
| matrix_mautrix_wsproxy_container_labels_traefik_docker_network: "{{ matrix_mautrix_wsproxy_container_network }}"
 | |
| matrix_mautrix_wsproxy_container_labels_traefik_hostname: "{{ matrix_mautrix_wsproxy_hostname }}"
 | |
| # The path prefix must either be `/` or not end with a slash (e.g. `/wsproxy`).
 | |
| matrix_mautrix_wsproxy_container_labels_traefik_rule: "Host(`{{ matrix_mautrix_wsproxy_container_labels_traefik_hostname }}`)"
 | |
| matrix_mautrix_wsproxy_container_labels_traefik_priority: 0
 | |
| matrix_mautrix_wsproxy_container_labels_traefik_entrypoints: web-secure
 | |
| matrix_mautrix_wsproxy_container_labels_traefik_tls: "{{ matrix_mautrix_wsproxy_container_labels_traefik_entrypoints != 'web' }}"
 | |
| matrix_mautrix_wsproxy_container_labels_traefik_tls_certResolver: default  # noqa var-naming
 | |
| 
 | |
| # Controls which additional headers to attach to all HTTP responses.
 | |
| # To add your own headers, use `matrix_mautrix_wsproxy_container_labels_traefik_additional_response_headers_custom`
 | |
| matrix_mautrix_wsproxy_container_labels_traefik_additional_response_headers_auto: {}
 | |
| matrix_mautrix_wsproxy_container_labels_traefik_additional_response_headers_custom: {}
 | |
| matrix_mautrix_wsproxy_container_labels_traefik_additional_response_headers: "{{ matrix_mautrix_wsproxy_container_labels_traefik_additional_response_headers_auto | combine(matrix_mautrix_wsproxy_container_labels_traefik_additional_response_headers_custom) }}"
 | |
| 
 | |
| # matrix_mautrix_wsproxy_container_labels_additional_labels contains a multiline string with additional labels to add to the container label file.
 | |
| # See `../templates/labels.j2` for details.
 | |
| #
 | |
| # Example:
 | |
| # matrix_mautrix_wsproxy_container_labels_additional_labels: |
 | |
| #   my.label=1
 | |
| #   another.label="here"
 | |
| matrix_mautrix_wsproxy_container_labels_additional_labels: ''
 | |
| 
 | |
| # A list of extra arguments to pass to the container
 | |
| matrix_mautrix_wsproxy_container_extra_arguments: []
 | |
| 
 | |
| # List of systemd services that matrix-mautrix-wsproxy.service depends on.
 | |
| matrix_mautrix_wsproxy_systemd_required_services_list: "{{ matrix_mautrix_wsproxy_systemd_required_services_list_default + matrix_mautrix_wsproxy_systemd_required_services_list_auto + matrix_mautrix_wsproxy_systemd_required_services_list_custom }}"
 | |
| matrix_mautrix_wsproxy_systemd_required_services_list_default: "{{ [devture_systemd_docker_base_docker_service_name] if devture_systemd_docker_base_docker_service_name else [] }}"
 | |
| matrix_mautrix_wsproxy_systemd_required_services_list_auto: []
 | |
| matrix_mautrix_wsproxy_systemd_required_services_list_custom: []
 | |
| 
 | |
| # List of systemd services that matrix-mautrix-wsproxy.service wants
 | |
| matrix_mautrix_wsproxy_systemd_wanted_services_list: []
 | |
| 
 | |
| matrix_mautrix_androidsms_appservice_token: ''
 | |
| matrix_mautrix_androidsms_homeserver_token: ''
 | |
| 
 | |
| matrix_mautrix_imessage_appservice_token: ''
 | |
| matrix_mautrix_imessage_homeserver_token: ''
 | |
| 
 | |
| matrix_mautrix_androidsms_appservice_bot_username: androidsmsbot
 | |
| matrix_mautrix_imessage_appservice_bot_username: imessagebot
 | |
| 
 | |
| # Default mautrix-wsproxy 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_wsproxy_configuration_extension_yaml`)
 | |
| # or completely replace this variable with your own template.
 | |
| matrix_mautrix_wsproxy_configuration_yaml: "{{ lookup('template', 'templates/config.yaml.j2') }}"
 | |
| 
 | |
| matrix_mautrix_wsproxy_configuration_extension_yaml: |
 | |
|   # Your custom YAML configuration goes here.
 | |
|   # This configuration extends the default starting configuration (`matrix_mautrix_wsproxy_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_wsproxy_configuration_yaml`.
 | |
| 
 | |
| matrix_mautrix_wsproxy_configuration_extension: "{{ matrix_mautrix_wsproxy_configuration_extension_yaml | from_yaml if matrix_mautrix_wsproxy_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_wsproxy_configuration_yaml`.
 | |
| matrix_mautrix_wsproxy_configuration: "{{ matrix_mautrix_wsproxy_configuration_yaml | from_yaml | combine(matrix_mautrix_wsproxy_configuration_extension, recursive=True) }}"
 | |
| 
 | |
| matrix_mautrix_androidsms_registration_yaml: |
 | |
|   id: androidsms
 | |
|   url: {{ matrix_mautrix_wsproxy_appservice_address }}
 | |
|   as_token: "{{ matrix_mautrix_androidsms_appservice_token }}"
 | |
|   hs_token: "{{ matrix_mautrix_androidsms_homeserver_token }}"
 | |
|   sender_localpart: _bot_{{ matrix_mautrix_androidsms_appservice_bot_username }}
 | |
|   rate_limited: false
 | |
|   namespaces:
 | |
|       users:
 | |
|       - regex: '@androidsms_.+:{{ matrix_mautrix_wsproxy_homeserver_domain | regex_escape }}$'
 | |
|         exclusive: true
 | |
|       - exclusive: true
 | |
|         regex: '^@{{ matrix_mautrix_androidsms_appservice_bot_username | regex_escape }}:{{ matrix_mautrix_wsproxy_homeserver_domain | regex_escape }}$'
 | |
| 
 | |
| matrix_mautrix_androidsms_registration: "{{ matrix_mautrix_androidsms_registration_yaml | from_yaml }}"
 | |
| 
 | |
| matrix_mautrix_imessage_registration_yaml: |
 | |
|   id: imessage
 | |
|   url: {{ matrix_mautrix_wsproxy_appservice_address }}
 | |
|   as_token: "{{ matrix_mautrix_imessage_appservice_token }}"
 | |
|   hs_token: "{{ matrix_mautrix_imessage_homeserver_token }}"
 | |
|   sender_localpart: _bot_{{ matrix_mautrix_imessage_appservice_bot_username }}
 | |
|   rate_limited: false
 | |
|   namespaces:
 | |
|       users:
 | |
|       - regex: '@imessage_.+:{{ matrix_mautrix_wsproxy_homeserver_domain | regex_escape }}$'
 | |
|         exclusive: true
 | |
|       - exclusive: true
 | |
|         regex: '^@{{ matrix_mautrix_imessage_appservice_bot_username | regex_escape }}:{{ matrix_mautrix_wsproxy_homeserver_domain | regex_escape }}$'
 | |
| 
 | |
| matrix_mautrix_imessage_registration: "{{ matrix_mautrix_imessage_registration_yaml | from_yaml }}"
 | |
| 
 | |
| # Syncproxy-related configuration fields
 | |
| # renovate: datasource=docker depName=dock.mau.dev/mautrix/syncproxy
 | |
| matrix_mautrix_wsproxy_syncproxy_version: latest
 | |
| # See: https://mau.dev/mautrix/wsproxy/container_registry
 | |
| matrix_mautrix_wsproxy_syncproxy_docker_image: "dock.mau.dev/mautrix/syncproxy:{{ matrix_mautrix_wsproxy_syncproxy_version }}"
 | |
| matrix_mautrix_wsproxy_syncproxy_docker_image_force_pull: "{{ matrix_mautrix_wsproxy_syncproxy_docker_image.endswith(':latest') }}"
 | |
| matrix_mautrix_wsproxy_syncproxy_container_extra_arguments: []
 | |
| 
 | |
| matrix_mautrix_wsproxy_syncproxy_systemd_required_services_list: |-
 | |
|   {{
 | |
|     ([devture_systemd_docker_base_docker_service_name] if devture_systemd_docker_base_docker_service_name else [])
 | |
|     +
 | |
|     ['matrix-mautrix-wsproxy.service']
 | |
|   }}
 | |
| matrix_mautrix_wsproxy_syncproxy_systemd_wanted_services_list: []
 | |
| 
 | |
| matrix_mautrix_wsproxy_syncproxy_homeserver_url: ''
 | |
| 
 | |
| matrix_mautrix_wsproxy_syncproxy_shared_secret: ''
 | |
| matrix_mautrix_wsproxy_syncproxy_port: 29332
 | |
| matrix_mautrix_wsproxy_syncproxy_appservice_address: "http://matrix-mautrix-wsproxy-syncproxy:{{ matrix_mautrix_wsproxy_syncproxy_port }}"
 | |
| 
 | |
| # Database-related configuration fields
 | |
| #
 | |
| # This bridge supports Postgres and SQLite.
 | |
| #
 | |
| matrix_mautrix_wsproxy_syncproxy_database_engine: 'postgres'
 | |
| 
 | |
| matrix_mautrix_wsproxy_syncproxy_database_username: 'matrix_mautrix_wsproxy_syncproxy'
 | |
| matrix_mautrix_wsproxy_syncproxy_database_password: ''
 | |
| matrix_mautrix_wsproxy_syncproxy_database_hostname: ''
 | |
| matrix_mautrix_wsproxy_syncproxy_database_port: 5432
 | |
| matrix_mautrix_wsproxy_syncproxy_database_name: 'matrix_mautrix_wsproxy_syncproxy'
 | |
| 
 | |
| matrix_mautrix_signal_wsproxy_syncproxy_connection_string: 'postgres://{{ matrix_mautrix_wsproxy_syncproxy_database_username }}:{{ matrix_mautrix_wsproxy_syncproxy_database_password }}@{{ matrix_mautrix_wsproxy_syncproxy_database_hostname }}:{{ matrix_mautrix_wsproxy_syncproxy_database_port }}/{{ matrix_mautrix_wsproxy_syncproxy_database_name }}'
 |