4299d4ebd5
* Inital work, copeid from mautrix-amp PR * Some fixes leftover code copeid over from whatsapp * Got it to run and register * Fixed service issue with docker image * I now realize I need 2 roles wsproxy and imessage * Got someting working, still rough * Closer to working but still not working * reverting ports * Update main.yml * Add matrix-nginx-proxy config for mautrix-wsproxy * Changed * Add back file * fix for error hopefully * Changed the the way nginx was recieved * basically did not add anything ugh * Added some arguments * just trying stuff now * Ugh i messed up port number * Changed docs * Change dns config * changed generic secret key * Testing new nginx proxy * test * Fix linting errors * Add mautrix syncproxy to wsproxy for Android SMS * WIP * Move wsproxy to custom * Squashed commit of the following: commit943189a9aa
Merge:4a229d68
f5a09f30
Author: Slavi Pantaleev <slavi@devture.com> Date: Sun Nov 13 08:54:32 2022 +0200 Merge pull request #2259 from throny/patch-3 warn users about upgrading to pg15 when using borg commit4a229d6870
Merge:9b326e08
c68def08
Author: Slavi Pantaleev <slavi@devture.com> Date: Sun Nov 13 08:53:13 2022 +0200 Merge pull request #2260 from etkecc/patch-117 Update ntfy 1.28.0 -> 1.29.0 commitf5a09f30b7
Author: throny <m.throne12@gmail.com> Date: Sat Nov 12 23:48:57 2022 +0100 Update maintenance-postgres.md commitb12cdbd99d
Author: throny <m.throne12@gmail.com> Date: Sat Nov 12 23:40:46 2022 +0100 Update maintenance-postgres.md commitc68def0809
Author: Aine <97398200+etkecc@users.noreply.github.com> Date: Sat Nov 12 22:01:31 2022 +0000 Update ntfy 1.28.0 -> 1.29.0 commitadbc09f152
Author: throny <m.throne12@gmail.com> Date: Sat Nov 12 11:20:43 2022 +0100 warn users about upgrading to pg15 when using borg * Fix linting errors * Cleanup after merge * Correct outdated variable names * Enable both Android and iMessage with wsproxy * Restructure wsproxy service defs and nginx config * Fix linter errors * Apply suggestions from code review Co-authored-by: Slavi Pantaleev <slavi@devture.com> * Fix comments for documentation, volumes and ports * Correct mount syntax * Complete network and traefik support for wsproxy * Remove wsproxy data_path * Fix wsproxy service definitions * Actually include syncproxy service * Remove wsproxy PathPrefix, it needs a subdomain There's no setting in the iMessage bridge that allows a path. Also don't bind port by default, wsproxy has no TLS. Syncproxy should never expose a port, it's only internal. --------- Co-authored-by: hanthor <jreilly112@gmail.com> Co-authored-by: Miguel Alatzar <miguel@natrx.io> Co-authored-by: Shreyas Ajjarapu <github.tzarina@aleeas.com> Co-authored-by: Slavi Pantaleev <slavi@devture.com>
156 lines
8.5 KiB
YAML
156 lines
8.5 KiB
YAML
---
|
|
# 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: "dock.mau.dev/mautrix/wsproxy:{{ matrix_mautrix_wsproxy_version }}"
|
|
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_homeserver_container_url }}"
|
|
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_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: ['docker.service']
|
|
|
|
# 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
|
|
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: ['docker.service', 'matrix-mautrix-wsproxy.service']
|
|
matrix_mautrix_wsproxy_syncproxy_systemd_wanted_services_list: []
|
|
|
|
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: 'some-password'
|
|
matrix_mautrix_wsproxy_syncproxy_database_hostname: 'matrix-postgres'
|
|
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 }}'
|