mirror of
				https://github.com/spantaleev/matrix-docker-ansible-deploy.git
				synced 2025-10-21 15:43:25 +00:00 
			
		
		
		
	Merge branch 'patch-2' of https://github.com/sakkiii/matrix-docker-ansible-deploy into patch-2
This commit is contained in:
		
							
								
								
									
										25
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										25
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,3 +1,28 @@ | ||||
| # 2021-08-23 | ||||
|  | ||||
| ## LinkedIn bridging support via beeper-linkedin | ||||
|  | ||||
| Thanks to [Alexandar Mechev](https://github.com/apmechev), the playbook can now install the [beeper-linkedin](https://gitlab.com/beeper/linkedin) bridge for bridging to [LinkedIn](https://www.linkedin.com/) Messaging. | ||||
|  | ||||
| This brings the total number of bridges supported by the playbook up to 20. See all supported bridges [here](docs/configuring-playbook.md#bridging-other-networks). | ||||
|  | ||||
| To get started with bridging to LinkedIn, see [Setting up Beeper LinkedIn bridging](docs/configuring-playbook-bridge-beeper-linkedin.md). | ||||
|  | ||||
|  | ||||
| # 2021-08-20 | ||||
|  | ||||
| # Sygnal upgraded - ARM support and no longer requires a database | ||||
|  | ||||
| The [Sygnal](docs/configuring-playbook-sygnal.md) push gateway has been upgraded from `v0.9.0` to `v0.10.1`. | ||||
|  | ||||
| This is an optional component for the playbook, so most of our users wouldn't care about this announcement. | ||||
|  | ||||
| Since this feels like a relatively big (and untested, as of yet) Sygnal change, we're putting up this changelog entry. | ||||
|  | ||||
| The new version is also available for the ARM architecture. It also no longer requires a database anymore. | ||||
| If you need to downgrade to the previous version, changing `matrix_sygnal_version` or `matrix_sygnal_docker_image` will not be enough, as we've removed the `database` configuration completely. You'd need to switch to an earlier playbook commit. | ||||
|  | ||||
|  | ||||
| # 2021-05-21 | ||||
|  | ||||
| ## Hydrogen support | ||||
|   | ||||
							
								
								
									
										14
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								README.md
									
									
									
									
									
								
							| @@ -45,17 +45,19 @@ Using this playbook, you can get the following services configured on your serve | ||||
|  | ||||
| - (optional, advanced) the [Matrix Corporal](https://github.com/devture/matrix-corporal) reconciliator and gateway for a managed Matrix server | ||||
|  | ||||
| - (optional) the [mautrix-telegram](https://github.com/tulir/mautrix-telegram) bridge for bridging your Matrix server to [Telegram](https://telegram.org/) | ||||
| - (optional) the [mautrix-telegram](https://github.com/mautrix/telegram) bridge for bridging your Matrix server to [Telegram](https://telegram.org/) | ||||
|  | ||||
| - (optional) the [mautrix-whatsapp](https://github.com/tulir/mautrix-whatsapp) bridge for bridging your Matrix server to [WhatsApp](https://www.whatsapp.com/) | ||||
| - (optional) the [mautrix-whatsapp](https://github.com/mautrix/whatsapp) bridge for bridging your Matrix server to [WhatsApp](https://www.whatsapp.com/) | ||||
|  | ||||
| - (optional) the [mautrix-facebook](https://github.com/tulir/mautrix-facebook) bridge for bridging your Matrix server to [Facebook](https://facebook.com/) | ||||
| - (optional) the [mautrix-facebook](https://github.com/mautrix/facebook) bridge for bridging your Matrix server to [Facebook](https://facebook.com/) | ||||
|  | ||||
| - (optional) the [mautrix-hangouts](https://github.com/tulir/mautrix-hangouts) bridge for bridging your Matrix server to [Google Hangouts](https://en.wikipedia.org/wiki/Google_Hangouts) | ||||
| - (optional) the [mautrix-hangouts](https://github.com/mautrix/hangouts) bridge for bridging your Matrix server to [Google Hangouts](https://en.wikipedia.org/wiki/Google_Hangouts) | ||||
|  | ||||
| - (optional) the [mautrix-instagram](https://github.com/tulir/mautrix-instagram) bridge for bridging your Matrix server to [Instagram](https://instagram.com/) | ||||
| - (optional) the [mautrix-instagram](https://github.com/mautrix/instagram) bridge for bridging your Matrix server to [Instagram](https://instagram.com/) | ||||
|  | ||||
| - (optional) the [mautrix-signal](https://github.com/tulir/mautrix-signal) bridge for bridging your Matrix server to [Signal](https://www.signal.org/) | ||||
| - (optional) the [mautrix-signal](https://github.com/mautrix/signal) bridge for bridging your Matrix server to [Signal](https://www.signal.org/) | ||||
|  | ||||
| - (optional) the [beeper-linkedin](https://gitlab.com/beeper/linkedin) bridge for bridging your Matrix server to [LinkedIn](https://www.linkedin.com/) | ||||
|  | ||||
| - (optional) the [matrix-appservice-irc](https://github.com/matrix-org/matrix-appservice-irc) bridge for bridging your Matrix server to [IRC](https://wikipedia.org/wiki/Internet_Relay_Chat) | ||||
|  | ||||
|   | ||||
							
								
								
									
										59
									
								
								docs/configuring-playbook-bridge-beeper-linkedin.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								docs/configuring-playbook-bridge-beeper-linkedin.md
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | ||||
| # Setting up Beeper Linkedin (optional) | ||||
|  | ||||
| The playbook can install and configure [beeper-linkedin](https://gitlab.com/beeper/linkedin) for you, for bridging to [LinkedIn](https://www.linkedin.com/) Messaging. This bridge is based on the mautrix-python framework and can be configured in a similar way to the other mautrix bridges | ||||
|  | ||||
| See the project's [documentation](https://gitlab.com/beeper/linkedin/-/blob/master/README.md) to learn what it does and why it might be useful to you. | ||||
|  | ||||
| ```yaml | ||||
| matrix_beeper_linkedin_enabled: true | ||||
| ``` | ||||
|  | ||||
| There are some additional things you may wish to configure about the bridge before you continue. | ||||
|  | ||||
| Encryption support is off by default. If you would like to enable encryption, add the following to your `vars.yml` file: | ||||
| ```yaml | ||||
| matrix_beeper_linkedin_configuration_extension_yaml: | | ||||
|   bridge: | ||||
|     encryption: | ||||
|       allow: true | ||||
|       default: true | ||||
| ``` | ||||
|  | ||||
| If you would like to be able to administrate the bridge from your account it can be configured like this: | ||||
| ```yaml | ||||
| matrix_beeper_linkedin_configuration_extension_yaml: | | ||||
|   bridge: | ||||
|     permissions: | ||||
|       '@YOUR_USERNAME:YOUR_DOMAIN': admin | ||||
| ``` | ||||
|  | ||||
| You may wish to look at `roles/matrix-bridge-beeper-linkedin/templates/config.yaml.j2` to find other things you would like to configure. | ||||
|  | ||||
|  | ||||
| ## Set up Double Puppeting | ||||
|  | ||||
| If you'd like to use [Double Puppeting](https://docs.mau.fi/bridges/general/double-puppeting.html) (hint: you most likely do), you have 2 ways of going about it. | ||||
|  | ||||
| ### Method 1: automatically, by enabling Shared Secret Auth | ||||
|  | ||||
| The bridge will automatically perform Double Puppeting if you enable [Shared Secret Auth](configuring-playbook-shared-secret-auth.md) for this playbook. | ||||
|  | ||||
| This is the recommended way of setting up Double Puppeting, as it's easier to accomplish, works for all your users automatically, and has less of a chance of breaking in the future. | ||||
|  | ||||
|  | ||||
| ## Usage | ||||
|  | ||||
| You then need to start a chat with `@linkedinbot:YOUR_DOMAIN` (where `YOUR_DOMAIN` is your base domain, not the `matrix.` domain). | ||||
|  | ||||
| Send `login YOUR_LINKEDIN_EMAIL_ADDRESS` to the bridge bot to enable bridging for your LinkedIn account. | ||||
|  | ||||
| If you run into trouble, check the [Troubleshooting](#troubleshooting) section below. | ||||
|  | ||||
| After successfully enabling bridging, you may wish to [set up Double Puppeting](#set-up-double-puppeting), if you haven't already done so. | ||||
|  | ||||
|  | ||||
| ## Troubleshooting | ||||
|  | ||||
| ### Bridge asking for 2FA even if you don't have 2FA enabled | ||||
|  | ||||
| If you don't have 2FA enabled and are logging in from a strange IP for the first time, LinkedIn will send an email with a one-time code. You can use this code to authorize the bridge session. In my experience, once the IP is authorized, you will not be asked again. | ||||
| @@ -1,8 +1,8 @@ | ||||
| # Setting up Mautrix Facebook (optional) | ||||
|  | ||||
| The playbook can install and configure [mautrix-facebook](https://github.com/tulir/mautrix-facebook) for you. | ||||
| The playbook can install and configure [mautrix-facebook](https://github.com/mautrix/facebook) for you. | ||||
|  | ||||
| See the project's [documentation](https://github.com/tulir/mautrix-facebook/blob/master/ROADMAP.md) to learn what it does and why it might be useful to you. | ||||
| See the project's [documentation](https://github.com/mautrix/facebook/blob/master/ROADMAP.md) to learn what it does and why it might be useful to you. | ||||
|  | ||||
| ```yaml | ||||
| matrix_mautrix_facebook_enabled: true | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| # Setting up Mautrix Hangouts (optional) | ||||
|  | ||||
| The playbook can install and configure [mautrix-hangouts](https://github.com/tulir/mautrix-hangouts) for you. | ||||
| The playbook can install and configure [mautrix-hangouts](https://github.com/mautrix/hangouts) for you. | ||||
|  | ||||
| See the project's [documentation](https://github.com/tulir/mautrix-hangouts/wiki#usage) to learn what it does and why it might be useful to you. | ||||
| See the project's [documentation](https://docs.mau.fi/bridges/python/hangouts/index.html) to learn what it does and why it might be useful to you. | ||||
|  | ||||
| To enable the [Google Hangouts](https://hangouts.google.com/) bridge just use the following playbook configuration: | ||||
|  | ||||
| @@ -14,7 +14,7 @@ matrix_mautrix_hangouts_enabled: true | ||||
|  | ||||
| ## Set up Double Puppeting | ||||
|  | ||||
| If you'd like to use [Double Puppeting](https://github.com/tulir/mautrix-hangouts/wiki/Authentication#double-puppeting) (hint: you most likely do), you have 2 ways of going about it. | ||||
| If you'd like to use [Double Puppeting](https://docs.mau.fi/bridges/general/double-puppeting.html) (hint: you most likely do), you have 2 ways of going about it. | ||||
|  | ||||
| ### Method 1: automatically, by enabling Shared Secret Auth | ||||
|  | ||||
| @@ -52,7 +52,7 @@ Automatic login may not work. If it does not, reload the page and select the "Ma | ||||
|  | ||||
| Once logged in, recent chats should show up as new conversations automatically. Other chats will get portals as you receive messages. | ||||
|  | ||||
| You can learn more about authentication from the bridge's [official documentation on Authentication](https://github.com/tulir/mautrix-hangouts/wiki/Authentication). | ||||
| You can learn more about authentication from the bridge's [official documentation on Authentication](https://docs.mau.fi/bridges/python/hangouts/authentication.html). | ||||
|  | ||||
| After successfully enabling bridging, you may wish to [set up Double Puppeting](#set-up-double-puppeting), if you haven't already done so. | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| # Setting up Mautrix Instagram (optional) | ||||
|  | ||||
| The playbook can install and configure [mautrix-instagram](https://github.com/tulir/mautrix-instagram) for you. | ||||
| The playbook can install and configure [mautrix-instagram](https://github.com/mautrix/instagram) for you. | ||||
|  | ||||
| See the project's [documentation](https://docs.mau.fi/bridges/python/instagram/index.html) to learn what it does and why it might be useful to you. | ||||
|  | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| # Setting up Mautrix Signal (optional) | ||||
|  | ||||
| The playbook can install and configure [mautrix-signal](https://github.com/tulir/mautrix-signal) for you. | ||||
| The playbook can install and configure [mautrix-signal](https://github.com/mautrix/signal) for you. | ||||
|  | ||||
| See the project's [documentation](https://github.com/tulir/mautrix-signal/wiki) to learn what it does and why it might be useful to you. | ||||
| See the project's [documentation](https://docs.mau.fi/bridges/python/signal/index.html) to learn what it does and why it might be useful to you. | ||||
|  | ||||
| **Note/Prerequisite**: If you're running with the Postgres database server integrated by the playbook (which is the default), you don't need to do anything special and can easily proceed with installing. However, if you're [using an external Postgres server](configuring-playbook-external-postgres.md), you'd need to manually prepare a Postgres database for this bridge and adjust the variables related to that (`matrix_mautrix_signal_database_*`). | ||||
|  | ||||
| @@ -12,9 +12,54 @@ Use the following playbook configuration: | ||||
| matrix_mautrix_signal_enabled: true | ||||
| ``` | ||||
|  | ||||
| There are some additional things you may wish to configure about the bridge before you continue. | ||||
|  | ||||
| The relay bot functionality is off by default. If you would like to enable the relay bot, add the following to your `vars.yml` file: | ||||
| ```yaml | ||||
| matrix_mautrix_signal_relaybot_enabled: true | ||||
| ``` | ||||
| If you want to activate the relay bot in a room, use `!signal set-relay`. | ||||
| Use `!signal unset-relay` to deactivate. | ||||
| By default, any user on your homeserver will be able to use the bridge. | ||||
| If you enable the relay bot functionality, it will relay every user's messages in a portal room - no matter which homeserver they're from. | ||||
|  | ||||
| Different levels of permission can be granted to users: | ||||
|  | ||||
| * relay - Allowed to be relayed through the bridge, no access to commands; | ||||
| * user - Use the bridge with puppeting; | ||||
| * admin - Use and administer the bridge. | ||||
|  | ||||
| The permissions are following the sequence: nothing < relay < user < admin. | ||||
|  | ||||
| The default permissions are set as follows: | ||||
| ```yaml | ||||
| permissions: | ||||
|   '*': relay | ||||
|   YOUR_DOMAIN: user | ||||
| ``` | ||||
|  | ||||
| If you want to augment the preset permissions, you might want to set the additional permissions with the following settings in your `vars.yml` file: | ||||
| ```yaml | ||||
| matrix_mautrix_signal_configuration_extension_yaml: | | ||||
|   bridge: | ||||
|     permissions: | ||||
|       '@YOUR_USERNAME:YOUR_DOMAIN': admin | ||||
| ``` | ||||
|  | ||||
| This will add the admin permission to the specific user, while keepting the default permissions. | ||||
|  | ||||
| In case you want to replace the default permissions settings **completely**, populate the following item within your `vars.yml` file: | ||||
| ```yaml | ||||
| matrix_mautrix_signal_bridge_permissions: | | ||||
|   '@ADMIN:YOUR_DOMAIN': admin | ||||
|   '@USER:YOUR_DOMAIN' : user | ||||
| ``` | ||||
|  | ||||
| You may wish to look at `roles/matrix-bridge-mautrix-signal/templates/config.yaml.j2` to find more information on the permissions settings and other options you would like to configure. | ||||
|  | ||||
| ## Set up Double Puppeting | ||||
|  | ||||
| If you'd like to use [Double Puppeting](https://github.com/tulir/mautrix-signal/wiki/Authentication#double-puppeting) (hint: you most likely do), you have 2 ways of going about it. | ||||
| If you'd like to use [Double Puppeting](https://docs.mau.fi/bridges/general/double-puppeting.html) (hint: you most likely do), you have 2 ways of going about it. | ||||
|  | ||||
| ### Method 1: automatically, by enabling Shared Secret Auth | ||||
|  | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| # Setting up Mautrix Telegram (optional) | ||||
|  | ||||
| The playbook can install and configure [mautrix-telegram](https://github.com/tulir/mautrix-telegram) for you. | ||||
| The playbook can install and configure [mautrix-telegram](https://github.com/mautrix/telegram) for you. | ||||
|  | ||||
| See the project's [documentation](https://github.com/tulir/mautrix-telegram/wiki#usage) to learn what it does and why it might be useful to you. | ||||
| See the project's [documentation](https://docs.mau.fi/bridges/python/telegram/index.html) to learn what it does and why it might be useful to you. | ||||
|  | ||||
| You'll need to obtain API keys from [https://my.telegram.org/apps](https://my.telegram.org/apps) and then use the following playbook configuration: | ||||
|  | ||||
| @@ -14,7 +14,7 @@ matrix_mautrix_telegram_api_hash: YOUR_TELEGRAM_API_HASH | ||||
|  | ||||
| ## Set up Double Puppeting | ||||
|  | ||||
| If you'd like to use [Double Puppeting](https://github.com/tulir/mautrix-telegram/wiki/Authentication#replacing-telegram-accounts-matrix-puppet-with-matrix-account) (hint: you most likely do), you have 2 ways of going about it. | ||||
| If you'd like to use [Double Puppeting](https://docs.mau.fi/bridges/general/double-puppeting.html) (hint: you most likely do), you have 2 ways of going about it. | ||||
|  | ||||
| ### Method 1: automatically, by enabling Shared Secret Auth | ||||
|  | ||||
| @@ -45,7 +45,7 @@ https://matrix.DOMAIN/_matrix/client/r0/login | ||||
|  | ||||
| You then need to start a chat with `@telegrambot:YOUR_DOMAIN` (where `YOUR_DOMAIN` is your base domain, not the `matrix.` domain). | ||||
|  | ||||
| If you want to use the relay-bot feature ([relay bot documentation](https://github.com/tulir/mautrix-telegram/wiki/Relay-bot)), which allows anonymous user to chat with telegram users, use the following additional playbook configuration: | ||||
| If you want to use the relay-bot feature ([relay bot documentation](https://docs.mau.fi/bridges/python/telegram/relay-bot.html)), which allows anonymous user to chat with telegram users, use the following additional playbook configuration: | ||||
|  | ||||
| ```yaml | ||||
| matrix_mautrix_telegram_bot_token: YOUR_TELEGRAM_BOT_TOKEN | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| # Setting up Mautrix Whatsapp (optional) | ||||
|  | ||||
| The playbook can install and configure [mautrix-whatsapp](https://github.com/tulir/mautrix-whatsapp) for you. | ||||
| The playbook can install and configure [mautrix-whatsapp](https://github.com/mautrix/whatsapp) for you. | ||||
|  | ||||
| See the project's [documentation](https://github.com/tulir/mautrix-whatsapp/wiki) to learn what it does and why it might be useful to you. | ||||
| See the project's [documentation](https://docs.mau.fi/bridges/go/whatsapp/index.html) to learn what it does and why it might be useful to you. | ||||
|  | ||||
| Use the following playbook configuration: | ||||
|  | ||||
| @@ -13,7 +13,7 @@ matrix_mautrix_whatsapp_enabled: true | ||||
|  | ||||
| ## Set up Double Puppeting | ||||
|  | ||||
| If you'd like to use [Double Puppeting](https://github.com/tulir/mautrix-whatsapp/wiki/Authentication#replacing-whatsapp-accounts-matrix-puppet-with-matrix-account) (hint: you most likely do), you have 2 ways of going about it. | ||||
| If you'd like to use [Double Puppeting](https://docs.mau.fi/bridges/general/double-puppeting.html) (hint: you most likely do), you have 2 ways of going about it. | ||||
|  | ||||
| ### Method 1: automatically, by enabling Shared Secret Auth | ||||
|  | ||||
|   | ||||
| @@ -129,7 +129,7 @@ Until this gets integrated into the playbook, we need to register new users / me | ||||
| Please SSH into your matrix host machine and execute the following command targeting the `matrix-jitsi-prosody` container: | ||||
|  | ||||
| ```bash | ||||
| docker exec matrix-jitsi-prosody prosodyctl --config /config/prosody.cfg.lua register <USERNAME> matrix-jitsi-web <PASSWORD> | ||||
| docker exec matrix-jitsi-prosody prosodyctl --config /config/prosody.cfg.lua register <USERNAME> meet.jitsi <PASSWORD> | ||||
| ``` | ||||
|  | ||||
| Run this command for each user you would like to create, replacing `<USERNAME>` and `<PASSWORD>` accordingly. After you've finished, please exit the host. | ||||
|   | ||||
| @@ -104,6 +104,8 @@ When you're done with all the configuration you'd like to do, continue with [Ins | ||||
|  | ||||
| - [Setting up Appservice IRC bridging](configuring-playbook-bridge-appservice-irc.md) (optional) | ||||
|  | ||||
| - [Setting up Beeper LinkedIn bridging](configuring-playbook-bridge-beeper-linkedin.md) (optional) | ||||
|  | ||||
| - [Setting up Appservice Discord bridging](configuring-playbook-bridge-appservice-discord.md) (optional) | ||||
|  | ||||
| - [Setting up Appservice Slack bridging](configuring-playbook-bridge-appservice-slack.md) (optional) | ||||
|   | ||||
| @@ -69,7 +69,7 @@ It is, however, **a little fragile**, as future updates performed by this playbo | ||||
|  | ||||
| If you don't need the base domain (e.g. `example.com`) for anything else (hosting a website, etc.), you can point it to the Matrix server's IP address and tell the playbook to configure it. | ||||
|  | ||||
| This is the easiest way to set up well-known serving -- letting the playbook handle the whole base domain for you (including SSL certificates, etc.). However, if you need to use the base domain for other things (such as hosting some website, etc.), going with Option 1 or Option 2 might be more suitable. | ||||
| This is the easiest way to set up well-known serving -- letting the playbook handle the whole base domain for you (including SSL certificates, etc.). However, if you need to use the base domain for other things (such as hosting some website, etc.), going with Option 1 or Option 3 might be more suitable. | ||||
|  | ||||
| See [Serving the base domain](configuring-playbook-base-domain-serving.md) to learn how the playbook can help you set it up. | ||||
|  | ||||
|   | ||||
| @@ -40,17 +40,17 @@ These services are not part of our default installation, but can be enabled by [ | ||||
|  | ||||
| - [zeratax/matrix-registration](https://hub.docker.com/r/devture/zeratax-matrix-registration/) - [matrix-registration](https://github.com/ZerataX/matrix-registration): a simple python application to have a token based matrix registration (optional) | ||||
|  | ||||
| - [tulir/mautrix-telegram](https://mau.dev/tulir/mautrix-telegram/container_registry) - the [mautrix-telegram](https://github.com/tulir/mautrix-telegram) bridge to [Telegram](https://telegram.org/) (optional) | ||||
| - [mautrix/telegram](https://mau.dev/mautrix/telegram/container_registry) - the [mautrix-telegram](https://github.com/mautrix/telegram) bridge to [Telegram](https://telegram.org/) (optional) | ||||
|  | ||||
| - [tulir/mautrix-whatsapp](https://mau.dev/tulir/mautrix-whatsapp/container_registry) - the [mautrix-whatsapp](https://github.com/tulir/mautrix-whatsapp) bridge to [Whatsapp](https://www.whatsapp.com/) (optional) | ||||
| - [mautrix/whatsapp](https://mau.dev/mautrix/whatsapp/container_registry) - the [mautrix-whatsapp](https://github.com/mautrix/whatsapp) bridge to [Whatsapp](https://www.whatsapp.com/) (optional) | ||||
|  | ||||
| - [tulir/mautrix-facebook](https://mau.dev/tulir/mautrix-facebook/container_registry) - the [mautrix-facebook](https://github.com/tulir/mautrix-facebook) bridge to [Facebook](https://facebook.com/) (optional) | ||||
| - [mautrix/facebook](https://mau.dev/mautrix/facebook/container_registry) - the [mautrix-facebook](https://github.com/mautrix/facebook) bridge to [Facebook](https://facebook.com/) (optional) | ||||
|  | ||||
| - [tulir/mautrix-hangouts](https://mau.dev/tulir/mautrix-hangouts/container_registry) - the [mautrix-hangouts](https://github.com/tulir/mautrix-hangouts) bridge to [Google Hangouts](https://en.wikipedia.org/wiki/Google_Hangouts) (optional) | ||||
| - [mautrix/hangouts](https://mau.dev/mautrix/hangouts/container_registry) - the [mautrix-hangouts](https://github.com/mautrix/hangouts) bridge to [Google Hangouts](https://en.wikipedia.org/wiki/Google_Hangouts) (optional) | ||||
|  | ||||
| - [tulir/mautrix-instagram](https://mau.dev/tulir/mautrix-instagram/container_registry) - the [mautrix-instagram](https://github.com/tulir/mautrix-instagram) bridge to [Instagram](https://instagram.com/) (optional) | ||||
| - [mautrix/instagram](https://mau.dev/mautrix/instagram/container_registry) - the [mautrix-instagram](https://github.com/mautrix/instagram) bridge to [Instagram](https://instagram.com/) (optional) | ||||
|  | ||||
| - [tulir/mautrix-signal](https://mau.dev/tulir/mautrix-signal/container_registry) - the [mautrix-signal](https://github.com/tulir/mautrix-signal) bridge to [Signal](https://www.signal.org/) (optional) | ||||
| - [mautrix/signal](https://mau.dev/mautrix/signal/container_registry) - the [mautrix-signal](https://github.com/mautrix/signal) bridge to [Signal](https://www.signal.org/) (optional) | ||||
|  | ||||
| - [matrixdotorg/matrix-appservice-irc](https://hub.docker.com/r/matrixdotorg/matrix-appservice-irc) - the [matrix-appservice-irc](https://github.com/matrix-org/matrix-appservice-irc) bridge to [IRC](https://wikipedia.org/wiki/Internet_Relay_Chat) (optional) | ||||
|  | ||||
|   | ||||
| @@ -82,8 +82,8 @@ Based on your setup, you have different ways to go about it: | ||||
| # | ||||
| # NOTE: these are in-container paths. `/matrix/ssl` on the host is mounted into the container | ||||
| # at the same path (`/matrix/ssl`) by default, so if that's the path you need, it would be seamless. | ||||
| matrix_nginx_proxy_proxy_matrix_federation_api_ssl_certificate: /matrix/ssl/config/live/matrix.<your-domain>/fullchain.pem | ||||
| matrix_nginx_proxy_proxy_matrix_federation_api_ssl_certificate_key: /matrix/ssl/config/live/matrix.<your-domain>/privkey.pem | ||||
| matrix_nginx_proxy_proxy_matrix_federation_api_ssl_certificate: /matrix/ssl/config/live/<your-domain>/fullchain.pem | ||||
| matrix_nginx_proxy_proxy_matrix_federation_api_ssl_certificate_key: /matrix/ssl/config/live/<your-domain>/privkey.pem | ||||
| ``` | ||||
|  | ||||
| If your files are not in `/matrix/ssl` but in some other location, you would need to mount them into the container: | ||||
|   | ||||
| @@ -23,7 +23,7 @@ To import, run this command (make sure to replace `<server-path-to-postgres-dump | ||||
|  | ||||
| ```sh | ||||
| ansible-playbook -i inventory/hosts setup.yml \ | ||||
| --extra-vars='postgres_default_import_database=synapse server_path_postgres_dump=<server-path-to-postgres-dump.sql>' \ | ||||
| --extra-vars='server_path_postgres_dump=<server-path-to-postgres-dump.sql>' \ | ||||
| --tags=import-postgres | ||||
| ``` | ||||
|  | ||||
|   | ||||
| @@ -25,8 +25,11 @@ List of roles where self-building the Docker image is currently possible: | ||||
| - `matrix-bridge-mautrix-facebook` | ||||
| - `matrix-bridge-mautrix-hangouts` | ||||
| - `matrix-bridge-mautrix-telegram` | ||||
| - `matrix-bridge-mautrix-signal` | ||||
| - `matrix-bridge-mx-puppet-skype` | ||||
| - `matrix-bot-mjolnir` | ||||
| - `matrix-bot-matrix-reminder-bot` | ||||
| - `matrix-email2matrix` | ||||
|  | ||||
| Adding self-building support to other roles is welcome. Feel free to contribute! | ||||
|  | ||||
|   | ||||
| @@ -41,6 +41,8 @@ matrix_awx_enabled: false | ||||
|  | ||||
| matrix_nginx_proxy_data_path: "{{ '/chroot/website' if (matrix_awx_enabled and not matrix_nginx_proxy_base_domain_homepage_enabled) else (matrix_nginx_proxy_base_path + '/data') }}" | ||||
| matrix_nginx_proxy_data_path_in_container: "{{ '/nginx-data/matrix-domain' if (matrix_awx_enabled and not matrix_nginx_proxy_base_domain_homepage_enabled) else '/nginx-data' }}" | ||||
| matrix_nginx_proxy_data_path_extension: "{{ '' if (matrix_awx_enabled and not matrix_nginx_proxy_base_domain_homepage_enabled) else '/matrix-domain' }}" | ||||
| matrix_nginx_proxy_base_domain_create_directory: "{{ not matrix_awx_enabled }}" | ||||
|  | ||||
| ###################################################################### | ||||
| # | ||||
| @@ -214,6 +216,42 @@ matrix_appservice_irc_database_password: "{{ matrix_synapse_macaroon_secret_key | ||||
| ###################################################################### | ||||
|  | ||||
|  | ||||
| ###################################################################### | ||||
| # | ||||
| # matrix-bridge-beeper-linkedin | ||||
| # | ||||
| ###################################################################### | ||||
|  | ||||
| # We don't enable bridges by default. | ||||
| matrix_beeper_linkedin_enabled: false | ||||
|  | ||||
| matrix_beeper_linkedin_systemd_required_services_list: | | ||||
|   {{ | ||||
|     ['docker.service'] | ||||
|     + | ||||
|     (['matrix-synapse.service'] if matrix_synapse_enabled else []) | ||||
|     + | ||||
|     (['matrix-postgres.service'] if matrix_postgres_enabled else []) | ||||
|     + | ||||
|     (['matrix-nginx-proxy.service'] if matrix_nginx_proxy_enabled else []) | ||||
|   }} | ||||
|  | ||||
| matrix_beeper_linkedin_appservice_token: "{{ matrix_synapse_macaroon_secret_key | password_hash('sha512', 'linked.as.token') | to_uuid }}" | ||||
|  | ||||
| matrix_beeper_linkedin_homeserver_token: "{{ matrix_synapse_macaroon_secret_key | password_hash('sha512', 'linked.hs.token') | to_uuid }}" | ||||
|  | ||||
| matrix_beeper_linkedin_login_shared_secret: "{{ matrix_synapse_ext_password_provider_shared_secret_auth_shared_secret if matrix_synapse_ext_password_provider_shared_secret_auth_enabled else '' }}" | ||||
|  | ||||
| matrix_beeper_linkedin_bridge_presence: "{{ matrix_synapse_presence_enabled if matrix_synapse_enabled else true }}" | ||||
|  | ||||
| matrix_beeper_linkedin_database_password: "{{ matrix_synapse_macaroon_secret_key | password_hash('sha512', 'maulinkedin.db') | to_uuid }}" | ||||
|  | ||||
| ###################################################################### | ||||
| # | ||||
| # /matrix-bridge-beeper-linkedin | ||||
| # | ||||
| ###################################################################### | ||||
|  | ||||
| ###################################################################### | ||||
| # | ||||
| # matrix-bridge-mautrix-facebook | ||||
| @@ -811,6 +849,7 @@ matrix_bot_matrix_reminder_bot_systemd_required_services_list: | | ||||
| # Postgres is the default, except if not using `matrix_postgres` (internal postgres) | ||||
| matrix_bot_matrix_reminder_bot_database_engine: "{{ 'postgres' if matrix_postgres_enabled else 'sqlite' }}" | ||||
| matrix_bot_matrix_reminder_bot_database_password: "{{ matrix_synapse_macaroon_secret_key | password_hash('sha512', 'reminder.bot.db') | to_uuid }}" | ||||
| matrix_bot_matrix_reminder_bot_container_self_build: "{{ matrix_architecture != 'amd64' }}" | ||||
|  | ||||
| ###################################################################### | ||||
| # | ||||
| @@ -1036,6 +1075,8 @@ matrix_dynamic_dns_enabled: false | ||||
|  | ||||
| matrix_email2matrix_enabled: false | ||||
|  | ||||
| matrix_email2matrix_container_image_self_build: "{{ matrix_architecture != 'amd64' }}" | ||||
|  | ||||
| ###################################################################### | ||||
| # | ||||
| # /matrix-email2matrix | ||||
| @@ -1121,17 +1162,7 @@ matrix_mailer_container_image_self_build: "{{ matrix_architecture != 'amd64'}}" | ||||
| # If you wish to use the public identity servers (matrix.org, vector.im) instead of your own you may wish to disable this. | ||||
| matrix_ma1sd_enabled: true | ||||
|  | ||||
| # There's no prebuilt ma1sd image for the `arm32` architecture. | ||||
| # We're relying on self-building there. | ||||
| matrix_ma1sd_architecture: "{{ | ||||
| 	{ | ||||
| 		'amd64': 'amd64', | ||||
| 		'arm32': 'arm32', | ||||
| 		'arm64': 'arm64', | ||||
| 	}[matrix_architecture] | ||||
| }}" | ||||
|  | ||||
| matrix_ma1sd_container_image_self_build: "{{ matrix_architecture not in ['arm64', 'amd64'] }}" | ||||
| matrix_ma1sd_container_image_self_build: "{{ matrix_architecture != 'amd64' }}" | ||||
|  | ||||
| # Normally, matrix-nginx-proxy is enabled and nginx can reach ma1sd over the container network. | ||||
| # If matrix-nginx-proxy is not enabled, or you otherwise have a need for it, you can expose | ||||
| @@ -1377,6 +1408,12 @@ matrix_postgres_additional_databases: | | ||||
|       'password': matrix_appservice_irc_database_password, | ||||
|     }] if (matrix_appservice_irc_enabled and matrix_appservice_irc_database_engine == 'postgres' and matrix_appservice_irc_database_hostname == 'matrix-postgres') else []) | ||||
|     + | ||||
|     ([{ | ||||
|       'name': matrix_beeper_linkedin_database_name, | ||||
|       'username': matrix_beeper_linkedin_database_username, | ||||
|       'password': matrix_beeper_linkedin_database_password, | ||||
|     }] if (matrix_beeper_linkedin_enabled and matrix_beeper_linkedin_database_engine == 'postgres' and matrix_beeper_linkedin_database_hostname == 'matrix-postgres') else []) | ||||
|     + | ||||
|     ([{ | ||||
|       'name': matrix_mautrix_facebook_database_name, | ||||
|       'username': matrix_mautrix_facebook_database_username, | ||||
| @@ -1467,12 +1504,6 @@ matrix_postgres_additional_databases: | | ||||
|       'password': matrix_etherpad_database_password, | ||||
|     }] if (matrix_etherpad_enabled and matrix_etherpad_database_engine == 'postgres' and matrix_etherpad_database_hostname == 'matrix-postgres') else []) | ||||
|     + | ||||
|     ([{ | ||||
|       'name': matrix_sygnal_database_name, | ||||
|       'username': matrix_sygnal_database_username, | ||||
|       'password': matrix_sygnal_database_password, | ||||
|     }] if (matrix_sygnal_enabled and matrix_sygnal_database_engine == 'postgres' and matrix_sygnal_database_hostname == 'matrix-postgres') else []) | ||||
|      + | ||||
|     ([{ | ||||
|       'name': matrix_prometheus_postgres_exporter_database_name, | ||||
|       'username': matrix_prometheus_postgres_exporter_database_username, | ||||
| @@ -1517,10 +1548,6 @@ matrix_sygnal_metrics_prometheus_enabled: "{{ matrix_prometheus_enabled }}" | ||||
|  | ||||
| matrix_sygnal_container_http_host_bind_port: "{{ '' if matrix_nginx_proxy_enabled else '127.0.0.1:6000' }}" | ||||
|  | ||||
| # Postgres is the default, except if not using `matrix_postgres` (internal postgres) | ||||
| matrix_sygnal_database_engine: "{{ 'postgres' if matrix_postgres_enabled else 'sqlite' }}" | ||||
| matrix_sygnal_database_password: "{{ matrix_synapse_macaroon_secret_key | password_hash('sha512', 'sygnal') | to_uuid }}" | ||||
|  | ||||
| ###################################################################### | ||||
| # | ||||
| # /matrix-sygnal | ||||
|   | ||||
| @@ -176,7 +176,7 @@ | ||||
|     state: directory | ||||
|     owner: matrix | ||||
|     group: matrix | ||||
|     mode: '0574' | ||||
|     mode: '0770' | ||||
|   when: customise_base_domain_website is defined | ||||
|  | ||||
| - name: Ensure /chroot/export location exists | ||||
|   | ||||
| @@ -29,12 +29,7 @@ | ||||
|     insertafter: '# Synapse Extension Start' | ||||
|   with_dict: | ||||
|     'matrix_synapse_ext_password_provider_rest_auth_enabled': 'true' | ||||
|     'matrix_synapse_ext_password_provider_rest_auth_endpoint': 'http://matrix-ma1sd:8090' | ||||
|   when: ext_matrix_ma1sd_auth_store == 'LDAP/AD' | ||||
|  | ||||
| - name: Strip header from ma1sd configuration extension if using internal auth | ||||
|   set_fact: | ||||
|     ext_matrix_ma1sd_configuration_extension_yaml_parsed: "{{ ext_matrix_ma1sd_configuration_extension_yaml.splitlines() | reject('search', '^matrix_client_element_configuration_extension_json:') | list }}" | ||||
|     'matrix_synapse_ext_password_provider_rest_auth_endpoint': '"http://matrix-ma1sd:8090"' | ||||
|   when: ext_matrix_ma1sd_auth_store == 'LDAP/AD' | ||||
|  | ||||
| - name: Remove entire ma1sd configuration extension | ||||
| @@ -52,22 +47,13 @@ | ||||
|     regexp: '^# Start ma1sd Extension# End ma1sd Extension' | ||||
|     replace: '# Start ma1sd Extension\n# End ma1sd Extension' | ||||
|  | ||||
| - name: Insert ma1sd configuration extension header if using external LDAP/AD with ma1sd | ||||
| - name: Insert/Update ma1sd configuration extension variables | ||||
|   delegate_to: 127.0.0.1 | ||||
|   lineinfile: | ||||
|   blockinfile: | ||||
|     path: '{{ awx_cached_matrix_vars }}' | ||||
|     line: "matrix_ma1sd_configuration_extension_yaml: |" | ||||
|     marker: "# {mark} ma1sd ANSIBLE MANAGED BLOCK" | ||||
|     insertafter: '# Start ma1sd Extension' | ||||
|   when: ext_matrix_ma1sd_auth_store == 'LDAP/AD' | ||||
|  | ||||
| - name: Set ma1sd configuration extension if using external LDAP/AD with ma1sd | ||||
|   delegate_to: 127.0.0.1 | ||||
|   lineinfile: | ||||
|     path: '{{ awx_cached_matrix_vars }}' | ||||
|     insertbefore: '# End ma1sd Extension' | ||||
|     line: '{{ item }}' | ||||
|   with_items: "{{ ext_matrix_ma1sd_configuration_extension_yaml_parsed }}" | ||||
|   when: ext_matrix_ma1sd_auth_store == 'LDAP/AD' | ||||
|     block: '{{ ext_matrix_ma1sd_configuration_extension_yaml }}' | ||||
|  | ||||
| - name: Record ma1sd Custom variables locally on AWX | ||||
|   delegate_to: 127.0.0.1 | ||||
| @@ -79,6 +65,7 @@ | ||||
|   with_dict: | ||||
|     'ext_matrix_ma1sd_auth_store': '{{ ext_matrix_ma1sd_auth_store }}' | ||||
|     'ext_matrix_ma1sd_configuration_extension_yaml': '{{ ext_matrix_ma1sd_configuration_extension_yaml.splitlines() | to_json }}' | ||||
|   no_log: True | ||||
|  | ||||
| - name: Save new 'Configure ma1sd' survey.json to the AWX tower, template | ||||
|   delegate_to: 127.0.0.1 | ||||
|   | ||||
| @@ -154,17 +154,6 @@ | ||||
|   with_items: "{{ ext_federation_whitelist_raw.splitlines() }}" | ||||
|   when: ext_federation_whitelist_raw|length > 0 | ||||
|  | ||||
| - name: Record Synapse Custom variables locally on AWX | ||||
|   delegate_to: 127.0.0.1 | ||||
|   lineinfile: | ||||
|     path: '{{ awx_cached_matrix_vars }}' | ||||
|     regexp: "^#? *{{ item.key | regex_escape() }}:" | ||||
|     line: "{{ item.key }}: {{ item.value }}" | ||||
|     insertafter: '# Custom Settings Start' | ||||
|   with_dict: | ||||
|     'ext_federation_whitelist_raw': '{{ ext_federation_whitelist_raw.splitlines() | to_json }}' | ||||
|     'ext_url_preview_accept_language_default': '{{ ext_url_preview_accept_language_default.splitlines() | to_json }}' | ||||
|  | ||||
| - name: Set ext_recaptcha_public_key to a 'public-key' if undefined | ||||
|   set_fact: ext_recaptcha_public_key="public-key" | ||||
|   when: (ext_recaptcha_public_key is not defined) or (ext_recaptcha_public_key|length == 0) | ||||
| @@ -185,6 +174,20 @@ | ||||
|     '  recaptcha_public_key': '{{ ext_recaptcha_public_key }}' | ||||
|     '  recaptcha_private_key': '{{ ext_recaptcha_private_key }}' | ||||
|  | ||||
| - name: Record Synapse Custom variables locally on AWX | ||||
|   delegate_to: 127.0.0.1 | ||||
|   lineinfile: | ||||
|     path: '{{ awx_cached_matrix_vars }}' | ||||
|     regexp: "^#? *{{ item.key | regex_escape() }}:" | ||||
|     line: "{{ item.key }}: {{ item.value }}" | ||||
|     insertafter: '# Custom Settings Start' | ||||
|   with_dict: | ||||
|     'ext_federation_whitelist_raw': '{{ ext_federation_whitelist_raw.splitlines() | to_json }}' | ||||
|     'ext_url_preview_accept_language_default': '{{ ext_url_preview_accept_language_default.splitlines() | to_json }}' | ||||
|     'ext_enable_registration_captcha': '{{ ext_enable_registration_captcha }}' | ||||
|     'ext_recaptcha_public_key': '"{{ ext_recaptcha_public_key }}"' | ||||
|     'ext_recaptcha_private_key': '"{{ ext_recaptcha_private_key }}"' | ||||
|  | ||||
| - name: Save new 'Configure Synapse' survey.json to the AWX tower, template | ||||
|   delegate_to: 127.0.0.1 | ||||
|   template: | ||||
|   | ||||
| @@ -23,14 +23,7 @@ | ||||
|     repo: "deb [arch={{ matrix_debian_arch }}] https://download.docker.com/linux/{{ ansible_distribution|lower }} {{ ansible_distribution_release }} stable" | ||||
|     state: present | ||||
|     update_cache: yes | ||||
|   when: matrix_docker_installation_enabled|bool and matrix_docker_package_name == 'docker-ce' and not ansible_distribution_release == 'bullseye' | ||||
|  | ||||
| - name: Ensure Docker repository is enabled (using Debian Buster on Debian Bullseye, for which there is no Docker yet) | ||||
|   apt_repository: | ||||
|     repo: "deb [arch={{ matrix_debian_arch }}] https://download.docker.com/linux/{{ ansible_distribution|lower }} buster stable" | ||||
|     state: present | ||||
|     update_cache: yes | ||||
|   when: matrix_docker_installation_enabled|bool and matrix_docker_package_name == 'docker-ce' and ansible_distribution_release == 'bullseye' | ||||
|   when: matrix_docker_installation_enabled|bool and matrix_docker_package_name == 'docker-ce' | ||||
|  | ||||
| - name: Ensure APT packages are installed | ||||
|   apt: | ||||
|   | ||||
| @@ -2,6 +2,11 @@ | ||||
| # See: https://github.com/anoadragon453/matrix-reminder-bot | ||||
|  | ||||
| matrix_bot_matrix_reminder_bot_enabled: true | ||||
|  | ||||
| matrix_bot_matrix_reminder_bot_container_self_build: false | ||||
| matrix_bot_matrix_reminder_bot_docker_repo: "https://github.com/anoadragon453/matrix-reminder-bot.git" | ||||
| matrix_bot_matrix_reminder_bot_docker_src_files_path: "{{ matrix_base_data_path }}/matrix-reminder-bot/docker-src" | ||||
|  | ||||
| matrix_bot_matrix_reminder_bot_version: release-v0.2.1 | ||||
| matrix_bot_matrix_reminder_bot_docker_image: "{{ matrix_container_global_registry_prefix }}anoa/matrix-reminder-bot:{{ matrix_bot_matrix_reminder_bot_version }}" | ||||
| matrix_bot_matrix_reminder_bot_docker_image_force_pull: "{{ matrix_bot_matrix_reminder_bot_docker_image.endswith(':latest') }}" | ||||
|   | ||||
| @@ -37,6 +37,7 @@ | ||||
|     - { path: "{{ matrix_bot_matrix_reminder_bot_config_path }}", when: true } | ||||
|     - { path: "{{ matrix_bot_matrix_reminder_bot_data_path }}", when: true } | ||||
|     - { path: "{{ matrix_bot_matrix_reminder_bot_data_store_path }}", when: true } | ||||
|     - { path: "{{ matrix_bot_matrix_reminder_bot_docker_src_files_path }}", when: true} | ||||
|   when: "item.when|bool" | ||||
|  | ||||
| - name: Ensure matrix-reminder-bot image is pulled | ||||
| @@ -45,6 +46,27 @@ | ||||
|     source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}" | ||||
|     force_source: "{{ matrix_bot_matrix_reminder_bot_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_bot_matrix_reminder_bot_docker_image_force_pull }}" | ||||
|   when: "not matrix_bot_matrix_reminder_bot_container_self_build|bool" | ||||
|  | ||||
| - name: Ensure matrix-reminder-bot repository is present on self-build | ||||
|   git: | ||||
|     repo: "{{ matrix_bot_matrix_reminder_bot_docker_repo }}" | ||||
|     dest: "{{ matrix_bot_matrix_reminder_bot_docker_src_files_path }}" | ||||
|     force: "yes" | ||||
|   register: matrix_bot_matrix_reminder_bot_git_pull_results | ||||
|   when: "matrix_bot_matrix_reminder_bot_container_self_build|bool" | ||||
|  | ||||
| - name: Ensure matrix-reminder-bot image is built | ||||
|   docker_image: | ||||
|     name: "{{ matrix_bot_matrix_reminder_bot_docker_image }}" | ||||
|     source: build | ||||
|     force_source: "{{ matrix_bot_matrix_reminder_bot_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_mailer_git_pull_results.changed }}" | ||||
|     build: | ||||
|       dockerfile: docker/Dockerfile | ||||
|       path: "{{ matrix_bot_matrix_reminder_bot_docker_src_files_path }}" | ||||
|       pull: yes | ||||
|   when: "matrix_bot_matrix_reminder_bot_container_self_build|bool" | ||||
|  | ||||
| - name: Ensure matrix-reminder-bot config installed | ||||
|   copy: | ||||
|   | ||||
| @@ -7,7 +7,7 @@ matrix_appservice_irc_container_self_build: false | ||||
| matrix_appservice_irc_docker_repo: "https://github.com/matrix-org/matrix-appservice-irc.git" | ||||
| matrix_appservice_irc_docker_src_files_path: "{{ matrix_base_data_path }}/appservice-irc/docker-src" | ||||
|  | ||||
| matrix_appservice_irc_version: release-0.27.0 | ||||
| matrix_appservice_irc_version: release-v0.30.0 | ||||
| matrix_appservice_irc_docker_image: "{{ matrix_container_global_registry_prefix }}matrixdotorg/matrix-appservice-irc:{{ matrix_appservice_irc_version }}" | ||||
| matrix_appservice_irc_docker_image_force_pull: "{{ matrix_appservice_irc_docker_image.endswith(':latest') }}" | ||||
|  | ||||
|   | ||||
							
								
								
									
										100
									
								
								roles/matrix-bridge-beeper-linkedin/defaults/main.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								roles/matrix-bridge-beeper-linkedin/defaults/main.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,100 @@ | ||||
| # beeper-linkedin is a Matrix <-> LinkedIn bridge | ||||
| # See: https://gitlab.com/beeper/linkedin | ||||
|  | ||||
| matrix_beeper_linkedin_enabled: true | ||||
|  | ||||
| matrix_beeper_linkedin_version: v0.5.0 | ||||
| # See: https://gitlab.com/beeper/linkedin/container_registry | ||||
| matrix_beeper_linkedin_docker_image: "registry.gitlab.com/beeper/linkedin:{{ matrix_beeper_linkedin_version }}-amd64" | ||||
| matrix_beeper_linkedin_docker_image_force_pull: "{{ matrix_beeper_linkedin_docker_image.endswith(':latest-amd64') }}" | ||||
|  | ||||
| matrix_beeper_linkedin_base_path: "{{ matrix_base_data_path }}/beeper-linkedin" | ||||
| matrix_beeper_linkedin_config_path: "{{ matrix_beeper_linkedin_base_path }}/config" | ||||
| matrix_beeper_linkedin_data_path: "{{ matrix_beeper_linkedin_base_path }}/data" | ||||
|  | ||||
| matrix_beeper_linkedin_homeserver_address: "{{ matrix_homeserver_container_url }}" | ||||
| matrix_beeper_linkedin_homeserver_domain: "{{ matrix_domain }}" | ||||
| matrix_beeper_linkedin_appservice_address: "http://matrix-beeper-linkedin:29319" | ||||
|  | ||||
| # A list of extra arguments to pass to the container | ||||
| matrix_beeper_linkedin_container_extra_arguments: [] | ||||
|  | ||||
| # List of systemd services that matrix-beeper-linkedin.service depends on. | ||||
| matrix_beeper_linkedin_systemd_required_services_list: ['docker.service'] | ||||
|  | ||||
| # List of systemd services that matrix-beeper-linkedin.service wants | ||||
| matrix_beeper_linkedin_systemd_wanted_services_list: [] | ||||
|  | ||||
| matrix_beeper_linkedin_appservice_token: "" | ||||
| matrix_beeper_linkedin_homeserver_token: "" | ||||
|  | ||||
| matrix_beeper_linkedin_appservice_bot_username: linkedinbot | ||||
|  | ||||
|  | ||||
| # Database-related configuration fields. | ||||
| # Only Postgres is supported. | ||||
| matrix_beeper_linkedin_database_engine: "postgres" | ||||
|  | ||||
| matrix_beeper_linkedin_database_username: 'matrix_beeper_linkedin' | ||||
| matrix_beeper_linkedin_database_password: "" | ||||
| matrix_beeper_linkedin_database_hostname: 'matrix-postgres' | ||||
| matrix_beeper_linkedin_database_port: 5432 | ||||
| matrix_beeper_linkedin_database_name: 'matrix_beeper_linkedin' | ||||
|  | ||||
| matrix_beeper_linkedin_database_connection_string: 'postgresql://{{ matrix_beeper_linkedin_database_username }}:{{ matrix_beeper_linkedin_database_password }}@{{ matrix_beeper_linkedin_database_hostname }}:{{ matrix_beeper_linkedin_database_port }}/{{ matrix_beeper_linkedin_database_name }}?sslmode=disable' | ||||
|  | ||||
| matrix_beeper_linkedin_appservice_database_type: "{{ | ||||
| 	{ | ||||
| 		'postgres':'postgres', | ||||
| 	}[matrix_beeper_linkedin_database_engine] | ||||
| }}" | ||||
|  | ||||
| matrix_beeper_linkedin_appservice_database_uri: "{{ | ||||
| 	{ | ||||
| 		'postgres': matrix_beeper_linkedin_database_connection_string, | ||||
| 	}[matrix_beeper_linkedin_database_engine] | ||||
| }}" | ||||
|  | ||||
|  | ||||
| # Can be set to enable automatic double-puppeting via Shared Secret Auth (https://github.com/devture/matrix-synapse-shared-secret-auth). | ||||
| matrix_beeper_linkedin_login_shared_secret: '' | ||||
|  | ||||
| # Default beeper-linkedin 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_beeper_linkedin_configuration_extension_yaml`) | ||||
| # or completely replace this variable with your own template. | ||||
| matrix_beeper_linkedin_configuration_yaml: "{{ lookup('template', 'templates/config.yaml.j2') }}" | ||||
|  | ||||
| matrix_beeper_linkedin_configuration_extension_yaml: | | ||||
|   # Your custom YAML configuration goes here. | ||||
|   # This configuration extends the default starting configuration (`matrix_beeper_linkedin_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_beeper_linkedin_configuration_yaml`. | ||||
|  | ||||
| matrix_beeper_linkedin_configuration_extension: "{{ matrix_beeper_linkedin_configuration_extension_yaml|from_yaml if matrix_beeper_linkedin_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_beeper_linkedin_configuration_yaml`. | ||||
| matrix_beeper_linkedin_configuration: "{{ matrix_beeper_linkedin_configuration_yaml|from_yaml|combine(matrix_beeper_linkedin_configuration_extension, recursive=True) }}" | ||||
|  | ||||
| matrix_beeper_linkedin_registration_yaml: | | ||||
|   id: linkedin | ||||
|   url: {{ matrix_beeper_linkedin_appservice_address }} | ||||
|   as_token: "{{ matrix_beeper_linkedin_appservice_token }}" | ||||
|   hs_token: "{{ matrix_beeper_linkedin_homeserver_token }}" | ||||
|  | ||||
|   sender_localpart: _bot_{{ matrix_beeper_linkedin_appservice_bot_username }} | ||||
|   rate_limited: false | ||||
|   namespaces: | ||||
|       users: | ||||
|       - regex: '^@linkedin_.+:{{ matrix_beeper_linkedin_homeserver_domain|regex_escape }}$' | ||||
|         exclusive: true | ||||
|       - exclusive: true | ||||
|         regex: '^@{{ matrix_beeper_linkedin_appservice_bot_username|regex_escape }}:{{ matrix_beeper_linkedin_homeserver_domain|regex_escape }}$' | ||||
|   de.sorunome.msc2409.push_ephemeral: true | ||||
|  | ||||
| matrix_beeper_linkedin_registration: "{{ matrix_beeper_linkedin_registration_yaml|from_yaml }}" | ||||
							
								
								
									
										16
									
								
								roles/matrix-bridge-beeper-linkedin/tasks/init.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								roles/matrix-bridge-beeper-linkedin/tasks/init.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| - set_fact: | ||||
|     matrix_systemd_services_list: "{{ matrix_systemd_services_list + ['matrix-beeper-linkedin.service'] }}" | ||||
|   when: matrix_beeper_linkedin_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_beeper_linkedin_config_path }}/registration.yaml,dst=/matrix-beeper-linkedin-registration.yaml,ro"] | ||||
|  | ||||
|     matrix_synapse_app_service_config_files: > | ||||
|       {{ matrix_synapse_app_service_config_files|default([]) }} | ||||
|       + | ||||
|       {{ ["/matrix-beeper-linkedin-registration.yaml"] }} | ||||
|   when: matrix_beeper_linkedin_enabled|bool | ||||
							
								
								
									
										21
									
								
								roles/matrix-bridge-beeper-linkedin/tasks/main.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								roles/matrix-bridge-beeper-linkedin/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_beeper_linkedin_enabled|bool" | ||||
|   tags: | ||||
|     - setup-all | ||||
|     - setup-beeper-linkedin | ||||
|  | ||||
| - import_tasks: "{{ role_path }}/tasks/setup_install.yml" | ||||
|   when: "run_setup and matrix_beeper_linkedin_enabled" | ||||
|   tags: | ||||
|     - setup-all | ||||
|     - setup-beeper-linkedin | ||||
|  | ||||
| - import_tasks: "{{ role_path }}/tasks/setup_uninstall.yml" | ||||
|   when: "run_setup and not matrix_beeper_linkedin_enabled" | ||||
|   tags: | ||||
|     - setup-all | ||||
|     - setup-beeper-linkedin | ||||
							
								
								
									
										56
									
								
								roles/matrix-bridge-beeper-linkedin/tasks/setup_install.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										56
									
								
								roles/matrix-bridge-beeper-linkedin/tasks/setup_install.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,56 @@ | ||||
| --- | ||||
|  | ||||
| # 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-beeper-linkedin role needs to execute before the matrix-synapse role. | ||||
|   when: "matrix_synapse_role_executed|default(False)" | ||||
|  | ||||
| - name: Ensure Beeper LinkedIn image is pulled | ||||
|   docker_image: | ||||
|     name: "{{ matrix_beeper_linkedin_docker_image }}" | ||||
|     source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}" | ||||
|     force_source: "{{ matrix_beeper_linkedin_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_beeper_linkedin_docker_image_force_pull }}" | ||||
|  | ||||
| - name: Ensure Beeper LinkedIn paths exists | ||||
|   file: | ||||
|     path: "{{ item }}" | ||||
|     state: directory | ||||
|     mode: 0750 | ||||
|     owner: "{{ matrix_user_username }}" | ||||
|     group: "{{ matrix_user_groupname }}" | ||||
|   with_items: | ||||
|     - "{{ matrix_beeper_linkedin_base_path }}" | ||||
|     - "{{ matrix_beeper_linkedin_config_path }}" | ||||
|     - "{{ matrix_beeper_linkedin_data_path }}" | ||||
|  | ||||
| - name: Ensure beeper-linkedin config.yaml installed | ||||
|   copy: | ||||
|     content: "{{ matrix_beeper_linkedin_configuration|to_nice_yaml }}" | ||||
|     dest: "{{ matrix_beeper_linkedin_config_path }}/config.yaml" | ||||
|     mode: 0644 | ||||
|     owner: "{{ matrix_user_username }}" | ||||
|     group: "{{ matrix_user_groupname }}" | ||||
|  | ||||
| - name: Ensure beeper-linkedin registration.yaml installed | ||||
|   copy: | ||||
|     content: "{{ matrix_beeper_linkedin_registration|to_nice_yaml }}" | ||||
|     dest: "{{ matrix_beeper_linkedin_config_path }}/registration.yaml" | ||||
|     mode: 0644 | ||||
|     owner: "{{ matrix_user_username }}" | ||||
|     group: "{{ matrix_user_groupname }}" | ||||
|  | ||||
| - name: Ensure matrix-beeper-linkedin.service installed | ||||
|   template: | ||||
|     src: "{{ role_path }}/templates/systemd/matrix-beeper-linkedin.service.j2" | ||||
|     dest: "{{ matrix_systemd_path }}/matrix-beeper-linkedin.service" | ||||
|     mode: 0644 | ||||
|   register: matrix_beeper_linkedin_systemd_service_result | ||||
|  | ||||
| - name: Ensure systemd reloaded after matrix-beeper-linkedin.service installation | ||||
|   service: | ||||
|     daemon_reload: yes | ||||
|   when: "matrix_beeper_linkedin_systemd_service_result.changed" | ||||
| @@ -0,0 +1,24 @@ | ||||
| --- | ||||
|  | ||||
| - name: Check existence of matrix-beeper-linkedin service | ||||
|   stat: | ||||
|     path: "{{ matrix_systemd_path }}/matrix-beeper-linkedin.service" | ||||
|   register: matrix_beeper_linkedin_service_stat | ||||
|  | ||||
| - name: Ensure matrix-beeper-linkedin is stopped | ||||
|   service: | ||||
|     name: matrix-beeper-linkedin | ||||
|     state: stopped | ||||
|     daemon_reload: yes | ||||
|   when: "matrix_beeper_linkedin_service_stat.stat.exists" | ||||
|  | ||||
| - name: Ensure matrix-beeper-linkedin.service doesn't exist | ||||
|   file: | ||||
|     path: "{{ matrix_systemd_path }}/matrix-beeper-linkedin.service" | ||||
|     state: absent | ||||
|   when: "matrix_beeper_linkedin_service_stat.stat.exists" | ||||
|  | ||||
| - name: Ensure systemd reloaded after matrix-beeper-linkedin.service removal | ||||
|   service: | ||||
|     daemon_reload: yes | ||||
|   when: "matrix_beeper_linkedin_service_stat.stat.exists" | ||||
| @@ -0,0 +1,11 @@ | ||||
| --- | ||||
|  | ||||
| - name: Fail if required settings not defined | ||||
|   fail: | ||||
|     msg: >- | ||||
|       You need to define a required configuration setting (`{{ item }}`). | ||||
|   when: "vars[item] == ''" | ||||
|   with_items: | ||||
|     - "matrix_beeper_linkedin_appservice_token" | ||||
|     - "matrix_beeper_linkedin_homeserver_token" | ||||
|  | ||||
							
								
								
									
										267
									
								
								roles/matrix-bridge-beeper-linkedin/templates/config.yaml.j2
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										267
									
								
								roles/matrix-bridge-beeper-linkedin/templates/config.yaml.j2
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,267 @@ | ||||
| #jinja2: lstrip_blocks: "True" | ||||
| # Homeserver details. | ||||
| homeserver: | ||||
|     # The address that this appservice can use to connect to the homeserver. | ||||
|     address: {{ matrix_beeper_linkedin_homeserver_address }} | ||||
|     # The domain of the homeserver (for MXIDs, etc). | ||||
|     domain: {{ matrix_beeper_linkedin_homeserver_domain }} | ||||
|     # Whether or not to verify the SSL certificate of the homeserver. | ||||
|     # Only applies if address starts with https:// | ||||
|     verify_ssl: true | ||||
|     # Whether or not the homeserver supports asmux-specific endpoints, | ||||
|     # such as /_matrix/client/unstable/net.maunium.asmux/dms for atomically | ||||
|     # updating m.direct. | ||||
|     asmux: false | ||||
|     # Number of retries for all HTTP requests if the homeserver isn't reachable. | ||||
|     http_retry_count: 4 | ||||
|  | ||||
|  | ||||
| appservice: | ||||
|     # The address that the homeserver can use to connect to this appservice. | ||||
|     address: {{ matrix_beeper_linkedin_appservice_address }} | ||||
|  | ||||
|     # The hostname and port where this appservice should listen. | ||||
|     hostname: 0.0.0.0 | ||||
|     port: 29319 | ||||
|  | ||||
|     # 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. Only Postgres is currently supported. | ||||
|     database: {{ matrix_beeper_linkedin_appservice_database_uri|to_json }} | ||||
|     # Additional arguments for asyncpg.create_pool() | ||||
|     # https://magicstack.github.io/asyncpg/current/api/index.html#asyncpg.pool.create_pool | ||||
|     database_opts: | ||||
|         min_size: 5 | ||||
|         max_size: 10 | ||||
|  | ||||
|     # Provisioning API part of the web server for automated portal creation and fetching information. | ||||
|     # Used by things like mautrix-manager (https://github.com/tulir/mautrix-manager). | ||||
|     provisioning: | ||||
|         # Whether or not the provisioning API should be enabled. | ||||
|         enabled: true | ||||
|         # 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: beeper_linkedin | ||||
|     # Appservice bot details. | ||||
|     bot: | ||||
|         # Username of the appservice bot. | ||||
|         username: {{ matrix_beeper_linkedin_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. | ||||
|         displayname: LinkedIn bridge bot | ||||
|         avatar: mxc://sumnerevans.com/XMtwdeUBnxYvWNFFrfeTSHqB  | ||||
|  | ||||
|     # Whether or not to receive ephemeral events via appservice transactions. | ||||
|     # Requires MSC2409 support (i.e. Synapse 1.22+). | ||||
|     # You should disable bridge -> sync_with_custom_puppets when this is enabled. | ||||
|     ephemeral_events: false | ||||
|  | ||||
|     # Authentication tokens for AS <-> HS communication. Autogenerated; do not modify. | ||||
|     as_token: "{{ matrix_beeper_linkedin_appservice_token }}" | ||||
|     hs_token: "{{ matrix_beeper_linkedin_homeserver_token }}" | ||||
|  | ||||
|  | ||||
| # Prometheus telemetry config. Requires prometheus-client to be installed. | ||||
| metrics: | ||||
|     enabled: false | ||||
|     listen_port: 8000 | ||||
|  | ||||
| # Manhole config. | ||||
| manhole: | ||||
|     # Whether or not opening the manhole is allowed. | ||||
|     enabled: false | ||||
|     # The path for the unix socket. | ||||
|     path: /var/tmp/linkedin-matrix.manhole | ||||
|     # The list of UIDs who can be added to the whitelist. | ||||
|     # If empty, any UIDs can be specified in the open-manhole command. | ||||
|     whitelist: | ||||
|     - 0 | ||||
|  | ||||
|  | ||||
| # Bridge config | ||||
| bridge: | ||||
|     # Localpart template of MXIDs for LinkedIn  users. | ||||
|     username_template: "linkedin_{userid}" | ||||
|     # Displayname template for LinkedIn users. | ||||
|     # Localpart template for per-user room grouping community IDs. | ||||
|     # The bridge will create these communities and add all of the specific user's portals to the community. | ||||
|     # {localpart} is the MXID localpart and {server} is the MXID server part of the user. | ||||
|     # (Note that, by default, non-admins might not have your homeserver's permission to create | ||||
|     # communities. You should set `enable_group_creation: true` in homeserver.yaml to fix this.) | ||||
|     # `linkedin_{localpart}={server}` is a good value. | ||||
|     community_template: null | ||||
|  | ||||
|     # Displayname template for LinkedIn users. | ||||
|     # {displayname} is replaced with the display name of the LinkedIn user | ||||
|     #               as defined below in displayname_preference. | ||||
|     # Keys available for displayname_preference are also available here. | ||||
|     displayname_template: "{displayname} (LinkedIn)" | ||||
|  | ||||
|     # Number of chats to sync (and create portals for) on startup/login. | ||||
|     # Set 0 to disable automatic syncing. | ||||
|     initial_chat_sync: 10 | ||||
|  | ||||
|     # Whether or not the LinkedIn users of logged in Matrix users should be | ||||
|     # invited to private chats when the user sends a message from another client. | ||||
|     invite_own_puppet_to_pm: false | ||||
|     # Whether or not to use /sync to get presence, read receipts and typing notifications | ||||
|     # when double puppeting is enabled | ||||
|     sync_with_custom_puppets: true | ||||
|     # Whether or not to update the m.direct account data event when double puppeting is enabled. | ||||
|     # Note that updating the m.direct event is not atomic (except with mautrix-asmux) | ||||
|     # and is therefore prone to race conditions. | ||||
|     sync_direct_chat_list: false | ||||
|     # Servers to always allow double puppeting from | ||||
|     double_puppet_server_map: {} | ||||
|     #    example.com: https://example.com | ||||
|     # Allow using double puppeting from any server with a valid client .well-known file. | ||||
|  | ||||
|     # Maximum number of seconds since last message in chat to skip | ||||
|     # syncing the chat in any case. This setting will take priority | ||||
|     # over both recovery_chat_sync_limit and initial_chat_sync_count. | ||||
|     # Default is 3 days = 259200 seconds | ||||
|     sync_max_chat_age: 259200 | ||||
|  | ||||
|     # Whether or not to sync with custom puppets to receive EDUs that | ||||
|     # are not normally sent to appservices. | ||||
|     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_beeper_linkedin_login_shared_secret|to_json }} | ||||
|  | ||||
|     # Allow using double puppeting from any server with a valid client .well-known file. | ||||
|     double_puppet_allow_discovery: false | ||||
|  | ||||
|     # Whether or not to bridge presence in both directions. LinkedIn allows users not to broadcast | ||||
|     # presence, but then it won't send other users' presence to the client. | ||||
|     presence: {{ matrix_beeper_linkedin_bridge_presence|to_json }} | ||||
|     # Whether or not to update avatars when syncing all contacts at startup. | ||||
|     update_avatar_initial_sync: true | ||||
|  | ||||
|  | ||||
|     # 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 | ||||
|         # Options for automatic key sharing. | ||||
|         key_sharing: | ||||
|             # Enable key sharing? If enabled, key requests for rooms where users are in will be fulfilled. | ||||
|             # You must use a client that supports requesting keys from other users to use this feature. | ||||
|             allow: false | ||||
|             # Require the requesting device to have a valid cross-signing signature? | ||||
|             # This doesn't require that the bridge has verified the device, only that the user has verified it. | ||||
|             # Not yet implemented. | ||||
|             require_cross_signing: false | ||||
|             # Require devices to be verified by the bridge? | ||||
|             # Verification by the bridge is not yet implemented. | ||||
|             require_verification: true | ||||
|     # Whether or not the bridge should send a read receipt from the bridge bot when a message has | ||||
|     # been sent to LinkedIn. | ||||
|     delivery_receipts: false | ||||
|     # Whether to allow inviting arbitrary mxids to portal rooms | ||||
|     allow_invites: false | ||||
|  | ||||
|     # Settings for backfilling messages from LinkedIn. | ||||
|     backfill: | ||||
|         # Whether or not the LinkedIn users of logged in Matrix users should be | ||||
|         # invited to private chats when backfilling history from LinkedIn. This is | ||||
|         # usually needed to prevent rate limits and to allow timestamp massaging. | ||||
|         invite_own_puppet: true | ||||
|         # Maximum number of messages to backfill initially. | ||||
|         # Set to 0 to disable backfilling when creating portal. | ||||
|         initial_limit: 0 | ||||
|         # Maximum number of messages to backfill if messages were missed while | ||||
|         # the bridge was disconnected. | ||||
|         # Set to 0 to disable backfilling missed messages. | ||||
|         missed_limit: 1000 | ||||
|         # If using double puppeting, should notifications be disabled | ||||
|         # while the initial backfill is in progress? | ||||
|         disable_notifications: false | ||||
|     periodic_reconnect: | ||||
|         # TODO needed? | ||||
|         # Interval in seconds in which to automatically reconnect all users. | ||||
|         # This can be used to automatically mitigate the bug where Linkedin stops sending messages. | ||||
|         # Set to -1 to disable periodic reconnections entirely. | ||||
|         interval: -1 | ||||
|         # What to do in periodic reconnects. Either "refresh" or "reconnect" | ||||
|         mode: refresh | ||||
|         # Should even disconnected users be reconnected? | ||||
|         always: false | ||||
|     # The number of seconds that a disconnection can last without triggering an automatic re-sync | ||||
|     # and missed message backfilling when reconnecting. | ||||
|     # Set to 0 to always re-sync, or -1 to never re-sync automatically. | ||||
|     resync_max_disconnected_time: 5 | ||||
|     # Whether or not temporary disconnections should send notices to the notice room. | ||||
|     # If this is false, disconnections will never send messages and connections will only send | ||||
|     # messages if it was disconnected for more than resync_max_disconnected_time seconds. | ||||
|     temporary_disconnect_notices: true | ||||
|     # Whether or not the bridge should try to "refresh" the connection if a normal reconnection | ||||
|     # attempt fails. | ||||
|     refresh_on_reconnection_fail: 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 | ||||
|     # When using double puppeting, should muted chats be muted in Matrix? | ||||
|     mute_bridging: false | ||||
|     # Whether or not mute status and tags should only be bridged when the portal room is created. | ||||
|     tag_only_on_create: true | ||||
|  | ||||
|  | ||||
|     # The prefix for commands. Only required in non-management rooms. | ||||
|     command_prefix: "!li" | ||||
|  | ||||
|     # Permissions for using the bridge. | ||||
|     # Permitted values: | ||||
|     #     user - Access to use the bridge to chat with a Linkedin 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_beeper_linkedin_homeserver_domain }}": user | ||||
|  | ||||
|  | ||||
|  | ||||
| # Logging config. | ||||
| logging: | ||||
|     version: 1 | ||||
|     formatters: | ||||
|         colored: | ||||
|             (): mautrix.util.logging.color.ColorFormatter | ||||
|             format: "[%(asctime)s] [%(levelname)s@%(name)s] %(message)s" | ||||
|         normal: | ||||
|             format: "[%(asctime)s] [%(levelname)s@%(name)s] %(message)s" | ||||
|     handlers: | ||||
|         console: | ||||
|             class: logging.StreamHandler | ||||
|             formatter: colored | ||||
|     loggers: | ||||
|         mau: | ||||
|             level: DEBUG | ||||
|         paho: | ||||
|             level: INFO | ||||
|         aiohttp: | ||||
|             level: INFO | ||||
|     root: | ||||
|         level: DEBUG | ||||
|         handlers: [ console] | ||||
|  | ||||
| @@ -0,0 +1,42 @@ | ||||
| #jinja2: lstrip_blocks: "True" | ||||
| [Unit] | ||||
| Description=Matrix Beeper Linkedin bridge | ||||
| {% for service in matrix_beeper_linkedin_systemd_required_services_list %} | ||||
| Requires={{ service }} | ||||
| After={{ service }} | ||||
| {% endfor %} | ||||
| {% for service in matrix_beeper_linkedin_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-beeper-linkedin 2>/dev/null' | ||||
| ExecStartPre=-{{ matrix_host_command_sh }} -c '{{ matrix_host_command_docker }} rm matrix-beeper-linkedin 2>/dev/null' | ||||
|  | ||||
| # 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-beeper-linkedin \ | ||||
| 			--log-driver=none \ | ||||
| 			--user={{ matrix_user_uid }}:{{ matrix_user_gid }} \ | ||||
| 			--cap-drop=ALL \ | ||||
| 			--network={{ matrix_docker_network }} \ | ||||
| 			-v {{ matrix_beeper_linkedin_config_path }}:/data:z \ | ||||
| 			--workdir=/opt/linkedin-matrix \ | ||||
| 			{% for arg in matrix_beeper_linkedin_container_extra_arguments %} | ||||
| 			{{ arg }} \ | ||||
| 			{% endfor %} | ||||
| 			{{ matrix_beeper_linkedin_docker_image }} \ | ||||
|                         python3 -m linkedin_matrix -c /data/config.yaml -r /data/registration.yaml | ||||
|  | ||||
| ExecStop=-{{ matrix_host_command_sh }} -c '{{ matrix_host_command_docker }} kill matrix-beeper-linkedin 2>/dev/null' | ||||
| ExecStop=-{{ matrix_host_command_sh }} -c '{{ matrix_host_command_docker }} rm matrix-beeper-linkedin 2>/dev/null' | ||||
| Restart=always | ||||
| RestartSec=30 | ||||
| SyslogIdentifier=matrix-beeper-linkedin | ||||
|  | ||||
| [Install] | ||||
| WantedBy=multi-user.target | ||||
| @@ -3,7 +3,7 @@ | ||||
|  | ||||
| matrix_heisenbridge_enabled: true | ||||
|  | ||||
| matrix_heisenbridge_version: latest | ||||
| matrix_heisenbridge_version: 1.0.0 | ||||
| matrix_heisenbridge_docker_image: "{{ matrix_container_global_registry_prefix }}hif1/heisenbridge:{{ matrix_heisenbridge_version }}" | ||||
| matrix_heisenbridge_docker_image_force_pull: "{{ matrix_heisenbridge_docker_image.endswith(':latest') }}" | ||||
|  | ||||
|   | ||||
| @@ -1,14 +1,13 @@ | ||||
| # mautrix-facebook is a Matrix <-> Facebook bridge | ||||
| # See: https://github.com/tulir/mautrix-facebook | ||||
| # See: https://github.com/mautrix/facebook | ||||
|  | ||||
| matrix_mautrix_facebook_enabled: true | ||||
|  | ||||
| matrix_mautrix_facebook_container_image_self_build: false | ||||
| matrix_mautrix_facebook_container_image_self_build_repo: "https://github.com/tulir/mautrix-facebook.git" | ||||
| matrix_mautrix_facebook_container_image_self_build_repo: "https://mau.dev/mautrix/facebook.git" | ||||
|  | ||||
| matrix_mautrix_facebook_version: latest | ||||
| # See: https://mau.dev/tulir/mautrix-facebook/container_registry | ||||
| matrix_mautrix_facebook_docker_image: "{{ matrix_mautrix_facebook_docker_image_name_prefix }}tulir/mautrix-facebook:{{ matrix_mautrix_facebook_version }}" | ||||
| matrix_mautrix_facebook_version: v0.3.1 | ||||
| matrix_mautrix_facebook_docker_image: "{{ matrix_mautrix_facebook_docker_image_name_prefix }}mautrix/facebook:{{ matrix_mautrix_facebook_version }}" | ||||
| matrix_mautrix_facebook_docker_image_name_prefix: "{{ 'localhost/' if matrix_mautrix_facebook_container_image_self_build else 'dock.mau.dev/' }}" | ||||
| matrix_mautrix_facebook_docker_image_force_pull: "{{ matrix_mautrix_facebook_docker_image.endswith(':latest') }}" | ||||
|  | ||||
| @@ -107,7 +106,7 @@ matrix_mautrix_facebook_registration_yaml: | | ||||
|     - exclusive: true | ||||
|       regex: '^@{{ matrix_mautrix_facebook_appservice_bot_username|regex_escape }}:{{ matrix_mautrix_facebook_homeserver_domain|regex_escape }}$' | ||||
|   url: {{ matrix_mautrix_facebook_appservice_address }} | ||||
|   # See https://github.com/tulir/mautrix-signal/issues/43 | ||||
|   # See https://github.com/mautrix/signal/issues/43 | ||||
|   sender_localpart: _bot_{{ matrix_mautrix_facebook_appservice_bot_username }} | ||||
|   rate_limited: false | ||||
|   de.sorunome.msc2409.push_ephemeral: true | ||||
|   | ||||
| @@ -40,7 +40,7 @@ | ||||
|     source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}" | ||||
|     force_source: "{{ matrix_mautrix_facebook_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_facebook_docker_image_force_pull }}" | ||||
|   when: matrix_mautrix_facebook_enabled|bool and not matrix_mautrix_facebook_container_image_self_build | ||||
|   when: not matrix_mautrix_facebook_container_image_self_build | ||||
|  | ||||
| - name: Ensure Mautrix Facebook paths exist | ||||
|   file: | ||||
| @@ -63,7 +63,7 @@ | ||||
| #    version: "{{ matrix_coturn_docker_image.split(':')[1] }}" | ||||
|     force: "yes" | ||||
|   register: matrix_mautrix_facebook_git_pull_results | ||||
|   when: "matrix_mautrix_facebook_enabled|bool and matrix_mautrix_facebook_container_image_self_build" | ||||
|   when: "matrix_mautrix_facebook_container_image_self_build|bool" | ||||
|  | ||||
| - name: Ensure Mautrix Facebook Docker image is built | ||||
|   docker_image: | ||||
| @@ -75,7 +75,7 @@ | ||||
|       dockerfile: Dockerfile | ||||
|       path: "{{ matrix_mautrix_facebook_docker_src_files_path }}" | ||||
|       pull: yes | ||||
|   when: "matrix_mautrix_facebook_enabled|bool and matrix_mautrix_facebook_container_image_self_build|bool" | ||||
|   when: "matrix_mautrix_facebook_container_image_self_build|bool" | ||||
|  | ||||
| - name: Check if an old database file already exists | ||||
|   stat: | ||||
|   | ||||
| @@ -1,14 +1,14 @@ | ||||
| # mautrix-hangouts is a Matrix <-> Hangouts bridge | ||||
| # See: https://github.com/tulir/mautrix-hangouts | ||||
| # See: https://github.com/mautrix/hangouts | ||||
|  | ||||
| matrix_mautrix_hangouts_enabled: true | ||||
|  | ||||
| matrix_mautrix_hangouts_container_image_self_build: false | ||||
| matrix_mautrix_hangouts_container_image_self_build_repo: "https://github.com/tulir/mautrix-hangouts.git" | ||||
| matrix_mautrix_hangouts_container_image_self_build_repo: "https://github.com/mautrix/hangouts.git" | ||||
|  | ||||
| matrix_mautrix_hangouts_version: latest | ||||
| # See: https://mau.dev/tulir/mautrix-hangouts/container_registry | ||||
| matrix_mautrix_hangouts_docker_image: "{{ matrix_mautrix_hangouts_docker_image_name_prefix }}tulir/mautrix-hangouts:{{ matrix_mautrix_hangouts_version }}" | ||||
| # See: https://mau.dev/mautrix/hangouts/container_registry | ||||
| matrix_mautrix_hangouts_docker_image: "{{ matrix_mautrix_hangouts_docker_image_name_prefix }}mautrix/hangouts:{{ matrix_mautrix_hangouts_version }}" | ||||
| matrix_mautrix_hangouts_docker_image_name_prefix: "{{ 'localhost/' if matrix_mautrix_hangouts_container_image_self_build else 'dock.mau.dev/' }}" | ||||
| matrix_mautrix_hangouts_docker_image_force_pull: "{{ matrix_mautrix_hangouts_docker_image.endswith(':latest') }}" | ||||
|  | ||||
| @@ -107,7 +107,7 @@ matrix_mautrix_hangouts_registration_yaml: | | ||||
|     - exclusive: true | ||||
|       regex: '^@{{ matrix_mautrix_hangouts_appservice_bot_username|regex_escape }}:{{ matrix_mautrix_hangouts_homeserver_domain|regex_escape }}$' | ||||
|   url: {{ matrix_mautrix_hangouts_appservice_address }} | ||||
|   # See https://github.com/tulir/mautrix-signal/issues/43 | ||||
|   # See https://github.com/mautrix/signal/issues/43 | ||||
|   sender_localpart: _bot_{{ matrix_mautrix_hangouts_appservice_bot_username }} | ||||
|   rate_limited: false | ||||
|   de.sorunome.msc2409.push_ephemeral: true | ||||
|   | ||||
| @@ -40,7 +40,7 @@ | ||||
|     source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}" | ||||
|     force_source: "{{ matrix_mautrix_hangouts_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_hangouts_docker_image_force_pull }}" | ||||
|   when: matrix_mautrix_hangouts_enabled|bool and not matrix_mautrix_hangouts_container_image_self_build | ||||
|   when: not matrix_mautrix_hangouts_container_image_self_build | ||||
|  | ||||
| - name: Ensure Mautrix Hangouts paths exist | ||||
|   file: | ||||
| @@ -54,7 +54,7 @@ | ||||
|     - { path: "{{ matrix_mautrix_hangouts_config_path }}", when: true } | ||||
|     - { path: "{{ matrix_mautrix_hangouts_data_path }}", when: true } | ||||
|     - { path: "{{ matrix_mautrix_hangouts_docker_src_files_path }}", when: "{{ matrix_mautrix_hangouts_container_image_self_build }}" } | ||||
|   when: matrix_mautrix_hangouts_enabled|bool and item.when|bool | ||||
|   when: "item.when|bool" | ||||
|  | ||||
| - name: Ensure Mautrix Hangots repository is present on self build | ||||
|   git: | ||||
| @@ -62,7 +62,7 @@ | ||||
|     dest: "{{ matrix_mautrix_hangouts_docker_src_files_path }}" | ||||
|     force: "yes" | ||||
|   register: matrix_mautrix_hangouts_git_pull_results | ||||
|   when: "matrix_mautrix_hangouts_enabled|bool and matrix_mautrix_hangouts_container_image_self_build|bool" | ||||
|   when: "matrix_mautrix_hangouts_container_image_self_build|bool" | ||||
|  | ||||
| - name: Ensure Mautrix Hangouts Docker image is built | ||||
|   docker_image: | ||||
| @@ -74,7 +74,7 @@ | ||||
|       dockerfile: Dockerfile | ||||
|       path: "{{ matrix_mautrix_hangouts_docker_src_files_path }}" | ||||
|       pull: yes | ||||
|   when: "matrix_mautrix_hangouts_enabled|bool and matrix_mautrix_hangouts_container_image_self_build|bool" | ||||
|   when: "matrix_mautrix_hangouts_container_image_self_build|bool" | ||||
|  | ||||
| - name: Check if an old database file already exists | ||||
|   stat: | ||||
|   | ||||
| @@ -1,14 +1,14 @@ | ||||
| # mautrix-instagram is a Matrix <-> Instagram bridge | ||||
| # See: https://github.com/tulir/mautrix-instagram | ||||
| # See: https://github.com/mautrix/instagram | ||||
|  | ||||
| matrix_mautrix_instagram_enabled: true | ||||
|  | ||||
| matrix_mautrix_instagram_container_image_self_build: false | ||||
| matrix_mautrix_instagram_container_image_self_build_repo: "https://github.com/tulir/mautrix-instagram.git" | ||||
| matrix_mautrix_instagram_container_image_self_build_repo: "https://github.com/mautrix/instagram.git" | ||||
|  | ||||
| matrix_mautrix_instagram_version: latest | ||||
| # See: https://mau.dev/tulir/mautrix-instagram/container_registry | ||||
| matrix_mautrix_instagram_docker_image: "{{ matrix_mautrix_instagram_docker_image_name_prefix }}tulir/mautrix-instagram:{{ matrix_mautrix_instagram_version }}" | ||||
| matrix_mautrix_instagram_docker_image: "{{ matrix_mautrix_instagram_docker_image_name_prefix }}mautrix/instagram:{{ matrix_mautrix_instagram_version }}" | ||||
| matrix_mautrix_instagram_docker_image_name_prefix: "{{ 'localhost/' if matrix_mautrix_instagram_container_image_self_build else 'dock.mau.dev/' }}" | ||||
| matrix_mautrix_instagram_docker_image_force_pull: "{{ matrix_mautrix_instagram_docker_image.endswith(':latest') }}" | ||||
|  | ||||
| @@ -97,7 +97,7 @@ matrix_mautrix_instagram_registration_yaml: | | ||||
|     - exclusive: true | ||||
|       regex: '^@{{ matrix_mautrix_instagram_appservice_bot_username|regex_escape }}:{{ matrix_mautrix_instagram_homeserver_domain|regex_escape }}$' | ||||
|   url: {{ matrix_mautrix_instagram_appservice_address }} | ||||
|   # See https://github.com/tulir/mautrix-signal/issues/43 | ||||
|   # See https://github.com/mautrix/signal/issues/43 | ||||
|   sender_localpart: _bot_{{ matrix_mautrix_instagram_appservice_bot_username }} | ||||
|   rate_limited: false | ||||
|   de.sorunome.msc2409.push_ephemeral: true | ||||
|   | ||||
| @@ -13,7 +13,7 @@ | ||||
|     source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}" | ||||
|     force_source: "{{ matrix_mautrix_instagram_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_instagram_docker_image_force_pull }}" | ||||
|   when: matrix_mautrix_instagram_enabled|bool and not matrix_mautrix_instagram_container_image_self_build | ||||
|   when: not matrix_mautrix_instagram_container_image_self_build | ||||
|  | ||||
| - name: Ensure Mautrix instagram paths exist | ||||
|   file: | ||||
| @@ -38,7 +38,7 @@ | ||||
|     dest: "{{ matrix_mautrix_instagram_docker_src_files_path }}" | ||||
|     force: "yes" | ||||
|   register: matrix_mautrix_instagram_git_pull_results | ||||
|   when: "matrix_mautrix_instagram_enabled|bool and matrix_mautrix_instagram_container_image_self_build" | ||||
|   when: "matrix_mautrix_instagram_container_image_self_build|bool" | ||||
|  | ||||
| - name: Ensure Mautrix instagram Docker image is built | ||||
|   docker_image: | ||||
| @@ -50,7 +50,7 @@ | ||||
|       dockerfile: Dockerfile | ||||
|       path: "{{ matrix_mautrix_instagram_docker_src_files_path }}" | ||||
|       pull: yes | ||||
|   when: "matrix_mautrix_instagram_enabled|bool and matrix_mautrix_instagram_container_image_self_build|bool" | ||||
|   when: "matrix_mautrix_instagram_container_image_self_build|bool" | ||||
|  | ||||
| - name: Ensure mautrix-instagram config.yaml installed | ||||
|   copy: | ||||
|   | ||||
| @@ -1,16 +1,16 @@ | ||||
| # mautrix-signal is a Matrix <-> Signal bridge | ||||
| # See: https://github.com/tulir/mautrix-signal | ||||
| # See: https://github.com/mautrix/signal | ||||
|  | ||||
| matrix_mautrix_signal_enabled: true | ||||
|  | ||||
| matrix_mautrix_signal_container_self_build: false | ||||
| matrix_mautrix_signal_docker_repo: "https://mau.dev/tulir/mautrix-signal.git" | ||||
| matrix_mautrix_signal_docker_repo: "https://mau.dev/mautrix/signal.git" | ||||
| matrix_mautrix_signal_docker_src_files_path: "{{ matrix_base_data_path }}/mautrix-signal/docker-src" | ||||
|  | ||||
| matrix_mautrix_signal_version: latest | ||||
| matrix_mautrix_signal_daemon_version: latest | ||||
| # See: https://mau.dev/tulir/mautrix-signal/container_registry | ||||
| matrix_mautrix_signal_docker_image: "dock.mau.dev/tulir/mautrix-signal:{{ matrix_mautrix_signal_version }}" | ||||
| # See: https://mau.dev/mautrix/signal/container_registry | ||||
| matrix_mautrix_signal_docker_image: "dock.mau.dev/mautrix/signal:{{ matrix_mautrix_signal_version }}" | ||||
| matrix_mautrix_signal_docker_image_force_pull: "{{ matrix_mautrix_signal_docker_image.endswith(':latest') }}" | ||||
|  | ||||
| matrix_mautrix_signal_daemon_container_self_build: false | ||||
| @@ -70,14 +70,30 @@ matrix_mautrix_signal_database_name: 'matrix_mautrix_signal' | ||||
| matrix_mautrix_signal_database_connection_string: 'postgres://{{ matrix_mautrix_signal_database_username }}:{{ matrix_mautrix_signal_database_password }}@{{ matrix_mautrix_signal_database_hostname }}:{{ matrix_mautrix_signal_database_port }}/{{ matrix_mautrix_signal_database_name }}' | ||||
|  | ||||
| matrix_mautrix_signal_appservice_database: "{{ | ||||
|  	{ | ||||
|  		'postgres': matrix_mautrix_signal_database_connection_string, | ||||
|  	}[matrix_mautrix_signal_database_engine] | ||||
|   { | ||||
|     'postgres': matrix_mautrix_signal_database_connection_string, | ||||
|   }[matrix_mautrix_signal_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_signal_login_shared_secret: '' | ||||
|  | ||||
| # Enable bridge relay bot functionality | ||||
| matrix_mautrix_signal_relaybot_enabled: false | ||||
|  | ||||
| # Permissions for using the bridge. | ||||
| # Permitted values: | ||||
| #      relay - Allowed to be relayed through the bridge, no access to commands. | ||||
| #       user - Use the bridge with puppeting. | ||||
| #      admin - Use and administrate the bridge. | ||||
| # Permitted keys: | ||||
| #        * - All Matrix users | ||||
| #   domain - All users on that homeserver | ||||
| #     mxid - Specific user | ||||
| matrix_mautrix_signal_bridge_permissions: | | ||||
|   '*': relay | ||||
|   '{{ matrix_mautrix_signal_homeserver_domain }}': user | ||||
|  | ||||
| # Default configuration template which covers the generic use case. | ||||
| # You can customize it by controlling the various variables inside it. | ||||
| # | ||||
|   | ||||
| @@ -14,7 +14,7 @@ | ||||
|     source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}" | ||||
|     force_source: "{{ matrix_mautrix_signal_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_signal_docker_image_force_pull }}" | ||||
|   when: "matrix_mautrix_signal_enabled|bool and not matrix_mautrix_signal_container_self_build|bool" | ||||
|   when: "not matrix_mautrix_signal_container_self_build|bool" | ||||
|  | ||||
|  | ||||
| - name: Ensure Mautrix Signal repository is present on self-build | ||||
| @@ -23,7 +23,7 @@ | ||||
|     dest: "{{ matrix_mautrix_signal_docker_src_files_path }}" | ||||
|     force: "yes" | ||||
|   register: matrix_mautrix_signal_git_pull_results | ||||
|   when: "matrix_mautrix_signal_enabled|bool and matrix_mautrix_signal_container_self_build|bool" | ||||
|   when: "matrix_mautrix_signal_container_self_build|bool" | ||||
|  | ||||
| - name: Ensure Mautrix Signal image is built | ||||
|   docker_image: | ||||
| @@ -35,8 +35,8 @@ | ||||
|       dockerfile: Dockerfile | ||||
|       path: "{{ matrix_mautrix_signal_docker_src_files_path }}" | ||||
|       pull: yes | ||||
|   when: "matrix_mautrix_signal_enabled|bool and matrix_mautrix_signal_container_self_build|bool" | ||||
|    | ||||
|   when: "matrix_mautrix_signal_container_self_build|bool" | ||||
|  | ||||
|  | ||||
| - name: Ensure Mautrix Signal Daemon image is pulled | ||||
|   docker_image: | ||||
| @@ -53,7 +53,7 @@ | ||||
|     dest: "{{ matrix_mautrix_signal_daemon_docker_src_files_path }}" | ||||
|     force: "yes" | ||||
|   register: matrix_mautrix_signal_daemon_git_pull_results | ||||
|   when: "matrix_mautrix_signal_enabled|bool and matrix_mautrix_signal_daemon_container_self_build|bool" | ||||
|   when: "matrix_mautrix_signal_daemon_container_self_build|bool" | ||||
|  | ||||
| - name: Ensure Mautrix Signal Daemon image is built | ||||
|   docker_image: | ||||
| @@ -65,7 +65,7 @@ | ||||
|       dockerfile: Dockerfile | ||||
|       path: "{{ matrix_mautrix_signal_daemon_docker_src_files_path }}" | ||||
|       pull: yes | ||||
|   when: "matrix_mautrix_signal_enabled|bool and matrix_mautrix_signal_daemon_container_self_build|bool" | ||||
|   when: "matrix_mautrix_signal_daemon_container_self_build|bool" | ||||
|  | ||||
| - name: Ensure Mautrix Signal paths exist | ||||
|   file: | ||||
|   | ||||
| @@ -9,6 +9,12 @@ homeserver: | ||||
|     # Only applies if address starts with https:// | ||||
|     verify_ssl: true | ||||
|     asmux: false | ||||
|     # Number of retries for all HTTP requests if the homeserver isn't reachable. | ||||
|     http_retry_count: 4 | ||||
|     # The URL to push real-time bridge status to. | ||||
|     # If set, the bridge will make POST requests to this URL whenever a user's Signal connection state changes. | ||||
|     # The bridge will use the appservice as_token to authorize requests. | ||||
|     status_endpoint: null | ||||
|  | ||||
| # Application service host/registration related details | ||||
| # Changing these values requires regeneration of the registration. | ||||
| @@ -80,6 +86,9 @@ signal: | ||||
|     avatar_dir: /signald/avatars | ||||
|     # Directory where signald stores auth data. Used to delete data when logging out. | ||||
|     data_dir: /signald/data | ||||
|     # Whether or not unknown signald accounts should be deleted when the bridge is started. | ||||
|     # When this is enabled, any UserInUse errors should be resolved by restarting the bridge. | ||||
|     delete_unknown_accounts_on_start: false | ||||
|     # Whether or not message attachments should be removed from disk after they're bridged. | ||||
|     remove_file_after_handling: true | ||||
|  | ||||
| @@ -131,7 +140,7 @@ bridge: | ||||
|     # If false, created portal rooms will never be federated. | ||||
|     federate_rooms: true | ||||
|     # End-to-bridge encryption support options. You must install the e2be optional dependency for | ||||
|     # this to work. See https://github.com/tulir/mautrix-telegram/wiki/End‐to‐bridge-encryption | ||||
|     # this to work. See https://docs.mau.fi/bridges/general/end-to-bridge-encryption.html | ||||
|     encryption: | ||||
|         # Allow encryption, work in group chat rooms with e2ee enabled | ||||
|         allow: false | ||||
| @@ -164,20 +173,44 @@ bridge: | ||||
|     # This field will automatically be changed back to false after it, | ||||
|     # except if the config file is not writable. | ||||
|     resend_bridge_info: false | ||||
|     # Interval at which to resync contacts. | ||||
|     periodic_sync: 0 | ||||
|  | ||||
|     # The prefix for commands. Only required in non-management rooms. | ||||
|     command_prefix: "!signal" | ||||
|  | ||||
|     # Permissions for using the bridge. | ||||
|     # Permitted values: | ||||
|     #      relay - Allowed to be relayed through the bridge, no access to commands. | ||||
|     #       user - Use the bridge with puppeting. | ||||
|     #      admin - Use and administrate the bridge. | ||||
|     # Permitted keys: | ||||
|     #        * - All Matrix users | ||||
|     #   domain - All users on that homeserver | ||||
|     #     mxid - Specific user | ||||
|     permissions: | ||||
|       '{{ matrix_mautrix_signal_homeserver_domain }}': user | ||||
|     permissions:  | ||||
|         {{ matrix_mautrix_signal_bridge_permissions|from_yaml }} | ||||
|  | ||||
|     relay: | ||||
|         # Whether or not relay mode should be allowed. If allowed, `!signal set-relay` can be used to turn any | ||||
|         # authenticated user into a relaybot for that chat. | ||||
|         enabled: {{ matrix_mautrix_signal_relaybot_enabled }} | ||||
|         # The formats to use when sending messages to Signal via a relay user. | ||||
|         # | ||||
|         # 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 | ||||
|         message_formats: | ||||
|             m.text: '$sender_displayname: $message' | ||||
|             m.notice: '$sender_displayname: $message' | ||||
|             m.emote: '* $sender_displayname $message' | ||||
|             m.file: '$sender_displayname sent a file' | ||||
|             m.image: '$sender_displayname  sent an image' | ||||
|             m.audio: '$sender_displayname  sent an audio file' | ||||
|             m.video: '$sender_displayname  sent a video' | ||||
|             m.location: '$sender_displayname  sent a location' | ||||
|  | ||||
|  | ||||
| # Python logging configuration. | ||||
|   | ||||
| @@ -12,7 +12,7 @@ namespaces: | ||||
|     - exclusive: true | ||||
|       regex: '^#signal_.+:{{ matrix_mautrix_signal_homeserver_domain|regex_escape }}$' | ||||
| url: {{ matrix_mautrix_signal_appservice_address }} | ||||
| # See https://github.com/tulir/mautrix-signal/issues/43 | ||||
| # See https://github.com/mautrix/signal/issues/43 | ||||
| sender_localpart: _bot_{{ matrix_mautrix_signal_appservice_bot_username }} | ||||
| rate_limited: false | ||||
| de.sorunome.msc2409.push_ephemeral: true | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| # mautrix-telegram is a Matrix <-> Telegram bridge | ||||
| # See: https://github.com/tulir/mautrix-telegram | ||||
| # See: https://github.com/mautrix/telegram | ||||
|  | ||||
| matrix_mautrix_telegram_enabled: true | ||||
|  | ||||
| @@ -10,12 +10,12 @@ matrix_telegram_lottieconverter_docker_src_files_path: "{{ matrix_base_data_path | ||||
| 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_repo: "https://mau.dev/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_version: v0.10.1 | ||||
| # See: https://mau.dev/mautrix/telegram/container_registry | ||||
| matrix_mautrix_telegram_docker_image: "dock.mau.dev/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" | ||||
| @@ -123,7 +123,7 @@ matrix_mautrix_telegram_registration_yaml: | | ||||
|       aliases: | ||||
|       - exclusive: true | ||||
|         regex: '^#telegram_.+:{{ matrix_mautrix_telegram_homeserver_domain|regex_escape }}$' | ||||
|   # See https://github.com/tulir/mautrix-signal/issues/43 | ||||
|   # See https://github.com/mautrix/signal/issues/43 | ||||
|   sender_localpart: _bot_{{ matrix_mautrix_telegram_appservice_bot_username }} | ||||
|   url: {{ matrix_mautrix_telegram_appservice_address }} | ||||
|   rate_limited: false | ||||
|   | ||||
| @@ -1,11 +1,11 @@ | ||||
| # mautrix-whatsapp is a Matrix <-> Whatsapp bridge | ||||
| # See: https://github.com/tulir/mautrix-whatsapp | ||||
| # See: https://github.com/mautrix/whatsapp | ||||
|  | ||||
| matrix_mautrix_whatsapp_enabled: true | ||||
|  | ||||
| matrix_mautrix_whatsapp_version: latest | ||||
| # See: https://mau.dev/tulir/mautrix-whatsapp/container_registry | ||||
| matrix_mautrix_whatsapp_docker_image: "dock.mau.dev/tulir/mautrix-whatsapp:{{ matrix_mautrix_whatsapp_version }}" | ||||
| # See: https://mau.dev/mautrix/whatsapp/container_registry | ||||
| matrix_mautrix_whatsapp_docker_image: "dock.mau.dev/mautrix/whatsapp:{{ matrix_mautrix_whatsapp_version }}" | ||||
| matrix_mautrix_whatsapp_docker_image_force_pull: "{{ matrix_mautrix_whatsapp_docker_image.endswith(':latest') }}" | ||||
|  | ||||
| matrix_mautrix_whatsapp_base_path: "{{ matrix_base_data_path }}/mautrix-whatsapp" | ||||
| @@ -96,7 +96,7 @@ matrix_mautrix_whatsapp_registration_yaml: | | ||||
|   url: {{ matrix_mautrix_whatsapp_appservice_address }} | ||||
|   as_token: "{{ matrix_mautrix_whatsapp_appservice_token }}" | ||||
|   hs_token: "{{ matrix_mautrix_whatsapp_homeserver_token }}" | ||||
|   # See https://github.com/tulir/mautrix-signal/issues/43 | ||||
|   # See https://github.com/mautrix/signal/issues/43 | ||||
|   sender_localpart: _bot_{{ matrix_mautrix_whatsapp_appservice_bot_username }} | ||||
|   rate_limited: false | ||||
|   namespaces: | ||||
|   | ||||
| @@ -3,7 +3,7 @@ matrix_client_element_enabled: true | ||||
| matrix_client_element_container_image_self_build: false | ||||
| matrix_client_element_container_image_self_build_repo: "https://github.com/vector-im/riot-web.git" | ||||
|  | ||||
| matrix_client_element_version: v1.7.33 | ||||
| matrix_client_element_version: v1.8.1 | ||||
| matrix_client_element_docker_image: "{{ matrix_client_element_docker_image_name_prefix }}vectorim/element-web:{{ matrix_client_element_version }}" | ||||
| matrix_client_element_docker_image_name_prefix: "{{ 'localhost/' if matrix_client_element_container_image_self_build else matrix_container_global_registry_prefix }}" | ||||
| matrix_client_element_docker_image_force_pull: "{{ matrix_client_element_docker_image.endswith(':latest') }}" | ||||
|   | ||||
| @@ -5,7 +5,7 @@ matrix_client_hydrogen_enabled: true | ||||
| matrix_client_hydrogen_container_image_self_build: true | ||||
| matrix_client_hydrogen_container_image_self_build_repo: "https://github.com/vector-im/hydrogen-web.git" | ||||
|  | ||||
| matrix_client_hydrogen_version: v0.2.3 | ||||
| matrix_client_hydrogen_version: v0.2.5 | ||||
| matrix_client_hydrogen_docker_image: "{{ matrix_client_hydrogen_docker_image_name_prefix }}vectorim/hydrogen-web:{{ matrix_client_hydrogen_version }}" | ||||
| matrix_client_hydrogen_docker_image_name_prefix: "{{ 'localhost/' if matrix_client_hydrogen_container_image_self_build }}" | ||||
| matrix_client_hydrogen_docker_image_force_pull: "{{ matrix_client_hydrogen_docker_image.endswith(':latest') }}" | ||||
|   | ||||
| @@ -60,11 +60,5 @@ | ||||
|     state: directory | ||||
|     owner: matrix | ||||
|     group: matrix | ||||
|     mode: '0574' | ||||
|   when: customise_base_domain_website is defined | ||||
|  | ||||
| - name: Ensure erroneous /chroot/website/matrix-domain location doesn't exist | ||||
|   file: | ||||
|     path: /chroot/website/matrix-domain | ||||
|     state: absent | ||||
|     mode: '0770' | ||||
|   when: customise_base_domain_website is defined | ||||
|   | ||||
| @@ -22,7 +22,7 @@ matrix_corporal_container_extra_arguments: [] | ||||
| # List of systemd services that matrix-corporal.service depends on | ||||
| matrix_corporal_systemd_required_services_list: ['docker.service'] | ||||
|  | ||||
| matrix_corporal_version: 2.1.1 | ||||
| matrix_corporal_version: 2.1.2 | ||||
| matrix_corporal_docker_image: "{{ matrix_corporal_docker_image_name_prefix }}devture/matrix-corporal:{{ matrix_corporal_docker_image_tag }}" | ||||
| matrix_corporal_docker_image_name_prefix: "{{ 'localhost/' if matrix_corporal_container_image_self_build else matrix_container_global_registry_prefix }}" | ||||
| matrix_corporal_docker_image_tag: "{{ matrix_corporal_version }}" # for backward-compatibility | ||||
|   | ||||
| @@ -5,7 +5,7 @@ matrix_coturn_container_image_self_build_repo: "https://github.com/coturn/coturn | ||||
| matrix_coturn_container_image_self_build_repo_version: "docker/{{ matrix_coturn_version }}" | ||||
| matrix_coturn_container_image_self_build_repo_dockerfile_path: "docker/coturn/alpine/Dockerfile" | ||||
|  | ||||
| matrix_coturn_version: 4.5.2-r2 | ||||
| matrix_coturn_version: 4.5.2-r3 | ||||
| matrix_coturn_docker_image: "{{ matrix_coturn_docker_image_name_prefix }}coturn/coturn:{{ matrix_coturn_version }}-alpine" | ||||
| matrix_coturn_docker_image_name_prefix: "{{ 'localhost/' if matrix_coturn_container_image_self_build else matrix_container_global_registry_prefix }}" | ||||
| matrix_coturn_docker_image_force_pull: "{{ matrix_coturn_docker_image.endswith(':latest') }}" | ||||
|   | ||||
| @@ -2,9 +2,15 @@ matrix_email2matrix_enabled: true | ||||
|  | ||||
| matrix_email2matrix_base_path: "{{ matrix_base_data_path }}/email2matrix" | ||||
| matrix_email2matrix_config_dir_path: "{{ matrix_email2matrix_base_path }}/config" | ||||
| matrix_email2matrix_docker_src_files_path: "{{ matrix_email2matrix_base_path }}/docker-src" | ||||
|  | ||||
| matrix_email2matrix_container_image_self_build: false | ||||
| matrix_email2matrix_container_image_self_build_repo: "https://github.com/devture/email2matrix.git" | ||||
| matrix_email2matrix_container_image_self_build_branch: "{{ matrix_email2matrix_version }}" | ||||
|  | ||||
| matrix_email2matrix_version: 1.0.1 | ||||
| matrix_email2matrix_docker_image: "{{ matrix_container_global_registry_prefix }}devture/email2matrix:{{ matrix_email2matrix_version }}" | ||||
| matrix_email2matrix_docker_image_prefix: "{{ 'localhost/' if matrix_email2matrix_container_image_self_build else matrix_container_global_registry_prefix }}" | ||||
| matrix_email2matrix_docker_image: "{{ matrix_email2matrix_docker_image_prefix }}devture/email2matrix:{{ matrix_email2matrix_version }}" | ||||
| matrix_email2matrix_docker_image_force_pull: "{{ matrix_email2matrix_docker_image.endswith(':latest') }}" | ||||
|  | ||||
| # A list of extra arguments to pass to the container | ||||
|   | ||||
| @@ -8,8 +8,14 @@ | ||||
|     - setup-all | ||||
|     - setup-email2matrix | ||||
|  | ||||
| - import_tasks: "{{ role_path }}/tasks/setup_email2matrix.yml" | ||||
|   when: run_setup|bool | ||||
| - import_tasks: "{{ role_path }}/tasks/setup_install.yml" | ||||
|   when: "run_setup|bool and matrix_email2matrix_enabled|bool" | ||||
|   tags: | ||||
|     - setup-all | ||||
|     - setup-email2matrix | ||||
|  | ||||
| - import_tasks: "{{ role_path }}/tasks/setup_uninstall.yml" | ||||
|   when: "run_setup|bool and not matrix_email2matrix_enabled|bool" | ||||
|   tags: | ||||
|     - setup-all | ||||
|     - setup-email2matrix | ||||
|   | ||||
| @@ -1,88 +0,0 @@ | ||||
| --- | ||||
|  | ||||
| # | ||||
| # Tasks related to setting up Email2Matrix | ||||
| # | ||||
|  | ||||
| - name: Ensure Email2Matrix paths exist | ||||
|   file: | ||||
|     path: "{{ item }}" | ||||
|     state: directory | ||||
|     mode: 0750 | ||||
|     owner: "{{ matrix_user_username }}" | ||||
|     group: "{{ matrix_user_groupname }}" | ||||
|   with_items: | ||||
|     - "{{ matrix_email2matrix_base_path }}" | ||||
|     - "{{ matrix_email2matrix_config_dir_path }}" | ||||
|   when: matrix_email2matrix_enabled|bool | ||||
|  | ||||
| - name: Ensure Email2Matrix configuration file created | ||||
|   template: | ||||
|     src: "{{ role_path }}/templates/config.json.j2" | ||||
|     dest: "{{ matrix_email2matrix_config_dir_path }}/config.json" | ||||
|     owner: "{{ matrix_user_username }}" | ||||
|     group: "{{ matrix_user_groupname }}" | ||||
|     mode: 0640 | ||||
|   when: matrix_email2matrix_enabled|bool | ||||
|  | ||||
| - name: Ensure Email2Matrix image is pulled | ||||
|   docker_image: | ||||
|     name: "{{ matrix_email2matrix_docker_image }}" | ||||
|     source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}" | ||||
|     force_source: "{{ matrix_email2matrix_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_email2matrix_docker_image_force_pull }}" | ||||
|   when: matrix_email2matrix_enabled|bool | ||||
|  | ||||
| - name: Ensure matrix-email2matrix.service installed | ||||
|   template: | ||||
|     src: "{{ role_path }}/templates/systemd/matrix-email2matrix.service.j2" | ||||
|     dest: "{{ matrix_systemd_path }}/matrix-email2matrix.service" | ||||
|     mode: 0644 | ||||
|   register: matrix_email2matrix_systemd_service_result | ||||
|   when: matrix_email2matrix_enabled|bool | ||||
|  | ||||
| - name: Ensure systemd reloaded after matrix-email2matrix.service installation | ||||
|   service: | ||||
|     daemon_reload: yes | ||||
|   when: "matrix_email2matrix_enabled|bool and matrix_email2matrix_systemd_service_result.changed" | ||||
|  | ||||
| # | ||||
| # Tasks related to getting rid of the Email2Matrix (if it was previously enabled) | ||||
| # | ||||
|  | ||||
| - name: Check existence of matrix-email2matrix service | ||||
|   stat: | ||||
|     path: "{{ matrix_systemd_path }}/matrix-email2matrix.service" | ||||
|   register: matrix_email2matrix_service_stat | ||||
|   when: "not matrix_email2matrix_enabled|bool" | ||||
|  | ||||
| - name: Ensure matrix-email2matrix is stopped | ||||
|   service: | ||||
|     name: matrix-email2matrix | ||||
|     state: stopped | ||||
|     daemon_reload: yes | ||||
|   register: stopping_result | ||||
|   when: "not matrix_email2matrix_enabled|bool and matrix_email2matrix_service_stat.stat.exists" | ||||
|  | ||||
| - name: Ensure matrix-email2matrix.service doesn't exist | ||||
|   file: | ||||
|     path: "{{ matrix_systemd_path }}/matrix-email2matrix.service" | ||||
|     state: absent | ||||
|   when: "not matrix_email2matrix_enabled|bool and matrix_email2matrix_service_stat.stat.exists" | ||||
|  | ||||
| - name: Ensure systemd reloaded after matrix-email2matrix.service removal | ||||
|   service: | ||||
|     daemon_reload: yes | ||||
|   when: "not matrix_email2matrix_enabled|bool and matrix_email2matrix_service_stat.stat.exists" | ||||
|  | ||||
| - name: Ensure Email2Matrix data path doesn't exist | ||||
|   file: | ||||
|     path: "{{ matrix_email2matrix_base_path }}" | ||||
|     state: absent | ||||
|   when: "not matrix_email2matrix_enabled|bool" | ||||
|  | ||||
| - name: Ensure Email2Matrix Docker image doesn't exist | ||||
|   docker_image: | ||||
|     name: "{{ matrix_email2matrix_docker_image }}" | ||||
|     state: absent | ||||
|   when: "not matrix_email2matrix_enabled|bool" | ||||
							
								
								
									
										63
									
								
								roles/matrix-email2matrix/tasks/setup_install.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								roles/matrix-email2matrix/tasks/setup_install.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,63 @@ | ||||
| --- | ||||
|  | ||||
| - name: Ensure Email2Matrix paths exist | ||||
|   file: | ||||
|     path: "{{ item.path }}" | ||||
|     state: directory | ||||
|     mode: 0750 | ||||
|     owner: "{{ matrix_user_username }}" | ||||
|     group: "{{ matrix_user_groupname }}" | ||||
|   with_items: | ||||
|     - { path: "{{ matrix_email2matrix_base_path }}", when: true } | ||||
|     - { path: "{{ matrix_email2matrix_config_dir_path }}", when: true } | ||||
|     - { path: "{{ matrix_email2matrix_docker_src_files_path }}", when: "{{ matrix_email2matrix_container_image_self_build }}"} | ||||
|   when: "item.when|bool" | ||||
|  | ||||
| - name: Ensure Email2Matrix configuration file created | ||||
|   template: | ||||
|     src: "{{ role_path }}/templates/config.json.j2" | ||||
|     dest: "{{ matrix_email2matrix_config_dir_path }}/config.json" | ||||
|     owner: "{{ matrix_user_username }}" | ||||
|     group: "{{ matrix_user_groupname }}" | ||||
|     mode: 0640 | ||||
|  | ||||
| - name: Ensure Email2Matrix image is pulled | ||||
|   docker_image: | ||||
|     name: "{{ matrix_email2matrix_docker_image }}" | ||||
|     source: "{{ 'pull' if ansible_version.major > 2 or ansible_version.minor > 7 else omit }}" | ||||
|     force_source: "{{ matrix_email2matrix_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_email2matrix_docker_image_force_pull }}" | ||||
|   when: "not matrix_email2matrix_container_image_self_build|bool" | ||||
|  | ||||
| - name: Ensure Email2Matrix repository is present on self-build | ||||
|   git: | ||||
|     repo: "{{ matrix_email2matrix_container_image_self_build_repo }}" | ||||
|     dest: "{{ matrix_email2matrix_docker_src_files_path }}" | ||||
|     version: "{{ matrix_email2matrix_container_image_self_build_branch }}" | ||||
|     force: "yes" | ||||
|   register: matrix_email2matrix_git_pull_results | ||||
|   when: "matrix_email2matrix_container_image_self_build|bool" | ||||
|  | ||||
| - name: Ensure Email2Matrix Docker image is built | ||||
|   docker_image: | ||||
|     name: "{{ matrix_email2matrix_docker_image }}" | ||||
|     source: build | ||||
|     force_source: "{{ matrix_email2matrix_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_email2matrix_git_pull_results.changed }}" | ||||
|     build: | ||||
|       dockerfile: etc/docker/Dockerfile | ||||
|       path: "{{ matrix_email2matrix_docker_src_files_path }}" | ||||
|       pull: yes | ||||
|   when: "matrix_email2matrix_container_image_self_build|bool" | ||||
|  | ||||
| - name: Ensure matrix-email2matrix.service installed | ||||
|   template: | ||||
|     src: "{{ role_path }}/templates/systemd/matrix-email2matrix.service.j2" | ||||
|     dest: "{{ matrix_systemd_path }}/matrix-email2matrix.service" | ||||
|     mode: 0644 | ||||
|   register: matrix_email2matrix_systemd_service_result | ||||
|  | ||||
| - name: Ensure systemd reloaded after matrix-email2matrix.service installation | ||||
|   service: | ||||
|     daemon_reload: yes | ||||
|   when: "matrix_email2matrix_systemd_service_result.changed|bool" | ||||
							
								
								
									
										35
									
								
								roles/matrix-email2matrix/tasks/setup_uninstall.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								roles/matrix-email2matrix/tasks/setup_uninstall.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | ||||
| --- | ||||
|  | ||||
| - name: Check existence of matrix-email2matrix service | ||||
|   stat: | ||||
|     path: "{{ matrix_systemd_path }}/matrix-email2matrix.service" | ||||
|   register: matrix_email2matrix_service_stat | ||||
|  | ||||
| - name: Ensure matrix-email2matrix is stopped | ||||
|   service: | ||||
|     name: matrix-email2matrix | ||||
|     state: stopped | ||||
|     daemon_reload: yes | ||||
|   register: stopping_result | ||||
|   when: "matrix_email2matrix_service_stat.stat.exists|bool" | ||||
|  | ||||
| - name: Ensure matrix-email2matrix.service doesn't exist | ||||
|   file: | ||||
|     path: "{{ matrix_systemd_path }}/matrix-email2matrix.service" | ||||
|     state: absent | ||||
|   when: "matrix_email2matrix_service_stat.stat.exists|bool" | ||||
|  | ||||
| - name: Ensure systemd reloaded after matrix-email2matrix.service removal | ||||
|   service: | ||||
|     daemon_reload: yes | ||||
|   when: "matrix_email2matrix_service_stat.stat.exists|bool" | ||||
|  | ||||
| - name: Ensure Email2Matrix data path doesn't exist | ||||
|   file: | ||||
|     path: "{{ matrix_email2matrix_base_path }}" | ||||
|     state: absent | ||||
|  | ||||
| - name: Ensure Email2Matrix Docker image doesn't exist | ||||
|   docker_image: | ||||
|     name: "{{ matrix_email2matrix_docker_image }}" | ||||
|     state: absent | ||||
| @@ -1,7 +1,7 @@ | ||||
| AUTH_TYPE={{ matrix_jitsi_auth_type }} | ||||
| BRIDGE_AVG_PARTICIPANT_STRESS | ||||
| BRIDGE_STRESS_THRESHOLD | ||||
| ENABLE_AUTH | ||||
| ENABLE_AUTH={{ 1 if matrix_jitsi_enable_auth else 0 }} | ||||
| ENABLE_AUTO_OWNER | ||||
| ENABLE_CODEC_VP8 | ||||
| ENABLE_CODEC_VP9 | ||||
|   | ||||
| @@ -7,11 +7,9 @@ matrix_ma1sd_container_image_self_build: false | ||||
| matrix_ma1sd_container_image_self_build_repo: "https://github.com/ma1uta/ma1sd.git" | ||||
| matrix_ma1sd_container_image_self_build_branch: "{{ matrix_ma1sd_version }}" | ||||
|  | ||||
| matrix_ma1sd_architecture: "amd64" | ||||
| matrix_ma1sd_version: "2.5.0" | ||||
|  | ||||
| matrix_ma1sd_version: "2.4.0" | ||||
|  | ||||
| matrix_ma1sd_docker_image: "{{ matrix_ma1sd_docker_image_name_prefix }}ma1uta/ma1sd:{{ matrix_ma1sd_version }}-{{ matrix_ma1sd_architecture }}" | ||||
| matrix_ma1sd_docker_image: "{{ matrix_ma1sd_docker_image_name_prefix }}ma1uta/ma1sd:{{ matrix_ma1sd_version }}" | ||||
| matrix_ma1sd_docker_image_name_prefix: "{{ 'localhost/' if matrix_ma1sd_container_image_self_build else matrix_container_global_registry_prefix }}" | ||||
| matrix_ma1sd_docker_image_force_pull: "{{ matrix_ma1sd_docker_image.endswith(':latest') }}" | ||||
|  | ||||
|   | ||||
| @@ -28,6 +28,7 @@ | ||||
|     - 'matrix_ma1sd_ldap_auth_filter' | ||||
|     - 'matrix_ma1sd_ldap_directory_filter' | ||||
|     - 'matrix_ma1sd_template_config' | ||||
|     - 'matrix_ma1sd_architecture' | ||||
|  | ||||
| - name: Ensure ma1sd configuration does not contain any dot-notation keys | ||||
|   fail: | ||||
|   | ||||
| @@ -7,7 +7,7 @@ matrix_mailer_container_image_self_build_repository_url: "https://github.com/dev | ||||
| matrix_mailer_container_image_self_build_src_files_path: "{{ matrix_mailer_base_path }}/docker-src" | ||||
| matrix_mailer_container_image_self_build_version: "{{ matrix_mailer_docker_image.split(':')[1] }}" | ||||
|  | ||||
| matrix_mailer_version: 4.94.2-r0-2 | ||||
| matrix_mailer_version: 4.94.2-r0-3 | ||||
| matrix_mailer_docker_image: "{{ matrix_mailer_docker_image_name_prefix }}devture/exim-relay:{{ matrix_mailer_version }}" | ||||
| matrix_mailer_docker_image_name_prefix: "{{ 'localhost/' if matrix_mailer_container_image_self_build else matrix_container_global_registry_prefix }}" | ||||
| matrix_mailer_docker_image_force_pull: "{{ matrix_mailer_docker_image.endswith(':latest') }}" | ||||
|   | ||||
| @@ -10,6 +10,7 @@ matrix_nginx_proxy_docker_image_force_pull: "{{ matrix_nginx_proxy_docker_image. | ||||
| matrix_nginx_proxy_base_path: "{{ matrix_base_data_path }}/nginx-proxy" | ||||
| matrix_nginx_proxy_data_path: "{{ matrix_nginx_proxy_base_path }}/data" | ||||
| matrix_nginx_proxy_data_path_in_container: "/nginx-data" | ||||
| matrix_nginx_proxy_data_path_extension: "/matrix_domain" | ||||
| matrix_nginx_proxy_confd_path: "{{ matrix_nginx_proxy_base_path }}/conf.d" | ||||
|  | ||||
| # List of systemd services that matrix-nginx-proxy.service depends on | ||||
| @@ -75,6 +76,9 @@ matrix_nginx_proxy_container_federation_host_bind_port: '8448' | ||||
| # in the `{{ matrix_nginx_proxy_data_path }}/matrix-domain` (`/matrix/nginx-proxy/data/matrix-domain`) directory. | ||||
| matrix_nginx_proxy_base_domain_serving_enabled: false | ||||
|  | ||||
| # Controls whether the base domain directory and default index.html file are created. | ||||
| matrix_nginx_proxy_base_domain_create_directory: true | ||||
|  | ||||
| matrix_nginx_proxy_base_domain_hostname: "{{ matrix_domain }}" | ||||
|  | ||||
| # Controls whether `matrix_nginx_proxy_base_domain_homepage_template` would be dumped to an `index.html` file | ||||
| @@ -405,7 +409,7 @@ matrix_ssl_additional_domains_to_obtain_certificates_for: [] | ||||
|  | ||||
| # Controls whether to obtain production or staging certificates from Let's Encrypt. | ||||
| matrix_ssl_lets_encrypt_staging: false | ||||
| matrix_ssl_lets_encrypt_certbot_docker_image: "{{ matrix_container_global_registry_prefix }}certbot/certbot:{{ matrix_ssl_architecture }}-v1.17.0" | ||||
| matrix_ssl_lets_encrypt_certbot_docker_image: "{{ matrix_container_global_registry_prefix }}certbot/certbot:{{ matrix_ssl_architecture }}-v1.18.0" | ||||
| matrix_ssl_lets_encrypt_certbot_docker_image_force_pull: "{{ matrix_ssl_lets_encrypt_certbot_docker_image.endswith(':latest') }}" | ||||
| matrix_ssl_lets_encrypt_certbot_standalone_http_port: 2402 | ||||
| matrix_ssl_lets_encrypt_support_email: ~ | ||||
|   | ||||
| @@ -127,7 +127,7 @@ | ||||
|     mode: 0750 | ||||
|     owner: "{{ matrix_user_username }}" | ||||
|     group: "{{ matrix_user_groupname }}" | ||||
|   when: matrix_nginx_proxy_base_domain_serving_enabled|bool | ||||
|   when: matrix_nginx_proxy_base_domain_serving_enabled|bool and matrix_nginx_proxy_base_domain_create_directory|bool | ||||
|  | ||||
| - name: Ensure Matrix nginx-proxy homepage for base domain exists | ||||
|   copy: | ||||
| @@ -136,7 +136,7 @@ | ||||
|     mode: 0644 | ||||
|     owner: "{{ matrix_user_username }}" | ||||
|     group: "{{ matrix_user_groupname }}" | ||||
|   when: matrix_nginx_proxy_base_domain_serving_enabled|bool and matrix_nginx_proxy_base_domain_homepage_enabled|bool | ||||
|   when: matrix_nginx_proxy_base_domain_serving_enabled|bool and matrix_nginx_proxy_base_domain_homepage_enabled|bool and matrix_nginx_proxy_base_domain_create_directory|bool | ||||
|  | ||||
| - name: Ensure Matrix nginx-proxy configuration for base domain exists | ||||
|   template: | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| #jinja2: lstrip_blocks: "True" | ||||
|  | ||||
| {% macro render_vhost_directives() %} | ||||
| 	root {{ matrix_nginx_proxy_data_path_in_container if matrix_nginx_proxy_enabled else matrix_nginx_proxy_data_path }}/matrix-domain; | ||||
| 	root {{ matrix_nginx_proxy_data_path_in_container if matrix_nginx_proxy_enabled else matrix_nginx_proxy_data_path }}{{ matrix_nginx_proxy_data_path_extension }}; | ||||
|  | ||||
| 	gzip on; | ||||
| 	gzip_types text/plain application/json; | ||||
|   | ||||
| @@ -17,11 +17,11 @@ matrix_postgres_architecture: amd64 | ||||
| # > LOG:  startup process (PID 37) was terminated by signal 11: Segmentation fault | ||||
| matrix_postgres_docker_image_suffix: "{{ '-alpine' if matrix_postgres_architecture in ['amd64', 'arm64'] else '' }}" | ||||
|  | ||||
| matrix_postgres_docker_image_v9: "{{ matrix_container_global_registry_prefix }}postgres:9.6.22{{ matrix_postgres_docker_image_suffix }}" | ||||
| matrix_postgres_docker_image_v10: "{{ matrix_container_global_registry_prefix }}postgres:10.17{{ matrix_postgres_docker_image_suffix }}" | ||||
| matrix_postgres_docker_image_v11: "{{ matrix_container_global_registry_prefix }}postgres:11.12{{ matrix_postgres_docker_image_suffix }}" | ||||
| matrix_postgres_docker_image_v12: "{{ matrix_container_global_registry_prefix }}postgres:12.7{{ matrix_postgres_docker_image_suffix }}" | ||||
| matrix_postgres_docker_image_v13: "{{ matrix_container_global_registry_prefix }}postgres:13.3{{ matrix_postgres_docker_image_suffix }}" | ||||
| matrix_postgres_docker_image_v9: "{{ matrix_container_global_registry_prefix }}postgres:9.6.23{{ matrix_postgres_docker_image_suffix }}" | ||||
| matrix_postgres_docker_image_v10: "{{ matrix_container_global_registry_prefix }}postgres:10.18{{ matrix_postgres_docker_image_suffix }}" | ||||
| matrix_postgres_docker_image_v11: "{{ matrix_container_global_registry_prefix }}postgres:11.13{{ matrix_postgres_docker_image_suffix }}" | ||||
| matrix_postgres_docker_image_v12: "{{ matrix_container_global_registry_prefix }}postgres:12.8{{ matrix_postgres_docker_image_suffix }}" | ||||
| matrix_postgres_docker_image_v13: "{{ matrix_container_global_registry_prefix }}postgres:13.4{{ matrix_postgres_docker_image_suffix }}" | ||||
| matrix_postgres_docker_image_latest: "{{ matrix_postgres_docker_image_v13 }}" | ||||
|  | ||||
| # This variable is assigned at runtime. Overriding its value has no effect. | ||||
|   | ||||
| @@ -7,7 +7,7 @@ matrix_sygnal_base_path: "{{ matrix_base_data_path }}/sygnal" | ||||
| matrix_sygnal_config_path: "{{ matrix_sygnal_base_path }}/config" | ||||
| matrix_sygnal_data_path: "{{ matrix_sygnal_base_path }}/data" | ||||
|  | ||||
| matrix_sygnal_version: v0.9.0 | ||||
| matrix_sygnal_version: v0.10.1 | ||||
| matrix_sygnal_docker_image: "{{ matrix_container_global_registry_prefix }}matrixdotorg/sygnal:{{ matrix_sygnal_version }}" | ||||
| matrix_sygnal_docker_image_force_pull: "{{ matrix_sygnal_docker_image.endswith(':latest') }}" | ||||
|  | ||||
| @@ -25,26 +25,6 @@ matrix_sygnal_container_http_host_bind_port: '' | ||||
| # A list of extra arguments to pass to the container | ||||
| matrix_sygnal_container_extra_arguments: [] | ||||
|  | ||||
| # Database-related configuration fields. | ||||
| # | ||||
| # To use SQLite, stick to these defaults. | ||||
| # | ||||
| # To use Postgres: | ||||
| # - change the engine (`matrix_sygnal_database_engine: 'postgres'`) | ||||
| # - adjust your database credentials via the `matrix_sygnal_postgres_*` variables | ||||
| matrix_sygnal_database_engine: 'sqlite' | ||||
|  | ||||
| matrix_sygnal_sqlite_database_path_local: "{{ matrix_sygnal_data_path }}/sygnal.db" | ||||
| matrix_sygnal_sqlite_database_path_in_container: "/data/sygnal.db" | ||||
|  | ||||
| matrix_sygnal_database_username: 'matrix_sygnal' | ||||
| matrix_sygnal_database_password: 'some-password' | ||||
| matrix_sygnal_database_hostname: 'matrix-postgres' | ||||
| matrix_sygnal_database_port: 5432 | ||||
| matrix_sygnal_database_name: 'matrix_sygnal' | ||||
|  | ||||
| matrix_sygnal_database_connection_string: 'postgres://{{ matrix_sygnal_database_username }}:{{ matrix_sygnal_database_password }}@{{ matrix_sygnal_database_hostname }}:{{ matrix_sygnal_database_port }}/{{ matrix_sygnal_database_name }}' | ||||
|  | ||||
| # A map (dictionary) of apps instances that this server works with. | ||||
| # | ||||
| # Example configuration: | ||||
|   | ||||
| @@ -1,32 +1,5 @@ | ||||
| --- | ||||
|  | ||||
| - set_fact: | ||||
|     matrix_sygnal_requires_restart: false | ||||
|  | ||||
| - block: | ||||
|     - name: Check if an SQLite database already exists | ||||
|       stat: | ||||
|         path: "{{ matrix_sygnal_sqlite_database_path_local }}" | ||||
|       register: matrix_sygnal_sqlite_database_path_local_stat_result | ||||
|  | ||||
|     - block: | ||||
|         - set_fact: | ||||
|             matrix_postgres_db_migration_request: | ||||
|               src: "{{ matrix_sygnal_sqlite_database_path_local }}" | ||||
|               dst: "{{ matrix_sygnal_database_connection_string }}" | ||||
|               caller: "{{ role_path|basename }}" | ||||
|               engine_variable_name: 'matrix_sygnal_database_engine' | ||||
|               engine_old: 'sqlite' | ||||
|               systemd_services_to_stop: ['matrix-sygnal.service'] | ||||
|               pgloader_options: ['--with "quote identifiers"'] | ||||
|  | ||||
|         - import_tasks: "{{ role_path }}/../matrix-postgres/tasks/util/migrate_db_to_postgres.yml" | ||||
|  | ||||
|         - set_fact: | ||||
|             matrix_sygnal_requires_restart: true | ||||
|       when: "matrix_sygnal_sqlite_database_path_local_stat_result.stat.exists|bool" | ||||
|   when: "matrix_sygnal_database_engine == 'postgres'" | ||||
|  | ||||
| - name: Ensure Sygnal image is pulled | ||||
|   docker_image: | ||||
|     name: "{{ matrix_sygnal_docker_image }}" | ||||
| @@ -65,9 +38,3 @@ | ||||
|   service: | ||||
|     daemon_reload: yes | ||||
|   when: "matrix_sygnal_systemd_service_result.changed|bool" | ||||
|  | ||||
| - name: Ensure matrix-sygnal.service restarted, if necessary | ||||
|   service: | ||||
|     name: "matrix-sygnal.service" | ||||
|     state: restarted | ||||
|   when: "matrix_sygnal_requires_restart|bool" | ||||
|   | ||||
| @@ -3,11 +3,3 @@ | ||||
|     msg: >- | ||||
|       Enabling Sygnal requires that you specify at least one app in `matrix_sygnal_apps` | ||||
|   when: "matrix_sygnal_enabled and matrix_sygnal_apps|length == 0" | ||||
|  | ||||
| - name: Fail if running on a non-supported architecture | ||||
|   fail: | ||||
|     msg: >- | ||||
|       Sygnal can only be used on the amd64 architecture for now. | ||||
|       Only amd64 container images are pushed for the `docker.io/matrixdotorg/sygnal` container image. | ||||
|       Either use a different image (by redefining `matrix_sygnal_docker_image`) or consider contributing self-building support to this role. | ||||
|   when: "matrix_sygnal_enabled and matrix_architecture != 'amd64' and matrix_sygnal_docker_image.startswith('docker.io/matrixdotorg/sygnal')" | ||||
|   | ||||
| @@ -3,57 +3,6 @@ | ||||
| # See: matrix.org | ||||
| ## | ||||
|  | ||||
| # The 'database' setting defines the database that sygnal uses to store all of | ||||
| # its data. | ||||
| # | ||||
| # 'name' gives the database engine to use: either 'sqlite3' (for SQLite) or | ||||
| # 'psycopg2' (for PostgreSQL). | ||||
| # | ||||
| # 'args' gives options which are passed through to the database engine, | ||||
| # except for options starting 'cp_', which are used to configure the Twisted | ||||
| # connection pool. For a reference to valid arguments, see: | ||||
| #   * for sqlite: https://docs.python.org/3/library/sqlite3.html#sqlite3.connect | ||||
| #   * for postgres: https://www.postgresql.org/docs/current/libpq-connect.html#LIBPQ-PARAMKEYWORDS | ||||
| #   * for the connection pool: https://twistedmatrix.com/documents/current/api/twisted.enterprise.adbapi.ConnectionPool.html#__init__ | ||||
| # | ||||
| # | ||||
| # Example SQLite configuration: | ||||
| # | ||||
| #database: | ||||
| #  name: sqlite3 | ||||
| #  args: | ||||
| #    dbfile: /path/to/database.db | ||||
| # | ||||
| # | ||||
| # Example Postgres configuration: | ||||
| # | ||||
| #database: | ||||
| #  name: psycopg2 | ||||
| #  args: | ||||
| #    host: localhost | ||||
| #    database: sygnal | ||||
| #    user: sygnal | ||||
| #    password: pass | ||||
| #    cp_min: 1 | ||||
| #    cp_max: 5 | ||||
| # | ||||
| {% if matrix_sygnal_database_engine == 'sqlite' %} | ||||
| database: | ||||
|   name: sqlite3 | ||||
|   args: | ||||
|     dbfile: {{ matrix_sygnal_sqlite_database_path_in_container|to_json }} | ||||
| {% else %} | ||||
| database: | ||||
|   name: psycopg2 | ||||
|   args: | ||||
|     host: {{ matrix_sygnal_database_hostname|to_json }} | ||||
|     database: {{ matrix_sygnal_database_name|to_json }} | ||||
|     user: {{ matrix_sygnal_database_username|to_json }} | ||||
|     password: {{ matrix_sygnal_database_password|to_json }} | ||||
|     cp_min: 1 | ||||
|     cp_max: 5 | ||||
| {% endif %} | ||||
|  | ||||
| ## Logging # | ||||
| # | ||||
| log: | ||||
|   | ||||
| @@ -15,8 +15,8 @@ matrix_synapse_docker_image_name_prefix: "{{ 'localhost/' if matrix_synapse_cont | ||||
| # amd64 gets released first. | ||||
| # arm32 relies on self-building, so the same version can be built immediately. | ||||
| # arm64 users need to wait for a prebuilt image to become available. | ||||
| matrix_synapse_version: v1.38.1 | ||||
| matrix_synapse_version_arm64: v1.38.1 | ||||
| matrix_synapse_version: v1.40.0 | ||||
| matrix_synapse_version_arm64: v1.40.0 | ||||
| matrix_synapse_docker_image_tag: "{{ matrix_synapse_version if matrix_architecture in ['arm32', 'amd64'] else matrix_synapse_version_arm64 }}" | ||||
| matrix_synapse_docker_image_force_pull: "{{ matrix_synapse_docker_image.endswith(':latest') }}" | ||||
|  | ||||
| @@ -453,6 +453,7 @@ matrix_synapse_replication_http_port: 9093 | ||||
| matrix_synapse_sentry_dsn: "" | ||||
|  | ||||
| # Postgres database information | ||||
| matrix_synapse_database_txn_limit: 0 | ||||
| matrix_synapse_database_host: "matrix-postgres" | ||||
| matrix_synapse_database_port: 5432 | ||||
| matrix_synapse_database_user: "synapse" | ||||
|   | ||||
| @@ -732,9 +732,52 @@ caches: | ||||
|  | ||||
| ## Database ## | ||||
|  | ||||
| # The 'database' setting defines the database that synapse uses to store all of | ||||
| # its data. | ||||
| # | ||||
| # 'name' gives the database engine to use: either 'sqlite3' (for SQLite) or | ||||
| # 'psycopg2' (for PostgreSQL). | ||||
| # | ||||
| # 'txn_limit' gives the maximum number of transactions to run per connection | ||||
| # before reconnecting. Defaults to 0, which means no limit. | ||||
| # | ||||
| # 'args' gives options which are passed through to the database engine, | ||||
| # except for options starting 'cp_', which are used to configure the Twisted | ||||
| # connection pool. For a reference to valid arguments, see: | ||||
| #   * for sqlite: https://docs.python.org/3/library/sqlite3.html#sqlite3.connect | ||||
| #   * for postgres: https://www.postgresql.org/docs/current/libpq-connect.html#LIBPQ-PARAMKEYWORDS | ||||
| #   * for the connection pool: https://twistedmatrix.com/documents/current/api/twisted.enterprise.adbapi.ConnectionPool.html#__init__ | ||||
| # | ||||
| # | ||||
| # Example SQLite configuration: | ||||
| # | ||||
| #database: | ||||
| #  name: sqlite3 | ||||
| #  args: | ||||
| #    database: /path/to/homeserver.db | ||||
| # | ||||
| # | ||||
| # Example Postgres configuration: | ||||
| # | ||||
| #database: | ||||
| #  name: psycopg2 | ||||
| #  txn_limit: 10000 | ||||
| #  args: | ||||
| #    user: synapse_user | ||||
| #    password: secretpassword | ||||
| #    database: synapse | ||||
| #    host: localhost | ||||
| #    port: 5432 | ||||
| #    cp_min: 5 | ||||
| #    cp_max: 10 | ||||
| # | ||||
| # For more information on using Synapse with Postgres, | ||||
| # see https://matrix-org.github.io/synapse/latest/postgres.html. | ||||
| # | ||||
| database: | ||||
|   # The database engine name | ||||
|   name: "psycopg2" | ||||
|   txn_limit: {{ matrix_synapse_database_txn_limit }} | ||||
|   args: | ||||
|     user: {{ matrix_synapse_database_user|string|to_json }} | ||||
|     password: {{ matrix_synapse_database_password|string|to_json }} | ||||
| @@ -1314,91 +1357,6 @@ autocreate_auto_join_rooms: {{ matrix_synapse_autocreate_auto_join_rooms|to_json | ||||
| #auto_join_rooms_for_guests: false | ||||
|  | ||||
|  | ||||
| ## Account Validity ## | ||||
|  | ||||
| # Optional account validity configuration. This allows for accounts to be denied | ||||
| # any request after a given period. | ||||
| # | ||||
| # Once this feature is enabled, Synapse will look for registered users without an | ||||
| # expiration date at startup and will add one to every account it found using the | ||||
| # current settings at that time. | ||||
| # This means that, if a validity period is set, and Synapse is restarted (it will | ||||
| # then derive an expiration date from the current validity period), and some time | ||||
| # after that the validity period changes and Synapse is restarted, the users' | ||||
| # expiration dates won't be updated unless their account is manually renewed. This | ||||
| # date will be randomly selected within a range [now + period - d ; now + period], | ||||
| # where d is equal to 10% of the validity period. | ||||
| # | ||||
| account_validity: | ||||
|   # The account validity feature is disabled by default. Uncomment the | ||||
|   # following line to enable it. | ||||
|   # | ||||
|   #enabled: true | ||||
|  | ||||
|   # The period after which an account is valid after its registration. When | ||||
|   # renewing the account, its validity period will be extended by this amount | ||||
|   # of time. This parameter is required when using the account validity | ||||
|   # feature. | ||||
|   # | ||||
|   #period: 6w | ||||
|  | ||||
|   # The amount of time before an account's expiry date at which Synapse will | ||||
|   # send an email to the account's email address with a renewal link. By | ||||
|   # default, no such emails are sent. | ||||
|   # | ||||
|   # If you enable this setting, you will also need to fill out the 'email' and | ||||
|   # 'public_baseurl' configuration sections. | ||||
|   # | ||||
|   #renew_at: 1w | ||||
|  | ||||
|   # The subject of the email sent out with the renewal link. '%(app)s' can be | ||||
|   # used as a placeholder for the 'app_name' parameter from the 'email' | ||||
|   # section. | ||||
|   # | ||||
|   # Note that the placeholder must be written '%(app)s', including the | ||||
|   # trailing 's'. | ||||
|   # | ||||
|   # If this is not set, a default value is used. | ||||
|   # | ||||
|   #renew_email_subject: "Renew your %(app)s account" | ||||
|  | ||||
|   # Directory in which Synapse will try to find templates for the HTML files to | ||||
|   # serve to the user when trying to renew an account. If not set, default | ||||
|   # templates from within the Synapse package will be used. | ||||
|   # | ||||
|   # The currently available templates are: | ||||
|   # | ||||
|   # * account_renewed.html: Displayed to the user after they have successfully | ||||
|   #       renewed their account. | ||||
|   # | ||||
|   # * account_previously_renewed.html: Displayed to the user if they attempt to | ||||
|   #       renew their account with a token that is valid, but that has already | ||||
|   #       been used. In this case the account is not renewed again. | ||||
|   # | ||||
|   # * invalid_token.html: Displayed to the user when they try to renew an account | ||||
|   #       with an unknown or invalid renewal token. | ||||
|   # | ||||
|   # See https://github.com/matrix-org/synapse/tree/master/synapse/res/templates for | ||||
|   # default template contents. | ||||
|   # | ||||
|   # The file name of some of these templates can be configured below for legacy | ||||
|   # reasons. | ||||
|   # | ||||
|   #template_dir: "res/templates" | ||||
|  | ||||
|   # A custom file name for the 'account_renewed.html' template. | ||||
|   # | ||||
|   # If not set, the file is assumed to be named "account_renewed.html". | ||||
|   # | ||||
|   #account_renewed_html_path: "account_renewed.html" | ||||
|  | ||||
|   # A custom file name for the 'invalid_token.html' template. | ||||
|   # | ||||
|   # If not set, the file is assumed to be named "invalid_token.html". | ||||
|   # | ||||
|   #invalid_token_html_path: "invalid_token.html" | ||||
|  | ||||
|  | ||||
| ## Metrics ### | ||||
|  | ||||
| # Enable collection and rendering of performance metrics | ||||
| @@ -2710,11 +2668,6 @@ stats: | ||||
|   # | ||||
|   #enabled: false | ||||
|  | ||||
|   # The size of each timeslice in the room_stats_historical and | ||||
|   # user_stats_historical tables, as a time period. Defaults to "1d". | ||||
|   # | ||||
|   #bucket_size: 1h | ||||
|  | ||||
|  | ||||
| # Server Notices room configuration | ||||
| # | ||||
| @@ -2807,19 +2760,6 @@ alias_creation_rules: {{ matrix_synapse_alias_creation_rules|to_json }} | ||||
| room_list_publication_rules: {{ matrix_synapse_room_list_publication_rules|to_json }} | ||||
|  | ||||
|  | ||||
| # Server admins can define a Python module that implements extra rules for | ||||
| # allowing or denying incoming events. In order to work, this module needs to | ||||
| # override the methods defined in synapse/events/third_party_rules.py. | ||||
| # | ||||
| # This feature is designed to be used in closed federations only, where each | ||||
| # participating server enforces the same rules. | ||||
| # | ||||
| #third_party_event_rules: | ||||
| #  module: "my_custom_project.SuperRulesSet" | ||||
| #  config: | ||||
| #    example_option: 'things' | ||||
|  | ||||
|  | ||||
| ## Opentracing ## | ||||
|  | ||||
| # These settings enable opentracing, which implements distributed tracing. | ||||
|   | ||||
		Reference in New Issue
	
	Block a user