Move mautrix telegram and whatsapp into separate roles
The goal is to move each bridge into its own separate role. This commit starts off the work on this with 2 bridges: - mautrix-telegram - mautrix-whatsapp Each bridge's role (including these 2) is meant to: - depend only on the matrix-base role - integrate nicely with the matrix-synapse role (if available) - integrate nicely with the matrix-nginx-proxy role (if available and if required). mautrix-telegram bridge benefits from integrating with it. - not break if matrix-synapse or matrix-nginx-proxy are not used at all This has been provoked by #174 (Github Issue).
This commit is contained in:
		| @@ -1,272 +0,0 @@ | ||||
| #jinja2: lstrip_blocks: "True" | ||||
| # Homeserver details | ||||
| homeserver: | ||||
|     # The address that this appservice can use to connect to the homeserver. | ||||
|     address: https://{{ matrix_server_fqn_matrix }} | ||||
|     # The domain of the homeserver (for MXIDs, etc). | ||||
|     domain: {{ matrix_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: http://matrix-mautrix-telegram:8080 | ||||
|  | ||||
|     # 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: sqlite:////data/mautrix-telegram.db | ||||
|  | ||||
|     # 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 }} | ||||
|         # The base URL where the public-facing endpoints are available. The prefix is not added | ||||
|         # implicitly. | ||||
|         external: https://{{ matrix_server_fqn_matrix }}{{ matrix_mautrix_telegram_public_endpoint }} | ||||
|  | ||||
|     # 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: telegrambot | ||||
|     # 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. Autogenerated; do not modify. | ||||
|     as_token: "This value is generated when generating the registration" | ||||
|     hs_token: "This value is generated when generating the registration" | ||||
|  | ||||
| # 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 | ||||
|  | ||||
|     # Show message editing as a reply to the original message. | ||||
|     # If this is false, message edits are not shown at all, as Matrix does not support editing yet. | ||||
|     edits_as_replies: false | ||||
|     # Highlight changed/added parts in edits. Requires lxml. | ||||
|     highlight_edits: false | ||||
|     # Whether or not Matrix bot messages (type m.notice) should be bridged. | ||||
|     bridge_notices: true | ||||
|     # Whether to bridge Telegram bot messages as m.notices or m.texts. | ||||
|     bot_messages_as_notices: true | ||||
|     # 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 | ||||
|     # 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 | ||||
|     # Allow logging in within Matrix. If false, the only way to log in is using the out-of-Matrix | ||||
|     # login website (see appservice.public config section) | ||||
|     allow_matrix_login: true | ||||
|     # Use inline images instead of m.image to make rich captions possible. | ||||
|     # N.B. Inline images are not supported on all clients (e.g. Riot iOS). | ||||
|     inline_images: 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 to send stickers as the new native m.sticker type or normal m.images. | ||||
|     # Old versions of Riot don't support the new type at all. | ||||
|     # Remember that proper sticker support always requires Pillow to convert webp into png. | ||||
|     native_stickers: true | ||||
|     # Whether or not to fetch and handle Telegram updates at startup from the time the bridge was down. | ||||
|     # WARNING: Probably buggy, might get stuck in infinite loop. | ||||
|     catch_up: false | ||||
|     # 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 | ||||
|  | ||||
|     # 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.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" | ||||
|  | ||||
|     # 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_domain }}': full | ||||
|  | ||||
|     # Options related to the message relay Telegram bot. | ||||
|     relaybot: | ||||
|         # Whether or not to allow creating portals from Telegram. | ||||
|         authless_portals: false | ||||
|         # Whether or not to allow Telegram group admins to use the bot commands. | ||||
|         whitelist_group_admins: false | ||||
|         # 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 }} | ||||
|     api_hash: {{ matrix_mautrix_telegram_api_hash }} | ||||
|     # (Optional) Create your own bot at https://t.me/BotFather | ||||
|     bot_token: disabled | ||||
|     # 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: | ||||
|         file: | ||||
|             class: logging.handlers.RotatingFileHandler | ||||
|             formatter: precise | ||||
|             filename: /data/mautrix-telegram.log | ||||
|             maxBytes: 10485760 | ||||
|             backupCount: 10 | ||||
|         console: | ||||
|             class: logging.StreamHandler | ||||
|             formatter: precise | ||||
|     loggers: | ||||
|         mau: | ||||
|             level: DEBUG | ||||
|         telethon: | ||||
|             level: DEBUG | ||||
|         aiohttp: | ||||
|             level: INFO | ||||
|     root: | ||||
|         level: DEBUG | ||||
|         handlers: [file, console] | ||||
| @@ -1,37 +0,0 @@ | ||||
| #jinja2: lstrip_blocks: "True" | ||||
| [Unit] | ||||
| Description=Matrix Mautrix Telegram server | ||||
| After=docker.service | ||||
| Requires=docker.service | ||||
| Requires=matrix-synapse.service | ||||
| After=matrix-synapse.service | ||||
|  | ||||
| [Service] | ||||
| Type=simple | ||||
| ExecStartPre=-/usr/bin/docker kill matrix-mautrix-telegram | ||||
| ExecStartPre=-/usr/bin/docker rm matrix-mautrix-telegram | ||||
| ExecStartPre=/usr/bin/docker run --rm --name matrix-mautrix-telegram-db \ | ||||
| 			--log-driver=none \ | ||||
| 			--user={{ matrix_user_uid }}:{{ matrix_user_gid }} \ | ||||
| 			--cap-drop=ALL \ | ||||
| 			-v {{ matrix_mautrix_telegram_base_path }}:/data:z \ | ||||
| 			{{ matrix_mautrix_telegram_docker_image }} \ | ||||
| 			alembic -x config=/data/config.yaml upgrade head | ||||
| ExecStart=/usr/bin/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_exposed_port_number is not none %} | ||||
| 			-p 127.0.0.1:{{ matrix_mautrix_telegram_container_exposed_port_number }}:8080 \ | ||||
| 			{% endif %} | ||||
| 			-v {{ matrix_mautrix_telegram_base_path }}:/data:z \ | ||||
| 			{{ matrix_mautrix_telegram_docker_image }} \ | ||||
| 			python3 -m mautrix_telegram -c /data/config.yaml | ||||
| ExecStop=-/usr/bin/docker kill matrix-mautrix-telegram | ||||
| ExecStop=-/usr/bin/docker rm matrix-mautrix-telegram | ||||
| Restart=always | ||||
| RestartSec=30 | ||||
|  | ||||
| [Install] | ||||
| WantedBy=multi-user.target | ||||
| @@ -1,87 +0,0 @@ | ||||
| #jinja2: lstrip_blocks: "True" | ||||
| # Homeserver details. | ||||
| homeserver: | ||||
|   # The address that this appservice can use to connect to the homeserver. | ||||
|   address: https://{{ matrix_server_fqn_matrix }} | ||||
|   # The domain of the homeserver (for MXIDs, etc). | ||||
|   domain: {{ matrix_domain }} | ||||
|  | ||||
| # 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: http://matrix-mautrix-whatsapp:8080 | ||||
|  | ||||
|   # The hostname and port where this appservice should listen. | ||||
|   hostname: 0.0.0.0 | ||||
|   port: 8080 | ||||
|  | ||||
|   # Database config. | ||||
|   database: | ||||
|     # The database type. Only "sqlite3" is supported. | ||||
|     type: sqlite3 | ||||
|     # The database URI. Usually file name. https://github.com/mattn/go-sqlite3#connection-string | ||||
|     uri: mautrix-whatsapp.db | ||||
|   # Path to the Matrix room state store. | ||||
|   state_store_path: ./mx-state.json | ||||
|  | ||||
|   # The unique ID of this appservice. | ||||
|   id: whatsapp | ||||
|   # Appservice bot details. | ||||
|   bot: | ||||
|     # Username of the appservice bot. | ||||
|     username: whatsappbot | ||||
|     # Display name and avatar for bot. Set to "remove" to remove display name/avatar, leave empty | ||||
|     # to leave display name/avatar as-is. | ||||
|     displayname: WhatsApp bridge bot | ||||
|     avatar: remove | ||||
|  | ||||
|   # Authentication tokens for AS <-> HS communication. Autogenerated; do not modify. | ||||
|   as_token: "This value is generated when generating the registration" | ||||
|   hs_token: "This value is generated when generating the registration" | ||||
|  | ||||
| # Bridge config. Currently unused. | ||||
| bridge: | ||||
|   # {% raw %} | ||||
|   # protecting the go templates inside the raw section. | ||||
|   # Localpart template of MXIDs for WhatsApp users. | ||||
|   # {{.}} is replaced with the phone number of the WhatsApp user. | ||||
|   username_template: whatsapp_{{.}} | ||||
|   # Displayname template for WhatsApp users. | ||||
|   # {{.Notify}} - nickname set by the WhatsApp user | ||||
|   # {{.Jid}}    - phone number (international format) | ||||
|   # The following variables are also available, but will cause problems on multi-user instances: | ||||
|   # {{.Name}}   - display name from contact list | ||||
|   # {{.Short}}  - short display name from contact list | ||||
|   displayname_template: "{{if .Notify}}{{.Notify}}{{else}}{{.Jid}}{{end}} (WA)" | ||||
|   # {% endraw %} | ||||
|  | ||||
|   # The prefix for commands. Only required in non-management rooms. | ||||
|   command_prefix: "!wa" | ||||
|  | ||||
|   # Permissions for using the bridge. | ||||
|   # Permitted values: | ||||
|   #     user - Access to use the bridge to chat with a WhatsApp account. | ||||
|   #    admin - User level and some additional administration tools | ||||
|   # Permitted keys: | ||||
|   #        * - All Matrix users | ||||
|   #   domain - All users on that homeserver | ||||
|   #     mxid - Specific user | ||||
|   permissions: | ||||
|     '{{ matrix_domain }}': user | ||||
|  | ||||
| # Logging config. | ||||
| logging: | ||||
|   # The directory for log files. Will be created if not found. | ||||
|   directory: ./logs | ||||
|   # Available variables: .Date for the file date and .Index for different log files on the same day. | ||||
|   file_name_format: {% raw %}"{{.Date}}-{{.Index}}.log"{% endraw %} | ||||
|   # Date format for file names in the Go time format: https://golang.org/pkg/time/#pkg-constants | ||||
|   file_date_format: 2006-01-02 | ||||
|   # Log file permissions. | ||||
|   file_mode: 0600 | ||||
|   # Timestamp format for log entries in the Go time format. | ||||
|   timestamp_format: Jan _2, 2006 15:04:05 | ||||
|   # Minimum severity for log messages. | ||||
|   # Options: debug, info, warn, error, fatal | ||||
|   print_level: debug | ||||
| @@ -1,28 +0,0 @@ | ||||
| #jinja2: lstrip_blocks: "True" | ||||
| [Unit] | ||||
| Description=Matrix Mautrix Whatsapp server | ||||
| After=docker.service | ||||
| Requires=docker.service | ||||
| Requires=matrix-synapse.service | ||||
| After=matrix-synapse.service | ||||
|  | ||||
| [Service] | ||||
| Type=simple | ||||
| ExecStartPre=-/usr/bin/docker kill matrix-mautrix-whatsapp | ||||
| ExecStartPre=-/usr/bin/docker rm matrix-mautrix-whatsapp | ||||
| ExecStart=/usr/bin/docker run --rm --name matrix-mautrix-whatsapp \ | ||||
| 			--log-driver=none \ | ||||
| 			--user={{ matrix_user_uid }}:{{ matrix_user_gid }} \ | ||||
| 			--cap-drop=ALL \ | ||||
| 			--network={{ matrix_docker_network }} \ | ||||
| 			-v {{ matrix_mautrix_whatsapp_base_path }}:/data:z \ | ||||
| 			--workdir=/data \ | ||||
| 			{{ matrix_mautrix_whatsapp_docker_image }} \ | ||||
| 			/usr/bin/mautrix-whatsapp | ||||
| ExecStop=-/usr/bin/docker kill matrix-mautrix-whatsapp | ||||
| ExecStop=-/usr/bin/docker rm matrix-mautrix-whatsapp | ||||
| Restart=always | ||||
| RestartSec=30 | ||||
|  | ||||
| [Install] | ||||
| WantedBy=multi-user.target | ||||
		Reference in New Issue
	
	Block a user