mirror of
				https://github.com/spantaleev/matrix-docker-ansible-deploy.git
				synced 2025-10-20 15:13:24 +00:00 
			
		
		
		
	Compare commits
	
		
			204 Commits
		
	
	
		
			dd70df545a
			...
			element-ca
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | d5c24fcafe | ||
|  | 4d61cc571b | ||
|  | 9c24064fb6 | ||
|  | a757b515fb | ||
|  | ba9cedbeda | ||
|  | 4a638c2df3 | ||
|  | 155d5dad38 | ||
|  | 6b8a3fc891 | ||
|  | 3ea1ea2f34 | ||
|  | d3913a015e | ||
|  | ac7f96806d | ||
|  | b8d800f6ef | ||
|  | 2c1c49444a | ||
|  | 6bc0185d50 | ||
|  | a0470fe248 | ||
|  | d4ceebc6a9 | ||
|  | 6a86de958f | ||
|  | d9df022d55 | ||
|  | 676f9dd9ad | ||
|  | 251561ff81 | ||
|  | 1e60f41a59 | ||
|  | f8e84c4b2f | ||
|  | 3f5e8f656b | ||
|  | 72118f2f03 | ||
|  | 585377975b | ||
|  | 22ef579444 | ||
|  | 32f8c6de6e | ||
|  | 370feb740f | ||
|  | 9a11e5e1fe | ||
|  | 8291b2f99d | ||
|  | 890f10f765 | ||
|  | 031cf68cbb | ||
|  | 5961841e52 | ||
|  | 2be4923aef | ||
|  | 23efad9cb7 | ||
|  | 6b55ba29ab | ||
|  | 0d1112638d | ||
|  | c3c2ba34b4 | ||
|  | 0215708f79 | ||
|  | e1b57f3d45 | ||
|  | de2a8f11d2 | ||
|  | 2a69ca35be | ||
|  | 72d64cfa6b | ||
|  | f161c7c58f | ||
|  | 6c6b44dc25 | ||
|  | 8eb1c57e2b | ||
|  | 61069d6313 | ||
|  | 74d6a99b1e | ||
|  | 81a30f17ac | ||
|  | 413d591562 | ||
|  | 7572522820 | ||
|  | 0b9389fd64 | ||
|  | 9a8a569431 | ||
|  | bb403e1aee | ||
|  | 74fbacbd9f | ||
|  | 5642755273 | ||
|  | bb925f4782 | ||
|  | c57d0d192d | ||
|  | 006920882c | ||
|  | 69d702643f | ||
|  | 252ca52f60 | ||
|  | 3f52cec25c | ||
|  | 7a6fcaa402 | ||
|  | 394fdca066 | ||
|  | f0466d5a99 | ||
|  | be7271760e | ||
|  | 8b84eb6390 | ||
|  | 3e86adac0d | ||
|  | 721fb39aa2 | ||
|  | 783d4a23f8 | ||
|  | fa4ebd2a64 | ||
|  | 79ae704a24 | ||
|  | c07b093902 | ||
|  | c321ca160e | ||
|  | 164be875b0 | ||
|  | 0f23e36e12 | ||
|  | 83bb546c64 | ||
|  | 3783922275 | ||
|  | 66cc36466c | ||
|  | ec41c1aba5 | ||
|  | df6ef106d1 | ||
|  | eb048da8a1 | ||
|  | ccb29beb30 | ||
|  | 32ea60fdc5 | ||
|  | 25a8cb3b4a | ||
|  | 55da5c3213 | ||
|  | 925ebfbd4b | ||
|  | 88d4668450 | ||
|  | 1838a541ae | ||
|  | 1e82530080 | ||
|  | 82127830b3 | ||
|  | 85c0ffa9e1 | ||
|  | b691f39d39 | ||
|  | 10df145101 | ||
|  | fa2a913d39 | ||
|  | e18b28136c | ||
|  | 1906d61c39 | ||
|  | b7e0a41134 | ||
|  | a03f5985a5 | ||
|  | 1e6698cb99 | ||
|  | f684719b2a | ||
|  | a6e3203398 | ||
|  | 2b4fdea70f | ||
|  | 6c8923ae28 | ||
|  | 9691577b22 | ||
|  | 46109565e1 | ||
|  | 4acb025130 | ||
|  | e421852af5 | ||
|  | 5507fb3bab | ||
|  | 9864996aad | ||
|  | dbbaae4fbe | ||
|  | d53c2428b8 | ||
|  | f98a505df8 | ||
|  | d5aabc85be | ||
|  | 7cdec5f251 | ||
|  | fd2f505b34 | ||
|  | 812b57cfaa | ||
|  | b7b8ed573b | ||
|  | 97f93ebd76 | ||
|  | 8cb7deff15 | ||
|  | 71dff50a65 | ||
|  | 58a9642e8c | ||
|  | 3de399025f | ||
|  | e952ba1c3a | ||
|  | 8cb3e33bbf | ||
|  | b907777ae5 | ||
|  | cb41fb02ae | ||
|  | 31a138a6ba | ||
|  | 6143ad7ffa | ||
|  | f762048a8d | ||
|  | 93650cf20e | ||
|  | 9dbee212d8 | ||
|  | 1167e1ec13 | ||
|  | f036e18789 | ||
|  | a274d32c6d | ||
|  | 5db9a5c061 | ||
|  | 2492672025 | ||
|  | a0917fa283 | ||
|  | 8b172cc194 | ||
|  | 63133d6599 | ||
|  | 5b8dcf32d5 | ||
|  | 14614cb211 | ||
|  | 3c084e17d2 | ||
|  | 089c5f14c8 | ||
|  | b6571fc4fd | ||
|  | 6d6f9ab853 | ||
|  | 5730dbfc6e | ||
|  | c14f9cdcb5 | ||
|  | 805b726c6d | ||
|  | 5f49433f6c | ||
|  | 510cfb2dac | ||
|  | 1721e85195 | ||
|  | 25909b1029 | ||
|  | 3264408758 | ||
|  | dd96b93d89 | ||
|  | df4bf4a0c9 | ||
|  | 2f2cb8962e | ||
|  | d2e2781d3b | ||
|  | 80763804f9 | ||
|  | 1d7a60055c | ||
|  | 2cf471075d | ||
|  | 6a519bb053 | ||
|  | f0632b20eb | ||
|  | 5cc9c70ba6 | ||
|  | e34e5da9a4 | ||
|  | 656d4275bc | ||
|  | 6ef304b118 | ||
|  | 85be68946c | ||
|  | 3f6c327da2 | ||
|  | ba54e549c4 | ||
|  | f2acc7430d | ||
|  | 9cb236da30 | ||
|  | f38d6a0d88 | ||
|  | ac1295ac45 | ||
|  | bc2ed60762 | ||
|  | f7621283fd | ||
|  | e31e688a41 | ||
|  | a533ec4204 | ||
|  | f16ca24408 | ||
|  | e910d09ff1 | ||
|  | bc9658c06b | ||
|  | 45c8a61f04 | ||
|  | 954d46cfd7 | ||
|  | dfeca192ab | ||
|  | f306a47b83 | ||
|  | becdb0810c | ||
|  | 37fd2e701d | ||
|  | 68cc1f4b2b | ||
|  | 5efc189293 | ||
|  | 02479e8bec | ||
|  | 0eef094f2b | ||
|  | 16ed788b3f | ||
|  | 6364101410 | ||
|  | 81735503f8 | ||
|  | 8644a7383e | ||
|  | ce827e7953 | ||
|  | c93d30bcb8 | ||
|  | 90ea758c3b | ||
|  | 350d4d4bcd | ||
|  | fc6357a089 | ||
|  | 60f34cd7af | ||
|  | d1ba784dde | ||
|  | 434157eb98 | ||
|  | 6594cce570 | 
| @@ -1,2 +0,0 @@ | |||||||
| [codespell] |  | ||||||
| ignore-words-list = aNULL,brose,doub,Udo,re-use,re-used,registr |  | ||||||
							
								
								
									
										29
									
								
								.github/renovate.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										29
									
								
								.github/renovate.json
									
									
									
									
										vendored
									
									
								
							| @@ -1,17 +1,12 @@ | |||||||
| { | { | ||||||
| 	"$schema": "https://docs.renovatebot.com/renovate-schema.json", | 	"$schema": "https://docs.renovatebot.com/renovate-schema.json", | ||||||
| 	"extends": [ | 	"extends": [ | ||||||
| 		"config:recommended" | 		"config:base" | ||||||
| 	], | 	], | ||||||
| 	"labels": [ | 	"labels": ["dependencies"], | ||||||
| 		"dependencies" | 	"regexManagers": [ | ||||||
| 	], |  | ||||||
| 	"customManagers": [ |  | ||||||
| 		{ | 		{ | ||||||
| 			"customType": "regex", | 			"fileMatch": ["defaults/main.yml$"], | ||||||
| 			"managerFilePatterns": [ |  | ||||||
| 				"/defaults/main.yml$/" |  | ||||||
| 			], |  | ||||||
| 			"matchStrings": [ | 			"matchStrings": [ | ||||||
| 				"# renovate: datasource=(?<datasource>[a-z-.]+?) depName=(?<depName>[^\\s]+?)(?: (?:lookupName|packageName)=(?<packageName>[^\\s]+?))?(?: versioning=(?<versioning>[a-z-0-9]+?))?\\s+[A-Za-z0-9_]+?(?:_version|_tag)\\s*:\\s*[\"']?(?<currentValue>.+?)[\"']?\\s" | 				"# renovate: datasource=(?<datasource>[a-z-.]+?) depName=(?<depName>[^\\s]+?)(?: (?:lookupName|packageName)=(?<packageName>[^\\s]+?))?(?: versioning=(?<versioning>[a-z-0-9]+?))?\\s+[A-Za-z0-9_]+?(?:_version|_tag)\\s*:\\s*[\"']?(?<currentValue>.+?)[\"']?\\s" | ||||||
| 			] | 			] | ||||||
| @@ -19,18 +14,14 @@ | |||||||
| 	], | 	], | ||||||
| 	"packageRules": [ | 	"packageRules": [ | ||||||
| 		{ | 		{ | ||||||
| 			"ignoreUnstable": false, | 			"matchSourceUrlPrefixes": [ | ||||||
| 			"versioning": "loose", | 				"https://github.com/devture/com.devture.ansible.role", | ||||||
| 			"matchSourceUrls": [ | 				"https://github.com/mother-of-all-self-hosting" | ||||||
| 				"https://github.com/devture/com.devture.ansible.role{/,}**", | 			], | ||||||
| 				"https://github.com/mother-of-all-self-hosting{/,}**" | 			"ignoreUnstable": false | ||||||
| 			] |  | ||||||
| 		} | 		} | ||||||
| 	], | 	], | ||||||
| 	"ignoreDeps": [ | 	"ignoreDeps": [ | ||||||
| 		"ghcr.io/matrixgpt/matrix-chatgpt-bot" | 		"ghcr.io/matrixgpt/matrix-chatgpt-bot" | ||||||
| 	], | 	] | ||||||
| 	"pre-commit": { |  | ||||||
| 		"enabled": true |  | ||||||
| 	} |  | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								.github/workflows/close-stale-issues.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/close-stale-issues.yml
									
									
									
									
										vendored
									
									
								
							| @@ -19,7 +19,7 @@ jobs: | |||||||
|     if: github.repository == 'spantaleev/matrix-docker-ansible-deploy' |     if: github.repository == 'spantaleev/matrix-docker-ansible-deploy' | ||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - uses: actions/stale@v10 |       - uses: actions/stale@v9 | ||||||
|         with: |         with: | ||||||
|           ###################################################################### |           ###################################################################### | ||||||
|           # Issues/PRs |           # Issues/PRs | ||||||
|   | |||||||
							
								
								
									
										29
									
								
								.github/workflows/lock-threads.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										29
									
								
								.github/workflows/lock-threads.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,29 +0,0 @@ | |||||||
| # SPDX-FileCopyrightText: 2017 - 2023 Armin Sebastian |  | ||||||
| # |  | ||||||
| # SPDX-License-Identifier: MIT |  | ||||||
|  |  | ||||||
| --- |  | ||||||
| name: 'Lock Threads' |  | ||||||
| on:  # yamllint disable-line rule:truthy |  | ||||||
|   # Use this to do a dry run from a pull request |  | ||||||
|   # pull_request: |  | ||||||
|   schedule: |  | ||||||
|     - cron: '0 * * * *' |  | ||||||
|   workflow_dispatch: |  | ||||||
|  |  | ||||||
| permissions: |  | ||||||
|   issues: write |  | ||||||
|   pull-requests: write |  | ||||||
|  |  | ||||||
| concurrency: |  | ||||||
|   group: lock-threads |  | ||||||
|  |  | ||||||
| jobs: |  | ||||||
|   action: |  | ||||||
|     if: github.repository == 'spantaleev/matrix-docker-ansible-deploy' |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|       - uses: dessant/lock-threads@v5 |  | ||||||
|         with: |  | ||||||
|           add-issue-labels: 'outdated' |  | ||||||
|           process-only: 'issues, prs' |  | ||||||
							
								
								
									
										24
									
								
								.github/workflows/matrix.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										24
									
								
								.github/workflows/matrix.yml
									
									
									
									
										vendored
									
									
								
							| @@ -7,7 +7,9 @@ | |||||||
| --- | --- | ||||||
| name: Matrix CI | name: Matrix CI | ||||||
|  |  | ||||||
| on: [push, pull_request]  # yamllint disable-line rule:truthy | on:  # yamllint disable-line rule:truthy | ||||||
|  |   push: | ||||||
|  |   pull_request: | ||||||
|  |  | ||||||
| jobs: | jobs: | ||||||
|   yamllint: |   yamllint: | ||||||
| @@ -15,7 +17,7 @@ jobs: | |||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - name: Check out |       - name: Check out | ||||||
|         uses: actions/checkout@v5 |         uses: actions/checkout@v4 | ||||||
|       - name: Run yamllint |       - name: Run yamllint | ||||||
|         uses: frenck/action-yamllint@v1.5.0 |         uses: frenck/action-yamllint@v1.5.0 | ||||||
|   ansible-lint: |   ansible-lint: | ||||||
| @@ -23,20 +25,8 @@ jobs: | |||||||
|     runs-on: ubuntu-latest |     runs-on: ubuntu-latest | ||||||
|     steps: |     steps: | ||||||
|       - name: Check out |       - name: Check out | ||||||
|         uses: actions/checkout@v5 |         uses: actions/checkout@v4 | ||||||
|  |  | ||||||
|       - name: Run ansible-lint |       - name: Run ansible-lint | ||||||
|         uses: ansible/ansible-lint@v25.9.2 |         uses: ansible-community/ansible-lint-action@v6.17.0 | ||||||
|         with: |         with: | ||||||
|           args: "roles/custom" |           path: roles/custom | ||||||
|           setup_python: "true" |  | ||||||
|           working_directory: "" |  | ||||||
|           requirements_file: requirements.yml |  | ||||||
|   precommit: |  | ||||||
|     name: Run pre-commit |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|       - name: Checkout code |  | ||||||
|         uses: actions/checkout@v5 |  | ||||||
|       - name: Run pre-commit |  | ||||||
|         uses: pre-commit/action@v3.0.1 |  | ||||||
|   | |||||||
							
								
								
									
										20
									
								
								.github/workflows/reuse.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								.github/workflows/reuse.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | # SPDX-FileCopyrightText: 2022 Free Software Foundation Europe e.V. <https://fsfe.org> | ||||||
|  | # | ||||||
|  | # SPDX-License-Identifier: CC0-1.0 | ||||||
|  | --- | ||||||
|  | name: REUSE Compliance Check | ||||||
|  |  | ||||||
|  | on: [push, pull_request]  # yamllint disable-line rule:truthy | ||||||
|  |  | ||||||
|  | permissions: | ||||||
|  |   contents: read | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   reuse-compliance-check: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |     steps: | ||||||
|  |       - name: Checkout | ||||||
|  |         uses: actions/checkout@v4 | ||||||
|  |  | ||||||
|  |       - name: REUSE Compliance Check | ||||||
|  |         uses: fsfe/reuse-action@v5 | ||||||
| @@ -1,26 +0,0 @@ | |||||||
| --- |  | ||||||
| default_install_hook_types: [pre-push] |  | ||||||
|  |  | ||||||
| exclude: "LICENSES/" |  | ||||||
|  |  | ||||||
| # See: https://pre-commit.com/hooks.html |  | ||||||
| repos: |  | ||||||
|   - repo: https://github.com/pre-commit/pre-commit-hooks |  | ||||||
|     rev: v6.0.0 |  | ||||||
|     hooks: |  | ||||||
|       # - id: check-executables-have-shebangs |  | ||||||
|       - id: check-added-large-files |  | ||||||
|       - id: check-case-conflict |  | ||||||
|       - id: check-json |  | ||||||
|       - id: check-toml |  | ||||||
|       - id: trailing-whitespace |  | ||||||
|       - id: end-of-file-fixer |  | ||||||
|   - repo: https://github.com/codespell-project/codespell |  | ||||||
|     rev: v2.4.1 |  | ||||||
|     hooks: |  | ||||||
|       - id: codespell |  | ||||||
|         args: ["--skip=*.po,*.pot,i18n/"] |  | ||||||
|   - repo: https://github.com/fsfe/reuse-tool  # https://reuse.software/dev/#pre-commit-hook |  | ||||||
|     rev: v6.1.2 |  | ||||||
|     hooks: |  | ||||||
|       - id: reuse |  | ||||||
							
								
								
									
										73
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										73
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,56 +1,3 @@ | |||||||
| # 2025-10-02 |  | ||||||
|  |  | ||||||
| ## Element Admin support |  | ||||||
|  |  | ||||||
| The playbook now supports [Element Admin](./docs/configuring-playbook-element-admin.md) - a new web-based administration panel for Synapse and [Matrix Authentication Service](./docs/configuring-playbook-matrix-authentication-service.md). |  | ||||||
|  |  | ||||||
| Deployments based on Matrix Authentication Service may find it useful to run both Synapse Admin and Element Admin at the same time. |  | ||||||
|  |  | ||||||
| Deployments that don't rely on Matrix Authentication Service are unlikely to find anything useful in Element Admin right now (it's too basic in its current form). |  | ||||||
|  |  | ||||||
|  |  | ||||||
| # 2025-04-26 |  | ||||||
|  |  | ||||||
| ## Continuwuity support |  | ||||||
|  |  | ||||||
| Thanks to [Virkkunen](https://github.com/Virkkunen), we now have optional experimental [Continuwuity](./docs/configuring-playbook-continuwuity.md) homeserver support. |  | ||||||
|  |  | ||||||
| Continuwuity is a fork of [conduwuit](./docs/configuring-playbook-conduwuit.md), which the playbook also supports. It appears that conduwuit has been abandoned and various forks (like Continuwuity, [Tuwunel](https://github.com/matrix-construct/tuwunel) and possibly others) are continuing in its path. |  | ||||||
|  |  | ||||||
| Existing installations do **not** need to be updated. **Synapse is still the default homeserver implementation** installed by the playbook. |  | ||||||
|  |  | ||||||
| People that used to run conduwuit, may wish to: |  | ||||||
|  |  | ||||||
| - either [migrate from conduwuit to Continuwuity](./docs/configuring-playbook-continuwuity.md#migrating-from-conduwuit) |  | ||||||
| - or wait for some of the other forks to progress and for support for them to get added to the playbook |  | ||||||
|  |  | ||||||
| **The homeserver implementation of an existing server cannot be changed** (e.g. from Synapse/Conduit/Dendrite to Continuwuity) without data loss. |  | ||||||
|  |  | ||||||
|  |  | ||||||
| # 2025-04-09 |  | ||||||
|  |  | ||||||
| ## Element Call frontend installation is now optional |  | ||||||
|  |  | ||||||
| Because all Element clients (Element Web and Element X mobile) now embed and use their own Element Call frontend application (and not the one hosted via the playbook), it makes little sense for the playbook to self-host the Element Call frontend for you. Setting up the frontend requires an additional hostname (DNS setup) and it won't be used by Element clients anyway, so **we now recommend not installing the Element Call frontend**. |  | ||||||
|  |  | ||||||
| 💡 A reason you may wish to continue installing the Element Call frontend (despite Matrix clients not making use of it), is if you need to use it standalone - directly via a browser (without a Matrix client). |  | ||||||
|  |  | ||||||
| The playbook now lets you [Decide between Element Call vs just the Matrix RTC stack](./docs/configuring-playbook-element-call.md#decide-between-element-call-vs-just-the-matrix-rtc-stack). |  | ||||||
|  |  | ||||||
| If you've already installed Element Call (via `matrix_element_call_enabled: true`), you can switch to installing just the [Matrix RTC (Real-Time Communication) stack](./docs/configuring-playbook-matrix-rtc.md) (all supporting services **without the Element Call frontend**) by: |  | ||||||
|  |  | ||||||
| 1. Adjusting your `vars.yml` configuration like this: |  | ||||||
|  |  | ||||||
| ```diff |  | ||||||
| -matrix_element_call_enabled: true |  | ||||||
| +matrix_rtc_enabled: true |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| 2. [Re-running the playbook](./docs/installing.md) with the `setup-all` Ansible tag (e.g. `just setup-all`) |  | ||||||
|  |  | ||||||
| 3. Getting rid of the `call.element.example.com` DNS record |  | ||||||
|  |  | ||||||
|  |  | ||||||
| # 2025-03-15 | # 2025-03-15 | ||||||
|  |  | ||||||
| ## Element Call support | ## Element Call support | ||||||
| @@ -167,7 +114,7 @@ To **completely eliminate the problem** of DDoS amplification attacks done throu | |||||||
|  |  | ||||||
| The playbook now **only exposes the Coturn STUN port (`3478`) over TCP by default**. | The playbook now **only exposes the Coturn STUN port (`3478`) over TCP by default**. | ||||||
|  |  | ||||||
| 💡 Users may wish to further remove the (now unnecessary) firewall rule allowing access to `3478/udp`. | 💡 Users may wish to further remove the (now unnnecessary) firewall rule allowing access to `3478/udp`. | ||||||
|  |  | ||||||
| If you'd like the Coturn STUN port to be exposed over UDP like before, you can revert to the previous behavior by using the following configuration in your `vars.yml` file: | If you'd like the Coturn STUN port to be exposed over UDP like before, you can revert to the previous behavior by using the following configuration in your `vars.yml` file: | ||||||
|  |  | ||||||
| @@ -181,7 +128,7 @@ matrix_coturn_container_stun_plain_host_bind_port_udp: "3478" | |||||||
|  |  | ||||||
| # 2025-02-17 | # 2025-02-17 | ||||||
|  |  | ||||||
| ## FluffyChat Web support | ## FluffyChat Web suport | ||||||
|  |  | ||||||
| Thanks to [Aine](https://gitlab.com/etke.cc) of [etke.cc](https://etke.cc/), the playbook now supports [FluffyChat Web](https://github.com/krille-chan/fluffychat) as an additional Matrix client you can self-host. | Thanks to [Aine](https://gitlab.com/etke.cc) of [etke.cc](https://etke.cc/), the playbook now supports [FluffyChat Web](https://github.com/krille-chan/fluffychat) as an additional Matrix client you can self-host. | ||||||
|  |  | ||||||
| @@ -203,7 +150,7 @@ The playbook will let you know if you're using any `matrix_mautrix_hangouts_*` v | |||||||
|  |  | ||||||
| ## Redis and KeyDB are no longer part of the playbook | ## Redis and KeyDB are no longer part of the playbook | ||||||
|  |  | ||||||
| **TLDR**: The playbook now exclusively uses Valkey as its Redis-compatible memorystore implementation, removing support for Redis and KeyDB. Most users are unaffected by this change unless they explicitly configured Redis or KeyDB variables. Only users that were explicitly defining `redis_*` or `keydb_*` variables will need to update their configuration to use `valkey_*` variables instead. | **TLDR**: The playbook now exclusively uses Valkey as its Redis-compatible memorystore implementation, removing support for Redis and KeyDB. Most users are unaffected by this change unless they explicitly configured Redis or KeyDB variables. Only users that were explicitly definining `redis_*` or `keydb_*` variables will need to update their configuration to use `valkey_*` variables instead. | ||||||
|  |  | ||||||
| The playbook has gone through several iterations of memorystore implementations: | The playbook has gone through several iterations of memorystore implementations: | ||||||
|  |  | ||||||
| @@ -756,7 +703,7 @@ For people building commercial products on top of Synapse, they may have to eith | |||||||
|  |  | ||||||
| We're no lawyers and this changelog entry does not aim to give you the best legal advice, so please research on your own! | We're no lawyers and this changelog entry does not aim to give you the best legal advice, so please research on your own! | ||||||
|  |  | ||||||
| If you'd like to continue using the old Apache-2.0-licensed Synapse (for a while longer anyway), the playbook makes it possible by introducing a new Ansible variable. You can do it like this: | If you'd like to continue using the old Apache-2.0-licensed Synapse (for a while longer anyway), the playbook makes it possible by intruducing a new Ansible variable. You can do it like this: | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| # Switch the organization that Synapse container images (or source code for self-building) are pulled from. | # Switch the organization that Synapse container images (or source code for self-building) are pulled from. | ||||||
| @@ -839,7 +786,7 @@ Despite these downsides (which the playbook manages automatically), we believe i | |||||||
|  |  | ||||||
| People running the default Traefik setup do not need to do anything to make Traefik take on this extra job. Your Traefik configuration will be updated automatically. | People running the default Traefik setup do not need to do anything to make Traefik take on this extra job. Your Traefik configuration will be updated automatically. | ||||||
|  |  | ||||||
| **People running their own Traefik reverse-proxy need to do [minor adjustments](#people-managing-their-own-traefik-instance-need-to-do-minor-changes)**, as described in the section below. | **People runnning their own Traefik reverse-proxy need to do [minor adjustments](#people-managing-their-own-traefik-instance-need-to-do-minor-changes)**, as described in the section below. | ||||||
|  |  | ||||||
| You may disable Traefik acting as an intermediary by explicitly setting `matrix_playbook_public_matrix_federation_api_traefik_entrypoint_enabled` to `false`. Services would then be configured to talk to the homeserver directly, giving you a slight performance boost and a "simpler" Traefik setup. However, such a configuration is less tested and will cause troubles, especially if you enable more services (like `matrix-media-repo`, etc.) in the future. As such, it's not recommended. | You may disable Traefik acting as an intermediary by explicitly setting `matrix_playbook_public_matrix_federation_api_traefik_entrypoint_enabled` to `false`. Services would then be configured to talk to the homeserver directly, giving you a slight performance boost and a "simpler" Traefik setup. However, such a configuration is less tested and will cause troubles, especially if you enable more services (like `matrix-media-repo`, etc.) in the future. As such, it's not recommended. | ||||||
|  |  | ||||||
| @@ -2862,7 +2809,7 @@ As always, re-running the playbook is enough to get the updated bits. | |||||||
|  |  | ||||||
| ## SMS bridging requires db reset | ## SMS bridging requires db reset | ||||||
|  |  | ||||||
| The current version of [matrix-sms-bridge](https://github.com/benkuly/matrix-sms-bridge) needs you to delete the database to work as expected. Just remove `/matrix/matrix-sms-bridge/database/*`. It also adds a new required var `matrix_sms_bridge_default_region`. | The current version of [matrix-sms-bridge](https://github.com/benkuly/matrix-sms-bridge) needs you to delete the database to work as expected. Just remove `/matrix/matrix-sms-bridge/database/*`. It also adds a new requried var `matrix_sms_bridge_default_region`. | ||||||
|  |  | ||||||
| To reuse your existing rooms, invite `@smsbot:yourServer` to the room or write a message. You are also able to use automated room creation with telephonenumers by writing `sms send -t 01749292923 "Hello World"` in a room with `@smsbot:yourServer`. See [the docs](https://github.com/benkuly/matrix-sms-bridge) for more information. | To reuse your existing rooms, invite `@smsbot:yourServer` to the room or write a message. You are also able to use automated room creation with telephonenumers by writing `sms send -t 01749292923 "Hello World"` in a room with `@smsbot:yourServer`. See [the docs](https://github.com/benkuly/matrix-sms-bridge) for more information. | ||||||
|  |  | ||||||
| @@ -2894,7 +2841,7 @@ Until the issue gets fixed, we're making User Directory search not go to ma1sd b | |||||||
|  |  | ||||||
| This upgrades matrix-appservice-irc from 0.14.1 to 0.16.0. Upstream | This upgrades matrix-appservice-irc from 0.14.1 to 0.16.0. Upstream | ||||||
| made a change to how you define manual mappings. If you added a | made a change to how you define manual mappings. If you added a | ||||||
| `mapping` to your configuration, you will need to update it according | `mapping` to your configuration, you will need to update it accoring | ||||||
| to the [upstream | to the [upstream | ||||||
| instructions](https://github.com/matrix-org/matrix-appservice-irc/blob/master/CHANGELOG.md#0150-2020-02-05). If you did not include `mappings` in your configuration for IRC, no | instructions](https://github.com/matrix-org/matrix-appservice-irc/blob/master/CHANGELOG.md#0150-2020-02-05). If you did not include `mappings` in your configuration for IRC, no | ||||||
| change is necessary. `mappings` is not part of the default | change is necessary. `mappings` is not part of the default | ||||||
| @@ -3057,7 +3004,7 @@ As per this [advisory blog post](https://matrix.org/blog/2019/11/09/avoiding-unw | |||||||
|  |  | ||||||
| Our general goal is to favor privacy and security when running personal (family & friends) and corporate homeservers. Both of these likely benefit from having a more secure default of **not showing the room directory without authentication** and **not publishing the room directory over federation**. | Our general goal is to favor privacy and security when running personal (family & friends) and corporate homeservers. Both of these likely benefit from having a more secure default of **not showing the room directory without authentication** and **not publishing the room directory over federation**. | ||||||
|  |  | ||||||
| As with anything else, these new defaults can be overridden by changing the `matrix_synapse_allow_public_rooms_without_auth` and `matrix_synapse_allow_public_rooms_over_federation` variables, respectively. | As with anything else, these new defaults can be overriden by changing the `matrix_synapse_allow_public_rooms_without_auth` and `matrix_synapse_allow_public_rooms_over_federation` variables, respectively. | ||||||
|  |  | ||||||
|  |  | ||||||
| # 2019-10-05 | # 2019-10-05 | ||||||
| @@ -3611,7 +3558,7 @@ The following changes had to be done: | |||||||
|  |  | ||||||
| - glue variables had to be introduced to the playbook, so it can wire together the various components. Those glue vars are stored in the [`group_vars/matrix-servers`](group_vars/matrix-servers) file. When overriding variables for a given component (role), you need to be aware of both the role defaults (`role/ROLE/defaults/main.yml`) and the role's corresponding section in the [`group_vars/matrix-servers`](group_vars/matrix-servers) file. | - glue variables had to be introduced to the playbook, so it can wire together the various components. Those glue vars are stored in the [`group_vars/matrix-servers`](group_vars/matrix-servers) file. When overriding variables for a given component (role), you need to be aware of both the role defaults (`role/ROLE/defaults/main.yml`) and the role's corresponding section in the [`group_vars/matrix-servers`](group_vars/matrix-servers) file. | ||||||
|  |  | ||||||
| - `matrix_postgres_use_external` has been superseded by the more consistently named `matrix_postgres_enabled` variable and a few other `matrix_synapse_database_` variables. See the [Using an external PostgreSQL server (optional)](docs/configuring-playbook-external-postgres.md) documentation page for an up-to-date replacement. | - `matrix_postgres_use_external` has been superceeded by the more consistently named `matrix_postgres_enabled` variable and a few other `matrix_synapse_database_` variables. See the [Using an external PostgreSQL server (optional)](docs/configuring-playbook-external-postgres.md) documentation page for an up-to-date replacement. | ||||||
|  |  | ||||||
| - Postgres tools (`matrix-postgres-cli` and `matrix-make-user-admin`) are no longer installed if you're not enabling the `matrix-postgres` role (`matrix_postgres_enabled: false`) | - Postgres tools (`matrix-postgres-cli` and `matrix-make-user-admin`) are no longer installed if you're not enabling the `matrix-postgres` role (`matrix_postgres_enabled: false`) | ||||||
|  |  | ||||||
| @@ -3800,7 +3747,7 @@ matrix_riot_web_integrations_jitsi_widget_url: "https://dimension.t2bot.io/widge | |||||||
|  |  | ||||||
| There's now a new `matrix_nginx_proxy_ssl_protocols` playbook variable, which controls the SSL protocols used to serve Riot and Synapse. Its default value is `TLSv1.1 TLSv1.2`. This playbook previously used `TLSv1 TLSv1.1 TLSv1.2` to serve Riot and Synapse. | There's now a new `matrix_nginx_proxy_ssl_protocols` playbook variable, which controls the SSL protocols used to serve Riot and Synapse. Its default value is `TLSv1.1 TLSv1.2`. This playbook previously used `TLSv1 TLSv1.1 TLSv1.2` to serve Riot and Synapse. | ||||||
|  |  | ||||||
| You may wish to re-enable TLSv1 if you need to access Riot in older browsers. | You may wish to reenable TLSv1 if you need to access Riot in older browsers. | ||||||
|  |  | ||||||
| Note: Currently the dockerized nginx doesn't support TLSv1.3. See https://github.com/nginxinc/docker-nginx/issues/190 for more details. | Note: Currently the dockerized nginx doesn't support TLSv1.3. See https://github.com/nginxinc/docker-nginx/issues/190 for more details. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,18 +0,0 @@ | |||||||
| MIT License |  | ||||||
|  |  | ||||||
| Copyright (c) <year> <copyright holders> |  | ||||||
|  |  | ||||||
| Permission is hereby granted, free of charge, to any person obtaining a copy of this software and  |  | ||||||
| associated documentation files (the "Software"), to deal in the Software without restriction, including  |  | ||||||
| without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell  |  | ||||||
| copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the  |  | ||||||
| following conditions: |  | ||||||
|  |  | ||||||
| The above copyright notice and this permission notice shall be included in all copies or substantial  |  | ||||||
| portions of the Software. |  | ||||||
|  |  | ||||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT  |  | ||||||
| LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO  |  | ||||||
| EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER  |  | ||||||
| IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE  |  | ||||||
| USE OR OTHER DEALINGS IN THE SOFTWARE. |  | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| [](https://matrix.to/#/#matrix-docker-ansible-deploy:devture.com) [](https://liberapay.com/s.pantaleev/donate) [](https://api.reuse.software/info/github.com/spantaleev/matrix-docker-ansible-deploy) | [](https://matrix.to/#/#matrix-docker-ansible-deploy:devture.com) [](https://liberapay.com/s.pantaleev/donate) [](https://api.reuse.software/info/github.com/spantaleev/matrix-docker-ansible-deploy) | ||||||
|  |  | ||||||
| # Matrix (An open network for secure, decentralized communication) server setup using Ansible and Docker | # Matrix (An open network for secure, decentralized communication) server setup using Ansible and Docker | ||||||
|  |  | ||||||
| @@ -53,7 +53,6 @@ The homeserver is the backbone of your Matrix system. Choose one from the follow | |||||||
| | [Synapse](https://github.com/element-hq/synapse) | ✅ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network | [Link](docs/configuring-playbook-synapse.md) | | | [Synapse](https://github.com/element-hq/synapse) | ✅ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network | [Link](docs/configuring-playbook-synapse.md) | | ||||||
| | [Conduit](https://conduit.rs) | ❌ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network. Conduit is a lightweight open-source server implementation of the Matrix Specification with a focus on easy setup and low system requirements | [Link](docs/configuring-playbook-conduit.md) | | | [Conduit](https://conduit.rs) | ❌ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network. Conduit is a lightweight open-source server implementation of the Matrix Specification with a focus on easy setup and low system requirements | [Link](docs/configuring-playbook-conduit.md) | | ||||||
| | [conduwuit](https://conduwuit.puppyirl.gay/) | ❌ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network. conduwuit is a fork of Conduit. | [Link](docs/configuring-playbook-conduwuit.md) | | | [conduwuit](https://conduwuit.puppyirl.gay/) | ❌ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network. conduwuit is a fork of Conduit. | [Link](docs/configuring-playbook-conduwuit.md) | | ||||||
| | [continuwuity](https://continuwuity.org) | ❌ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network. continuwuity is a continuation of conduwuit. | [Link](docs/configuring-playbook-continuwuity.md) | |  | ||||||
| | [Dendrite](https://github.com/element-hq/dendrite) | ❌ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network. Dendrite is a second-generation Matrix homeserver written in Go, an alternative to Synapse. | [Link](docs/configuring-playbook-dendrite.md) | | | [Dendrite](https://github.com/element-hq/dendrite) | ❌ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network. Dendrite is a second-generation Matrix homeserver written in Go, an alternative to Synapse. | [Link](docs/configuring-playbook-dendrite.md) | | ||||||
|  |  | ||||||
| ### Clients | ### Clients | ||||||
| @@ -141,7 +140,6 @@ Bridges can be used to connect your Matrix installation with third-party communi | |||||||
| | [mx-puppet-discord](https://gitlab.com/mx-puppet/discord/mx-puppet-discord) | ❌ | Bridge to [Discord](https://discordapp.com/) | [Link](docs/configuring-playbook-bridge-mx-puppet-discord.md) | | | [mx-puppet-discord](https://gitlab.com/mx-puppet/discord/mx-puppet-discord) | ❌ | Bridge to [Discord](https://discordapp.com/) | [Link](docs/configuring-playbook-bridge-mx-puppet-discord.md) | | ||||||
| | [mx-puppet-groupme](https://gitlab.com/xangelix-pub/matrix/mx-puppet-groupme) | ❌ | Bridge to [GroupMe](https://groupme.com/) | [Link](docs/configuring-playbook-bridge-mx-puppet-groupme.md) | | | [mx-puppet-groupme](https://gitlab.com/xangelix-pub/matrix/mx-puppet-groupme) | ❌ | Bridge to [GroupMe](https://groupme.com/) | [Link](docs/configuring-playbook-bridge-mx-puppet-groupme.md) | | ||||||
| | [mx-puppet-steam](https://github.com/icewind1991/mx-puppet-steam) | ❌ | Bridge to [Steam](https://steamapp.com/) | [Link](docs/configuring-playbook-bridge-mx-puppet-steam.md) | | | [mx-puppet-steam](https://github.com/icewind1991/mx-puppet-steam) | ❌ | Bridge to [Steam](https://steamapp.com/) | [Link](docs/configuring-playbook-bridge-mx-puppet-steam.md) | | ||||||
| | [matrix-steam-bridge](https://github.com/jasonlaguidice/matrix-steam-bridge) | ❌ | Bridge to [Steam](https://steampowered.com/) | [Link](docs/configuring-playbook-bridge-steam.md) | |  | ||||||
| | [Postmoogle](https://github.com/etkecc/postmoogle) | ❌ | Email to Matrix bridge | [Link](docs/configuring-playbook-bridge-postmoogle.md) | | | [Postmoogle](https://github.com/etkecc/postmoogle) | ❌ | Email to Matrix bridge | [Link](docs/configuring-playbook-bridge-postmoogle.md) | | ||||||
|  |  | ||||||
| ### Bots | ### Bots | ||||||
|   | |||||||
| @@ -13,12 +13,10 @@ path = [ | |||||||
|     "i18n/PUBLISHED_LANGUAGES", |     "i18n/PUBLISHED_LANGUAGES", | ||||||
|     "i18n/requirements.txt", |     "i18n/requirements.txt", | ||||||
|     "roles/custom/**/*.repo", |     "roles/custom/**/*.repo", | ||||||
|     ".codespellrc", |  | ||||||
|     ".editorconfig", |     ".editorconfig", | ||||||
|     ".envrc", |     ".envrc", | ||||||
|     ".gitattributes", |     ".gitattributes", | ||||||
|     ".gitignore", |     ".gitignore", | ||||||
|     ".pre-commit-config.yaml", |  | ||||||
|     ".yamllint", |     ".yamllint", | ||||||
|     "ansible.cfg", |     "ansible.cfg", | ||||||
|     "flake.lock", |     "flake.lock", | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ SPDX-License-Identifier: AGPL-3.0-or-later | |||||||
|  |  | ||||||
| 2023 is probably [the year of AI](https://journal.everypixel.com/2023-the-year-of-ai), with millions of people jumping aboard [OpenAI](https://openai.com/)'s [ChatGPT](https://openai.com/chatgpt) train. matrix-docker-ansible-deploy is no stranger to this and 2023 began with a PR from [bertybuttface](https://github.com/bertybuttface) who added support for [matrix-chatgpt-bot](https://github.com/matrixgpt/matrix-chatgpt-bot) (see the [changelog entry](https://github.com/spantaleev/matrix-docker-ansible-deploy/blob/850078b7e37401ce91a0f9b686f60b945f6c3a96/CHANGELOG.md#chatgpt-support)). While OpenAI's chat GPT website was frequently overloaded in the past, their API was up which made using this bot both convenient and more reliable. | 2023 is probably [the year of AI](https://journal.everypixel.com/2023-the-year-of-ai), with millions of people jumping aboard [OpenAI](https://openai.com/)'s [ChatGPT](https://openai.com/chatgpt) train. matrix-docker-ansible-deploy is no stranger to this and 2023 began with a PR from [bertybuttface](https://github.com/bertybuttface) who added support for [matrix-chatgpt-bot](https://github.com/matrixgpt/matrix-chatgpt-bot) (see the [changelog entry](https://github.com/spantaleev/matrix-docker-ansible-deploy/blob/850078b7e37401ce91a0f9b686f60b945f6c3a96/CHANGELOG.md#chatgpt-support)). While OpenAI's chat GPT website was frequently overloaded in the past, their API was up which made using this bot both convenient and more reliable. | ||||||
|  |  | ||||||
| AI aside, with the playbook's focus being containers, we're **doubling down on being "container native"** and becoming more interoperable for people hosting other containers on the Matrix server. In [2022](https://github.com/spantaleev/matrix-docker-ansible-deploy/blob/850078b7e37401ce91a0f9b686f60b945f6c3a96/YEAR-IN-REVIEW.md#2022), we've announced a few sibling Ansible playbooks, their use of [Traefik](https://doc.traefik.io/traefik/) and the possibility of matrix-docker-ansible-deploy also switching to this reverse-proxy. This prediction materialized quickly. The **largest change** in the playbook in 2023 happened way back in February - matrix-docker-ansible-deploy [starting the switch from nginx to Traefik](https://github.com/spantaleev/matrix-docker-ansible-deploy/blob/850078b7e37401ce91a0f9b686f60b945f6c3a96/CHANGELOG.md#backward-compatibility-reverse-proxy-configuration-changes-and-initial-traefik-support) and then quickly [making Treafik the default reverse-proxy](https://github.com/spantaleev/matrix-docker-ansible-deploy/blob/850078b7e37401ce91a0f9b686f60b945f6c3a96/CHANGELOG.md#traefik-is-the-default-reverse-proxy-now). As noted in the changelog entries, we envisioned a quick and complete elimination of `matrix-nginx-proxy`, but at the end of 2023, it hasn't happened yet. The playbook is already using Traefik as the front-most reverse-proxy, but nginx (via `matrix-nginx-proxy`) is still around - it has taken a step back and is only used internally for new setups. Work got to a stall due to: | AI aside, with the playbook's focus being containers, we're **doubling down on being "container native"** and becoming more interoperable for people hosting other containers on the Matrix server. In [2022](https://github.com/spantaleev/matrix-docker-ansible-deploy/blob/850078b7e37401ce91a0f9b686f60b945f6c3a96/YEAR-IN-REVIEW.md#2022), we've announced a few sibling Ansible playbooks, their use of [Traefik](https://doc.traefik.io/traefik/) and the possiblity of matrix-docker-ansible-deploy also switching to this reverse-proxy. This prediction materialized quickly. The **largest change** in the playbook in 2023 happened way back in February - matrix-docker-ansible-deploy [starting the switch from nginx to Traefik](https://github.com/spantaleev/matrix-docker-ansible-deploy/blob/850078b7e37401ce91a0f9b686f60b945f6c3a96/CHANGELOG.md#backward-compatibility-reverse-proxy-configuration-changes-and-initial-traefik-support) and then quickly [making Treafik the default reverse-proxy](https://github.com/spantaleev/matrix-docker-ansible-deploy/blob/850078b7e37401ce91a0f9b686f60b945f6c3a96/CHANGELOG.md#traefik-is-the-default-reverse-proxy-now). As noted in the changelog entries, we envisioned a quick and complete elimination of `matrix-nginx-proxy`, but at the end of 2023, it hasn't happened yet. The playbook is already using Traefik as the front-most reverse-proxy, but nginx (via `matrix-nginx-proxy`) is still around - it has taken a step back and is only used internally for new setups. Work got to a stall due to: | ||||||
|  |  | ||||||
| *   complexity: untangling the overly large and messy `matrix-nginx-proxy` component is difficult | *   complexity: untangling the overly large and messy `matrix-nginx-proxy` component is difficult | ||||||
| *   the current setup became "good enough" because nginx has become an internal implementation detail for those who have migrated to Traefik. Traefik is already the default public reverse-proxy and gives better possibilities to people wishing to run other web-exposed containers on their Matrix server via [Docker Compose](https://docs.docker.com/compose/), other Ansible playbooks like [mash-playbook](https://github.com/mother-of-all-self-hosting/mash-playbook) (more about this one, below) or any other way. | *   the current setup became "good enough" because nginx has become an internal implementation detail for those who have migrated to Traefik. Traefik is already the default public reverse-proxy and gives better possibilities to people wishing to run other web-exposed containers on their Matrix server via [Docker Compose](https://docs.docker.com/compose/), other Ansible playbooks like [mash-playbook](https://github.com/mother-of-all-self-hosting/mash-playbook) (more about this one, below) or any other way. | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ SPDX-License-Identifier: AGPL-3.0-or-later | |||||||
|  |  | ||||||
| # Table of Contents | # Table of Contents | ||||||
|  |  | ||||||
| ## ⬇️ Installation guides <!-- NOTE: the 🚀 emoji is used by "Getting started" on README.md --> | ## ⬇️ Installaton guides <!-- NOTE: the 🚀 emoji is used by "Getting started" on README.md --> | ||||||
|  |  | ||||||
| There are two installation guides available for beginners and advanced users. | There are two installation guides available for beginners and advanced users. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -20,13 +20,10 @@ To manually check which version of Ansible you're on, run: `ansible --version`. | |||||||
|  |  | ||||||
| For the **best experience**, we recommend getting the **latest version of Ansible available**. | For the **best experience**, we recommend getting the **latest version of Ansible available**. | ||||||
|  |  | ||||||
| We're not sure what's the minimum version of Ansible that can run this playbook successfully. The lowest version that we suspect (on 2025-09-03) to be working fine is: `ansible-core` (`2.15.1`). | We're not sure what's the minimum version of Ansible that can run this playbook successfully. The lowest version that we've confirmed (on 2022-11-26) to be working fine is: `ansible-core` (`2.11.7`) combined with `ansible` (`4.10.0`). | ||||||
|  |  | ||||||
| If your distro ships with an Ansible version older than this, you may run into issues. Consider [Upgrading Ansible](#upgrading-ansible) or [using Ansible via Docker](#using-ansible-via-docker). | If your distro ships with an Ansible version older than this, you may run into issues. Consider [Upgrading Ansible](#upgrading-ansible) or [using Ansible via Docker](#using-ansible-via-docker). | ||||||
|  |  | ||||||
| > [!WARNING] |  | ||||||
| > One reason for the version requirement being as such is that the playbook by default installs Docker for you using [this Docker role](https://github.com/geerlingguy/ansible-role-docker) which [has a hard requirement on Ansible v2.15.1](https://github.com/geerlingguy/ansible-role-docker/commit/7f44a1d9ad8132819ea9852918bca5dab8757cd0). If you install Docker yourself another way, you can tell the playbook to skip running this role (by adding `matrix_playbook_docker_installation_enabled: false` to your `vars.yml` configuration). It may then be possible to get the playbook running on an older version of Ansible. Still, this is a complication and your mileage may vary. We recommend [upgrading Ansible](#upgrading-ansible) instead of going into uncharted territory. |  | ||||||
|  |  | ||||||
| ## Upgrading Ansible | ## Upgrading Ansible | ||||||
|  |  | ||||||
| Depending on your distribution, you may be able to upgrade Ansible in a few different ways: | Depending on your distribution, you may be able to upgrade Ansible in a few different ways: | ||||||
| @@ -74,7 +71,7 @@ docker run \ | |||||||
| -w /work \ | -w /work \ | ||||||
| --mount type=bind,src=`pwd`,dst=/work \ | --mount type=bind,src=`pwd`,dst=/work \ | ||||||
| --entrypoint=/bin/sh \ | --entrypoint=/bin/sh \ | ||||||
| ghcr.io/devture/ansible:11.6.0-r0-0 | ghcr.io/devture/ansible:11.1.0-r0-0 | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Once you execute the above command, you'll be dropped into a `/work` directory inside a Docker container. The `/work` directory contains the playbook's code. | Once you execute the above command, you'll be dropped into a `/work` directory inside a Docker container. The `/work` directory contains the playbook's code. | ||||||
| @@ -95,7 +92,7 @@ docker run \ | |||||||
| --mount type=bind,src=`pwd`,dst=/work \ | --mount type=bind,src=`pwd`,dst=/work \ | ||||||
| --mount type=bind,src$HOME/.ssh/id_ed25519,dst=/root/.ssh/id_ed25519,ro \ | --mount type=bind,src$HOME/.ssh/id_ed25519,dst=/root/.ssh/id_ed25519,ro \ | ||||||
| --entrypoint=/bin/sh \ | --entrypoint=/bin/sh \ | ||||||
| ghcr.io/devture/ansible:11.6.0-r0-0 | ghcr.io/devture/ansible:11.1.0-r0-0 | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The above command tries to mount an SSH key (`$HOME/.ssh/id_ed25519`) into the container (at `/root/.ssh/id_ed25519`). If your SSH key is at a different path (not in `$HOME/.ssh/id_ed25519`), adjust that part. | The above command tries to mount an SSH key (`$HOME/.ssh/id_ed25519`) into the container (at `/root/.ssh/id_ed25519`). If your SSH key is at a different path (not in `$HOME/.ssh/id_ed25519`), adjust that part. | ||||||
| @@ -120,7 +117,7 @@ Then, to be asked for the password whenever running an `ansible-playbook` comman | |||||||
|  |  | ||||||
| #### Resolve directory ownership issues | #### Resolve directory ownership issues | ||||||
|  |  | ||||||
| Because you're `root` in the container running Ansible and this likely differs from the owner (your regular user account) of the playbook directory outside of the container, certain playbook features which use `git` locally may report warnings such as: | Because you're `root` in the container running Ansible and this likely differs fom the owner (your regular user account) of the playbook directory outside of the container, certain playbook features which use `git` locally may report warnings such as: | ||||||
|  |  | ||||||
| > fatal: unsafe repository ('/work' is owned by someone else) | > fatal: unsafe repository ('/work' is owned by someone else) | ||||||
| > To add an exception for this directory, call: | > To add an exception for this directory, call: | ||||||
|   | |||||||
| @@ -105,12 +105,16 @@ After configuring the playbook and potentially [adjusting your DNS records](#adj | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -35,12 +35,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -95,13 +95,13 @@ ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | |||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
| If you made it through all the steps above and your main control room was joined by a user called `@draupnir-main:example.com` you have successfully installed Draupnir for All and can now start using it. | If you made it through all the steps above and your main control room was joined by a user called `@draupnir-main:example.com` you have succesfully installed Draupnir for All and can now start using it. | ||||||
|  |  | ||||||
| The installation of Draupnir for all in this playbook is very much Alpha quality. Usage-wise, Draupnir for all is almost identical to Draupnir bot mode. | The installation of Draupnir for all in this playbook is very much Alpha quality. Usage-wise, Draupnir for all is almost identical to Draupnir bot mode. | ||||||
|  |  | ||||||
| ### Granting Users the ability to use D4A | ### Granting Users the ability to use D4A | ||||||
|  |  | ||||||
| Draupnir for all includes several security measures like that it only allows users that are on its allow list to ask for a bot. To add a user to this list we have 2 primary options. Using the chat to tell Draupnir to do this for us or if you want to automatically do it by sending `m.policy.rule.user` events that target the subject you want to allow provisioning for with the `org.matrix.mjolnir.allow` recommendation. Using the chat is recommended. | Draupnir for all includes several security measures like that it only allows users that are on its allow list to ask for a bot. To add a user to this list we have 2 primary options. Using the chat to tell Draupnir to do this for us or if you want to automatically do it by sending `m.policy.rule.user` events that target the subject you want to allow provisioning for with the `org.matrix.mjolnir.allow` recomendation. Using the chat is recomended. | ||||||
|  |  | ||||||
| The bot requires a powerlevel of 50 in the management room to control who is allowed to use the bot. The bot does currently not say anything if this is true or false. (This is considered a bug and is documented in issue [#297](https://github.com/the-draupnir-project/Draupnir/issues/297)) | The bot requires a powerlevel of 50 in the management room to control who is allowed to use the bot. The bot does currently not say anything if this is true or false. (This is considered a bug and is documented in issue [#297](https://github.com/the-draupnir-project/Draupnir/issues/297)) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -242,7 +242,7 @@ matrix_bot_baibot_config_agents_static_definitions_openai_config_api_key: "YOUR_ | |||||||
| # matrix_bot_baibot_config_agents_static_definitions_openai_config_text_generation_prompt: "{{ matrix_bot_baibot_config_agents_static_definitions_prompt }}" | # matrix_bot_baibot_config_agents_static_definitions_openai_config_text_generation_prompt: "{{ matrix_bot_baibot_config_agents_static_definitions_prompt }}" | ||||||
|  |  | ||||||
| # If you'd like to use another text-generation agent, uncomment and adjust: | # If you'd like to use another text-generation agent, uncomment and adjust: | ||||||
| # matrix_bot_baibot_config_agents_static_definitions_openai_config_text_generation_model_id: gpt-4.1 | # matrix_bot_baibot_config_agents_static_definitions_openai_config_text_generation_model_id: gpt-4o | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Because this is a [statically](https://github.com/etkecc/baibot/blob/main/docs/configuration/README.md#static-configuration)-defined agent, it will be given a `static/` ID prefix and will be named `static/openai`. | Because this is a [statically](https://github.com/etkecc/baibot/blob/main/docs/configuration/README.md#static-configuration)-defined agent, it will be given a `static/` ID prefix and will be named `static/openai`. | ||||||
|   | |||||||
| @@ -57,7 +57,7 @@ matrix_bot_chatgpt_openai_api_key: 'API_KEY_HERE' | |||||||
|  |  | ||||||
| matrix_bot_chatgpt_matrix_access_token: 'ACCESS_TOKEN_HERE' | matrix_bot_chatgpt_matrix_access_token: 'ACCESS_TOKEN_HERE' | ||||||
|  |  | ||||||
| # Configuring the system prompt used, needed if the bot is used for special tasks. | # Configuring the system promt used, needed if the bot is used for special tasks. | ||||||
| # More information: https://github.com/mustvlad/ChatGPT-System-Prompts | # More information: https://github.com/mustvlad/ChatGPT-System-Prompts | ||||||
| matrix_bot_chatgpt_matrix_bot_prompt_prefix: 'Instructions:\nYou are ChatGPT, a large language model trained by OpenAI.' | matrix_bot_chatgpt_matrix_bot_prompt_prefix: 'Instructions:\nYou are ChatGPT, a large language model trained by OpenAI.' | ||||||
| ``` | ``` | ||||||
|   | |||||||
| @@ -145,20 +145,6 @@ The bot can intercept the report API endpoint of the client-server API, which re | |||||||
| matrix_bot_draupnir_config_web_abuseReporting: true | matrix_bot_draupnir_config_web_abuseReporting: true | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### Enabling synapse-http-antispam support |  | ||||||
|  |  | ||||||
| Certain protections in Draupnir require the [synapse-http-antispam](https://github.com/maunium/synapse-http-antispam) module and a Synapse homeserver plus homeserver admin status to function. This module can be enabled in the playbook via setting `matrix_bot_draupnir_config_web_synapseHTTPAntispam_enabled` to `true` and making sure that Draupnir admin API access is enabled. |  | ||||||
|  |  | ||||||
| ```yaml |  | ||||||
| # Enables the integration between Draupnir and synapse-http-antispam module. |  | ||||||
| matrix_bot_draupnir_config_web_synapseHTTPAntispam_enabled: true |  | ||||||
|  |  | ||||||
| # Enables draupnir to access Synapse admin APIs. This is required for the module functionality to take full effect. |  | ||||||
| matrix_bot_draupnir_admin_api_enabled: true |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| These protections need to be manually activated and consulting the [enabling protections](#enabling-built-in-protections) guide can be helpful or consulting upstream documentation. |  | ||||||
|  |  | ||||||
| <!-- | <!-- | ||||||
| NOTE: this is unsupported by the playbook due to the admin API being inaccessible from containers currently. | NOTE: this is unsupported by the playbook due to the admin API being inaccessible from containers currently. | ||||||
|  |  | ||||||
| @@ -204,15 +190,9 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| **Notes**: | The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
| - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` |  | ||||||
|  |  | ||||||
|   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. |  | ||||||
|  |  | ||||||
| - If you change the bot password (`matrix_bot_draupnir_password` in your `vars.yml` file) subsequently, the bot user's credentials on the homeserver won't be updated automatically. If you'd like to change the bot user's password, use a tool like [synapse-admin](configuring-playbook-synapse-admin.md) to change it, and then update `matrix_bot_draupnir_password` to let the bot know its new password. |  | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
| @@ -242,12 +222,9 @@ For Draupnir to do its job, you need to [give it permissions](https://the-draupn | |||||||
|  |  | ||||||
| We recommend **subscribing to a public [policy list](https://the-draupnir-project.github.io/draupnir-documentation/concepts/policy-lists)** using the [watch command](https://the-draupnir-project.github.io/draupnir-documentation/moderator/managing-policy-lists#using-draupnirs-watch-command-to-subscribe-to-policy-rooms). | We recommend **subscribing to a public [policy list](https://the-draupnir-project.github.io/draupnir-documentation/concepts/policy-lists)** using the [watch command](https://the-draupnir-project.github.io/draupnir-documentation/moderator/managing-policy-lists#using-draupnirs-watch-command-to-subscribe-to-policy-rooms). | ||||||
|  |  | ||||||
| Policy lists are maintained in Matrix rooms. Popular ones maintained in the public are: | Polcy lists are maintained in Matrix rooms. A popular policy list is maintained in the public `#community-moderation-effort-bl:neko.dev` room. | ||||||
|  |  | ||||||
| - `#community-moderation-effort-bl:neko.dev` | You can tell Draupnir to subscribe to it by sending the following command to the Management Room: `!draupnir watch #community-moderation-effort-bl:neko.dev` | ||||||
| - `#huginn-muninn-active-threats:feline.support` |  | ||||||
|  |  | ||||||
| You can tell Draupnir to subscribe to each of these by sending the following command to the Management Room: `!draupnir watch POLICY_LIST_ADDRESS_HERE` (e.g. `!draupnir watch #community-moderation-effort-bl:neko.dev`) |  | ||||||
|  |  | ||||||
| #### Creating your own policy lists and rules | #### Creating your own policy lists and rules | ||||||
|  |  | ||||||
| @@ -262,7 +239,7 @@ The simplest and most useful entity to target is `user`. Below are a few example | |||||||
| To create rules, you run commands in the Management Room (**not** in the policy list room). | To create rules, you run commands in the Management Room (**not** in the policy list room). | ||||||
|  |  | ||||||
| - (ban a single user on a given homeserver): `!draupnir ban @charles:example.com my-bans Rude to others` | - (ban a single user on a given homeserver): `!draupnir ban @charles:example.com my-bans Rude to others` | ||||||
| - (ban all users on a given homeserver by using a [wildcard](https://the-draupnir-project.github.io/draupnir-documentation/moderator/managing-users#wildcards)): `!draupnir ban @*:example.org my-bans Spam server, all users are fake` | - (ban all users on a given homeserver by using a [wildcard](https://the-draupnir-project.github.io/draupnir-documentation/moderator/managing-users#wildcards)): `!draupnir ban @*:example.org my-bans Spam server - all users are fake` | ||||||
|  |  | ||||||
| As a result of running these commands, you may observe: | As a result of running these commands, you may observe: | ||||||
|  |  | ||||||
| @@ -273,14 +250,14 @@ You can undo bans with the [unban command](https://the-draupnir-project.github.i | |||||||
|  |  | ||||||
| ### Enabling built-in protections | ### Enabling built-in protections | ||||||
|  |  | ||||||
| You can also **turn on various built-in [protections](https://the-draupnir-project.github.io/draupnir-documentation/protections)** like `JoinWaveShortCircuitProtection` ("If X amount of users join in Y time, set the room to invite-only"). | You can also **turn on various built-in [protections](https://the-draupnir-project.github.io/draupnir-documentation/protections)** like `JoinWaveShortCircuit` ("If X amount of users join in Y time, set the room to invite-only"). | ||||||
|  |  | ||||||
| To **see which protections are available and which are enabled**, send a `!draupnir protections` command to the Management Room. | To **see which protections are available and which are enabled**, send a `!draupnir protections` command to the Management Room. | ||||||
|  |  | ||||||
| To [**see the configuration options for a given protection**](https://the-draupnir-project.github.io/draupnir-documentation/protections/configuring-protections#displaying-the-protection-settings), send a `!draupnir protections show PROTECTION_NAME` (e.g. `!draupnir protections show JoinWaveShortCircuitProtection`). | To **see the configuration options for a given protection**, send a `!draupnir protections show PROTECTION_NAME` (e.g. `!draupnir protections show JoinWaveShortCircuit`). | ||||||
|  |  | ||||||
| To [**set a specific option for a given protection**](https://the-draupnir-project.github.io/draupnir-documentation/protections/configuring-protections#changing-protection-settings), send a command like this: `!draupnir protections config set PROTECTION_NAME OPTION VALUE` (e.g. `!draupnir protections config set JoinWaveShortCircuitProtection timescaleMinutes 30`). | To **set a specific option for a given protection**, send a command like this: `!draupnir config set PROTECTION_NAME.OPTION VALUE` (e.g. `!draupnir config set JoinWaveShortCircuit.timescaleMinutes 30`). | ||||||
|  |  | ||||||
| To [**enable a given protection**](https://the-draupnir-project.github.io/draupnir-documentation/protections/block-invitations-on-server-protection#enabling-the-protection), send a command like this: `!draupnir protections enable PROTECTION_NAME` (e.g. `!draupnir protections enable JoinWaveShortCircuitProtection`). | To **enable a given protection**, send a command like this: `!draupnir enable PROTECTION_NAME` (e.g. `!draupnir enable JoinWaveShortCircuit`). | ||||||
|  |  | ||||||
| To **disable a given protection**, send a command like this: `!draupnir protections disable PROTECTION_NAME` (e.g. `!draupnir protections disable JoinWaveShortCircuitProtection`). | To **disable a given protection**, send a command like this: `!draupnir disable PROTECTION_NAME` (e.g. `!draupnir disable JoinWaveShortCircuit`). | ||||||
|   | |||||||
| @@ -245,12 +245,16 @@ After configuring the playbook and potentially [adjusting your DNS records](#adj | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -37,10 +37,6 @@ matrix_synapse_enable_registration: true | |||||||
|  |  | ||||||
| # Restrict registration to users with a token | # Restrict registration to users with a token | ||||||
| matrix_synapse_registration_requires_token: true | matrix_synapse_registration_requires_token: true | ||||||
|  |  | ||||||
| # Set an optional command prefix for the bot. This can be any arbitrary string, including whitespace. |  | ||||||
| # Example: "!regbot " |  | ||||||
| matrix_bot_matrix_registration_bot_bot_prefix: "" |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The bot account will be created automatically. | The bot account will be created automatically. | ||||||
| @@ -81,7 +77,7 @@ Send `help` to the bot to see the available commands. | |||||||
|  |  | ||||||
| You can also refer to the upstream [Usage documentation](https://github.com/moan0s/matrix-registration-bot#supported-commands). | You can also refer to the upstream [Usage documentation](https://github.com/moan0s/matrix-registration-bot#supported-commands). | ||||||
|  |  | ||||||
| If you have any questions, or if you need help setting it up, read the [troubleshooting guide](https://github.com/moan0s/matrix-registration-bot/blob/main/docs/troubleshooting.md) or join [#matrix-registration-bot:hyteck.de](https://matrix.to/#/#matrix-registration-bot:hyteck.de). | If you have any questions, or if you need help setting it up, read the [troublshooting guide](https://github.com/moan0s/matrix-registration-bot/blob/main/docs/troubleshooting.md) or join [#matrix-registration-bot:hyteck.de](https://matrix.to/#/#matrix-registration-bot:hyteck.de). | ||||||
|  |  | ||||||
| To clean the cache (session & encryption data) after you changed the bot's username, changed the login method from access_token to password etc… you can use: | To clean the cache (session & encryption data) after you changed the bot's username, changed the login method from access_token to password etc… you can use: | ||||||
|  |  | ||||||
|   | |||||||
| @@ -189,11 +189,13 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| **Notes**: | **Notes**: | ||||||
|  |  | ||||||
|  | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
| - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|   | |||||||
| @@ -52,13 +52,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Self-Service Bridging (Manual) | ## Self-Service Bridging (Manual) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -84,12 +84,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -49,12 +49,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -94,12 +94,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -47,12 +47,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ SPDX-FileCopyrightText: 2021 - 2024 Slavi Pantaleev | |||||||
| SPDX-FileCopyrightText: 2021 Alexandar Mechev | SPDX-FileCopyrightText: 2021 Alexandar Mechev | ||||||
| SPDX-FileCopyrightText: 2022 Cody Wyatt Neiman | SPDX-FileCopyrightText: 2022 Cody Wyatt Neiman | ||||||
| SPDX-FileCopyrightText: 2023 Kuba Orlik | SPDX-FileCopyrightText: 2023 Kuba Orlik | ||||||
| SPDX-FileCopyrightText: 2024 - 2025 Suguru Hirahara | SPDX-FileCopyrightText: 2024 Suguru Hirahara | ||||||
|  |  | ||||||
| SPDX-License-Identifier: AGPL-3.0-or-later | SPDX-License-Identifier: AGPL-3.0-or-later | ||||||
| --> | --> | ||||||
| @@ -46,12 +46,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| <!-- | <!-- | ||||||
| SPDX-FileCopyrightText: 2022 Vladimir Panteleev | SPDX-FileCopyrightText: 2022 Vladimir Panteleev | ||||||
| SPDX-FileCopyrightText: 2024 - 2025 Suguru Hirahara | SPDX-FileCopyrightText: 2024 Suguru Hirahara | ||||||
|  |  | ||||||
| SPDX-License-Identifier: AGPL-3.0-or-later | SPDX-License-Identifier: AGPL-3.0-or-later | ||||||
| --> | --> | ||||||
| @@ -43,12 +43,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -65,12 +65,16 @@ After configuring the playbook and potentially [adjusting your DNS records](#adj | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -35,7 +35,7 @@ matrix_hookshot_enabled: true | |||||||
|  |  | ||||||
| # Uncomment to enable end-to-bridge encryption. | # Uncomment to enable end-to-bridge encryption. | ||||||
| # See: https://matrix-org.github.io/matrix-hookshot/latest/advanced/encryption.html | # See: https://matrix-org.github.io/matrix-hookshot/latest/advanced/encryption.html | ||||||
| # matrix_hookshot_encryption_enabled: true | # matrix_hookshot_experimental_encryption_enabled: true | ||||||
|  |  | ||||||
| # Uncomment and paste the contents of GitHub app private key to enable GitHub bridge. | # Uncomment and paste the contents of GitHub app private key to enable GitHub bridge. | ||||||
| # Alternatively, you can use one of the other methods explained below on the "Manage GitHub Private Key with aux role" section. | # Alternatively, you can use one of the other methods explained below on the "Manage GitHub Private Key with aux role" section. | ||||||
| @@ -103,6 +103,7 @@ Unless indicated otherwise, the following endpoints are reachable on your `matri | |||||||
| | github oauth | `/hookshot/webhooks/oauth` | `matrix_hookshot_github_oauth_endpoint` | GitHub "Callback URL" | | | github oauth | `/hookshot/webhooks/oauth` | `matrix_hookshot_github_oauth_endpoint` | GitHub "Callback URL" | | ||||||
| | jira oauth | `/hookshot/webhooks/jira/oauth` | `matrix_hookshot_jira_oauth_endpoint` | Jira OAuth | | | jira oauth | `/hookshot/webhooks/jira/oauth` | `matrix_hookshot_jira_oauth_endpoint` | Jira OAuth | | ||||||
| | figma endpoint | `/hookshot/webhooks/figma/webhook` | `matrix_hookshot_figma_endpoint` | Figma | | | figma endpoint | `/hookshot/webhooks/figma/webhook` | `matrix_hookshot_figma_endpoint` | Figma | | ||||||
|  | | provisioning | `/hookshot/v1/` | `matrix_hookshot_provisioning_endpoint` | Dimension [provisioning](#provisioning-api) | | ||||||
| | appservice | `/hookshot/_matrix/app/` | `matrix_hookshot_appservice_endpoint` | Matrix server | | | appservice | `/hookshot/_matrix/app/` | `matrix_hookshot_appservice_endpoint` | Matrix server | | ||||||
| | widgets | `/hookshot/widgetapi/` | `matrix_hookshot_widgets_endpoint` | Widgets | | | widgets | `/hookshot/widgetapi/` | `matrix_hookshot_widgets_endpoint` | Widgets | | ||||||
|  |  | ||||||
| @@ -125,12 +126,16 @@ aux_file_definitions: | |||||||
|   - dest: "{{ matrix_hookshot_base_path }}/{{ matrix_hookshot_github_private_key_file }}" |   - dest: "{{ matrix_hookshot_base_path }}/{{ matrix_hookshot_github_private_key_file }}" | ||||||
|     content: "{{ lookup('file', '/path/to/your-github-private-key.pem') }}" |     content: "{{ lookup('file', '/path/to/your-github-private-key.pem') }}" | ||||||
|     mode: '0400' |     mode: '0400' | ||||||
|     owner: "{{ matrix_user_name }}" |     owner: "{{ matrix_user_username }}" | ||||||
|     group: "{{ matrix_group_name }}" |     group: "{{ matrix_user_groupname }}" | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| For more information, see the documentation in the [default configuration of the aux role](https://github.com/mother-of-all-self-hosting/ansible-role-aux/blob/main/defaults/main.yml). | For more information, see the documentation in the [default configuration of the aux role](https://github.com/mother-of-all-self-hosting/ansible-role-aux/blob/main/defaults/main.yml). | ||||||
|  |  | ||||||
|  | ### Provisioning API | ||||||
|  |  | ||||||
|  | The provisioning API will be enabled automatically if you set `matrix_dimension_enabled: true` and provided a `matrix_hookshot_provisioning_secret`, unless you override it either way. To use hookshot with Dimension, you will need to enter as "Provisioning URL": `http://matrix-hookshot:9002`, which is made up of the variables `matrix_hookshot_container_url` and `matrix_hookshot_provisioning_port`. | ||||||
|  |  | ||||||
| ### Collision with matrix-appservice-webhooks | ### Collision with matrix-appservice-webhooks | ||||||
|  |  | ||||||
| If you are also running [matrix-appservice-webhooks](configuring-playbook-bridge-appservice-webhooks.md), it reserves its namespace by the default setting `matrix_appservice_webhooks_user_prefix: '_webhook_'`. You should take care if you modify its or hookshot's prefix that they do not collide with each other's namespace (default `matrix_hookshot_generic_userIdPrefix: '_webhooks_'`). | If you are also running [matrix-appservice-webhooks](configuring-playbook-bridge-appservice-webhooks.md), it reserves its namespace by the default setting `matrix_appservice_webhooks_user_prefix: '_webhook_'`. You should take care if you modify its or hookshot's prefix that they do not collide with each other's namespace (default `matrix_hookshot_generic_userIdPrefix: '_webhooks_'`). | ||||||
| @@ -167,7 +172,7 @@ To `matrix_hookshot_container_labels_metrics_middleware_basic_auth_users`, set t | |||||||
|  |  | ||||||
| #### Enable Grafana (optional) | #### Enable Grafana (optional) | ||||||
|  |  | ||||||
| Probably you wish to enable Grafana along with Prometheus for generating graphs of the metrics. | Probably you wish to enable Grafana along with Prometheus for generating graphs of the metics. | ||||||
|  |  | ||||||
| To enable Grafana, see [this section](configuring-playbook-prometheus-grafana.md#adjusting-the-playbook-configuration-grafana) for instructions. | To enable Grafana, see [this section](configuring-playbook-prometheus-grafana.md#adjusting-the-playbook-configuration-grafana) for instructions. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -54,12 +54,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,6 @@ | |||||||
| <!-- | <!-- | ||||||
| SPDX-FileCopyrightText: 2025 MDAD project contributors | SPDX-FileCopyrightText: 2025 MDAD project contributors | ||||||
| SPDX-FileCopyrightText: 2025 Slavi Pantaleev | SPDX-FileCopyrightText: 2025 Slavi Pantaleev | ||||||
| SPDX-FileCopyrightText: 2025 Suguru Hirahara |  | ||||||
|  |  | ||||||
| SPDX-License-Identifier: AGPL-3.0-or-later | SPDX-License-Identifier: AGPL-3.0-or-later | ||||||
| --> | --> | ||||||
| @@ -58,7 +57,7 @@ To use the bridge, you need to start a chat with `@blueskybot:example.com` (wher | |||||||
|  |  | ||||||
| You can then follow instructions on the bridge's [official documentation on Authentication](https://docs.mau.fi/bridges/go/bluesky/authentication.html). | You can then follow instructions on the bridge's [official documentation on Authentication](https://docs.mau.fi/bridges/go/bluesky/authentication.html). | ||||||
|  |  | ||||||
| After logging in, the bridge will create portal rooms for recent chats. Portal rooms for other chats will be created as you receive messages. | After logging in, the bridge will create portal rooms for some recent chats. Portal rooms for other chats will be created as you receive messages. | ||||||
|  |  | ||||||
| ## Troubleshooting | ## Troubleshooting | ||||||
|  |  | ||||||
|   | |||||||
| @@ -153,12 +153,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -57,12 +57,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -50,12 +50,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -43,12 +43,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -46,12 +46,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
| @@ -59,7 +63,7 @@ To use the bridge, you need to start a chat with `@googlechatbot:example.com` (w | |||||||
|  |  | ||||||
| You can then follow instructions on the bridge's [official documentation on Authentication](https://docs.mau.fi/bridges/python/googlechat/authentication.html). | You can then follow instructions on the bridge's [official documentation on Authentication](https://docs.mau.fi/bridges/python/googlechat/authentication.html). | ||||||
|  |  | ||||||
| After logging in, the bridge will create portal rooms for recent chats. Portal rooms for other chats will be created as you receive messages. | After logging in, the bridge will create portal rooms for some recent chats. Portal rooms for other chats will be created as you receive messages. | ||||||
|  |  | ||||||
| ## Troubleshooting | ## Troubleshooting | ||||||
|  |  | ||||||
|   | |||||||
| @@ -37,12 +37,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -58,12 +58,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -72,12 +72,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -56,12 +56,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -54,12 +54,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -88,12 +88,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -46,12 +46,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
| @@ -59,7 +63,7 @@ To use the bridge, you need to start a chat with `@twitterbot:example.com` (wher | |||||||
|  |  | ||||||
| You can then follow instructions on the bridge's [official documentation on Authentication](https://docs.mau.fi/bridges/go/twitter/authentication.html). | You can then follow instructions on the bridge's [official documentation on Authentication](https://docs.mau.fi/bridges/go/twitter/authentication.html). | ||||||
|  |  | ||||||
| After logging in, the bridge will create portal rooms for recent chats. Portal rooms for other chats will be created as you receive messages. | After logging in, the bridge will create portal rooms for some recent chats. Portal rooms for other chats will be created as you receive messages. | ||||||
|  |  | ||||||
| ## Troubleshooting | ## Troubleshooting | ||||||
|  |  | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ SPDX-FileCopyrightText: 2022 Dennis Ciba | |||||||
| SPDX-FileCopyrightText: 2022 Marko Weltzer | SPDX-FileCopyrightText: 2022 Marko Weltzer | ||||||
| SPDX-FileCopyrightText: 2023 James Collier | SPDX-FileCopyrightText: 2023 James Collier | ||||||
| SPDX-FileCopyrightText: 2023 Kuba Orlik | SPDX-FileCopyrightText: 2023 Kuba Orlik | ||||||
| SPDX-FileCopyrightText: 2024 - 2025 Suguru Hirahara | SPDX-FileCopyrightText: 2024 Suguru Hirahara | ||||||
|  |  | ||||||
| SPDX-License-Identifier: AGPL-3.0-or-later | SPDX-License-Identifier: AGPL-3.0-or-later | ||||||
| --> | --> | ||||||
| @@ -49,12 +49,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -61,16 +61,20 @@ After configuring the playbook and potentially [adjusting your DNS records](#adj | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
| Follow the [mautrix-imessage documentation](https://docs.mau.fi/bridges/go/imessage/index.html) for running `android-sms` and/or `matrix-imessage` on your device(s). | Follow the [mautrix-imessage documenation](https://docs.mau.fi/bridges/go/imessage/index.html) for running `android-sms` and/or `matrix-imessage` on your device(s). | ||||||
|  |  | ||||||
| ## Troubleshooting | ## Troubleshooting | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ | |||||||
| SPDX-FileCopyrightText: 2020 - 2022 Slavi Pantaleev | SPDX-FileCopyrightText: 2020 - 2022 Slavi Pantaleev | ||||||
| SPDX-FileCopyrightText: 2020 Hugues Morisset | SPDX-FileCopyrightText: 2020 Hugues Morisset | ||||||
| SPDX-FileCopyrightText: 2022 MDAD project contributors | SPDX-FileCopyrightText: 2022 MDAD project contributors | ||||||
| SPDX-FileCopyrightText: 2024 - 2025 Suguru Hirahara | SPDX-FileCopyrightText: 2024 Suguru Hirahara | ||||||
|  |  | ||||||
| SPDX-License-Identifier: AGPL-3.0-or-later | SPDX-License-Identifier: AGPL-3.0-or-later | ||||||
| --> | --> | ||||||
| @@ -10,7 +10,7 @@ SPDX-License-Identifier: AGPL-3.0-or-later | |||||||
| # Setting up MX Puppet Discord bridging (optional) | # Setting up MX Puppet Discord bridging (optional) | ||||||
|  |  | ||||||
| **Note**: bridging to [Discord](https://discordapp.com/) can also happen via the [matrix-appservice-discord](configuring-playbook-bridge-appservice-discord.md)and [mautrix-discord](configuring-playbook-bridge-mautrix-discord.md) bridges supported by the playbook. | **Note**: bridging to [Discord](https://discordapp.com/) can also happen via the [matrix-appservice-discord](configuring-playbook-bridge-appservice-discord.md)and [mautrix-discord](configuring-playbook-bridge-mautrix-discord.md) bridges supported by the playbook. | ||||||
| - For using as a Bot we recommend the [Appservice Discord](configuring-playbook-bridge-appservice-discord.md), because it supports plumbing. | - For using as a Bot we recommend the [Appservice Discord](configuring-playbook-bridge-appservice-discord.md), because it supports plumbing.   | ||||||
| - For personal use with a discord account we recommend the [mautrix-discord](configuring-playbook-bridge-mautrix-discord.md) bridge, because it is the most fully-featured and stable of the 3 Discord bridges supported by the playbook. | - For personal use with a discord account we recommend the [mautrix-discord](configuring-playbook-bridge-mautrix-discord.md) bridge, because it is the most fully-featured and stable of the 3 Discord bridges supported by the playbook. | ||||||
|  |  | ||||||
| The playbook can install and configure [mx-puppet-discord](https://gitlab.com/mx-puppet/discord/mx-puppet-discord) for you. | The playbook can install and configure [mx-puppet-discord](https://gitlab.com/mx-puppet/discord/mx-puppet-discord) for you. | ||||||
| @@ -31,12 +31,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,7 +2,7 @@ | |||||||
| SPDX-FileCopyrightText: 2021 Cody Neiman | SPDX-FileCopyrightText: 2021 Cody Neiman | ||||||
| SPDX-FileCopyrightText: 2021 Slavi Pantaleev | SPDX-FileCopyrightText: 2021 Slavi Pantaleev | ||||||
| SPDX-FileCopyrightText: 2022 Cody Wyatt Neiman | SPDX-FileCopyrightText: 2022 Cody Wyatt Neiman | ||||||
| SPDX-FileCopyrightText: 2024 - 2025 Suguru Hirahara | SPDX-FileCopyrightText: 2024 Suguru Hirahara | ||||||
|  |  | ||||||
| SPDX-License-Identifier: AGPL-3.0-or-later | SPDX-License-Identifier: AGPL-3.0-or-later | ||||||
| --> | --> | ||||||
| @@ -27,12 +27,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| <!-- | <!-- | ||||||
| SPDX-FileCopyrightText: 2021 MDAD project contributors | SPDX-FileCopyrightText: 2021 MDAD project contributors | ||||||
| SPDX-FileCopyrightText: 2024 - 2025 Suguru Hirahara | SPDX-FileCopyrightText: 2024 Suguru Hirahara | ||||||
|  |  | ||||||
| SPDX-License-Identifier: AGPL-3.0-or-later | SPDX-License-Identifier: AGPL-3.0-or-later | ||||||
| --> | --> | ||||||
| @@ -25,12 +25,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ SPDX-FileCopyrightText: 2020 Rodrigo Belem | |||||||
| SPDX-FileCopyrightText: 2021 Marcel Ackermann | SPDX-FileCopyrightText: 2021 Marcel Ackermann | ||||||
| SPDX-FileCopyrightText: 2022 Jim Myhrberg | SPDX-FileCopyrightText: 2022 Jim Myhrberg | ||||||
| SPDX-FileCopyrightText: 2022 Nikita Chernyi | SPDX-FileCopyrightText: 2022 Nikita Chernyi | ||||||
| SPDX-FileCopyrightText: 2024 - 2025 Suguru Hirahara | SPDX-FileCopyrightText: 2024 Suguru Hirahara | ||||||
|  |  | ||||||
| SPDX-License-Identifier: AGPL-3.0-or-later | SPDX-License-Identifier: AGPL-3.0-or-later | ||||||
| --> | --> | ||||||
| @@ -38,12 +38,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2,14 +2,12 @@ | |||||||
| SPDX-FileCopyrightText: 2020 - 2021 Slavi Pantaleev | SPDX-FileCopyrightText: 2020 - 2021 Slavi Pantaleev | ||||||
| SPDX-FileCopyrightText: 2020 Hugues Morisset | SPDX-FileCopyrightText: 2020 Hugues Morisset | ||||||
| SPDX-FileCopyrightText: 2020 Panagiotis Vasilopoulos | SPDX-FileCopyrightText: 2020 Panagiotis Vasilopoulos | ||||||
| SPDX-FileCopyrightText: 2024 - 2025 Suguru Hirahara | SPDX-FileCopyrightText: 2024 Suguru Hirahara | ||||||
|  |  | ||||||
| SPDX-License-Identifier: AGPL-3.0-or-later | SPDX-License-Identifier: AGPL-3.0-or-later | ||||||
| --> | --> | ||||||
|  |  | ||||||
| # Setting up MX Puppet Steam bridging (optional, deprecated) | # Setting up MX Puppet Steam bridging (optional) | ||||||
|  |  | ||||||
| **Note**: This bridge has been deprecated in favor of the [matrix-steam-bridge](https://github.com/jasonlaguidice/matrix-steam-bridge) bridge for Steam, which can be [installed using this playbook](configuring-playbook-bridge-steam.md). Consider using that bridge instead of this one. |  | ||||||
|  |  | ||||||
| The playbook can install and configure [mx-puppet-steam](https://github.com/icewind1991/mx-puppet-steam) for you. | The playbook can install and configure [mx-puppet-steam](https://github.com/icewind1991/mx-puppet-steam) for you. | ||||||
|  |  | ||||||
| @@ -29,12 +27,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| <!-- | <!-- | ||||||
| SPDX-FileCopyrightText: 2020 Tulir Asokan | SPDX-FileCopyrightText: 2020 Tulir Asokan | ||||||
| SPDX-FileCopyrightText: 2021 Slavi Pantaleev | SPDX-FileCopyrightText: 2021 Slavi Pantaleev | ||||||
| SPDX-FileCopyrightText: 2024 - 2025 Suguru Hirahara | SPDX-FileCopyrightText: 2024 Suguru Hirahara | ||||||
|  |  | ||||||
| SPDX-License-Identifier: AGPL-3.0-or-later | SPDX-License-Identifier: AGPL-3.0-or-later | ||||||
| --> | --> | ||||||
| @@ -37,12 +37,16 @@ After configuring the playbook, run it with [playbook tags](playbook-tags.md) as | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,48 +0,0 @@ | |||||||
| <!-- |  | ||||||
| SPDX-FileCopyrightText: 2025 Jason LaGuidice |  | ||||||
|  |  | ||||||
| SPDX-License-Identifier: AGPL-3.0-or-later |  | ||||||
| --> |  | ||||||
|  |  | ||||||
| # Setting up Steam bridging (optional) |  | ||||||
|  |  | ||||||
| The playbook can install and configure [matrix-steam-bridge](https://github.com/jasonlaguidice/matrix-steam-bridge) for you. |  | ||||||
|  |  | ||||||
| See the project's [documentation](https://github.com/jasonlaguidice/matrix-steam-bridge/blob/main/README.md) to learn what it does and why it might be useful to you. |  | ||||||
|  |  | ||||||
| ## Adjusting the playbook configuration |  | ||||||
|  |  | ||||||
| To enable the [Steam](https://steampowered.com/) bridge, add the following configuration to your `inventory/host_vars/matrix.example.com/vars.yml` file: |  | ||||||
|  |  | ||||||
| ```yaml |  | ||||||
| matrix_steam_bridge_enabled: true |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## Installing |  | ||||||
|  |  | ||||||
| After configuring the playbook, run it with [playbook tags](playbook-tags.md) as below: |  | ||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> |  | ||||||
| ```sh |  | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` and `just setup-all` |  | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. |  | ||||||
|  |  | ||||||
| The tag for `just` commands for this bridge is `matrix-steam-bridge` - for example: `just install-service matrix-steam-bridge` |  | ||||||
|  |  | ||||||
| ## Usage |  | ||||||
|  |  | ||||||
| To use the bridge, you need to start a chat with `Steam bridge bot` with the handle `@steambot:example.com` (where `example.com` is your base domain, not the `matrix.` domain). |  | ||||||
|  |  | ||||||
| The bridge supports QR code and password-based login as well as SteamGuard codes via app, SMS, or e-mail. See matrix-steam-bridge [documentation](https://github.com/jasonlaguidice/matrix-steam-bridge) for more information about how to configure the bridge. |  | ||||||
|  |  | ||||||
| To login, send `login [flow ID]` where possible flow IDs are `password` or `qr` |  | ||||||
|  |  | ||||||
| Once logged in, send `search [name]` to search through recognized Steam friends. You can send a user name, display name, or all forms of Steam ID. Send `start-chat [identifier]` to request the bridge bot to open a chat room with a user. |  | ||||||
|  |  | ||||||
| Chat rooms will automatically be opened as new messages are received. |  | ||||||
|  |  | ||||||
| Send `help` to the bot to see the available commands. |  | ||||||
| @@ -2,7 +2,7 @@ | |||||||
| SPDX-FileCopyrightText: 2022 - 2024 Slavi Pantaleev | SPDX-FileCopyrightText: 2022 - 2024 Slavi Pantaleev | ||||||
| SPDX-FileCopyrightText: 2022 Julian-Samuel Gebühr | SPDX-FileCopyrightText: 2022 Julian-Samuel Gebühr | ||||||
| SPDX-FileCopyrightText: 2023 MDAD project contributors | SPDX-FileCopyrightText: 2023 MDAD project contributors | ||||||
| SPDX-FileCopyrightText: 2024 - 2025 Suguru Hirahara | SPDX-FileCopyrightText: 2024 Suguru Hirahara | ||||||
|  |  | ||||||
| SPDX-License-Identifier: AGPL-3.0-or-later | SPDX-License-Identifier: AGPL-3.0-or-later | ||||||
| --> | --> | ||||||
| @@ -86,12 +86,16 @@ After configuring the playbook and potentially [adjusting your DNS records](#adj | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the bot's user account. | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -65,7 +65,6 @@ Find the `registration.yaml` in the `/matrix` directory, for example `/matrix/ma | |||||||
|     ``` |     ``` | ||||||
|     as_token: <token> |     as_token: <token> | ||||||
|     de.sorunome.msc2409.push_ephemeral: true |     de.sorunome.msc2409.push_ephemeral: true | ||||||
|     receive_ephemeral: true |  | ||||||
|     hs_token: <token> |     hs_token: <token> | ||||||
|     id: signal |     id: signal | ||||||
|     namespaces: |     namespaces: | ||||||
|   | |||||||
| @@ -18,7 +18,6 @@ By default, the playbook installs [Synapse](https://github.com/element-hq/synaps | |||||||
| > [!WARNING] | > [!WARNING] | ||||||
| > - **You can't switch an existing Matrix server's implementation** (e.g. Synapse -> conduwuit). Proceed below only if you're OK with losing data or you're dealing with a server on a new domain name, which hasn't participated in the Matrix federation yet. | > - **You can't switch an existing Matrix server's implementation** (e.g. Synapse -> conduwuit). Proceed below only if you're OK with losing data or you're dealing with a server on a new domain name, which hasn't participated in the Matrix federation yet. | ||||||
| > - **Homeserver implementations other than Synapse may not be fully functional**. The playbook may also not assist you in an optimal way (like it does with Synapse). Make yourself familiar with the downsides before proceeding | > - **Homeserver implementations other than Synapse may not be fully functional**. The playbook may also not assist you in an optimal way (like it does with Synapse). Make yourself familiar with the downsides before proceeding | ||||||
| > - **the Conduwuit project appears to have been abandoned**. You may wish to install [Conduit](./configuring-playbook-conduit.md), or one of the Conduwuit successors (like [Continuwuity](configuring-playbook-continuwuity.md)) |  | ||||||
|  |  | ||||||
| ## Adjusting the playbook configuration | ## Adjusting the playbook configuration | ||||||
|  |  | ||||||
| @@ -84,7 +83,6 @@ Then, send its content to the existing admin room: | |||||||
|     ``` |     ``` | ||||||
|     as_token: <token> |     as_token: <token> | ||||||
|     de.sorunome.msc2409.push_ephemeral: true |     de.sorunome.msc2409.push_ephemeral: true | ||||||
|     receive_ephemeral: true |  | ||||||
|     hs_token: <token> |     hs_token: <token> | ||||||
|     id: signal |     id: signal | ||||||
|     namespaces: |     namespaces: | ||||||
|   | |||||||
| @@ -1,117 +0,0 @@ | |||||||
| <!-- |  | ||||||
| SPDX-FileCopyrightText: 2025 Slavi Pantaleev |  | ||||||
| SPDX-FileCopyrightText: 2025 Suguru Hirahara |  | ||||||
|  |  | ||||||
| SPDX-License-Identifier: AGPL-3.0-or-later |  | ||||||
| --> |  | ||||||
|  |  | ||||||
| # Configuring Continuwuity (optional) |  | ||||||
|  |  | ||||||
| The playbook can install and configure the [Continuwuity](https://continuwuity.org) Matrix server for you. |  | ||||||
|  |  | ||||||
| See the project's [documentation](https://continuwuity.org) to learn what it does and why it might be useful to you. |  | ||||||
|  |  | ||||||
| By default, the playbook installs [Synapse](https://github.com/element-hq/synapse) as it's the only full-featured Matrix server at the moment. If that's okay, you can skip this document. |  | ||||||
|  |  | ||||||
| 💡 **Note**: continuwuity is a fork of [conduwuit](./configuring-playbook-conduwuit.md), which the playbook also supports. |  | ||||||
|  |  | ||||||
| > [!WARNING] |  | ||||||
| > - **You can't switch an existing Matrix server's implementation** (e.g. Synapse -> Continuwuity). Proceed below only if you're OK with losing data or you're dealing with a server on a new domain name, which hasn't participated in the Matrix federation yet. |  | ||||||
| > - **Homeserver implementations other than Synapse may not be fully functional**. The playbook may also not assist you in an optimal way (like it does with Synapse). Make yourself familiar with the downsides before proceeding |  | ||||||
|  |  | ||||||
| ## Adjusting the playbook configuration |  | ||||||
|  |  | ||||||
| To use Continuwuity, you **generally** need to adjust the `matrix_homeserver_implementation: synapse` configuration on your `inventory/host_vars/matrix.example.com/vars.yml` file as below: |  | ||||||
|  |  | ||||||
| ```yaml |  | ||||||
| matrix_homeserver_implementation: continuwuity |  | ||||||
|  |  | ||||||
| # Registering users can only happen via the API, |  | ||||||
| # so it makes sense to enable it, at least initially. |  | ||||||
| matrix_continuwuity_config_allow_registration: true |  | ||||||
|  |  | ||||||
| # Generate a strong registration token to protect the registration endpoint from abuse. |  | ||||||
| # You can create one with a command like `pwgen -s 64 1`. |  | ||||||
| matrix_continuwuity_config_registration_token: '' |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ### Extending the configuration |  | ||||||
|  |  | ||||||
| There are some additional things you may wish to configure about the server. |  | ||||||
|  |  | ||||||
| Take a look at: |  | ||||||
|  |  | ||||||
| - `roles/custom/matrix-continuwuity/defaults/main.yml` for some variables that you can customize via your `vars.yml` file |  | ||||||
| - `roles/custom/matrix-continuwuity/templates/continuwuity.toml.j2` for the server's default configuration |  | ||||||
|  |  | ||||||
| There are various Ansible variables that control settings in the `continuwuity.toml` file. |  | ||||||
|  |  | ||||||
| If a specific setting you'd like to change does not have a dedicated Ansible variable, you can either submit a PR to us to add it, or you can [override the setting using an environment variable](https://continuwuity.org/configuration#environment-variables) using `matrix_continuwuity_environment_variables_extension`. For example: |  | ||||||
|  |  | ||||||
| ```yaml |  | ||||||
| matrix_continuwuity_environment_variables_extension: | |  | ||||||
|   CONTINUWUITY_MAX_REQUEST_SIZE=50000000 |  | ||||||
|   CONTINUWUITY_REQUEST_TIMEOUT=60 |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## Creating the first user account |  | ||||||
|  |  | ||||||
| Unlike other homeserver implementations (like Synapse and Dendrite), continuwuity does not support creating users via the command line or via the playbook. |  | ||||||
|  |  | ||||||
| If you followed the instructions above (see [Adjusting the playbook configuration](#adjusting-the-playbook-configuration)), you should have registration enabled and protected by a registration token. |  | ||||||
|  |  | ||||||
| This should allow you to create the first user account via any client (like [Element Web](./configuring-playbook-client-element-web.md)) which supports creating users. |  | ||||||
|  |  | ||||||
| The **first user account that you create will be marked as an admin** and **will be automatically invited to an admin room**. |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ## Configuring bridges / appservices |  | ||||||
|  |  | ||||||
| For other homeserver implementations (like Synapse and Dendrite), the playbook automatically registers appservices (for bridges, bots, etc.) with the homeserver. |  | ||||||
|  |  | ||||||
| For continuwuity, you will have to manually register appservices using the [`!admin appservices register` command](https://continuwuity.org/appservices.html#set-up-the-appservice---general-instructions) sent to the server bot account. |  | ||||||
|  |  | ||||||
| The server's bot account has a Matrix ID of `@conduit:example.com` (not `@continuwuity:example.com`!) due to continuwuity's historical legacy. |  | ||||||
| Your first user account would already have been invited to an admin room with this bot. |  | ||||||
|  |  | ||||||
| Find the appservice file you'd like to register. This can be any `registration.yaml` file found in the `/matrix` directory, for example `/matrix/mautrix-signal/bridge/registration.yaml`. |  | ||||||
|  |  | ||||||
| Then, send its content to the existing admin room: |  | ||||||
|  |  | ||||||
|     !admin appservices register |  | ||||||
|  |  | ||||||
|     ``` |  | ||||||
|     as_token: <token> |  | ||||||
|     de.sorunome.msc2409.push_ephemeral: true |  | ||||||
|     receive_ephemeral: true |  | ||||||
|     hs_token: <token> |  | ||||||
|     id: signal |  | ||||||
|     namespaces: |  | ||||||
|       aliases: |  | ||||||
|       - exclusive: true |  | ||||||
|         regex: ^#signal_.+:example\.org$ |  | ||||||
|       users: |  | ||||||
|       - exclusive: true |  | ||||||
|         regex: ^@signal_.+:example\.org$ |  | ||||||
|       - exclusive: true |  | ||||||
|         regex: ^@signalbot:example\.org$ |  | ||||||
|     rate_limited: false |  | ||||||
|     sender_localpart: _bot_signalbot |  | ||||||
|     url: http://matrix-mautrix-signal:29328 |  | ||||||
|     ``` |  | ||||||
|  |  | ||||||
| ## Migrating from conduwuit |  | ||||||
|  |  | ||||||
| Since Continuwuity is a drop-in replacement for [conduwuit](configuring-playbook-conduwuit.md), migration is possible. |  | ||||||
|  |  | ||||||
| 1. Make sure that Continuwuity is properly set up on your `vars.yml` as described above |  | ||||||
|  |  | ||||||
| 2. Make sure that Conduwuit references are removed from your `vars.yml` file |  | ||||||
|  |  | ||||||
| 3. Run the installation in a way that installs new services and uninstalls old ones (e.g. `just setup-all`) |  | ||||||
|  |  | ||||||
| 4. Run the playbook with the `continuwuity-migrate-from-conduwuit` tag (e.g. `just run-tags continuwuity-migrate-from-conduwuit`). This migrates data from `/matrix/conduwuit` to `/matrix/continuwuity` |  | ||||||
|  |  | ||||||
| ## Troubleshooting |  | ||||||
|  |  | ||||||
| As with all other services, you can find the logs in [systemd-journald](https://www.freedesktop.org/software/systemd/man/systemd-journald.service.html) by logging in to the server with SSH and running `journalctl -fu matrix-continuwuity`. |  | ||||||
| @@ -14,7 +14,7 @@ Most cloud providers / ISPs will charge you extra for a static IP address. If yo | |||||||
|  |  | ||||||
| ## Prerequisite | ## Prerequisite | ||||||
|  |  | ||||||
| You'll need to authenticate with your DNS provider somehow, in most cases this is simply a username and password but can differ from provider to provider. Please consult with your providers documentation and the upstream [ddclient documentation](https://github.com/ddclient/ddclient/blob/main/ddclient.conf.in) to determine what you'll need to provide to authenticate. | You'll need to get a username and password from your DNS provider. Please consult with the provider about how to retrieve them. | ||||||
|  |  | ||||||
| ## Adjusting the playbook configuration | ## Adjusting the playbook configuration | ||||||
|  |  | ||||||
| @@ -31,8 +31,6 @@ matrix_dynamic_dns_domain_configurations: | |||||||
|     domain: "{{ matrix_domain }}" |     domain: "{{ matrix_domain }}" | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Keep in mind that certain providers may require a different configuration of the `matrix_dynamic_dns_domain_configurations` variable, for provider specific examples see the [upstream documentation](https://github.com/ddclient/ddclient/blob/main/ddclient.conf.in). |  | ||||||
|  |  | ||||||
| ### Extending the configuration | ### Extending the configuration | ||||||
|  |  | ||||||
| There are some additional things you may wish to configure about the component. | There are some additional things you may wish to configure about the component. | ||||||
| @@ -59,8 +57,7 @@ The shortcut commands with the [`just` program](just.md) are also available: `ju | |||||||
| Additional resources: | Additional resources: | ||||||
|  |  | ||||||
| - https://matrix.org/docs/guides/free-small-matrix-server | - https://matrix.org/docs/guides/free-small-matrix-server | ||||||
| - https://github.com/linuxserver/docker-ddclient |  | ||||||
|  |  | ||||||
| ## Troubleshooting | ## Troubleshooting | ||||||
|  |  | ||||||
| As with all other services, you can find the logs in [systemd-journald](https://www.freedesktop.org/software/systemd/man/systemd-journald.service.html) by logging in to the server with SSH and running `journalctl -fu matrix-dynamic-dns`. However, due to an [upstream issue](https://github.com/linuxserver/docker-ddclient/issues/54#issuecomment-1153143132) the logging output is not always complete. For advanced debugging purposes running the `ddclient` tool outside of the container is useful via the following: `ddclient -file ./ddclient.conf -daemon=0 -debug -verbose -noquiet`. | As with all other services, you can find the logs in [systemd-journald](https://www.freedesktop.org/software/systemd/man/systemd-journald.service.html) by logging in to the server with SSH and running `journalctl -fu matrix-dynamic-dns`. | ||||||
|   | |||||||
| @@ -1,67 +0,0 @@ | |||||||
| <!-- |  | ||||||
| SPDX-FileCopyrightText: 2024 wjbeckett |  | ||||||
| SPDX-FileCopyrightText: 2024 - 2025 Slavi Pantaleev |  | ||||||
|  |  | ||||||
| SPDX-License-Identifier: AGPL-3.0-or-later |  | ||||||
| --> |  | ||||||
|  |  | ||||||
| # Setting up Element Admin (optional) |  | ||||||
|  |  | ||||||
| The playbook can install and configure [Element Admin](https://github.com/element-hq/element-admin) for you. |  | ||||||
|  |  | ||||||
| Element Admin is a web-based administration panel for Synapse and [Matrix Authentication Service](./configuring-playbook-matrix-authentication-service.md). |  | ||||||
|  |  | ||||||
| See the project's [documentation](https://github.com/element-hq/element-admin) to learn more. |  | ||||||
|  |  | ||||||
| 💡 **Note**: This project is still very young and doesn't have many features. For now, it's recommended to use [Synapse Admin](./configuring-playbook-synapse-admin.md) instead. Deployments that use [Matrix Authentication Service](./configuring-playbook-matrix-authentication-service.md) can use Element Admin for user-management (something that Synapse Admin can't do), while continuing to use Synapse Admin for all other purposes. |  | ||||||
|  |  | ||||||
| ## Prerequisites |  | ||||||
|  |  | ||||||
| - A [Synapse](configuring-playbook-synapse.md) homeserver with its Admin API enabled (the playbook automatically enables it for you when you enable Element Admin) |  | ||||||
| - [Matrix Authentication Service](./configuring-playbook-matrix-authentication-service.md) with its Admin API enabled (the playbook automatically enables it for you when you enable Element Admin) |  | ||||||
|  |  | ||||||
| ## Decide on a domain and path |  | ||||||
|  |  | ||||||
| By default, the Element Admin is configured to be served on the `admin.element.example.com` domain. |  | ||||||
|  |  | ||||||
| If you'd like to run Element Admin on another hostname, see the [Adjusting the Element Admin URL](#adjusting-the-element-admin-url-optional) section below. |  | ||||||
|  |  | ||||||
| ## Adjusting DNS records (optional) |  | ||||||
|  |  | ||||||
| By default, this playbook installs Element Admin on the `admin.element.` subdomain (`admin.element.example.com`) and requires you to create a `CNAME` record for `admin.element`, which targets `matrix.example.com`. |  | ||||||
|  |  | ||||||
| When setting these values, replace `example.com` with your own. |  | ||||||
|  |  | ||||||
| ## Adjusting the playbook configuration |  | ||||||
|  |  | ||||||
| Add the following configuration to your `inventory/host_vars/matrix.example.com/vars.yml` file: |  | ||||||
|  |  | ||||||
| ```yaml |  | ||||||
| matrix_element_admin_enabled: true |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ### Adjusting the Element Admin URL (optional) |  | ||||||
|  |  | ||||||
| By tweaking the `matrix_element_admin_hostname` variable, you can easily make the service available at a **different hostname** than the default one. |  | ||||||
|  |  | ||||||
| Example additional configuration for your `vars.yml` file: |  | ||||||
|  |  | ||||||
| ```yaml |  | ||||||
| matrix_element_admin_hostname: element-admin.example.com |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| > [!WARNING] |  | ||||||
| > A `matrix_element_admin_path_prefix` variable is also available and mean to let you configure a path prefix for the Element Admin service, but **Element Admin does not support running under a sub-path yet**. |  | ||||||
|  |  | ||||||
| ## Installing |  | ||||||
|  |  | ||||||
| After configuring the playbook and potentially [adjusting your DNS records](#adjusting-dns-records), run the playbook with [playbook tags](playbook-tags.md) as below: |  | ||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> |  | ||||||
| ```sh |  | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` |  | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. |  | ||||||
| @@ -7,7 +7,7 @@ SPDX-License-Identifier: AGPL-3.0-or-later | |||||||
|  |  | ||||||
| # Setting up Element Call (optional) | # Setting up Element Call (optional) | ||||||
|  |  | ||||||
| The playbook can install and configure [Element Call](https://github.com/element-hq/element-call) and its supporting components that are part of the [Matrix RTC stack](configuring-playbook-matrix-rtc.md). | The playbook can install and configure [Element Call](https://github.com/element-hq/element-call) for you. | ||||||
|  |  | ||||||
| Element Call is a native Matrix video conferencing application developed by [Element](https://element.io), designed for secure, scalable, privacy-respecting, and decentralized video and voice calls over the Matrix protocol. Built on MatrixRTC ([MSC4143](https://github.com/matrix-org/matrix-spec-proposals/pull/4143)), it utilizes [MSC4195](https://github.com/hughns/matrix-spec-proposals/blob/hughns/matrixrtc-livekit/proposals/4195-matrixrtc-livekit.md) with [LiveKit Server](configuring-playbook-livekit-server.md) as its backend. | Element Call is a native Matrix video conferencing application developed by [Element](https://element.io), designed for secure, scalable, privacy-respecting, and decentralized video and voice calls over the Matrix protocol. Built on MatrixRTC ([MSC4143](https://github.com/matrix-org/matrix-spec-proposals/pull/4143)), it utilizes [MSC4195](https://github.com/hughns/matrix-spec-proposals/blob/hughns/matrixrtc-livekit/proposals/4195-matrixrtc-livekit.md) with [LiveKit Server](configuring-playbook-livekit-server.md) as its backend. | ||||||
|  |  | ||||||
| @@ -16,34 +16,18 @@ See the project's [documentation](https://github.com/element-hq/element-call) to | |||||||
| ## Prerequisites | ## Prerequisites | ||||||
|  |  | ||||||
| - A [Synapse](configuring-playbook-synapse.md) homeserver (see the warning below) | - A [Synapse](configuring-playbook-synapse.md) homeserver (see the warning below) | ||||||
| - The [Matrix RTC (Real-Time Communication) stack](configuring-playbook-matrix-rtc.md) (automatically done when Element Call is enabled) | - [Federation](configuring-playbook-federation.md) being enabled for your Matrix homeserver (federation is enabled by default, unless you've explicitly disabled it), because [LiveKit JWT Service](configuring-playbook-livekit-jwt-service.md) currently [requires it](https://github.com/spantaleev/matrix-docker-ansible-deploy/pull/3562#issuecomment-2725250554) ([relevant source code](https://github.com/element-hq/lk-jwt-service/blob/f5f5374c4bdcc00a4fb13d27c0b28e20e4c62334/main.go#L135-L146)) | ||||||
|  | - Various experimental features for the Synapse homeserver which Element Call [requires](https://github.com/element-hq/element-call/blob/93ae2aed9841e0b066d515c56bd4c122d2b591b2/docs/self-hosting.md#a-matrix-homeserver) (automatically done when Element Call is enabled) | ||||||
|  | - A [LiveKit Server](configuring-playbook-livekit-server.md) (automatically installed when Element Call is enabled) | ||||||
|  | - The [LiveKit JWT Service](configuring-playbook-livekit-jwt-service.md) (automatically installed when Element Call is enabled) | ||||||
| - A client compatible with Element Call. As of 2025-03-15, that's just [Element Web](configuring-playbook-client-element-web.md) and the Element X mobile clients (iOS and Android). | - A client compatible with Element Call. As of 2025-03-15, that's just [Element Web](configuring-playbook-client-element-web.md) and the Element X mobile clients (iOS and Android). | ||||||
| - (Optional) Guest accounts being enabled for your Matrix server, if you'd like guests to be able to use Element Call. See [Allowing guests to use Element Call](#allowing-guests-to-use-element-call-optional) |  | ||||||
|  |  | ||||||
| > [!WARNING] | > [!WARNING] | ||||||
| >  Because Element Call [requires](https://github.com/element-hq/element-call/blob/93ae2aed9841e0b066d515c56bd4c122d2b591b2/docs/self-hosting.md#a-matrix-homeserver) a few experimental features in the Matrix protocol, it's **very likely that it only works with the Synapse homeserver**. | >  Because Element Call [requires](https://github.com/element-hq/element-call/blob/93ae2aed9841e0b066d515c56bd4c122d2b591b2/docs/self-hosting.md#a-matrix-homeserver) a few experimental features in the Matrix protocol, it's **very likely that it only works with the Synapse homeserver**. | ||||||
|  |  | ||||||
| ## Decide between Element Call vs just the Matrix RTC stack |  | ||||||
|  |  | ||||||
| All clients that can currently use Element Call (Element Web and Element X on mobile) already embed the Element Call frontend within them. |  | ||||||
| These **clients will use their own embedded Element Call frontend**, so **self-hosting the Element Call frontend by the playbook is largely unnecessary**. |  | ||||||
|  |  | ||||||
| 💡 A reason you may wish to continue installing the Element Call frontend (despite Matrix clients not making use of it), is if you need to use it standalone - directly via a browser (without a Matrix client). Note that unless you [allow guest accounts to use Element Call](#allowing-guests-to-use-element-call-optional), you will still need a Matrix user account **on the same homeserver** to be able to use Element Call. |  | ||||||
|  |  | ||||||
| The playbook makes a distinction between enabling Element Call (`matrix_element_call_enabled`) and enabling the Matrix RTC Stack (`matrix_rtc_enabled`). Enabling Element Call automatically enables the Matrix RTC stack. Because installing the Element Call frontend is now unnecessary, **we recommend only installing the Matrix RTC stack, without the Element Call frontend**. |  | ||||||
|  |  | ||||||
| | Description / Variable | Element Call frontend | [LiveKit Server](configuring-playbook-livekit-server.md) | [LiveKit JWT Service](configuring-playbook-livekit-jwt-service.md) | |  | ||||||
| |------------------------|-----------------------|----------------|---------------------| |  | ||||||
| | Description | Static website that provides the Element Call UI (but often embedded by clients) | Scalable, multi-user conferencing solution based on WebRTC | A helper component that allows Element Call to integrate with LiveKit Server | |  | ||||||
| | Required for Element Call to function | No | Yes | Yes | |  | ||||||
| | `matrix_element_call_enabled` | ✅ Installed | ✅ Installed | ✅ Installed | |  | ||||||
| | `matrix_rtc_enabled` | ❌ Not Installed, but usually unnecessary | ✅ Installed | ✅ Installed | |  | ||||||
|  |  | ||||||
| All documentation below assumes that you've decided to install Element Call and not just the Matrix RTC stack. |  | ||||||
|  |  | ||||||
| ## Decide on a domain and path | ## Decide on a domain and path | ||||||
|  |  | ||||||
| By default, the Element Call frontend is configured to be served on the `call.element.example.com` domain. | By default, Element Call is configured to be served on the `call.element.example.com` domain. | ||||||
|  |  | ||||||
| If you'd like to run Element Call on another hostname, see the [Adjusting the Element Call URL](#adjusting-the-element-call-url-optional) section below. | If you'd like to run Element Call on another hostname, see the [Adjusting the Element Call URL](#adjusting-the-element-call-url-optional) section below. | ||||||
|  |  | ||||||
| @@ -64,8 +48,6 @@ In addition to the HTTP/HTTPS ports (which you've already exposed as per the [pr | |||||||
| Add the following configuration to your `inventory/host_vars/matrix.example.com/vars.yml` file: | Add the following configuration to your `inventory/host_vars/matrix.example.com/vars.yml` file: | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| # Enable the Element Call frontend UI to allow standalone use of Element Call. |  | ||||||
| # Enabling this also auto-enables the Matrix RTC stack. |  | ||||||
| matrix_element_call_enabled: true | matrix_element_call_enabled: true | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| @@ -82,28 +64,6 @@ matrix_element_call_hostname: element-call.example.com | |||||||
| > [!WARNING] | > [!WARNING] | ||||||
| > A `matrix_element_call_path_prefix` variable is also available and mean to let you configure a path prefix for the Element Call service, but [Element Call does not support running under a sub-path yet](https://github.com/element-hq/element-call/issues/3084). | > A `matrix_element_call_path_prefix` variable is also available and mean to let you configure a path prefix for the Element Call service, but [Element Call does not support running under a sub-path yet](https://github.com/element-hq/element-call/issues/3084). | ||||||
|  |  | ||||||
| ### Allowing guests to use Element Call (optional) |  | ||||||
|  |  | ||||||
| By default, Element Call can only be used by people having accounts on your Matrix server. |  | ||||||
|  |  | ||||||
| If you'd like guests to be able to use Element Call as well, you need to enable guest accounts support for your homeserver. |  | ||||||
|  |  | ||||||
| > [!WARNING] |  | ||||||
| > Enabling guest accounts means that your homeserver's user database may get polluted with guest account signups (potentially made by bots). |  | ||||||
| > Guest accounts should be limited in what (damage) they can do to your server and the rest of the Matrix ecosystem, but it's better to not enable them unless necessary. |  | ||||||
|  |  | ||||||
| For [Synapse](configuring-playbook-synapse.md) (the default homeserver implementation), the configuration is like this: |  | ||||||
|  |  | ||||||
| ```yml |  | ||||||
| matrix_synapse_allow_guest_access: true |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| For [Dendrite](configuring-playbook-dendrite.md), the configuration is like this: |  | ||||||
|  |  | ||||||
| ```yml |  | ||||||
| matrix_dendrite_guests_disabled: false |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## Installing | ## Installing | ||||||
|  |  | ||||||
| After configuring the playbook and potentially [adjusting your DNS records](#adjusting-dns-records) and [adjusting firewall rules](#adjusting-firewall-rules), run the playbook with [playbook tags](playbook-tags.md) as below: | After configuring the playbook and potentially [adjusting your DNS records](#adjusting-dns-records) and [adjusting firewall rules](#adjusting-firewall-rules), run the playbook with [playbook tags](playbook-tags.md) as below: | ||||||
|   | |||||||
| @@ -86,12 +86,16 @@ After configuring the playbook and potentially [adjusting your DNS records](#adj | |||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> | ||||||
| ```sh | ```sh | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | **Notes**: | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. | - The `ensure-matrix-users-created` playbook tag makes the playbook automatically create the Etherpad admin user (`etherpad_admin_username`). | ||||||
|  |  | ||||||
|  | - The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` | ||||||
|  |  | ||||||
|  |   `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. | ||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
|   | |||||||
| @@ -70,7 +70,7 @@ By default the Jitsi Meet instance **does not require for anyone to log in, and | |||||||
|  |  | ||||||
| If you would like to control who is allowed to start meetings on your instance, you'd need to enable Jitsi's authentication and optionally guests mode. | If you would like to control who is allowed to start meetings on your instance, you'd need to enable Jitsi's authentication and optionally guests mode. | ||||||
|  |  | ||||||
| See [this section](https://github.com/mother-of-all-self-hosting/ansible-role-jitsi/blob/main/docs/configuring-jitsi.md#configure-jitsi-authentication-and-guests-mode-optional) on the role's documentation for details about how to configure the authentication and guests mode. The recommended authentication method is `internal` as it also works in federated rooms. If you want to enable authentication with Matrix OpenID making use of [Matrix User Verification Service (UVS)](configuring-playbook-user-verification-service.md), see [here](https://github.com/mother-of-all-self-hosting/ansible-role-jitsi/blob/main/docs/configuring-jitsi.md#authenticate-using-matrix-openid-auth-type-matrix) for details about how to set it up. | See [this section](https://github.com/mother-of-all-self-hosting/ansible-role-jitsi/blob/main/docs/configuring-jitsi.md#configure-jitsi-authentication-and-guests-mode-optional) on the role's documentation for details about how to configure the authentication and guests mode. The recommended authentication method is `internal` as it also works in federated rooms. If you want to enable authentication with Matrix OpenID making use of [Matrix User Verification Service (UVS)](https://github.com/spantaleev/matrix-docker-ansible-deploy/blob/master/docs/configuring-playbook-user-verification-service.md), see [here](https://github.com/mother-of-all-self-hosting/ansible-role-jitsi/blob/main/docs/configuring-jitsi.md#authenticate-using-matrix-openid-auth-type-matrix) for details about how to set it up. | ||||||
|  |  | ||||||
| ### Enable Gravatar (optional) | ### Enable Gravatar (optional) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -8,11 +8,11 @@ SPDX-License-Identifier: AGPL-3.0-or-later | |||||||
|  |  | ||||||
| The playbook can install and configure [LiveKit JWT Service](https://github.com/element-hq/lk-jwt-service/) for you. | The playbook can install and configure [LiveKit JWT Service](https://github.com/element-hq/lk-jwt-service/) for you. | ||||||
|  |  | ||||||
| This is a helper component which is part of the [Matrix RTC stack](configuring-playbook-matrix-rtc.md) that allows [Element Call](configuring-playbook-element-call.md) to integrate with [LiveKit Server](configuring-playbook-livekit-server.md). | This is a helper component that allows [Element Call](configuring-playbook-element-call.md) to integrate with [LiveKit Server](configuring-playbook-livekit-server.md). | ||||||
|  |  | ||||||
| 💡 LiveKit JWT Service is automatically installed and configured when either [Element Call](configuring-playbook-element-call.md) or the [Matrix RTC stack](configuring-playbook-matrix-rtc.md) is enabled, so you don't need to do anything extra. | 💡 LiveKit JWT Service is automatically installed and configured when [Element Call](configuring-playbook-element-call.md) is enabled, so you don't need to do anything extra. | ||||||
|  |  | ||||||
| Take a look at: | Take a look at: | ||||||
|  |  | ||||||
| - `roles/custom/matrix-livekit-jwt-service/defaults/main.yml` for some variables that you can customize via your `vars.yml` file | - `roles/custom/matrix-livekit-jwt-service/defaults/main.yml` for some variables that you can customize via your `vars.yml` file | ||||||
| - `roles/custom/matrix-livekit-jwt-service/templates/env.j2` for the component's default configuration. | - `roles/custom/matrix-livekit-jwt-service/templates/env.j2` for the component's default configuration. | ||||||
| @@ -11,7 +11,7 @@ The playbook can install and configure [LiveKit Server](https://github.com/livek | |||||||
|  |  | ||||||
| LiveKit Server is an open source project that provides scalable, multi-user conferencing based on WebRTC. It's designed to provide everything you need to build real-time video audio data capabilities in your applications. | LiveKit Server is an open source project that provides scalable, multi-user conferencing based on WebRTC. It's designed to provide everything you need to build real-time video audio data capabilities in your applications. | ||||||
|  |  | ||||||
| 💡 LiveKit Server is automatically installed and configured when either [Element Call](configuring-playbook-element-call.md) or the [Matrix RTC stack](configuring-playbook-matrix-rtc.md) is enabled, so you don't need to do anything extra. | 💡 LiveKit Server is automatically installed and configured when [Element Call](configuring-playbook-element-call.md) is enabled, so you don't need to do anything extra. | ||||||
|  |  | ||||||
| The [Ansible role for LiveKit Server](https://github.com/mother-of-all-self-hosting/ansible-role-livekit-server) is developed and maintained by [the MASH (mother-of-all-self-hosting) project](https://github.com/mother-of-all-self-hosting). For details about configuring LiveKit Server, you can check them via: | The [Ansible role for LiveKit Server](https://github.com/mother-of-all-self-hosting/ansible-role-livekit-server) is developed and maintained by [the MASH (mother-of-all-self-hosting) project](https://github.com/mother-of-all-self-hosting). For details about configuring LiveKit Server, you can check them via: | ||||||
| - 🌐 [the role's documentation at the MASH project](https://github.com/mother-of-all-self-hosting/ansible-role-livekit-server/blob/main/docs/configuring-livekit-server.md) online | - 🌐 [the role's documentation at the MASH project](https://github.com/mother-of-all-self-hosting/ansible-role-livekit-server/blob/main/docs/configuring-livekit-server.md) online | ||||||
| @@ -25,14 +25,4 @@ To ensure LiveKit Server functions correctly, the following firewall rules and p | |||||||
|  |  | ||||||
| - `7882/udp`: ICE/UDP Mux | - `7882/udp`: ICE/UDP Mux | ||||||
|  |  | ||||||
| - `3479/udp`: TURN/UDP. Also see the [Limitations](#limitations) section below. |  | ||||||
|  |  | ||||||
| - `5350/tcp`: TURN/TCP. Also see the [Limitations](#limitations) section below. |  | ||||||
|  |  | ||||||
| 💡 The suggestions above are inspired by the upstream [Ports and Firewall](https://docs.livekit.io/home/self-hosting/ports-firewall/) documentation based on how LiveKit is configured in the playbook. If you've using custom configuration for the LiveKit Server role, you may need to adjust the firewall rules accordingly. | 💡 The suggestions above are inspired by the upstream [Ports and Firewall](https://docs.livekit.io/home/self-hosting/ports-firewall/) documentation based on how LiveKit is configured in the playbook. If you've using custom configuration for the LiveKit Server role, you may need to adjust the firewall rules accordingly. | ||||||
|  |  | ||||||
| ## Limitations |  | ||||||
|  |  | ||||||
| For some reason, LiveKit Server's TURN ports (`3479/udp` and `5350/tcp`) are not reachable over IPv6 regardless of whether you've [enabled IPv6](./configuring-ipv6.md) for your server. |  | ||||||
|  |  | ||||||
| It seems like LiveKit Server intentionally only listens on `udp4` and `tcp4` as seen [here](https://github.com/livekit/livekit/blob/154b4d26b769c68a03c096124094b97bf61a996f/pkg/service/turn.go#L128) and [here](https://github.com/livekit/livekit/blob/154b4d26b769c68a03c096124094b97bf61a996f/pkg/service/turn.go#L92). |  | ||||||
|   | |||||||
| @@ -41,7 +41,7 @@ Below, we'll try to **highlight some potential reasons for switching** to Matrix | |||||||
|  |  | ||||||
| ## Prerequisites | ## Prerequisites | ||||||
|  |  | ||||||
| - ⚠️ the [Synapse](configuring-playbook-synapse.md) homeserver implementation (which is the default for this playbook). Other homeserver implementations ([Dendrite](./configuring-playbook-dendrite.md), [Conduit](./configuring-playbook-conduit.md), etc.) do not support integrating with Matrix Authentication Service yet. | - ⚠️ the [Synapse](configuring-playbook-synapse.md) homeserver implementation (which is the default for this playbook). Other homeserver implementations ([Dendrite](./configuring-playbook-dendrite.md), [Conduit](./configuring-playbook-conduit.md), etc.) do not support integrating wtih Matrix Authentication Service yet. | ||||||
|  |  | ||||||
| - ❌ **disabling all password providers** for Synapse (things like [shared-secret-auth](./configuring-playbook-shared-secret-auth.md), [rest-auth](./configuring-playbook-rest-auth.md), [LDAP auth](./configuring-playbook-ldap-auth.md), etc.) More details about this are available in the [Expectations](#expectations) section below. | - ❌ **disabling all password providers** for Synapse (things like [shared-secret-auth](./configuring-playbook-shared-secret-auth.md), [rest-auth](./configuring-playbook-rest-auth.md), [LDAP auth](./configuring-playbook-ldap-auth.md), etc.) More details about this are available in the [Expectations](#expectations) section below. | ||||||
|  |  | ||||||
| @@ -51,17 +51,19 @@ This section details what you can expect when switching to the Matrix Authentica | |||||||
|  |  | ||||||
| - ❌ **Synapse password providers will need to be disabled**. You can no longer use [shared-secret-auth](./configuring-playbook-shared-secret-auth.md), [rest-auth](./configuring-playbook-rest-auth.md), [LDAP auth](./configuring-playbook-ldap-auth.md), etc. When the authentication flow is handled by MAS (not by Synapse anymore), it doesn't make sense to extend the Synapse authentication flow with additional modules. Many bridges used to rely on shared-secret-auth for doing double-puppeting (impersonating other users), but most (at least the mautrix bridges) nowadays use [Appservice Double Puppet](./configuring-playbook-appservice-double-puppet.md) as a better alternative. Older/maintained bridges may still rely on shared-secret-auth, as do other services like [matrix-corporal](./configuring-playbook-matrix-corporal.md). | - ❌ **Synapse password providers will need to be disabled**. You can no longer use [shared-secret-auth](./configuring-playbook-shared-secret-auth.md), [rest-auth](./configuring-playbook-rest-auth.md), [LDAP auth](./configuring-playbook-ldap-auth.md), etc. When the authentication flow is handled by MAS (not by Synapse anymore), it doesn't make sense to extend the Synapse authentication flow with additional modules. Many bridges used to rely on shared-secret-auth for doing double-puppeting (impersonating other users), but most (at least the mautrix bridges) nowadays use [Appservice Double Puppet](./configuring-playbook-appservice-double-puppet.md) as a better alternative. Older/maintained bridges may still rely on shared-secret-auth, as do other services like [matrix-corporal](./configuring-playbook-matrix-corporal.md). | ||||||
|  |  | ||||||
| - ❌ Certain **tools like [synapse-admin](./configuring-playbook-synapse-admin.md) do not have full compatibility with MAS yet**. synapse-admin already supports [login with access token](https://github.com/etkecc/synapse-admin/pull/58), browsing users (which Synapse will internally fetch from MAS) and updating user avatars. However, editing users (passwords, etc.) now needs to happen directly against MAS using the [MAS Admin API](https://element-hq.github.io/matrix-authentication-service/api/index.html), which synapse-admin cannot interact with yet. You may be interested in using [Element Admin](./configuring-playbook-element-admin.md) for these purposes. | - ❌ Certain **tools like [synapse-admin](./configuring-playbook-synapse-admin.md) do not have full compatibility with MAS yet**. synapse-admin already supports [login with access token](https://github.com/etkecc/synapse-admin/pull/58), browsing users (which Synapse will internally fetch from MAS) and updating user avatars. However, editing users (passwords, etc.) now needs to happen directly against MAS using the [MAS Admin API](https://element-hq.github.io/matrix-authentication-service/api/index.html), which synapse-admin cannot interact with yet. | ||||||
|  |  | ||||||
| - ❌ **Some services experience issues when authenticating via MAS**: | - ❌ **Some services experience issues when authenticating via MAS**: | ||||||
|  |  | ||||||
|   - [Reminder bot](configuring-playbook-bot-matrix-reminder-bot.md) seems to be losing some of its state on each restart and may reschedule old reminders once again |   - [Postmoogle](./configuring-playbook-bridge-postmoogle.md) works the first time around, but it consistently fails after restarting: | ||||||
|  |  | ||||||
|  |     > cannot initialize matrix bot error="olm account is marked as shared, keys seem to have disappeared from the server" | ||||||
|  |  | ||||||
| - ❌ **Encrypted appservices** do not work yet (related to [MSC4190](https://github.com/matrix-org/matrix-spec-proposals/pull/4190) and [PR 17705 for Synapse](https://github.com/element-hq/synapse/pull/17705)), so all bridges/bots that rely on encryption will fail to start (see [this issue](https://github.com/spantaleev/matrix-docker-ansible-deploy/issues/3658) for Hookshot). You can use these bridges/bots only if you **keep end-to-bridge encryption disabled** (which is the default setting). | - ❌ **Encrypted appservices** do not work yet (related to [MSC4190](https://github.com/matrix-org/matrix-spec-proposals/pull/4190) and [PR 17705 for Synapse](https://github.com/element-hq/synapse/pull/17705)), so all bridges/bots that rely on encryption will fail to start (see [this issue](https://github.com/spantaleev/matrix-docker-ansible-deploy/issues/3658) for Hookshot). You can use these bridges/bots only if you **keep end-to-bridge encryption disabled** (which is the default setting). | ||||||
|  |  | ||||||
| - ⚠️ [Migrating an existing Synapse homeserver to Matrix Authentication Service](#migrating-an-existing-synapse-homeserver-to-matrix-authentication-service) is **possible**, but requires **some playbook-assisted manual work**. Migration is **reversible with no or minor issues if done quickly enough**, but as users start logging in (creating new login sessions) via the new MAS setup, disabling MAS and reverting back to the Synapse user database will cause these new sessions to break. | - ⚠️ [Migrating an existing Synapse homeserver to Matrix Authentication Service](#migrating-an-existing-synapse-homeserver-to-matrix-authentication-service) is **possible**, but requires **some playbook-assisted manual work**. Migration is **reversible with no or minor issues if done quickly enough**, but as users start logging in (creating new login sessions) via the new MAS setup, disabling MAS and reverting back to the Synapse user database will cause these new sessions to break. | ||||||
|  |  | ||||||
| - ⚠️ Delegating user authentication to MAS causes **your Synapse server to be completely dependent on one more service** for its operations. MAS is quick & lightweight and should be stable enough already, but this is something to keep in mind when making the switch. | - ⚠️ Delegating user authentication to MAS causes **your Synapse server to be completely dependant on one more service** for its operations. MAS is quick & lightweight and should be stable enough already, but this is something to keep in mind when making the switch. | ||||||
|  |  | ||||||
| - ⚠️ If you've got [OIDC configured in Synapse](./configuring-playbook-synapse.md#synapse--openid-connect-for-single-sign-on), you will need to migrate your OIDC configuration to MAS by adding an [Upstream OAuth2 configuration](#upstream-oauth2-configuration). | - ⚠️ If you've got [OIDC configured in Synapse](./configuring-playbook-synapse.md#synapse--openid-connect-for-single-sign-on), you will need to migrate your OIDC configuration to MAS by adding an [Upstream OAuth2 configuration](#upstream-oauth2-configuration). | ||||||
|  |  | ||||||
| @@ -85,7 +87,7 @@ For new homeservers (which don't have any users in their Synapse database yet), | |||||||
|  |  | ||||||
| ### Existing homeserver | ### Existing homeserver | ||||||
|  |  | ||||||
| Other homeserver implementations ([Dendrite](./configuring-playbook-dendrite.md), [Conduit](./configuring-playbook-conduit.md), etc.) do not support integrating with Matrix Authentication Service yet. | Other homeserver implementations ([Dendrite](./configuring-playbook-dendrite.md), [Conduit](./configuring-playbook-conduit.md), etc.) do not support integrating wtih Matrix Authentication Service yet. | ||||||
|  |  | ||||||
| For existing Synapse homeservers: | For existing Synapse homeservers: | ||||||
|  |  | ||||||
| @@ -157,10 +159,6 @@ matrix_authentication_service_config_upstream_oauth2_providers: | |||||||
|   - # A unique identifier for the provider |   - # A unique identifier for the provider | ||||||
|     # Must be a valid ULID |     # Must be a valid ULID | ||||||
|     id: 01HFVBY12TMNTYTBV8W921M5FA |     id: 01HFVBY12TMNTYTBV8W921M5FA | ||||||
|     # This can be set if you're migrating an existing (legacy) Synapse OIDC configuration. |  | ||||||
|     # The value used here would most likely be "oidc" or "oidc-provider". |  | ||||||
|     # See: https://element-hq.github.io/matrix-authentication-service/setup/migration.html#map-any-upstream-sso-providers |  | ||||||
|     synapse_idp_id: null |  | ||||||
|     # The issuer URL, which will be used to discover the provider's configuration. |     # The issuer URL, which will be used to discover the provider's configuration. | ||||||
|     # If discovery is enabled, this *must* exactly match the `issuer` field |     # If discovery is enabled, this *must* exactly match the `issuer` field | ||||||
|     # advertised in `<issuer>/.well-known/openid-configuration`. |     # advertised in `<issuer>/.well-known/openid-configuration`. | ||||||
| @@ -308,7 +306,7 @@ ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start | |||||||
|  |  | ||||||
| Our migration guide is loosely based on the upstream [Migrating an existing homeserver](https://element-hq.github.io/matrix-authentication-service/setup/migration.html) guide. | Our migration guide is loosely based on the upstream [Migrating an existing homeserver](https://element-hq.github.io/matrix-authentication-service/setup/migration.html) guide. | ||||||
|  |  | ||||||
| Migration is done via a sub-command called `syn2mas`, which the playbook could run for you (in a container). | Migration is done via a tool called `syn2mas`, which the playbook could run for you (in a container). | ||||||
|  |  | ||||||
| The installation + migration steps are like this: | The installation + migration steps are like this: | ||||||
|  |  | ||||||
| @@ -324,7 +322,7 @@ The installation + migration steps are like this: | |||||||
|  |  | ||||||
|     - The `matrix-user-creator` role would be suppressed, so that it doesn't automatically attempt to create users (for bots, etc.) in the MAS database. These user accounts likely already exist in Synapse's user database and could be migrated over (via syn2mas, as per the steps below), so creating them in the MAS database would have been unnecessary and potentially problematic (conflicts during the syn2mas migration). |     - The `matrix-user-creator` role would be suppressed, so that it doesn't automatically attempt to create users (for bots, etc.) in the MAS database. These user accounts likely already exist in Synapse's user database and could be migrated over (via syn2mas, as per the steps below), so creating them in the MAS database would have been unnecessary and potentially problematic (conflicts during the syn2mas migration). | ||||||
|  |  | ||||||
| 3. Consider taking a full [backup of your Postgres database](./maintenance-postgres.md#backing-up-postgresql). This is done just in case. The **syn2mas migration command does not delete any data**, so it should be possible to revert to your previous setup by merely disabling MAS and re-running the playbook (no need to restore a Postgres backup). However, do note that as users start logging in (creating new login sessions) via the new MAS setup, disabling MAS and reverting back to the Synapse user database will cause these new sessions to break. | 3. Consider taking a full [backup of your Postgres database](./maintenance-postgres.md#backing-up-postgresql). This is done just in case. The **syn2mas migration tool does not delete any data**, so it should be possible to revert to your previous setup by merely disabling MAS and re-running the playbook (no need to restore a Postgres backup). However, do note that as users start logging in (creating new login sessions) via the new MAS setup, disabling MAS and reverting back to the Synapse user database will cause these new sessions to break. | ||||||
|  |  | ||||||
| 4. [Migrate your data from Synapse to Matrix Authentication Service using syn2mas](#migrate-your-data-from-synapse-to-matrix-authentication-service-using-syn2mas) | 4. [Migrate your data from Synapse to Matrix Authentication Service using syn2mas](#migrate-your-data-from-synapse-to-matrix-authentication-service-using-syn2mas) | ||||||
|  |  | ||||||
| @@ -344,7 +342,9 @@ The installation + migration steps are like this: | |||||||
|  |  | ||||||
| ### Migrate your data from Synapse to Matrix Authentication Service using syn2mas | ### Migrate your data from Synapse to Matrix Authentication Service using syn2mas | ||||||
|  |  | ||||||
| You can invoke the `syn2mas` tool via the playbook by running the playbook's `matrix-authentication-service-mas-cli-syn2mas` tag. We recommend first doing a [dry-run](#performing-a-syn2mas-dry-run) and then a [real migration](#performing-a-real-syn2mas-migration). | We **don't** ask you to [run the `syn2mas` migration advisor command](https://element-hq.github.io/matrix-authentication-service/setup/migration.html#run-the-migration-advisor), because it only gives you the green light if your Synapse configuration (`homeserver.yaml`) is configured in a way that's compatible with MAS (delegating authentication to MAS; disabling Synapse's password config; etc.). Until we migrate your data with the `syn2mas` tool, we intentionally avoid doing these changes to allow existing user sessions to work. | ||||||
|  |  | ||||||
|  | You can invoke the `syn2mas` tool via the playbook by running the playbook's `matrix-authentication-service-syn2mas` tag. We recommend first doing a [dry-run](#performing-a-syn2mas-dry-run) and then a [real migration](#performing-a-real-syn2mas-migration). | ||||||
|  |  | ||||||
| #### Configuring syn2mas | #### Configuring syn2mas | ||||||
|  |  | ||||||
| @@ -356,9 +356,26 @@ When you're done with potentially configuring `syn2mas`, proceed to doing a [dry | |||||||
|  |  | ||||||
| ##### Configuring upstream OIDC provider mapping for syn2mas | ##### Configuring upstream OIDC provider mapping for syn2mas | ||||||
|  |  | ||||||
| Since Matrix Authentication Service v0.16.0 (which replaced the standalone `syn2mas` tool with a `mas-cli syn2mas` sub-command), OIDC configuration (mapping from your old OIDC configuration to your new one, etc) is meant to be configured in the Matrix Authentication Service configuration (via `matrix_authentication_service_config_upstream_oauth2_providers`) as a `synapse_idp_id` property for each provider. | If you have existing OIDC users in your Synapse user database (which will be the case if when using [OIDC with Synapse](./configuring-playbook-synapse.md#synapse--openid-connect-for-single-sign-on)), you may need to pass an additional `--upstreamProviderMapping` argument to the `syn2mas` tool to tell it which provider (on the Synapse side) maps to which other provider on the MAS side. | ||||||
|  |  | ||||||
| You can refer to the [Map any upstream SSO providers](https://element-hq.github.io/matrix-authentication-service/setup/migration.html#map-any-upstream-sso-providers) section of the MAS documentation for figuring out how to set the `synapse_idp_id` value in `matrix_authentication_service_config_upstream_oauth2_providers` correctly. | If you don't do this, `syn2mas` would report errors like this one: | ||||||
|  |  | ||||||
|  | > [FATAL] migrate - [Failed to import external id 4264b0f0-4f11-4ddd-aedb-b500e4d07c25 with oidc-keycloak for user @alice:example.com: Error: Unknown upstream provider oidc-keycloak] | ||||||
|  |  | ||||||
|  | Below is an example situation and a guide for how to solve it. | ||||||
|  |  | ||||||
|  | If in `matrix_synapse_oidc_providers` your provider `idp_id` is (was) named `keycloak`, in the Synapse database users would be associated with the `oidc-keycloak` provider (note the `oidc-` prefix that was added automatically by Synapse to your `idp_id` value). | ||||||
|  |  | ||||||
|  | The same OIDC provider may have an `id` of `01HFVBY12TMNTYTBV8W921M5FA` on the MAS side, as defined in `matrix_authentication_service_config_upstream_oauth2_providers` (see the [Upstream OAuth2 configuration](#upstream-oauth2-configuration) section above). | ||||||
|  |  | ||||||
|  | To tell `syn2mas` how the Synapse-configured OIDC provider maps to the new MAS-configured OIDC provider, add this additional configuration to your `vars.yml` file: | ||||||
|  |  | ||||||
|  | ```yaml | ||||||
|  | # Adjust the mapping below to match your provider IDs on the Synapse side and the MAS side. | ||||||
|  | # Don't forget that Synapse automatically adds an `oidc-` prefix to provider ids defined in its configuration. | ||||||
|  | matrix_authentication_service_syn2mas_process_extra_arguments: | ||||||
|  |   - "--upstreamProviderMapping oidc-keycloak:01HFVBY12TMNTYTBV8W921M5FA" | ||||||
|  | ``` | ||||||
|  |  | ||||||
| #### Performing a syn2mas dry-run | #### Performing a syn2mas dry-run | ||||||
|  |  | ||||||
| @@ -369,7 +386,7 @@ A dry-run would not cause downtime, because it avoids stopping Synapse. | |||||||
| To perform a dry-run, run: | To perform a dry-run, run: | ||||||
|  |  | ||||||
| ```sh | ```sh | ||||||
| just run-tags matrix-authentication-service-mas-cli-syn2mas -e matrix_authentication_service_syn2mas_migrate_dry_run=true | just run-tags matrix-authentication-service-syn2mas -e matrix_authentication_service_syn2mas_dry_run=true | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Observe the command output (especially the last line of the the syn2mas output). If you are confident that the migration will work out as expected, you can proceed with a [real migration](#performing-a-real-syn2mas-migration). | Observe the command output (especially the last line of the the syn2mas output). If you are confident that the migration will work out as expected, you can proceed with a [real migration](#performing-a-real-syn2mas-migration). | ||||||
| @@ -388,13 +405,13 @@ Before performing a real migration make sure: | |||||||
|  |  | ||||||
| - you've performed a [syn2mas dry-run](#performing-a-syn2mas-dry-run) and don't see any issues in its output | - you've performed a [syn2mas dry-run](#performing-a-syn2mas-dry-run) and don't see any issues in its output | ||||||
|  |  | ||||||
| To perform a real migration, run the `matrix-authentication-service-mas-cli-syn2mas` tag **without** the `matrix_authentication_service_syn2mas_migrate_dry_run` variable: | To perform a real migration, run the `matrix-authentication-service-syn2mas` tag **without** the `matrix_authentication_service_syn2mas_dry_run` variable: | ||||||
|  |  | ||||||
| ```sh | ```sh | ||||||
| just run-tags matrix-authentication-service-mas-cli-syn2mas | just run-tags matrix-authentication-service-syn2mas | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Having performed a `syn2mas` migration once, trying to do it again will report errors (e.g. "Error: The MAS database is not empty: rows found in at least `users`. Please drop and recreate the database, then try again."). | Having performed a `syn2mas` migration once, trying to do it again will report errors for users that were already migrated (e.g. "Error: Unknown upstream provider oauth-delegated"). | ||||||
|  |  | ||||||
| ## Verify that Matrix Authentication Service is installed correctly | ## Verify that Matrix Authentication Service is installed correctly | ||||||
|  |  | ||||||
|   | |||||||
| @@ -13,7 +13,7 @@ SPDX-License-Identifier: AGPL-3.0-or-later | |||||||
|  |  | ||||||
| The playbook can install and configure [matrix-corporal](https://github.com/devture/matrix-corporal) for you. | The playbook can install and configure [matrix-corporal](https://github.com/devture/matrix-corporal) for you. | ||||||
|  |  | ||||||
| In short, it's a sort of automation and firewalling service, which is helpful if you're installing Matrix services in a controlled corporate environment. | In short, it's a sort of automation and firewalling service, which is helpful if you're instaling Matrix services in a controlled corporate environment. | ||||||
|  |  | ||||||
| See the project's [documentation](https://github.com/devture/matrix-corporal/blob/main/README.md) to learn what it does and why it might be useful to you. | See the project's [documentation](https://github.com/devture/matrix-corporal/blob/main/README.md) to learn what it does and why it might be useful to you. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -60,7 +60,7 @@ To `matrix_media_repo_container_labels_traefik_metrics_middleware_basic_auth_use | |||||||
|  |  | ||||||
| #### Enable Grafana (optional) | #### Enable Grafana (optional) | ||||||
|  |  | ||||||
| Probably you wish to enable Grafana along with Prometheus for generating graphs of the metrics. | Probably you wish to enable Grafana along with Prometheus for generating graphs of the metics. | ||||||
|  |  | ||||||
| To enable Grafana, see [this section](configuring-playbook-prometheus-grafana.md#adjusting-the-playbook-configuration-grafana) for instructions. | To enable Grafana, see [this section](configuring-playbook-prometheus-grafana.md#adjusting-the-playbook-configuration-grafana) for instructions. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,58 +0,0 @@ | |||||||
| <!-- |  | ||||||
| SPDX-FileCopyrightText: 2024 wjbeckett |  | ||||||
| SPDX-FileCopyrightText: 2024 - 2025 Slavi Pantaleev |  | ||||||
|  |  | ||||||
| SPDX-License-Identifier: AGPL-3.0-or-later |  | ||||||
| --> |  | ||||||
|  |  | ||||||
| # Setting up the Matrix RTC stack (optional) |  | ||||||
|  |  | ||||||
| The playbook can install and configure the Matrix RTC (Real-Time Communication) stack. |  | ||||||
|  |  | ||||||
| The Matrix RTC stack is a set of supporting components ([LiveKit Server](configuring-playbook-livekit-server.md) and [LiveKit JWT Service](configuring-playbook-livekit-jwt-service.md)) that allow the new [Element Call](configuring-playbook-element-call.md) audio/video calls to function. |  | ||||||
|  |  | ||||||
| 💡 If you only plan on doing audio/video calls via Matrix client (which typically embed the Element Call frontend UI within them), you only need to install the Matrix RTC stack and don't necessarily need to install [Element Call](configuring-playbook-element-call.md). See the [Decide between Element Call vs just the Matrix RTC stack](configuring-playbook-element-call.md#decide-between-element-call-vs-just-the-matrix-rtc-stack) section of the [Element Call documentation](configuring-playbook-element-call.md) for more details. |  | ||||||
|  |  | ||||||
| ## Prerequisites |  | ||||||
|  |  | ||||||
| - A [Synapse](configuring-playbook-synapse.md) homeserver (see the warning below) |  | ||||||
| - Various experimental features for the Synapse homeserver which Element Call [requires](https://github.com/element-hq/element-call/blob/93ae2aed9841e0b066d515c56bd4c122d2b591b2/docs/self-hosting.md#a-matrix-homeserver) (automatically done when Element Call is enabled) |  | ||||||
| - A [LiveKit Server](configuring-playbook-livekit-server.md) (automatically installed when [Element Call or the Matrix RTC stack is enabled](#decide-between-element-call-vs-just-the-matrix-rtc-stack)) |  | ||||||
| - The [LiveKit JWT Service](configuring-playbook-livekit-jwt-service.md) (automatically installed when [Element Call or the Matrix RTC stack is enabled](#decide-between-element-call-vs-just-the-matrix-rtc-stack)) |  | ||||||
| - A client compatible with Element Call. As of 2025-03-15, that's just [Element Web](configuring-playbook-client-element-web.md) and the Element X mobile clients (iOS and Android). |  | ||||||
|  |  | ||||||
| > [!WARNING] |  | ||||||
| >  Because Element Call [requires](https://github.com/element-hq/element-call/blob/93ae2aed9841e0b066d515c56bd4c122d2b591b2/docs/self-hosting.md#a-matrix-homeserver) a few experimental features in the Matrix protocol, it's **very likely that it only works with the Synapse homeserver**. |  | ||||||
|  |  | ||||||
| ## Adjusting the playbook configuration |  | ||||||
|  |  | ||||||
| Add the following configuration to your `inventory/host_vars/matrix.example.com/vars.yml` file: |  | ||||||
|  |  | ||||||
| ```yaml |  | ||||||
| # Enable the Matrix RTC stack. |  | ||||||
| # This provides all supporting services for Element Call, without the Element Call frontend. |  | ||||||
| matrix_rtc_enabled: true |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| ## Adjusting firewall rules |  | ||||||
|  |  | ||||||
| In addition to the HTTP/HTTPS ports (which you've already exposed as per the [prerequisites](prerequisites.md) document), you'll also need to open ports required by [LiveKit Server](configuring-playbook-livekit-server.md) as described in its own [Adjusting firewall rules](configuring-playbook-livekit-server.md#adjusting-firewall-rules) section. |  | ||||||
|  |  | ||||||
| ## Installing |  | ||||||
|  |  | ||||||
| After configuring the playbook and potentially [adjusting your DNS records](#adjusting-dns-records) and [adjusting firewall rules](#adjusting-firewall-rules), run the playbook with [playbook tags](playbook-tags.md) as below: |  | ||||||
|  |  | ||||||
| <!-- NOTE: let this conservative command run (instead of install-all) to make it clear that failure of the command means something is clearly broken. --> |  | ||||||
| ```sh |  | ||||||
| ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,start |  | ||||||
| ``` |  | ||||||
|  |  | ||||||
| The shortcut commands with the [`just` program](just.md) are also available: `just install-all` or `just setup-all` |  | ||||||
|  |  | ||||||
| `just install-all` is useful for maintaining your setup quickly ([2x-5x faster](../CHANGELOG.md#2x-5x-performance-improvements-in-playbook-runtime) than `just setup-all`) when its components remain unchanged. If you adjust your `vars.yml` to remove other components, you'd need to run `just setup-all`, or these components will still remain installed. Note these shortcuts run the `ensure-matrix-users-created` tag too. |  | ||||||
|  |  | ||||||
| ## Usage |  | ||||||
|  |  | ||||||
| Once installed, Matrix clients which support Element Call (like [Element Web](configuring-playbook-client-element-web.md) and Element X on mobile (iOS and Android)) will automatically use the Matrix RTC stack. |  | ||||||
|  |  | ||||||
| These clients typically embed the Element Call frontend UI within them, so installing [Element Call](configuring-playbook-element-call.md) is only necessary if you'd like to use it standalone - directly via a browser. |  | ||||||
| @@ -115,7 +115,7 @@ The shortcut commands with the [`just` program](just.md) are also available: `ju | |||||||
|  |  | ||||||
| ## Usage | ## Usage | ||||||
|  |  | ||||||
| To receive push notifications with UnifiedPush from the ntfy server, you need to **install [the ntfy Android app](https://docs.ntfy.sh/subscribe/phone/)** which works as the Distributor, **log in to the account on the ntfy app** if you have enabled the access control, and then **configure a UnifiedPush-compatible Matrix client**. After setting up the ntfy Android app, the Matrix client listens to it, and push notifications are "distributed" from it. | To receive push notifications with UnifiedPush from the ntfy server, you need to **install [the ntfy Android app](https://docs.ntfy.sh/subscribe/phone/)** which works as the Distrubutor, **log in to the account on the ntfy app** if you have enabled the access control, and then **configure a UnifiedPush-compatible Matrix client**. After setting up the ntfy Android app, the Matrix client listens to it, and push notitications are "distributed" from it. | ||||||
|  |  | ||||||
| For details about installing and configuring the ntfy Android app, take a look at [this section](https://github.com/mother-of-all-self-hosting/ansible-role-ntfy/blob/main/docs/configuring-ntfy.md#install-the-ntfy-androidios-app) on the role's documentation. | For details about installing and configuring the ntfy Android app, take a look at [this section](https://github.com/mother-of-all-self-hosting/ansible-role-ntfy/blob/main/docs/configuring-ntfy.md#install-the-ntfy-androidios-app) on the role's documentation. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -26,7 +26,7 @@ By default, this playbook installs its own [Traefik](https://traefik.io/) revers | |||||||
|  |  | ||||||
| - serving public traffic and providing SSL-termination with certificates obtained from [Let's Encrypt](https://letsencrypt.org/). See [Adjusting SSL certificate retrieval](./configuring-playbook-ssl-certificates.md). | - serving public traffic and providing SSL-termination with certificates obtained from [Let's Encrypt](https://letsencrypt.org/). See [Adjusting SSL certificate retrieval](./configuring-playbook-ssl-certificates.md). | ||||||
|  |  | ||||||
| - assists internal communication between addon services (bridges, bots, etc.) and the homeserver via an internal entrypoint (`matrix-internal-matrix-client-api`). | - assists internal communication between addon services (briges, bots, etc.) and the homeserver via an internal entrypoint (`matrix-internal-matrix-client-api`). | ||||||
|  |  | ||||||
| There are 2 ways to use Traefik with this playbook, as described below. | There are 2 ways to use Traefik with this playbook, as described below. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -258,4 +258,4 @@ As with all other services, you can find the logs in [systemd-journald](https:// | |||||||
| - [The Prometheus scraping rules](https://github.com/element-hq/synapse/tree/master/contrib/prometheus) (we use v2) | - [The Prometheus scraping rules](https://github.com/element-hq/synapse/tree/master/contrib/prometheus) (we use v2) | ||||||
| - [The Synapse Grafana dashboard](https://github.com/element-hq/synapse/tree/master/contrib/grafana) | - [The Synapse Grafana dashboard](https://github.com/element-hq/synapse/tree/master/contrib/grafana) | ||||||
| - [The Node Exporter dashboard](https://github.com/rfrail3/grafana-dashboards) (for generic non-synapse performance graphs) | - [The Node Exporter dashboard](https://github.com/rfrail3/grafana-dashboards) (for generic non-synapse performance graphs) | ||||||
| - [The PostgreSQL dashboard](https://grafana.com/grafana/dashboards/9628) (generic Postgres dashboard) | - [The PostgresSQL dashboard](https://grafana.com/grafana/dashboards/9628) (generic Postgres dashboard) | ||||||
|   | |||||||
| @@ -22,11 +22,13 @@ Finally, [set up S3 storage for Synapse](#setting-up) (with [Goofys](configuring | |||||||
|  |  | ||||||
| ## Choosing an Object Storage provider | ## Choosing an Object Storage provider | ||||||
|  |  | ||||||
| You can create [Amazon S3](https://aws.amazon.com/s3/) or another S3-compatible object storage like [Backblaze B2](https://www.backblaze.com/b2/cloud-storage.html), [Wasabi](https://wasabi.com), [Digital Ocean Spaces](https://www.digitalocean.com/products/spaces), [Storj](https://storj.io), etc. | You can create [Amazon S3](https://aws.amazon.com/s3/) or another S3-compatible object storage like [Backblaze B2](https://www.backblaze.com/b2/cloud-storage.html), [Storj](https://storj.io), [Wasabi](https://wasabi.com), [Digital Ocean Spaces](https://www.digitalocean.com/products/spaces), etc. | ||||||
|  |  | ||||||
| Amazon S3 and Backblaze B2 are pay-as-you with no minimum charges for storing too little data. Note that Backblaze egress is free, but for only certain users for up to 3x the amount of data stored. Beyond that you will pay $0.01/GB of egress. | Amazon S3, Backblaze B2, and Storj are pay-as-you with no minimum charges for storing too little data. | ||||||
|  |  | ||||||
| Wasabi has a minimum charge of 1TB if you're storing less than 1TB, which becomes expensive if you need to store less data than that. Likewise, Digital Ocean Spaces has also a minimum charge of 250GB ($5/month as of 2022-10). Though Storj does not set minimum amount of data to be stored, it also charges $5 minimum monthly usage fee since July 1, 2025, if your monthly usage (storage, bandwidth, and segments) totals less than $5. | All these providers have different prices, with Storj appearing to be the cheapest (as of 2024-10, storage fee is $0.004 per GB/month, and egress fee is $0.007 per GB; check actual pricing [here](https://storj.dev/dcs/pricing)). Backblaze egress is free, but for only certain users for up to 3x the amount of data stored. Beyond that you will pay $0.01/GB of egress. | ||||||
|  |  | ||||||
|  | Wasabi has a minimum charge of 1TB if you're storing less than 1TB, which becomes expensive if you need to store less data than that. Likewise, Digital Ocean Spaces has also a minimum charge of 250GB ($5/month as of 2022-10). | ||||||
|  |  | ||||||
| Here are some of the important aspects of choosing the right provider: | Here are some of the important aspects of choosing the right provider: | ||||||
|  |  | ||||||
|   | |||||||
| @@ -15,7 +15,7 @@ By default, the playbook retrieves and automatically renews free SSL certificate | |||||||
|  |  | ||||||
| **Notes**: | **Notes**: | ||||||
| - This guide is intended to be referred for configuring the integrated Traefik server with regard to SSL certificates retrieval. If you're using [your own webserver](configuring-playbook-own-webserver.md), consult its documentation about how to configure it. | - This guide is intended to be referred for configuring the integrated Traefik server with regard to SSL certificates retrieval. If you're using [your own webserver](configuring-playbook-own-webserver.md), consult its documentation about how to configure it. | ||||||
| - Let's Encrypt ends the expiration notification email service on June 4, 2025 (see: [the official announcement](https://letsencrypt.org/2025/01/22/ending-expiration-emails/)), and it recommends using a third party service for those who want to receive expiration notifications. If you are looking for a self-hosting service, you may be interested in a monitoring tool such as [Update Kuma](https://github.com/louislam/uptime-kuma/). | - Let's Encrypt ends the expiration notification email service on June 4, 2025 (see: [the official announcement](https://letsencrypt.org/2025/01/22/ending-expiration-emails/)), and it recommends using a third party service for those who want to receive expiriation notifications. If you are looking for a self-hosting service, you may be interested in a monitoring tool such as [Update Kuma](https://github.com/louislam/uptime-kuma/). | ||||||
|  |  | ||||||
|   The [Mother-of-All-Self-Hosting (MASH)](https://github.com/mother-of-all-self-hosting/mash-playbook) Ansible playbook can be used to install and manage an Uptime Kuma instance. See [this page](https://github.com/mother-of-all-self-hosting/mash-playbook/blob/main/docs/services/uptime-kuma.md) for the instruction to install it with the MASH playbook. If you are wondering how to use the MASH playbook for your Matrix server, refer [this page](https://github.com/mother-of-all-self-hosting/mash-playbook/blob/main/docs/setting-up-services-on-mdad-server.md). |   The [Mother-of-All-Self-Hosting (MASH)](https://github.com/mother-of-all-self-hosting/mash-playbook) Ansible playbook can be used to install and manage an Uptime Kuma instance. See [this page](https://github.com/mother-of-all-self-hosting/mash-playbook/blob/main/docs/services/uptime-kuma.md) for the instruction to install it with the MASH playbook. If you are wondering how to use the MASH playbook for your Matrix server, refer [this page](https://github.com/mother-of-all-self-hosting/mash-playbook/blob/main/docs/setting-up-services-on-mdad-server.md). | ||||||
|  |  | ||||||
| @@ -117,7 +117,7 @@ traefik_config_certificatesResolvers_acme_dnsChallenge_provider: "cloudflare" | |||||||
| traefik_config_certificatesResolvers_acme_dnsChallenge_delayBeforeCheck: 60 | traefik_config_certificatesResolvers_acme_dnsChallenge_delayBeforeCheck: 60 | ||||||
| traefik_config_certificatesResolvers_acme_dnsChallenge_resolvers: | traefik_config_certificatesResolvers_acme_dnsChallenge_resolvers: | ||||||
|   - "1.1.1.1:53" |   - "1.1.1.1:53" | ||||||
| traefik_environment_variables: | | traefik_environment_variables_additional_variables: | | ||||||
|   CF_API_EMAIL=redacted |   CF_API_EMAIL=redacted | ||||||
|   CF_ZONE_API_TOKEN=redacted |   CF_ZONE_API_TOKEN=redacted | ||||||
|   CF_DNS_API_TOKEN=redacted |   CF_DNS_API_TOKEN=redacted | ||||||
|   | |||||||
| @@ -49,8 +49,8 @@ aux_file_definitions: | |||||||
|       content |       content | ||||||
|       here |       here | ||||||
|     mode: '0600' |     mode: '0600' | ||||||
|     owner: "{{ matrix_user_name }}" |     owner: "{{ matrix_user_username }}" | ||||||
|     group: "{{ matrix_group_name }}" |     group: "{{ matrix_user_groupname }}" | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Configuring [GCM/FCM](https://firebase.google.com/docs/cloud-messaging/) is easier, as it only requires that you provide some config values. | Configuring [GCM/FCM](https://firebase.google.com/docs/cloud-messaging/) is easier, as it only requires that you provide some config values. | ||||||
|   | |||||||
| @@ -18,8 +18,6 @@ synapse-admin is a web UI tool you can use to **administrate users, rooms, media | |||||||
|  |  | ||||||
| 💡 **Note**: the latest version of synapse-admin is hosted by [etke.cc](https://etke.cc/) at [admin.etke.cc](https://admin.etke.cc/). If you only need this service occasionally and trust giving your admin credentials to a 3rd party Single Page Application, you can consider using it from there and avoiding the (small) overhead of self-hosting. | 💡 **Note**: the latest version of synapse-admin is hosted by [etke.cc](https://etke.cc/) at [admin.etke.cc](https://admin.etke.cc/). If you only need this service occasionally and trust giving your admin credentials to a 3rd party Single Page Application, you can consider using it from there and avoiding the (small) overhead of self-hosting. | ||||||
|  |  | ||||||
| 💡 **Note**: The playbook also supports an alternative management UI in the shape of [Element Admin](./configuring-playbook-element-admin.md). However, it's currently less feature-rich than Synapse Admin and has a dependency on [Matrix Authentication Service](./configuring-playbook-matrix-authentication-service.md). |  | ||||||
|  |  | ||||||
| ## Adjusting DNS records (optional) | ## Adjusting DNS records (optional) | ||||||
|  |  | ||||||
| By default, this playbook installs Synapse Admin on the `matrix.` subdomain, at the `/synapse-admin` path (https://matrix.example.com/synapse-admin). This makes it easy to install it, because it **doesn't require additional DNS records to be set up**. If that's okay, you can skip this section. | By default, this playbook installs Synapse Admin on the `matrix.` subdomain, at the `/synapse-admin` path (https://matrix.example.com/synapse-admin). This makes it easy to install it, because it **doesn't require additional DNS records to be set up**. If that's okay, you can skip this section. | ||||||
| @@ -42,7 +40,7 @@ matrix_synapse_admin_enabled: true | |||||||
| By default, synapse-admin installation will be [restricted to only work with one homeserver](https://github.com/etkecc/synapse-admin/blob/e21e44362c879ac41f47c580b04210842b6ff3d7/README.md#restricting-available-homeserver) — the one managed by the playbook. To adjust these restrictions, tweak the `matrix_synapse_admin_config_restrictBaseUrl` variable. | By default, synapse-admin installation will be [restricted to only work with one homeserver](https://github.com/etkecc/synapse-admin/blob/e21e44362c879ac41f47c580b04210842b6ff3d7/README.md#restricting-available-homeserver) — the one managed by the playbook. To adjust these restrictions, tweak the `matrix_synapse_admin_config_restrictBaseUrl` variable. | ||||||
|  |  | ||||||
| > [!WARNING] | > [!WARNING] | ||||||
| > If you're using [Matrix Authentication Service](./configuring-playbook-matrix-authentication-service.md) (MAS) for authentication, you will be able to [log into synapse-admin with an access token](https://github.com/etkecc/synapse-admin/pull/58), but certain synapse-admin features (especially those around user management) will be limited or not work at all. You may be interested in using [Element Admin](docs/configuring-playbook-element-admin.md) for these purposes. | > If you're using [Matrix Authentication Service](./configuring-playbook-matrix-authentication-service.md) (MAS) for authentication, you will be able to [log into synapse-admin with an access token](https://github.com/etkecc/synapse-admin/pull/58), but certain synapse-admin features (especially those around user management) will be limited or not work at all. | ||||||
|  |  | ||||||
| ### Adjusting the Synapse Admin URL (optional) | ### Adjusting the Synapse Admin URL (optional) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -24,15 +24,12 @@ matrix_synapse_auto_compressor_enabled: true | |||||||
|  |  | ||||||
| ### Edit the schedule (optional) | ### Edit the schedule (optional) | ||||||
|  |  | ||||||
| By default the task will around 0 a.m. every day based on the `matrix_synapse_auto_compressor_schedule` variable with a randomized delay of 6 hours (controlled by the `matrix_synapse_auto_compressor_schedule_randomized_delay_sec` variable). It is defined in the format of systemd timer calendar. | By default the task will run 0 a.m. every day based on the `matrix_synapse_auto_compressor_schedule` variable. It is defined in the format of systemd timer calendar. | ||||||
|  |  | ||||||
| To edit the schedule, add the following configuration to your `vars.yml` file (adapt to your needs): | To edit the schedule, add the following configuration to your `vars.yml` file (adapt to your needs): | ||||||
|  |  | ||||||
| ```yaml | ```yaml | ||||||
| matrix_synapse_auto_compressor_schedule: "*-*-* 00:00:00" | matrix_synapse_auto_compressor_schedule: "*-*-* 00:00:00" | ||||||
|  |  | ||||||
| # Consider adjusting the randomized delay or setting it to 0 to disable randomized delays. |  | ||||||
| # matrix_synapse_auto_compressor_schedule_randomized_delay_sec: 6h |  | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ### Extending the configuration | ### Extending the configuration | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ SPDX-License-Identifier: AGPL-3.0-or-later | |||||||
|  |  | ||||||
| The playbook can install and configure [synapse-simple-antispam](https://github.com/t2bot/synapse-simple-antispam) for you. | The playbook can install and configure [synapse-simple-antispam](https://github.com/t2bot/synapse-simple-antispam) for you. | ||||||
|  |  | ||||||
| It lets you fight invite-spam by automatically blocking invitations from a list of servers specified by you (blacklisting). | It lets you fight invite-spam by automatically blocking invitiations from a list of servers specified by you (blacklisting). | ||||||
|  |  | ||||||
| See the project's [documentation](https://github.com/t2bot/synapse-simple-antispam/blob/master/README.md) to learn what it does and why it might be useful to you. | See the project's [documentation](https://github.com/t2bot/synapse-simple-antispam/blob/master/README.md) to learn what it does and why it might be useful to you. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -53,7 +53,7 @@ You may also consider [tweaking the number of workers of each type](#controlling | |||||||
|  |  | ||||||
| ##### Specialized workers | ##### Specialized workers | ||||||
|  |  | ||||||
| The playbook now supports a smarter **specialized load-balancing** inspired by [Tom Foster](https://github.com/tcpipuk)'s [Synapse homeserver guide](https://tcpipuk.github.io/synapse/index.html). Instead of routing requests to one or more [generic workers](#generic-workers) based only on the requester's IP address, specialized load-balancing routes to **4 different types of specialized workers** based on **smarter criteria** — the access token (username) of the requester and/or on the resource (room, etc.) being requested. | The playbook now supports a smarter **specialized load-balancing** inspired by [Tom Foster](https://github.com/tcpipuk)'s [Synapse homeserver guide](https://tcpipuk.github.io/synapse/index.html). Instead of routing requests to one or more [generic workers](#generic-workers) based only on the requestor's IP adddress, specialized load-balancing routes to **4 different types of specialized workers** based on **smarter criteria** — the access token (username) of the requestor and/or on the resource (room, etc.) being requested. | ||||||
|  |  | ||||||
| The playbook supports these **4 types** of specialized workers: | The playbook supports these **4 types** of specialized workers: | ||||||
|  |  | ||||||
|   | |||||||
| @@ -53,8 +53,6 @@ For a more custom setup, see the [Other configuration options](#other-configurat | |||||||
|  |  | ||||||
|   - [Configuring conduwuit](configuring-playbook-conduwuit.md), if you've switched to the [conduwuit](https://conduwuit.puppyirl.gay/) homeserver implementation |   - [Configuring conduwuit](configuring-playbook-conduwuit.md), if you've switched to the [conduwuit](https://conduwuit.puppyirl.gay/) homeserver implementation | ||||||
|  |  | ||||||
|   - [Configuring continuwuity](configuring-playbook-continuwuity.md), if you've switched to the [continuwuity](https://continuwuity.org) homeserver implementation |  | ||||||
|  |  | ||||||
|   - [Configuring Dendrite](configuring-playbook-dendrite.md), if you've switched to the [Dendrite](https://matrix-org.github.io/dendrite) homeserver implementation |   - [Configuring Dendrite](configuring-playbook-dendrite.md), if you've switched to the [Dendrite](https://matrix-org.github.io/dendrite) homeserver implementation | ||||||
|  |  | ||||||
| - Server components: | - Server components: | ||||||
| @@ -184,8 +182,6 @@ Bridges can be used to connect your Matrix installation with third-party communi | |||||||
|  |  | ||||||
| - [Setting up MX Puppet GroupMe bridging](configuring-playbook-bridge-mx-puppet-groupme.md) | - [Setting up MX Puppet GroupMe bridging](configuring-playbook-bridge-mx-puppet-groupme.md) | ||||||
|  |  | ||||||
| - [Setting up Steam bridging](configuring-playbook-bridge-steam.md) |  | ||||||
|  |  | ||||||
| - [Setting up MX Puppet Steam bridging](configuring-playbook-bridge-mx-puppet-steam.md) | - [Setting up MX Puppet Steam bridging](configuring-playbook-bridge-mx-puppet-steam.md) | ||||||
|  |  | ||||||
| - [Setting up Go Skype Bridge bridging](configuring-playbook-bridge-go-skype-bridge.md) | - [Setting up Go Skype Bridge bridging](configuring-playbook-bridge-go-skype-bridge.md) | ||||||
| @@ -241,13 +237,11 @@ Services that help you in administrating and monitoring your Matrix installation | |||||||
|  |  | ||||||
| Various services that don't fit any other categories. | Various services that don't fit any other categories. | ||||||
|  |  | ||||||
| - [Setting up Element Call](configuring-playbook-element-call.md) — a native Matrix video conferencing application, built on top of the [Matrix RTC stack](configuring-playbook-matrix-rtc.md) (optional) | - [Setting up Element Call](configuring-playbook-element-call.md) — a native Matrix video conferencing application (optional) | ||||||
|  |  | ||||||
| - [Setting up LiveKit JWT Service](configuring-playbook-livekit-jwt-service.md) - a component of the [Matrix RTC stack](configuring-playbook-matrix-rtc.md) (optional) | - [Setting up LiveKit JWT Service](configuring-playbook-livekit-jwt-service.md) (optional) | ||||||
|  |  | ||||||
| - [Setting up LiveKit Server](configuring-playbook-livekit-server.md) - a component of the [Matrix RTC stack](configuring-playbook-matrix-rtc.md) (optional) | - [Setting up LiveKit Server](configuring-playbook-livekit-server.md) (optional) | ||||||
|  |  | ||||||
| - [Setting up Matrix RTC](configuring-playbook-matrix-rtc.md) (optional) |  | ||||||
|  |  | ||||||
| - [Setting up Synapse Auto Invite Accept](configuring-playbook-synapse-auto-accept-invite.md) | - [Setting up Synapse Auto Invite Accept](configuring-playbook-synapse-auto-accept-invite.md) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -28,7 +28,6 @@ We try to stick to official images (provided by their respective projects) as mu | |||||||
| | [Synapse](configuring-playbook-synapse.md) | [element-hq/synapse](https://ghcr.io/element-hq/synapse) | ✅ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network | | | [Synapse](configuring-playbook-synapse.md) | [element-hq/synapse](https://ghcr.io/element-hq/synapse) | ✅ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network | | ||||||
| | [Conduit](configuring-playbook-conduit.md) | [matrixconduit/matrix-conduit](https://hub.docker.com/r/matrixconduit/matrix-conduit) | ❌ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network. Conduit is a lightweight open-source server implementation of the Matrix Specification with a focus on easy setup and low system requirements | | | [Conduit](configuring-playbook-conduit.md) | [matrixconduit/matrix-conduit](https://hub.docker.com/r/matrixconduit/matrix-conduit) | ❌ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network. Conduit is a lightweight open-source server implementation of the Matrix Specification with a focus on easy setup and low system requirements | | ||||||
| | [conduwuit](configuring-playbook-conduwuit.md) | [girlbossceo/conduwuit](https://ghcr.io/girlbossceo/conduwuit) | ❌ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network. conduwuit is a fork of Conduit. | | | [conduwuit](configuring-playbook-conduwuit.md) | [girlbossceo/conduwuit](https://ghcr.io/girlbossceo/conduwuit) | ❌ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network. conduwuit is a fork of Conduit. | | ||||||
| | [continuwuity](configuring-playbook-continuwuity.md) | [continuwuation/continuwuity](https://forgejo.ellis.link/continuwuation/continuwuity) | ❌ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network. continuwuity is a continuation of conduwuit. | |  | ||||||
| | [Dendrite](configuring-playbook-dendrite.md) | [matrixdotorg/dendrite-monolith](https://hub.docker.com/r/matrixdotorg/dendrite-monolith/) | ❌ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network. Dendrite is a second-generation Matrix homeserver written in Go, an alternative to Synapse. | | | [Dendrite](configuring-playbook-dendrite.md) | [matrixdotorg/dendrite-monolith](https://hub.docker.com/r/matrixdotorg/dendrite-monolith/) | ❌ | Storing your data and managing your presence in the [Matrix](http://matrix.org/) network. Dendrite is a second-generation Matrix homeserver written in Go, an alternative to Synapse. | | ||||||
|  |  | ||||||
| ## Clients | ## Clients | ||||||
| @@ -114,7 +113,6 @@ Bridges can be used to connect your Matrix installation with third-party communi | |||||||
| | [mx-puppet-twitter](configuring-playbook-bridge-mx-puppet-twitter.md) | [sorunome/mx-puppet-twitter](https://hub.docker.com/r/sorunome/mx-puppet-twitter) | ❌ | Bridge for Twitter-DMs ([Twitter](https://twitter.com/)) | | | [mx-puppet-twitter](configuring-playbook-bridge-mx-puppet-twitter.md) | [sorunome/mx-puppet-twitter](https://hub.docker.com/r/sorunome/mx-puppet-twitter) | ❌ | Bridge for Twitter-DMs ([Twitter](https://twitter.com/)) | | ||||||
| | [mx-puppet-discord](configuring-playbook-bridge-mx-puppet-discord.md) | [mx-puppet/discord/mx-puppet-discord](https://gitlab.com/mx-puppet/discord/mx-puppet-discord/container_registry) | ❌ | Bridge to [Discord](https://discordapp.com/) | | | [mx-puppet-discord](configuring-playbook-bridge-mx-puppet-discord.md) | [mx-puppet/discord/mx-puppet-discord](https://gitlab.com/mx-puppet/discord/mx-puppet-discord/container_registry) | ❌ | Bridge to [Discord](https://discordapp.com/) | | ||||||
| | [mx-puppet-groupme](configuring-playbook-bridge-mx-puppet-groupme.md) | [xangelix/mx-puppet-groupme](https://hub.docker.com/r/xangelix/mx-puppet-groupme) | ❌ | Bridge to [GroupMe](https://groupme.com/) | | | [mx-puppet-groupme](configuring-playbook-bridge-mx-puppet-groupme.md) | [xangelix/mx-puppet-groupme](https://hub.docker.com/r/xangelix/mx-puppet-groupme) | ❌ | Bridge to [GroupMe](https://groupme.com/) | | ||||||
| | [matrix-steam-bridge](configuring-playbook-bridge-steam.md) | [jasonlaguidice/matrix-steam-bridge](https://github.com/jasonlaguidice/matrix-steam-bridge/pkgs/container/matrix-steam-bridge) | ❌ | Bridge to [Steam](https://steampowered.com/) | |  | ||||||
| | [mx-puppet-steam](configuring-playbook-bridge-mx-puppet-steam.md) | [icewind1991/mx-puppet-steam](https://hub.docker.com/r/icewind1991/mx-puppet-steam) | ❌ | Bridge to [Steam](https://steamapp.com/) | | | [mx-puppet-steam](configuring-playbook-bridge-mx-puppet-steam.md) | [icewind1991/mx-puppet-steam](https://hub.docker.com/r/icewind1991/mx-puppet-steam) | ❌ | Bridge to [Steam](https://steamapp.com/) | | ||||||
| | [Postmoogle](configuring-playbook-bridge-postmoogle.md) | [etke.cc/postmoogle](https://github.com/etkecc/postmoogle/container_registry) | ❌ | Email to Matrix bridge | | | [Postmoogle](configuring-playbook-bridge-postmoogle.md) | [etke.cc/postmoogle](https://github.com/etkecc/postmoogle/container_registry) | ❌ | Email to Matrix bridge | | ||||||
|  |  | ||||||
| @@ -159,7 +157,7 @@ Various services that don't fit any other categories. | |||||||
| | ------- | --------------- | -------- | ----------- | | | ------- | --------------- | -------- | ----------- | | ||||||
| | [sliding-sync](configuring-playbook-sliding-sync-proxy.md) | [matrix-org/sliding-sync](https://ghcr.io/matrix-org/sliding-sync) | ❌ | Sliding Sync support for clients which require it (like old Element X versions, before it got switched to Simplified Sliding Sync) | | | [sliding-sync](configuring-playbook-sliding-sync-proxy.md) | [matrix-org/sliding-sync](https://ghcr.io/matrix-org/sliding-sync) | ❌ | Sliding Sync support for clients which require it (like old Element X versions, before it got switched to Simplified Sliding Sync) | | ||||||
| | [synapse_auto_accept_invite](configuring-playbook-synapse-auto-accept-invite.md) | (N/A) | ❌ | Synapse module to automatically accept invites | | | [synapse_auto_accept_invite](configuring-playbook-synapse-auto-accept-invite.md) | (N/A) | ❌ | Synapse module to automatically accept invites | | ||||||
| | [synapse_auto_compressor](configuring-playbook-synapse-auto-compressor.md) | [mb-saces/rust-synapse-tools](https://gitlab.com/mb-saces/rust-synapse-tools/container_registry) | ❌ | Cli tool that automatically compresses Synapse's `state_groups` database table in background | | | [synapse_auto_compressor](configuring-playbook-synapse-auto-compressor.md) | [etke.cc/rust-synapse-compress-state](https://gitlab.com/etke.cc/rust-synapse-compress-state/container_registry) | ❌ | Cli tool that automatically compresses `state_groups` database table in background | | ||||||
| | [Matrix Corporal](configuring-playbook-matrix-corporal.md) (advanced) | [devture/matrix-corporal](https://hub.docker.com/r/devture/matrix-corporal/) | ❌ | Reconciliator and gateway for a managed Matrix server | | | [Matrix Corporal](configuring-playbook-matrix-corporal.md) (advanced) | [devture/matrix-corporal](https://hub.docker.com/r/devture/matrix-corporal/) | ❌ | Reconciliator and gateway for a managed Matrix server | | ||||||
| | [Etherpad](configuring-playbook-etherpad.md) | [etherpad/etherpad](https://hub.docker.com/r/etherpad/etherpad/) | ❌ | Open source collaborative text editor | | | [Etherpad](configuring-playbook-etherpad.md) | [etherpad/etherpad](https://hub.docker.com/r/etherpad/etherpad/) | ❌ | Open source collaborative text editor | | ||||||
| | [Jitsi](configuring-playbook-jitsi.md) | [jitsi/web](https://hub.docker.com/r/jitsi/web) | ❌ | [Jitsi](https://jitsi.org/) web UI | | | [Jitsi](configuring-playbook-jitsi.md) | [jitsi/web](https://hub.docker.com/r/jitsi/web) | ❌ | [Jitsi](https://jitsi.org/) web UI | | ||||||
|   | |||||||
| @@ -235,7 +235,7 @@ Running Matrix on a server with 1GB of memory is possible (especially if you dis | |||||||
|  |  | ||||||
| **We recommend starting with a server having at least 2GB of memory** and even then using it sparingly. If you know for sure you'll be joining various large rooms, etc., then going for 4GB of memory or more is a good idea. | **We recommend starting with a server having at least 2GB of memory** and even then using it sparingly. If you know for sure you'll be joining various large rooms, etc., then going for 4GB of memory or more is a good idea. | ||||||
|  |  | ||||||
| Besides the regular Matrix stuff, we also support things like video-conferencing using [Jitsi](configuring-playbook-jitsi.md) and other additional services which (when installed) may use up a lot of memory. Things do add up. Besides the Synapse Matrix server, Jitsi is especially notorious for consuming a lot of resources. If you plan on running Jitsi, we recommend a server with at least 2GB of memory (preferably more). See our [Jitsi documentation page](configuring-playbook-jitsi.md) to learn how to optimize its memory/CPU usage. | Besides the regular Matrix stuff, we also support things like video-conferencing using [Jitsi](configuring-playbook-jitsi.md) and other additional services which (when installed) may use up a lot of memory. Things do add up. Besides the Synapse Matrix server, Jitsi is especially notorious for consuming a lot of resources. If you plan on running Jitsi, we recommend a server with at least 2GB of memory (preferrably more). See our [Jitsi documentation page](configuring-playbook-jitsi.md) to learn how to optimize its memory/CPU usage. | ||||||
|  |  | ||||||
| ### Can I run this in an LXC container? | ### Can I run this in an LXC container? | ||||||
|  |  | ||||||
| @@ -362,7 +362,7 @@ Configuration variables are defined in multiple places in this playbook and are | |||||||
|  |  | ||||||
| You can discover the variables you can override in each role (`roles/*/*/defaults/main.yml`). | You can discover the variables you can override in each role (`roles/*/*/defaults/main.yml`). | ||||||
|  |  | ||||||
| As described in [How is the effective configuration determined?](#how-is-the-effective-configuration-determined), these role-defaults may be overridden by values defined in `group_vars/matrix_servers`. | As described in [How is the effective configuration determined?](#how-is-the-effective-configuration-determined), these role-defaults may be overriden by values defined in `group_vars/matrix_servers`. | ||||||
|  |  | ||||||
| Refer to both of these for inspiration. Still, as mentioned in [Configuring the playbook](configuring-playbook.md), you're only ever supposed to edit your own `inventory/host_vars/matrix.example.com/vars.yml` file and nothing else inside the playbook (unless you're meaning to contribute new features). | Refer to both of these for inspiration. Still, as mentioned in [Configuring the playbook](configuring-playbook.md), you're only ever supposed to edit your own `inventory/host_vars/matrix.example.com/vars.yml` file and nothing else inside the playbook (unless you're meaning to contribute new features). | ||||||
|  |  | ||||||
|   | |||||||
| @@ -26,7 +26,7 @@ The up-to-date list can be accessed on [traefik's documentation](https://doc.tra | |||||||
|  |  | ||||||
| **Note**: the changes below instruct you how to do this for a basic Synapse installation. You will need to adapt the variable name and the content of the labels: | **Note**: the changes below instruct you how to do this for a basic Synapse installation. You will need to adapt the variable name and the content of the labels: | ||||||
|  |  | ||||||
| - if you're using another homeserver implementation (e.g. [Conduit](./configuring-playbook-conduit.md), [conduwuit](./configuring-playbook-conduwuit.md), [continuwuity](./configuring-playbook-continuwuity.md) or [Dendrite](./configuring-playbook-dendrite.md)) | - if you're using another homeserver implementation (e.g. [Conduit](./configuring-playbook-conduit.md), [conduwuit](./configuring-playbook-conduwuit.md) or [Dendrite](./configuring-playbook-dendrite.md)) | ||||||
| - if you're using [Synapse with workers enabled](./configuring-playbook-synapse.md#load-balancing-with-workers) (`matrix_synapse_workers_enabled: true`). In that case, it's actually the `matrix-synapse-reverse-proxy-companion` service which has Traefik labels attached | - if you're using [Synapse with workers enabled](./configuring-playbook-synapse.md#load-balancing-with-workers) (`matrix_synapse_workers_enabled: true`). In that case, it's actually the `matrix-synapse-reverse-proxy-companion` service which has Traefik labels attached | ||||||
|  |  | ||||||
| Also, all instructions below are from an older version of the playbook and may not work anymore. | Also, all instructions below are from an older version of the playbook and may not work anymore. | ||||||
| @@ -42,7 +42,7 @@ This is because with SRV federation, some servers / tools (one of which being th | |||||||
|  |  | ||||||
| ### Tell Traefik which certificate to serve for the federation endpoint | ### Tell Traefik which certificate to serve for the federation endpoint | ||||||
|  |  | ||||||
| Now that the federation endpoint is not bound to a domain anymore we need to explicitly tell Traefik to use a wildcard certificate in addition to one containing the base name. | Now that the federation endpoint is not bound to a domain anymore we need to explicitely tell Traefik to use a wildcard certificate in addition to one containing the base name. | ||||||
|  |  | ||||||
| This is because the Matrix specification expects the federation endpoint to be served using a certificate compatible with the base domain, however, the other resources on the endpoint still need a valid certificate to work. | This is because the Matrix specification expects the federation endpoint to be served using a certificate compatible with the base domain, however, the other resources on the endpoint still need a valid certificate to work. | ||||||
|  |  | ||||||
| @@ -79,8 +79,8 @@ traefik_configuration_extension_yaml: | | |||||||
|             - "8.8.8.8:53" |             - "8.8.8.8:53" | ||||||
|         storage: {{ traefik_config_certificatesResolvers_acme_storage | to_json }} |         storage: {{ traefik_config_certificatesResolvers_acme_storage | to_json }} | ||||||
|  |  | ||||||
| # 2. Configure the environment variables needed by Traefik to automate the ACME DNS Challenge (example for Cloudflare) | # 2. Configure the environment variables needed by Rraefik to automate the ACME DNS Challenge (example for Cloudflare) | ||||||
| traefik_environment_variables: | | traefik_environment_variables_additional_variables: | | ||||||
|   CF_API_EMAIL=redacted |   CF_API_EMAIL=redacted | ||||||
|   CF_ZONE_API_TOKEN=redacted |   CF_ZONE_API_TOKEN=redacted | ||||||
|   CF_DNS_API_TOKEN=redacted |   CF_DNS_API_TOKEN=redacted | ||||||
| @@ -158,7 +158,7 @@ traefik_configuration_extension_yaml: | | |||||||
| traefik_certResolver_primary: "dns" | traefik_certResolver_primary: "dns" | ||||||
|  |  | ||||||
| # Configure the environment variables needed by Traefik to automate the ACME DNS Challenge (example for Cloudflare) | # Configure the environment variables needed by Traefik to automate the ACME DNS Challenge (example for Cloudflare) | ||||||
| traefik_environment_variables: | | traefik_environment_variables_additional_variables: | | ||||||
|   CF_API_EMAIL=redacted |   CF_API_EMAIL=redacted | ||||||
|   CF_ZONE_API_TOKEN=redacted |   CF_ZONE_API_TOKEN=redacted | ||||||
|   CF_DNS_API_TOKEN=redacted |   CF_DNS_API_TOKEN=redacted | ||||||
|   | |||||||
| @@ -157,8 +157,6 @@ The upstream projects, which this playbook makes use of, occasionally if not oft | |||||||
|  |  | ||||||
| Since it is unsafe to keep outdated services running on the server connected to the internet, please consider to update the playbook and re-run it periodically, in order to keep the services up-to-date. | Since it is unsafe to keep outdated services running on the server connected to the internet, please consider to update the playbook and re-run it periodically, in order to keep the services up-to-date. | ||||||
|  |  | ||||||
| Also, do not forget to update your system regularly. While this playbook may install basic services, such as Docker, it will not interfere further with system maintenance. Keeping the system itself up-to-date is out of scope for this playbook. |  | ||||||
|  |  | ||||||
| For more information about upgrading or maintaining services with the playbook, take a look at this page: [Upgrading the Matrix services](maintenance-upgrading-services.md) | For more information about upgrading or maintaining services with the playbook, take a look at this page: [Upgrading the Matrix services](maintenance-upgrading-services.md) | ||||||
|  |  | ||||||
| Feel free to **re-run the setup command any time** you think something is wrong with the server configuration. Ansible will take your configuration and update your server to match. | Feel free to **re-run the setup command any time** you think something is wrong with the server configuration. Ansible will take your configuration and update your server to match. | ||||||
|   | |||||||
| @@ -98,18 +98,18 @@ As part of the upgrade, the database is dumped to `/tmp`, an upgraded and empty | |||||||
|  |  | ||||||
| To save disk space in `/tmp`, the dump file is gzipped on the fly at the expense of CPU usage. If you have plenty of space in `/tmp` and would rather avoid gzipping, you can explicitly pass a dump filename which doesn't end in `.gz`. Example: `--extra-vars="postgres_dump_name=matrix-postgres-dump.sql"` | To save disk space in `/tmp`, the dump file is gzipped on the fly at the expense of CPU usage. If you have plenty of space in `/tmp` and would rather avoid gzipping, you can explicitly pass a dump filename which doesn't end in `.gz`. Example: `--extra-vars="postgres_dump_name=matrix-postgres-dump.sql"` | ||||||
|  |  | ||||||
| **All databases, roles, etc. on the Postgres server are migrated**. However, other components that depend on specific Postgres versions (like the [Postgres Backup](configuring-playbook-postgres-backup.md) service) may need to be updated after the upgrade by using `just install-all` | **All databases, roles, etc. on the Postgres server are migrated**. | ||||||
|  |  | ||||||
| ## Tuning PostgreSQL | ## Tuning PostgreSQL | ||||||
|  |  | ||||||
| PostgreSQL can be [tuned](https://wiki.postgresql.org/wiki/Tuning_Your_PostgreSQL_Server) to make it run faster. This is done by passing extra arguments to the Postgres process. | PostgreSQL can be [tuned](https://wiki.postgresql.org/wiki/Tuning_Your_PostgreSQL_Server) to make it run faster. This is done by passing extra arguments to the Postgres process. | ||||||
|  |  | ||||||
| The [Postgres Ansible role](https://github.com/mother-of-all-self-hosting/ansible-role-postgres) **already does some tuning by default**, which matches the [tuning logic](https://github.com/le0pard/pgtune/blob/master/src/features/configuration/configurationSlice.js) done by websites like https://pgtune.leopard.in.ua/. You can manually influence some of the tuning variables. These parameters (variables) are injected via the `postgres_postgres_process_extra_arguments_default` variable. | The [Postgres Ansible role](https://github.com/mother-of-all-self-hosting/ansible-role-postgres) **already does some tuning by default**, which matches the [tuning logic](https://github.com/le0pard/pgtune/blob/master/src/features/configuration/configurationSlice.js) done by websites like https://pgtune.leopard.in.ua/. You can manually influence some of the tuning variables. These parameters (variables) are injected via the `postgres_postgres_process_extra_arguments_auto` variable. | ||||||
|  |  | ||||||
| Most users should be fine with the automatically-done tuning. However, you may wish to: | Most users should be fine with the automatically-done tuning. However, you may wish to: | ||||||
|  |  | ||||||
| - **adjust the automatically-determined tuning parameters manually**: change the values for the tuning variables defined in the Postgres role's [default configuration file](https://github.com/mother-of-all-self-hosting/ansible-role-postgres/blob/main/defaults/main.yml) (see `postgres_max_connections`, `postgres_data_storage` etc). These variables are ultimately passed to Postgres via a `postgres_postgres_process_extra_arguments_default` variable | - **adjust the automatically-determined tuning parameters manually**: change the values for the tuning variables defined in the Postgres role's [default configuration file](https://github.com/mother-of-all-self-hosting/ansible-role-postgres/blob/main/defaults/main.yml) (see `postgres_max_connections`, `postgres_data_storage` etc). These variables are ultimately passed to Postgres via a `postgres_postgres_process_extra_arguments_auto` variable | ||||||
|  |  | ||||||
| - **turn automatically-performed tuning off**: override it like this: `postgres_postgres_process_extra_arguments_default: []` | - **turn automatically-performed tuning off**: override it like this: `postgres_postgres_process_extra_arguments_auto: []` | ||||||
|  |  | ||||||
| - **add additional tuning parameters**: define your additional Postgres configuration parameters in `postgres_postgres_process_extra_arguments_custom`. See `postgres_postgres_process_extra_arguments_default` defined in the Postgres role's [default configuration file](https://github.com/mother-of-all-self-hosting/ansible-role-postgres/blob/main/defaults/main.yml) for inspiration | - **add additional tuning parameters**: define your additional Postgres configuration parameters in `postgres_postgres_process_extra_arguments_custom`. See `postgres_postgres_process_extra_arguments_auto` defined in the Postgres role's [default configuration file](https://github.com/mother-of-all-self-hosting/ansible-role-postgres/blob/main/defaults/main.yml) for inspiration | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ Here are some playbook tags that you should be familiar with: | |||||||
|  |  | ||||||
| - `stop` — stops all systemd services | - `stop` — stops all systemd services | ||||||
|  |  | ||||||
| - `ensure-matrix-users-created` or its alias `ensure-users-created` — a special tag which ensures that all special users needed by the playbook (for bots, etc.) are created. See the variable `matrix_user_creator_users_auto` on [`group_vars/matrix_servers`](../group_vars/matrix_servers) for actual values of users which running this tag can create by default. | - `ensure-matrix-users-created` or its alias `ensure-users-created` — a special tag which ensures that all special users needed by the playbook (for bots, etc.) are created | ||||||
|  |  | ||||||
| **Notes**: | **Notes**: | ||||||
| - `setup-*` tags and `install-*` tags **do not start services** automatically, because you may wish to do things before starting services, such as importing a database dump, restoring data from another server, etc. | - `setup-*` tags and `install-*` tags **do not start services** automatically, because you may wish to do things before starting services, such as importing a database dump, restoring data from another server, etc. | ||||||
|   | |||||||
| @@ -49,7 +49,7 @@ We will be using `example.com` as the domain in the following instruction. Pleas | |||||||
|  |  | ||||||
| - [Python](https://www.python.org/). Most distributions install Python by default, but some don't (e.g. Ubuntu 18.04) and require manual installation (something like `apt-get install python3`). On some distros, Ansible may incorrectly [detect the Python version](https://docs.ansible.com/ansible/latest/reference_appendices/interpreter_discovery.html) (2 vs 3) and you may need to explicitly specify the interpreter path in `inventory/hosts` during installation (e.g. `ansible_python_interpreter=/usr/bin/python3`) | - [Python](https://www.python.org/). Most distributions install Python by default, but some don't (e.g. Ubuntu 18.04) and require manual installation (something like `apt-get install python3`). On some distros, Ansible may incorrectly [detect the Python version](https://docs.ansible.com/ansible/latest/reference_appendices/interpreter_discovery.html) (2 vs 3) and you may need to explicitly specify the interpreter path in `inventory/hosts` during installation (e.g. `ansible_python_interpreter=/usr/bin/python3`) | ||||||
|  |  | ||||||
| - [sudo](https://www.sudo.ws/), even when you've configured Ansible to log in as `root`, because this Ansible playbook sometimes uses the Ansible [become](https://docs.ansible.com/ansible/latest/playbook_guide/playbooks_privilege_escalation.html) module to perform tasks as another user (e.g. `matrix`) and the `become` module's default implementation uses `sudo`. Some distributions, like a minimal Debian net install, do not include the `sudo` package by default. | - [sudo](https://www.sudo.ws/), even when you've configured Ansible to log in as `root`. Some distributions, like a minimal Debian net install, do not include the `sudo` package by default. | ||||||
|  |  | ||||||
| - An HTTPS-capable web server at the base domain name (`example.com`) which is capable of serving static files. Unless you decide to [Serve the base domain from the Matrix server](configuring-playbook-base-domain-serving.md) or alternatively, to use DNS SRV records for [Server Delegation](howto-server-delegation.md). | - An HTTPS-capable web server at the base domain name (`example.com`) which is capable of serving static files. Unless you decide to [Serve the base domain from the Matrix server](configuring-playbook-base-domain-serving.md) or alternatively, to use DNS SRV records for [Server Delegation](howto-server-delegation.md). | ||||||
|  |  | ||||||
| @@ -59,10 +59,10 @@ We will be using `example.com` as the domain in the following instruction. Pleas | |||||||
|  |  | ||||||
|   - `80/tcp`: HTTP webserver |   - `80/tcp`: HTTP webserver | ||||||
|   - `443/tcp` and `443/udp`: HTTPS webserver |   - `443/tcp` and `443/udp`: HTTPS webserver | ||||||
|   - `3478/tcp`: STUN/TURN over TCP (used by [coturn](./configuring-playbook-turn.md)) |   - `3478/tcp`: STUN/TURN over TCP (used by [coturn](./docs/configuring-playbook-turn.md)) | ||||||
|   - `3478/udp`: STUN/TURN over UDP (used by [coturn](./configuring-playbook-turn.md)) |   - `3478/udp`: STUN/TURN over TCP (used by [coturn](./docs/configuring-playbook-turn.md)) | ||||||
|   - `5349/tcp`: TURN over TCP (used by [coturn](./configuring-playbook-turn.md)) |   - `5349/tcp`: TURN over TCP (used by [coturn](./docs/configuring-playbook-turn.md)) | ||||||
|   - `5349/udp`: TURN over UDP (used by [coturn](./configuring-playbook-turn.md)) |   - `5349/udp`: TURN over UDP (used by [coturn](./docs/configuring-playbook-turn.md)) | ||||||
|   - `8448/tcp` and `8448/udp`: Matrix Federation API HTTPS webserver. Some components like [Matrix User Verification Service](configuring-playbook-user-verification-service.md#open-matrix-federation-port) require this port to be opened **even with federation disabled**. |   - `8448/tcp` and `8448/udp`: Matrix Federation API HTTPS webserver. Some components like [Matrix User Verification Service](configuring-playbook-user-verification-service.md#open-matrix-federation-port) require this port to be opened **even with federation disabled**. | ||||||
|   - the range `49152-49172/udp`: TURN over UDP |   - the range `49152-49172/udp`: TURN over UDP | ||||||
|   - potentially some other ports, depending on the additional (non-default) services that you enable in the **configuring the playbook** step (later on). Consult each service's documentation page in `docs/` for that. |   - potentially some other ports, depending on the additional (non-default) services that you enable in the **configuring the playbook** step (later on). Consult each service's documentation page in `docs/` for that. | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ | |||||||
| # | # | ||||||
| # To connect using a non-root user (and elevate to root with sudo later), | # To connect using a non-root user (and elevate to root with sudo later), | ||||||
| # replace `ansible_ssh_user=root` with something like this: `ansible_ssh_user=username ansible_become=true ansible_become_user=root`. | # replace `ansible_ssh_user=root` with something like this: `ansible_ssh_user=username ansible_become=true ansible_become_user=root`. | ||||||
| # If sudo requires a password, either add `ansible_become_password=PASSWORD_HERE` to the host line | # If sudo requires a password, either add `become_password=PASSWORD_HERE` to the host line | ||||||
| # or tell Ansible to ask you for the password interactively by adding a `--ask-become-pass` (`-K`) flag to all `ansible-playbook` (or `just`) commands. | # or tell Ansible to ask you for the password interactively by adding a `--ask-become-pass` (`-K`) flag to all `ansible-playbook` (or `just`) commands. | ||||||
| # | # | ||||||
| # For improved Ansible performance, SSH pipelining is enabled by default in `ansible.cfg`. | # For improved Ansible performance, SSH pipelining is enabled by default in `ansible.cfg`. | ||||||
|   | |||||||
| @@ -33,12 +33,6 @@ | |||||||
| 	ProxyRequests Off | 	ProxyRequests Off | ||||||
| 	ProxyVia On | 	ProxyVia On | ||||||
| 	RequestHeader set "X-Forwarded-Proto" expr=%{REQUEST_SCHEME} | 	RequestHeader set "X-Forwarded-Proto" expr=%{REQUEST_SCHEME} | ||||||
| 	ProxyTimeout 86400 |  | ||||||
|  |  | ||||||
| 	RewriteEngine On |  | ||||||
| 	RewriteCond %{HTTP:Connection} Upgrade [NC] |  | ||||||
| 	RewriteCond %{HTTP:Upgrade} websocket [NC] |  | ||||||
| 	RewriteRule /(.*) ws://127.0.0.1:81/$1 [P,L] |  | ||||||
|  |  | ||||||
| 	AllowEncodedSlashes NoDecode | 	AllowEncodedSlashes NoDecode | ||||||
| 	ProxyPass / http://127.0.0.1:81/ retry=0 nocanon | 	ProxyPass / http://127.0.0.1:81/ retry=0 nocanon | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ matrix.example.com { | |||||||
|         encode zstd gzip |         encode zstd gzip | ||||||
|  |  | ||||||
|         # Use the docker service name instead of localhost or 127.0.0.1 here |         # Use the docker service name instead of localhost or 127.0.0.1 here | ||||||
|         reverse_proxy matrix-traefik:8080 { |         matrix-traefik:8080 { | ||||||
|                header_up X-Forwarded-Port {http.request.port} |                header_up X-Forwarded-Port {http.request.port} | ||||||
|                header_up X-Forwarded-TlsProto {tls_protocol} |                header_up X-Forwarded-TlsProto {tls_protocol} | ||||||
|                header_up X-Forwarded-TlsCipher {tls_cipher} |                header_up X-Forwarded-TlsCipher {tls_cipher} | ||||||
|   | |||||||
| @@ -23,7 +23,7 @@ If Matrix federation is enabled, then you will need to make changes to [NPM's Do | |||||||
|  |  | ||||||
| You'll need to create two proxy hosts in NPM for Matrix web and federation traffic. | You'll need to create two proxy hosts in NPM for Matrix web and federation traffic. | ||||||
|  |  | ||||||
| Open the 'Proxy Hosts' page in the NPM web interface and select `Add Proxy Host`, the first being for Matrix web traffic. Apply the proxy's configuration like this: | Open the 'Proxy Hosts' page in the NPM web interface and select `Add Proxy Host`, the first being for Matrix web traffic. Apply the proxys configuration like this: | ||||||
|  |  | ||||||
| ```md | ```md | ||||||
| # Details | # Details | ||||||
| @@ -44,7 +44,7 @@ Custom Nginx Configuration: | |||||||
| 	client_max_body_size 50M; | 	client_max_body_size 50M; | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Again, under the 'Proxy Hosts' page select `Add Proxy Host`, this time for your federation traffic. Apply the proxy's configuration like this: | Again, under the 'Proxy Hosts' page select `Add Proxy Host`, this time for your federation traffic. Apply the proxys configuration like this: | ||||||
|  |  | ||||||
| ```md | ```md | ||||||
| # Details | # Details | ||||||
|   | |||||||
| @@ -73,11 +73,11 @@ matrix_federation_traefik_entrypoint_tls: "{{ traefik_config_entrypoint_web_secu | |||||||
| #                                                                      # | #                                                                      # | ||||||
| ######################################################################## | ######################################################################## | ||||||
|  |  | ||||||
| aux_directory_default_owner: "{{ matrix_user_name }}" | aux_directory_default_owner: "{{ matrix_user_username }}" | ||||||
| aux_directory_default_group: "{{ matrix_group_name }}" | aux_directory_default_group: "{{ matrix_user_groupname }}" | ||||||
|  |  | ||||||
| aux_file_default_owner: "{{ matrix_user_name }}" | aux_file_default_owner: "{{ matrix_user_username }}" | ||||||
| aux_file_default_group: "{{ matrix_group_name }}" | aux_file_default_group: "{{ matrix_user_groupname }}" | ||||||
|  |  | ||||||
| ######################################################################## | ######################################################################## | ||||||
| #                                                                      # | #                                                                      # | ||||||
| @@ -162,8 +162,6 @@ matrix_homeserver_container_extra_arguments_auto: | | |||||||
|     + |     + | ||||||
|     (['--mount type=bind,src=' + matrix_sms_bridge_config_path + '/registration.yaml,dst=/matrix-sms-bridge-registration.yaml,ro'] if matrix_sms_bridge_enabled else []) |     (['--mount type=bind,src=' + matrix_sms_bridge_config_path + '/registration.yaml,dst=/matrix-sms-bridge-registration.yaml,ro'] if matrix_sms_bridge_enabled else []) | ||||||
|     + |     + | ||||||
|     (['--mount type=bind,src=' + matrix_steam_bridge_config_path + '/registration.yaml,dst=/matrix-steam-bridge-registration.yaml,ro'] if matrix_steam_bridge_enabled else []) |  | ||||||
|     + |  | ||||||
|     (['--mount type=bind,src=' + matrix_cactus_comments_app_service_config_file + ',dst=/matrix-cactus-comments.yaml,ro'] if matrix_cactus_comments_enabled else []) |     (['--mount type=bind,src=' + matrix_cactus_comments_app_service_config_file + ',dst=/matrix-cactus-comments.yaml,ro'] if matrix_cactus_comments_enabled else []) | ||||||
|   }} |   }} | ||||||
|  |  | ||||||
| @@ -238,8 +236,6 @@ matrix_homeserver_app_service_config_files_auto: | | |||||||
|     (['/matrix-sms-bridge-registration.yaml'] if matrix_sms_bridge_enabled else []) |     (['/matrix-sms-bridge-registration.yaml'] if matrix_sms_bridge_enabled else []) | ||||||
|     + |     + | ||||||
|     (['/matrix-cactus-comments.yaml'] if matrix_cactus_comments_enabled else []) |     (['/matrix-cactus-comments.yaml'] if matrix_cactus_comments_enabled else []) | ||||||
|     + |  | ||||||
|     (['/matrix-steam-bridge-registration.yaml'] if matrix_steam_bridge_enabled else []) |  | ||||||
|   }} |   }} | ||||||
|  |  | ||||||
| matrix_addons_homeserver_container_network: "{{ matrix_playbook_reverse_proxy_container_network if matrix_playbook_internal_matrix_client_api_traefik_entrypoint_enabled else matrix_homeserver_container_network }}" | matrix_addons_homeserver_container_network: "{{ matrix_playbook_reverse_proxy_container_network if matrix_playbook_internal_matrix_client_api_traefik_entrypoint_enabled else matrix_homeserver_container_network }}" | ||||||
| @@ -247,7 +243,7 @@ matrix_addons_homeserver_client_api_url: "{{ ('http://' + matrix_playbook_revers | |||||||
| matrix_addons_homeserver_systemd_services_list: "{{ ([traefik_identifier + '.service'] if matrix_playbook_reverse_proxy_type == 'playbook-managed-traefik' else []) if matrix_playbook_internal_matrix_client_api_traefik_entrypoint_enabled else matrix_homeserver_systemd_services_list }}" | matrix_addons_homeserver_systemd_services_list: "{{ ([traefik_identifier + '.service'] if matrix_playbook_reverse_proxy_type == 'playbook-managed-traefik' else []) if matrix_playbook_internal_matrix_client_api_traefik_entrypoint_enabled else matrix_homeserver_systemd_services_list }}" | ||||||
|  |  | ||||||
| # Starting from version `0.6.0` Conduit natively supports some sync v3 (sliding-sync) features. | # Starting from version `0.6.0` Conduit natively supports some sync v3 (sliding-sync) features. | ||||||
| matrix_homeserver_sliding_sync_url: "{{ matrix_sliding_sync_base_url if matrix_sliding_sync_enabled else (matrix_homeserver_url if matrix_homeserver_implementation in ['conduit', 'conduwuit', 'continuwuity'] else '') }}" | matrix_homeserver_sliding_sync_url: "{{ matrix_sliding_sync_base_url if matrix_sliding_sync_enabled else (matrix_homeserver_url if matrix_homeserver_implementation in ['conduit', 'conduwuit'] else '') }}" | ||||||
|  |  | ||||||
| ######################################################################## | ######################################################################## | ||||||
| #                                                                      # | #                                                                      # | ||||||
| @@ -385,8 +381,6 @@ devture_systemd_service_manager_services_list_auto: | | |||||||
|     + |     + | ||||||
|     ([{'name': 'matrix-sms-bridge.service', 'priority': 2000, 'groups': ['matrix', 'bridges', 'sms']}] if matrix_sms_bridge_enabled else []) |     ([{'name': 'matrix-sms-bridge.service', 'priority': 2000, 'groups': ['matrix', 'bridges', 'sms']}] if matrix_sms_bridge_enabled else []) | ||||||
|     + |     + | ||||||
|     ([{'name': 'matrix-steam-bridge.service', 'priority': 2000, 'groups': ['matrix', 'bridges', 'matrix-steam-bridge']}] if matrix_steam_bridge_enabled else []) |  | ||||||
|     + |  | ||||||
|     ([{'name': 'matrix-cactus-comments.service', 'priority': 2000, 'groups': ['matrix', 'cactus-comments']}] if matrix_cactus_comments_enabled else []) |     ([{'name': 'matrix-cactus-comments.service', 'priority': 2000, 'groups': ['matrix', 'cactus-comments']}] if matrix_cactus_comments_enabled else []) | ||||||
|     + |     + | ||||||
|     ([{'name': 'matrix-cactus-comments-client.service', 'priority': 2000, 'groups': ['matrix', 'cactus-comments-client']}] if matrix_cactus_comments_client_enabled else []) |     ([{'name': 'matrix-cactus-comments-client.service', 'priority': 2000, 'groups': ['matrix', 'cactus-comments-client']}] if matrix_cactus_comments_client_enabled else []) | ||||||
| @@ -453,8 +447,6 @@ devture_systemd_service_manager_services_list_auto: | | |||||||
|     + |     + | ||||||
|     ([{'name': 'matrix-pantalaimon.service', 'priority': 4000, 'groups': ['matrix', 'pantalaimon']}] if matrix_pantalaimon_enabled else []) |     ([{'name': 'matrix-pantalaimon.service', 'priority': 4000, 'groups': ['matrix', 'pantalaimon']}] if matrix_pantalaimon_enabled else []) | ||||||
|     + |     + | ||||||
|     ([{'name': 'matrix-element-admin.service', 'priority': 4000, 'groups': ['matrix', 'element-admin']}] if matrix_element_admin_enabled else []) |  | ||||||
|     + |  | ||||||
|     ([{'name': 'matrix-element-call.service', 'priority': 4000, 'groups': ['matrix', 'element-call']}] if matrix_element_call_enabled else []) |     ([{'name': 'matrix-element-call.service', 'priority': 4000, 'groups': ['matrix', 'element-call']}] if matrix_element_call_enabled else []) | ||||||
|     + |     + | ||||||
|     ([{'name': 'matrix-livekit-jwt-service.service', 'priority': 3500, 'groups': ['matrix', 'livekit-jwt-service']}] if matrix_livekit_jwt_service_enabled else []) |     ([{'name': 'matrix-livekit-jwt-service.service', 'priority': 3500, 'groups': ['matrix', 'livekit-jwt-service']}] if matrix_livekit_jwt_service_enabled else []) | ||||||
| @@ -575,7 +567,6 @@ matrix_homeserver_container_client_api_endpoint: |- | |||||||
|       'dendrite': ('matrix-dendrite:' + matrix_dendrite_http_bind_port | default('8008') | string), |       'dendrite': ('matrix-dendrite:' + matrix_dendrite_http_bind_port | default('8008') | string), | ||||||
|       'conduit': ('matrix-conduit:' + matrix_conduit_port_number | default('8008') | string), |       'conduit': ('matrix-conduit:' + matrix_conduit_port_number | default('8008') | string), | ||||||
|       'conduwuit': ('matrix-conduwuit:' + matrix_conduwuit_config_port_number | default('8008') | string), |       'conduwuit': ('matrix-conduwuit:' + matrix_conduwuit_config_port_number | default('8008') | string), | ||||||
|       'continuwuity': ('matrix-continuwuity:' + matrix_continuwuity_config_port_number | default('8008') | string), |  | ||||||
|     }[matrix_homeserver_implementation] |     }[matrix_homeserver_implementation] | ||||||
|   }} |   }} | ||||||
|  |  | ||||||
| @@ -586,7 +577,6 @@ matrix_homeserver_container_federation_api_endpoint: |- | |||||||
|       'dendrite': ('matrix-dendrite:' + matrix_dendrite_http_bind_port | default('8008') | string), |       'dendrite': ('matrix-dendrite:' + matrix_dendrite_http_bind_port | default('8008') | string), | ||||||
|       'conduit': ('matrix-conduit:' + matrix_conduit_port_number | default('8008') | string), |       'conduit': ('matrix-conduit:' + matrix_conduit_port_number | default('8008') | string), | ||||||
|       'conduwuit': ('matrix-conduwuit:' + matrix_conduwuit_config_port_number | default('8008') | string), |       'conduwuit': ('matrix-conduwuit:' + matrix_conduwuit_config_port_number | default('8008') | string), | ||||||
|       'continuwuity': ('matrix-continuwuity:' + matrix_continuwuity_config_port_number | default('8008') | string), |  | ||||||
|     }[matrix_homeserver_implementation] |     }[matrix_homeserver_implementation] | ||||||
|   }} |   }} | ||||||
|  |  | ||||||
| @@ -674,20 +664,30 @@ matrix_authentication_service_config_passwords_schemes: | |||||||
|   - version: 1 |   - version: 1 | ||||||
|     secret: "{{ matrix_synapse_password_config_pepper }}" |     secret: "{{ matrix_synapse_password_config_pepper }}" | ||||||
|     algorithm: bcrypt |     algorithm: bcrypt | ||||||
|     unicode_normalization: true |  | ||||||
|   - version: 2 |   - version: 2 | ||||||
|     algorithm: argon2id |     algorithm: argon2id | ||||||
|  |  | ||||||
|  | matrix_authentication_service_config_clients_auto: |- | ||||||
|  |   {{ | ||||||
|  |     ([ | ||||||
|  |       { | ||||||
|  |         'client_id': matrix_synapse_experimental_features_msc3861_client_id, | ||||||
|  |         'client_auth_method': matrix_synapse_experimental_features_msc3861_client_auth_method, | ||||||
|  |         'client_secret': matrix_synapse_experimental_features_msc3861_client_secret, | ||||||
|  |       } | ||||||
|  |     ] if matrix_synapse_experimental_features_msc3861_enabled else []) | ||||||
|  |   }} | ||||||
|  |  | ||||||
| matrix_authentication_service_config_email_transport: "{{ 'smtp' if exim_relay_enabled else 'blackhole' }}" | matrix_authentication_service_config_email_transport: "{{ 'smtp' if exim_relay_enabled else 'blackhole' }}" | ||||||
| matrix_authentication_service_config_email_hostname: "{{ exim_relay_identifier if exim_relay_enabled else '' }}" | matrix_authentication_service_config_email_hostname: "{{ exim_relay_identifier if exim_relay_enabled else '' }}" | ||||||
| matrix_authentication_service_config_email_port: "{{ 8025 if exim_relay_enabled else 587 }}" | matrix_authentication_service_config_email_port: "{{ 8025 if exim_relay_enabled else 587 }}" | ||||||
| matrix_authentication_service_config_email_mode: "{{ 'plain' if exim_relay_enabled else 'starttls' }}" | matrix_authentication_service_config_email_mode: "{{ 'plain' if exim_relay_enabled else 'starttls' }}" | ||||||
| matrix_authentication_service_config_email_from_address: "{{ exim_relay_sender_address }}" | matrix_authentication_service_config_email_from_address: "{{ exim_relay_sender_address }}" | ||||||
|  |  | ||||||
| matrix_authentication_service_admin_api_enabled: "{{ matrix_element_admin_enabled }}" |  | ||||||
|  |  | ||||||
| matrix_authentication_service_container_image_registry_prefix_upstream: "{{ matrix_container_global_registry_prefix_override if matrix_container_global_registry_prefix_override else matrix_authentication_service_container_image_registry_prefix_upstream_default }}" | matrix_authentication_service_container_image_registry_prefix_upstream: "{{ matrix_container_global_registry_prefix_override if matrix_container_global_registry_prefix_override else matrix_authentication_service_container_image_registry_prefix_upstream_default }}" | ||||||
|  |  | ||||||
|  | matrix_authentication_service_syn2mas_container_image_registry_prefix_upstream: "{{ matrix_container_global_registry_prefix_override if matrix_container_global_registry_prefix_override else matrix_authentication_service_syn2mas_container_image_registry_prefix_upstream_default }}" | ||||||
|  |  | ||||||
| matrix_authentication_service_container_image_self_build: "{{ matrix_architecture not in ['amd64', 'arm64'] }}" | matrix_authentication_service_container_image_self_build: "{{ matrix_architecture not in ['amd64', 'arm64'] }}" | ||||||
|  |  | ||||||
| matrix_authentication_service_container_network: "{{ matrix_homeserver_container_network }}" | matrix_authentication_service_container_network: "{{ matrix_homeserver_container_network }}" | ||||||
| @@ -997,8 +997,6 @@ matrix_appservice_kakaotalk_appservice_token: "{{ '%s' | format(matrix_homeserve | |||||||
| matrix_appservice_kakaotalk_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | matrix_appservice_kakaotalk_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | ||||||
| matrix_appservice_kakaotalk_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'as.kakao.hs', rounds=655555) | to_uuid }}" | matrix_appservice_kakaotalk_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'as.kakao.hs', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_appservice_kakaotalk_homeserver_async_media: "{{ matrix_homeserver_implementation in ['synapse'] }}" |  | ||||||
|  |  | ||||||
| matrix_appservice_kakaotalk_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_appservice_kakaotalk_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_appservice_kakaotalk_database_engine: "{{ 'postgres' if postgres_enabled else 'sqlite' }}" | matrix_appservice_kakaotalk_database_engine: "{{ 'postgres' if postgres_enabled else 'sqlite' }}" | ||||||
| @@ -1048,8 +1046,6 @@ matrix_beeper_linkedin_appservice_token: "{{ '%s' | format(matrix_homeserver_gen | |||||||
| matrix_beeper_linkedin_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | matrix_beeper_linkedin_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | ||||||
| matrix_beeper_linkedin_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'linked.hs.token', rounds=655555) | to_uuid }}" | matrix_beeper_linkedin_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'linked.hs.token', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_beeper_linkedin_homeserver_async_media: "{{ matrix_homeserver_implementation in ['synapse'] }}" |  | ||||||
|  |  | ||||||
| matrix_beeper_linkedin_bridge_login_shared_secret_map_auto: |- | matrix_beeper_linkedin_bridge_login_shared_secret_map_auto: |- | ||||||
|   {{ |   {{ | ||||||
|     ({ |     ({ | ||||||
| @@ -1170,8 +1166,6 @@ matrix_mautrix_bluesky_appservice_token: "{{ '%s' | format(matrix_homeserver_gen | |||||||
| matrix_mautrix_bluesky_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | matrix_mautrix_bluesky_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | ||||||
| matrix_mautrix_bluesky_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'bsky.hs.token', rounds=655555) | to_uuid }}" | matrix_mautrix_bluesky_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'bsky.hs.token', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_mautrix_bluesky_homeserver_async_media: "{{ matrix_homeserver_implementation in ['synapse'] }}" |  | ||||||
|  |  | ||||||
| matrix_mautrix_bluesky_provisioning_shared_secret: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'mau.bsky.prov', rounds=655555) | to_uuid }}" | matrix_mautrix_bluesky_provisioning_shared_secret: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'mau.bsky.prov', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_mautrix_bluesky_double_puppet_secrets_auto: |- | matrix_mautrix_bluesky_double_puppet_secrets_auto: |- | ||||||
| @@ -1241,8 +1235,6 @@ matrix_mautrix_discord_appservice_token: "{{ '%s' | format(matrix_homeserver_gen | |||||||
| matrix_mautrix_discord_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | matrix_mautrix_discord_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | ||||||
| matrix_mautrix_discord_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'maudisc.hs.tok', rounds=655555) | to_uuid }}" | matrix_mautrix_discord_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'maudisc.hs.tok', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_mautrix_discord_homeserver_async_media: "{{ matrix_homeserver_implementation in ['synapse'] }}" |  | ||||||
|  |  | ||||||
| matrix_mautrix_discord_bridge_avatar_proxy_key: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'maudisc.avatar', rounds=655555) | to_uuid }}" | matrix_mautrix_discord_bridge_avatar_proxy_key: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'maudisc.avatar', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_mautrix_discord_hostname: "{{ matrix_server_fqn_matrix }}" | matrix_mautrix_discord_hostname: "{{ matrix_server_fqn_matrix }}" | ||||||
| @@ -1309,8 +1301,6 @@ matrix_mautrix_slack_appservice_token: "{{ '%s' | format(matrix_homeserver_gener | |||||||
| matrix_mautrix_slack_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | matrix_mautrix_slack_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | ||||||
| matrix_mautrix_slack_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'mauslack.hs.tok', rounds=655555) | to_uuid }}" | matrix_mautrix_slack_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'mauslack.hs.tok', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_mautrix_slack_homeserver_async_media: "{{ matrix_homeserver_implementation in ['synapse'] }}" |  | ||||||
|  |  | ||||||
| matrix_mautrix_slack_double_puppet_secrets_auto: |- | matrix_mautrix_slack_double_puppet_secrets_auto: |- | ||||||
|   {{ |   {{ | ||||||
|     { |     { | ||||||
| @@ -1384,8 +1374,6 @@ matrix_mautrix_facebook_homeserver_address: "{{ matrix_addons_homeserver_client_ | |||||||
|  |  | ||||||
| matrix_mautrix_facebook_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'fb.hs.token', rounds=655555) | to_uuid }}" | matrix_mautrix_facebook_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'fb.hs.token', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_mautrix_facebook_homeserver_async_media: "{{ matrix_homeserver_implementation in ['synapse'] }}" |  | ||||||
|  |  | ||||||
| matrix_mautrix_facebook_appservice_public_enabled: true | matrix_mautrix_facebook_appservice_public_enabled: true | ||||||
| matrix_mautrix_facebook_appservice_public_hostname: "{{ matrix_server_fqn_matrix }}" | matrix_mautrix_facebook_appservice_public_hostname: "{{ matrix_server_fqn_matrix }}" | ||||||
| matrix_mautrix_facebook_appservice_public_prefix: "/{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'facebook', rounds=655555) | to_uuid }}" | matrix_mautrix_facebook_appservice_public_prefix: "/{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'facebook', rounds=655555) | to_uuid }}" | ||||||
| @@ -1606,8 +1594,6 @@ matrix_mautrix_signal_homeserver_domain: '{{ matrix_domain }}' | |||||||
| matrix_mautrix_signal_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | matrix_mautrix_signal_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | ||||||
| matrix_mautrix_signal_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'si.hs.token', rounds=655555) | to_uuid }}" | matrix_mautrix_signal_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'si.hs.token', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_mautrix_signal_homeserver_async_media: "{{ matrix_homeserver_implementation in ['synapse'] }}" |  | ||||||
|  |  | ||||||
| matrix_mautrix_signal_appservice_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'si.as.token', rounds=655555) | to_uuid }}" | matrix_mautrix_signal_appservice_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'si.as.token', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_mautrix_signal_double_puppet_secrets_auto: |- | matrix_mautrix_signal_double_puppet_secrets_auto: |- | ||||||
| @@ -1686,8 +1672,6 @@ matrix_mautrix_meta_messenger_homeserver_address: "{{ matrix_addons_homeserver_c | |||||||
|  |  | ||||||
| matrix_mautrix_meta_messenger_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'mau.meta.fb.hs', rounds=655555) | to_uuid }}" | matrix_mautrix_meta_messenger_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'mau.meta.fb.hs', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_mautrix_meta_messenger_homeserver_async_media: "{{ matrix_homeserver_implementation in ['synapse'] }}" |  | ||||||
|  |  | ||||||
| matrix_mautrix_meta_messenger_double_puppet_secrets_auto: |- | matrix_mautrix_meta_messenger_double_puppet_secrets_auto: |- | ||||||
|   {{ |   {{ | ||||||
|     { |     { | ||||||
| @@ -1764,8 +1748,6 @@ matrix_mautrix_meta_instagram_homeserver_address: "{{ matrix_addons_homeserver_c | |||||||
|  |  | ||||||
| matrix_mautrix_meta_instagram_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'mau.meta.ig.hs', rounds=655555) | to_uuid }}" | matrix_mautrix_meta_instagram_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'mau.meta.ig.hs', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_mautrix_meta_instagram_homeserver_async_media: "{{ matrix_homeserver_implementation in ['synapse'] }}" |  | ||||||
|  |  | ||||||
| matrix_mautrix_meta_instagram_double_puppet_secrets_auto: |- | matrix_mautrix_meta_instagram_double_puppet_secrets_auto: |- | ||||||
|   {{ |   {{ | ||||||
|     { |     { | ||||||
| @@ -1851,8 +1833,6 @@ matrix_mautrix_telegram_homeserver_domain: "{{ matrix_domain }}" | |||||||
| matrix_mautrix_telegram_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | matrix_mautrix_telegram_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | ||||||
| matrix_mautrix_telegram_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'telegr.hs.token', rounds=655555) | to_uuid }}" | matrix_mautrix_telegram_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'telegr.hs.token', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_mautrix_telegram_homeserver_async_media: "{{ matrix_homeserver_implementation in ['synapse'] }}" |  | ||||||
|  |  | ||||||
| matrix_mautrix_telegram_bridge_login_shared_secret_map_auto: |- | matrix_mautrix_telegram_bridge_login_shared_secret_map_auto: |- | ||||||
|   {{ |   {{ | ||||||
|     ({ |     ({ | ||||||
| @@ -1929,8 +1909,6 @@ matrix_mautrix_twitter_appservice_token: "{{ '%s' | format(matrix_homeserver_gen | |||||||
| matrix_mautrix_twitter_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | matrix_mautrix_twitter_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | ||||||
| matrix_mautrix_twitter_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'twt.hs.token', rounds=655555) | to_uuid }}" | matrix_mautrix_twitter_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'twt.hs.token', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_mautrix_twitter_homeserver_async_media: "{{ matrix_homeserver_implementation in ['synapse'] }}" |  | ||||||
|  |  | ||||||
| matrix_mautrix_twitter_provisioning_shared_secret: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'mau.twit.prov', rounds=655555) | to_uuid }}" | matrix_mautrix_twitter_provisioning_shared_secret: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'mau.twit.prov', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_mautrix_twitter_double_puppet_secrets_auto: |- | matrix_mautrix_twitter_double_puppet_secrets_auto: |- | ||||||
| @@ -2003,8 +1981,6 @@ matrix_mautrix_gmessages_appservice_token: "{{ '%s' | format(matrix_homeserver_g | |||||||
| matrix_mautrix_gmessages_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | matrix_mautrix_gmessages_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | ||||||
| matrix_mautrix_gmessages_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'gmessa.hs.token', rounds=655555) | to_uuid }}" | matrix_mautrix_gmessages_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'gmessa.hs.token', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_mautrix_gmessages_homeserver_async_media: "{{ matrix_homeserver_implementation in ['synapse'] }}" |  | ||||||
|  |  | ||||||
| matrix_mautrix_gmessages_double_puppet_secrets_auto: |- | matrix_mautrix_gmessages_double_puppet_secrets_auto: |- | ||||||
|   {{ |   {{ | ||||||
|     { |     { | ||||||
| @@ -2123,8 +2099,6 @@ matrix_wechat_appservice_token: "{{ '%s' | format(matrix_homeserver_generic_secr | |||||||
| matrix_wechat_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | matrix_wechat_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | ||||||
| matrix_wechat_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'wechat.hs.token', rounds=655555) | to_uuid }}" | matrix_wechat_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'wechat.hs.token', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_wechat_homeserver_async_media: "{{ matrix_homeserver_implementation in ['synapse'] }}" |  | ||||||
|  |  | ||||||
| matrix_wechat_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_wechat_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_wechat_bridge_listen_secret: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'wechat.lstn', rounds=655555) | to_uuid }}" | matrix_wechat_bridge_listen_secret: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'wechat.lstn', rounds=655555) | to_uuid }}" | ||||||
| @@ -2186,8 +2160,6 @@ matrix_mautrix_whatsapp_appservice_token: "{{ '%s' | format(matrix_homeserver_ge | |||||||
| matrix_mautrix_whatsapp_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | matrix_mautrix_whatsapp_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" | ||||||
| matrix_mautrix_whatsapp_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'whats.hs.token', rounds=655555) | to_uuid }}" | matrix_mautrix_whatsapp_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'whats.hs.token', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_mautrix_whatsapp_homeserver_async_media: "{{ matrix_homeserver_implementation in ['synapse'] }}" |  | ||||||
|  |  | ||||||
| matrix_mautrix_whatsapp_double_puppet_secrets_auto: |- | matrix_mautrix_whatsapp_double_puppet_secrets_auto: |- | ||||||
|   {{ |   {{ | ||||||
|     { |     { | ||||||
| @@ -2345,6 +2317,7 @@ matrix_hookshot_container_http_host_bind_ports_defaultmapping: | |||||||
|   - "{{ matrix_playbook_service_host_bind_interface_prefix }}{{ matrix_hookshot_appservice_port }}:{{ matrix_hookshot_appservice_port }}" |   - "{{ matrix_playbook_service_host_bind_interface_prefix }}{{ matrix_hookshot_appservice_port }}:{{ matrix_hookshot_appservice_port }}" | ||||||
|   - "{{ matrix_playbook_service_host_bind_interface_prefix }}{{ matrix_hookshot_metrics_port }}:{{ matrix_hookshot_metrics_port }}" |   - "{{ matrix_playbook_service_host_bind_interface_prefix }}{{ matrix_hookshot_metrics_port }}:{{ matrix_hookshot_metrics_port }}" | ||||||
|   - "{{ matrix_playbook_service_host_bind_interface_prefix }}{{ matrix_hookshot_webhook_port }}:{{ matrix_hookshot_webhook_port }}" |   - "{{ matrix_playbook_service_host_bind_interface_prefix }}{{ matrix_hookshot_webhook_port }}:{{ matrix_hookshot_webhook_port }}" | ||||||
|  |   - "{{ matrix_playbook_service_host_bind_interface_prefix }}{{ matrix_hookshot_provisioning_port }}:{{ matrix_hookshot_provisioning_port }}" | ||||||
|  |  | ||||||
| matrix_hookshot_container_http_host_bind_ports: "{{ matrix_hookshot_container_http_host_bind_ports_defaultmapping if matrix_playbook_service_host_bind_interface_prefix else [] }}" | matrix_hookshot_container_http_host_bind_ports: "{{ matrix_hookshot_container_http_host_bind_ports_defaultmapping if matrix_playbook_service_host_bind_interface_prefix else [] }}" | ||||||
|  |  | ||||||
| @@ -2353,6 +2326,8 @@ matrix_hookshot_container_labels_traefik_docker_network: "{{ matrix_playbook_rev | |||||||
| matrix_hookshot_container_labels_traefik_entrypoints: "{{ traefik_entrypoint_primary }}" | matrix_hookshot_container_labels_traefik_entrypoints: "{{ traefik_entrypoint_primary }}" | ||||||
| matrix_hookshot_container_labels_traefik_tls_certResolver: "{{ traefik_certResolver_primary }}" | matrix_hookshot_container_labels_traefik_tls_certResolver: "{{ traefik_certResolver_primary }}" | ||||||
|  |  | ||||||
|  | matrix_hookshot_provisioning_enabled: "{{ matrix_hookshot_provisioning_secret and matrix_dimension_enabled }}" | ||||||
|  |  | ||||||
| matrix_hookshot_metrics_enabled: "{{ prometheus_enabled or matrix_metrics_exposure_enabled }}" | matrix_hookshot_metrics_enabled: "{{ prometheus_enabled or matrix_metrics_exposure_enabled }}" | ||||||
|  |  | ||||||
| matrix_hookshot_metrics_proxying_enabled: "{{ matrix_hookshot_metrics_enabled and matrix_metrics_exposure_enabled }}" | matrix_hookshot_metrics_proxying_enabled: "{{ matrix_hookshot_metrics_enabled and matrix_metrics_exposure_enabled }}" | ||||||
| @@ -2777,82 +2752,6 @@ matrix_postmoogle_container_additional_networks_auto: |- | |||||||
| # | # | ||||||
| ###################################################################### | ###################################################################### | ||||||
|  |  | ||||||
| ###################################################################### |  | ||||||
| # |  | ||||||
| # matrix-bridge-steam |  | ||||||
| # |  | ||||||
| ###################################################################### |  | ||||||
|  |  | ||||||
| # We don't enable bridges by default. |  | ||||||
| matrix_steam_bridge_enabled: false |  | ||||||
|  |  | ||||||
| matrix_steam_bridge_systemd_required_services_list_auto: | |  | ||||||
|   {{ |  | ||||||
|     matrix_addons_homeserver_systemd_services_list |  | ||||||
|     + |  | ||||||
|     ([postgres_identifier ~ '.service'] if (postgres_enabled and matrix_steam_bridge_database_hostname == postgres_connection_hostname) else []) |  | ||||||
|   }} |  | ||||||
|  |  | ||||||
| matrix_steam_bridge_docker_image_registry_prefix_upstream: "{{ matrix_container_global_registry_prefix_override if matrix_container_global_registry_prefix_override else matrix_steam_bridge_docker_image_registry_prefix_upstream_default }}" |  | ||||||
|  |  | ||||||
| matrix_steam_bridge_container_image_self_build: "{{ matrix_architecture not in ['amd64', 'arm64'] }}" |  | ||||||
|  |  | ||||||
| matrix_steam_bridge_container_network: "{{ matrix_addons_container_network }}" |  | ||||||
|  |  | ||||||
| matrix_steam_bridge_container_additional_networks_auto: |- |  | ||||||
|   {{ |  | ||||||
|     ( |  | ||||||
|       ([] if matrix_addons_homeserver_container_network == '' else [matrix_addons_homeserver_container_network]) |  | ||||||
|       + |  | ||||||
|       ([postgres_container_network] if (postgres_enabled and matrix_steam_bridge_database_hostname == postgres_connection_hostname and matrix_steam_bridge_container_network != postgres_container_network) else []) |  | ||||||
|       + |  | ||||||
|       ([matrix_playbook_reverse_proxyable_services_additional_network] if matrix_playbook_reverse_proxyable_services_additional_network and matrix_steam_bridge_container_labels_traefik_enabled else []) |  | ||||||
|     ) | unique |  | ||||||
|   }} |  | ||||||
|  |  | ||||||
| matrix_steam_bridge_container_labels_traefik_enabled: "{{ matrix_playbook_reverse_proxy_type in ['playbook-managed-traefik', 'other-traefik-container'] }}" |  | ||||||
| matrix_steam_bridge_container_labels_traefik_docker_network: "{{ matrix_playbook_reverse_proxyable_services_additional_network }}" |  | ||||||
| matrix_steam_bridge_container_labels_traefik_entrypoints: "{{ traefik_entrypoint_primary }}" |  | ||||||
| matrix_steam_bridge_container_labels_traefik_tls_certResolver: "{{ traefik_certResolver_primary }}" |  | ||||||
|  |  | ||||||
| matrix_steam_bridge_container_labels_metrics_middleware_basic_auth_enabled: "{{ matrix_metrics_exposure_http_basic_auth_enabled }}" |  | ||||||
| matrix_steam_bridge_container_labels_metrics_middleware_basic_auth_users: "{{ matrix_metrics_exposure_http_basic_auth_users }}" |  | ||||||
|  |  | ||||||
| matrix_steam_bridge_appservice_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'steam.as.token', rounds=655555) | to_uuid }}" |  | ||||||
|  |  | ||||||
| matrix_steam_bridge_homeserver_address: "{{ matrix_addons_homeserver_client_api_url }}" |  | ||||||
| matrix_steam_bridge_homeserver_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'steam.hs.token', rounds=655555) | to_uuid }}" |  | ||||||
|  |  | ||||||
| matrix_steam_bridge_homeserver_async_media: "{{ matrix_homeserver_implementation in ['synapse'] }}" |  | ||||||
|  |  | ||||||
| matrix_steam_bridge_public_media_signing_key: "{{ ('%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'steam.pub.key', rounds=655555) | to_uuid) if matrix_steam_bridge_public_media_enabled else '' }}" |  | ||||||
|  |  | ||||||
| matrix_steam_bridge_provisioning_shared_secret: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'steam.prov', rounds=655555) | to_uuid }}" |  | ||||||
|  |  | ||||||
| matrix_steam_bridge_double_puppet_secrets_auto: |- |  | ||||||
|   {{ |  | ||||||
|     ({ |  | ||||||
|       matrix_steam_bridge_homeserver_domain: ("as_token:" + matrix_appservice_double_puppet_registration_as_token) |  | ||||||
|     }) |  | ||||||
|     if matrix_appservice_double_puppet_enabled |  | ||||||
|     else {} |  | ||||||
|   }} |  | ||||||
|  |  | ||||||
| matrix_steam_bridge_metrics_enabled: "{{ prometheus_enabled or matrix_metrics_exposure_enabled }}" |  | ||||||
|  |  | ||||||
| matrix_steam_bridge_metrics_proxying_enabled: "{{ matrix_steam_bridge_metrics_enabled and matrix_metrics_exposure_enabled }}" |  | ||||||
| matrix_steam_bridge_metrics_proxying_hostname: "{{ matrix_metrics_exposure_hostname }}" |  | ||||||
| matrix_steam_bridge_metrics_proxying_path_prefix: "{{ matrix_metrics_exposure_path_prefix }}/matrix-steam-bridge" |  | ||||||
|  |  | ||||||
| matrix_steam_bridge_database_hostname: "{{ postgres_connection_hostname if postgres_enabled else '' }}" |  | ||||||
| matrix_steam_bridge_database_password: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'mau.twt.db', rounds=655555) | to_uuid if postgres_enabled else '' }}" |  | ||||||
|  |  | ||||||
| ###################################################################### |  | ||||||
| # |  | ||||||
| # /matrix-bridge-steam |  | ||||||
| # |  | ||||||
| ###################################################################### |  | ||||||
|  |  | ||||||
| ###################################################################### | ###################################################################### | ||||||
| # | # | ||||||
| # matrix-bot-matrix-reminder-bot | # matrix-bot-matrix-reminder-bot | ||||||
| @@ -3300,11 +3199,8 @@ matrix_bot_draupnir_config_rawHomeserverUrl: "{{ matrix_addons_homeserver_client | |||||||
|  |  | ||||||
| matrix_bot_draupnir_container_labels_traefik_enabled: "{{ matrix_bot_draupnir_config_web_enabled and matrix_playbook_reverse_proxy_type in ['playbook-managed-traefik', 'other-traefik-container'] }}" | matrix_bot_draupnir_container_labels_traefik_enabled: "{{ matrix_bot_draupnir_config_web_enabled and matrix_playbook_reverse_proxy_type in ['playbook-managed-traefik', 'other-traefik-container'] }}" | ||||||
| matrix_bot_draupnir_container_labels_traefik_docker_network: "{{ matrix_playbook_reverse_proxyable_services_additional_network }}" | matrix_bot_draupnir_container_labels_traefik_docker_network: "{{ matrix_playbook_reverse_proxyable_services_additional_network }}" | ||||||
| matrix_bot_draupnir_container_labels_web_abuseReporting_traefik_entrypoints: "{{ traefik_entrypoint_primary }}" | matrix_bot_draupnir_container_labels_traefik_entrypoints: "{{ traefik_entrypoint_primary }}" | ||||||
| matrix_bot_draupnir_container_labels_web_abuseReporting_traefik_tls_certResolver: "{{ traefik_certResolver_primary }}" | matrix_bot_draupnir_container_labels_traefik_tls_certResolver: "{{ traefik_certResolver_primary }}" | ||||||
|  |  | ||||||
| #The salt is size restricted here as a maximum salt size of 16 characters exists due to the functions used. |  | ||||||
| matrix_bot_draupnir_config_web_synapseHTTPAntispam_authorization: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'draupnir.httpmod', rounds=655555) | to_uuid }}" # noqa var-naming |  | ||||||
|  |  | ||||||
| ###################################################################### | ###################################################################### | ||||||
| # | # | ||||||
| @@ -3416,7 +3312,7 @@ backup_borg_storage_archive_name_format: matrix-{now:%Y-%m-%d-%H%M%S} | |||||||
|  |  | ||||||
| backup_borg_base_path: "{{ matrix_base_data_path }}/backup-borg" | backup_borg_base_path: "{{ matrix_base_data_path }}/backup-borg" | ||||||
|  |  | ||||||
| backup_borg_username: "{{ matrix_user_name }}" | backup_borg_username: "{{ matrix_user_username }}" | ||||||
| backup_borg_uid: "{{ matrix_user_uid }}" | backup_borg_uid: "{{ matrix_user_uid }}" | ||||||
| backup_borg_gid: "{{ matrix_user_gid }}" | backup_borg_gid: "{{ matrix_user_gid }}" | ||||||
|  |  | ||||||
| @@ -3672,8 +3568,10 @@ matrix_coturn_container_additional_volumes: | | |||||||
|     ) |     ) | ||||||
|   }} |   }} | ||||||
|  |  | ||||||
| matrix_coturn_systemd_required_services_list_auto: | | matrix_coturn_systemd_required_services_list: | | ||||||
|   {{ |   {{ | ||||||
|  |     [devture_systemd_docker_base_docker_service_name] | ||||||
|  |     + | ||||||
|     ([traefik_certs_dumper_identifier + '-wait-for-domain@' + matrix_server_fqn_matrix + '.service'] if matrix_playbook_reverse_proxy_type in ['playbook-managed-traefik', 'other-traefik-container'] and traefik_certs_dumper_enabled and matrix_coturn_tls_enabled else []) |     ([traefik_certs_dumper_identifier + '-wait-for-domain@' + matrix_server_fqn_matrix + '.service'] if matrix_playbook_reverse_proxy_type in ['playbook-managed-traefik', 'other-traefik-container'] and traefik_certs_dumper_enabled and matrix_coturn_tls_enabled else []) | ||||||
|   }} |   }} | ||||||
|  |  | ||||||
| @@ -3797,10 +3695,10 @@ etherpad_systemd_required_services_list_auto: | | |||||||
|     ([postgres_identifier ~ '.service'] if postgres_enabled else []) |     ([postgres_identifier ~ '.service'] if postgres_enabled else []) | ||||||
|   }} |   }} | ||||||
|  |  | ||||||
| etherpad_database_postgres_hostname: "{{ postgres_connection_hostname if postgres_enabled else '' }}" | etherpad_database_hostname: "{{ postgres_connection_hostname if postgres_enabled else '' }}" | ||||||
| etherpad_database_name: matrix_etherpad | etherpad_database_name: matrix_etherpad | ||||||
| etherpad_database_postgres_username: matrix_etherpad | etherpad_database_username: matrix_etherpad | ||||||
| etherpad_database_postgres_password: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'etherpad.db', rounds=655555) | to_uuid }}" | etherpad_database_password: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'etherpad.db', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| ###################################################################### | ###################################################################### | ||||||
| # | # | ||||||
| @@ -3845,7 +3743,7 @@ jitsi_base_path: "{{ matrix_base_data_path }}/jitsi" | |||||||
| jitsi_uid: "{{ matrix_user_uid }}" | jitsi_uid: "{{ matrix_user_uid }}" | ||||||
| jitsi_gid: "{{ matrix_user_gid }}" | jitsi_gid: "{{ matrix_user_gid }}" | ||||||
|  |  | ||||||
| jitsi_user_username: "{{ matrix_user_name }}" | jitsi_user_username: "{{ matrix_user_username }}" | ||||||
|  |  | ||||||
| jitsi_web_container_image_registry_prefix_upstream: "{{ matrix_container_global_registry_prefix_override if matrix_container_global_registry_prefix_override else jitsi_web_container_image_registry_prefix_upstream_default }}" | jitsi_web_container_image_registry_prefix_upstream: "{{ matrix_container_global_registry_prefix_override if matrix_container_global_registry_prefix_override else jitsi_web_container_image_registry_prefix_upstream_default }}" | ||||||
|  |  | ||||||
| @@ -4482,12 +4380,6 @@ postgres_managed_databases_auto: | | |||||||
|       'password': matrix_mx_puppet_groupme_database_password, |       'password': matrix_mx_puppet_groupme_database_password, | ||||||
|     }] if (matrix_mx_puppet_groupme_enabled and matrix_mx_puppet_groupme_database_engine == 'postgres' and matrix_mx_puppet_groupme_database_hostname == postgres_connection_hostname) else []) |     }] if (matrix_mx_puppet_groupme_enabled and matrix_mx_puppet_groupme_database_engine == 'postgres' and matrix_mx_puppet_groupme_database_hostname == postgres_connection_hostname) else []) | ||||||
|     + |     + | ||||||
|     ([{ |  | ||||||
|       'name': matrix_steam_bridge_database_name, |  | ||||||
|       'username': matrix_steam_bridge_database_username, |  | ||||||
|       'password': matrix_steam_bridge_database_password, |  | ||||||
|     }] if (matrix_steam_bridge_enabled and matrix_steam_bridge_database_engine == 'postgres' and matrix_steam_bridge_database_hostname == postgres_connection_hostname) else []) |  | ||||||
|     + |  | ||||||
|     ([{ |     ([{ | ||||||
|       'name': matrix_dimension_database_name, |       'name': matrix_dimension_database_name, | ||||||
|       'username': matrix_dimension_database_username, |       'username': matrix_dimension_database_username, | ||||||
| @@ -4496,9 +4388,9 @@ postgres_managed_databases_auto: | | |||||||
|     + |     + | ||||||
|     ([{ |     ([{ | ||||||
|       'name': etherpad_database_name, |       'name': etherpad_database_name, | ||||||
|       'username': etherpad_database_postgres_username, |       'username': etherpad_database_username, | ||||||
|       'password': etherpad_database_postgres_password, |       'password': etherpad_database_password, | ||||||
|     }] if (etherpad_enabled and etherpad_database_type == 'postgres' and etherpad_database_postgres_hostname == postgres_connection_hostname) else []) |     }] if (etherpad_enabled and etherpad_database_engine == 'postgres' and etherpad_database_hostname == postgres_connection_hostname) else []) | ||||||
|     + |     + | ||||||
|     ([{ |     ([{ | ||||||
|       'name': prometheus_postgres_exporter_database_name, |       'name': prometheus_postgres_exporter_database_name, | ||||||
| @@ -4647,7 +4539,7 @@ ntfy_visitor_request_limit_exempt_hosts_hostnames_auto: | | |||||||
| # | # | ||||||
| ###################################################################### | ###################################################################### | ||||||
|  |  | ||||||
| valkey_enabled: "{{ matrix_synapse_workers_enabled or (matrix_hookshot_enabled and matrix_hookshot_encryption_enabled) }}" | valkey_enabled: "{{ matrix_synapse_workers_enabled or (matrix_hookshot_enabled and matrix_hookshot_encryption_enabled) or matrix_element_call_enabled }}" | ||||||
|  |  | ||||||
| valkey_identifier: matrix-valkey | valkey_identifier: matrix-valkey | ||||||
|  |  | ||||||
| @@ -4719,9 +4611,9 @@ matrix_client_element_enable_presence_by_hs_url: |- | |||||||
|  |  | ||||||
| matrix_client_element_jitsi_preferred_domain: "{{ matrix_server_fqn_jitsi if jitsi_enabled else '' }}" | matrix_client_element_jitsi_preferred_domain: "{{ matrix_server_fqn_jitsi if jitsi_enabled else '' }}" | ||||||
|  |  | ||||||
| matrix_client_element_features_feature_video_rooms: "{{ matrix_rtc_enabled }}" | matrix_client_element_features_feature_video_rooms: "{{ matrix_element_call_enabled }}" | ||||||
| matrix_client_element_features_feature_group_calls: "{{ matrix_rtc_enabled }}" | matrix_client_element_features_feature_group_calls: "{{ matrix_element_call_enabled }}" | ||||||
| matrix_client_element_features_feature_element_call_video_rooms: "{{ matrix_rtc_enabled }}" | matrix_client_element_features_feature_element_call_video_rooms: "{{ matrix_element_call_enabled }}" | ||||||
| matrix_client_element_features_feature_oidc_native_flow: "{{ matrix_authentication_service_enabled }}" | matrix_client_element_features_feature_oidc_native_flow: "{{ matrix_authentication_service_enabled }}" | ||||||
|  |  | ||||||
| matrix_client_element_element_call_enabled: "{{ matrix_element_call_enabled }}" | matrix_client_element_element_call_enabled: "{{ matrix_element_call_enabled }}" | ||||||
| @@ -4903,7 +4795,7 @@ matrix_client_fluffychat_self_check_validate_certificates: "{{ matrix_playbook_s | |||||||
|  |  | ||||||
| matrix_synapse_enabled: "{{ matrix_homeserver_implementation == 'synapse' }}" | matrix_synapse_enabled: "{{ matrix_homeserver_implementation == 'synapse' }}" | ||||||
|  |  | ||||||
| matrix_synapse_username: "{{ matrix_user_name }}" | matrix_synapse_username: "{{ matrix_user_username }}" | ||||||
| matrix_synapse_uid: "{{ matrix_user_uid }}" | matrix_synapse_uid: "{{ matrix_user_uid }}" | ||||||
| matrix_synapse_gid: "{{ matrix_user_gid }}" | matrix_synapse_gid: "{{ matrix_user_gid }}" | ||||||
|  |  | ||||||
| @@ -4945,8 +4837,6 @@ matrix_synapse_container_additional_networks_auto: | | |||||||
|       ([exim_relay_container_network] if (exim_relay_enabled and matrix_synapse_email_enabled and matrix_synapse_email_smtp_host == exim_relay_identifier and matrix_synapse_container_network != exim_relay_container_network) else []) |       ([exim_relay_container_network] if (exim_relay_enabled and matrix_synapse_email_enabled and matrix_synapse_email_smtp_host == exim_relay_identifier and matrix_synapse_container_network != exim_relay_container_network) else []) | ||||||
|       + |       + | ||||||
|       ([matrix_ma1sd_container_network] if (matrix_ma1sd_enabled and matrix_synapse_account_threepid_delegates_msisdn == matrix_synapse_account_threepid_delegates_msisdn_mas1sd_url and matrix_synapse_container_network != matrix_ma1sd_container_network) else []) |       ([matrix_ma1sd_container_network] if (matrix_ma1sd_enabled and matrix_synapse_account_threepid_delegates_msisdn == matrix_synapse_account_threepid_delegates_msisdn_mas1sd_url and matrix_synapse_container_network != matrix_ma1sd_container_network) else []) | ||||||
|       + |  | ||||||
|       ([matrix_bot_draupnir_container_network] if (matrix_synapse_ext_synapse_http_antispam_enabled and matrix_synapse_ext_synapse_http_antispam_config_base_url == matrix_bot_draupnir_synapse_http_antispam_config_base_url and matrix_bot_draupnir_container_network != matrix_synapse_container_network) else []) |  | ||||||
|     ) | unique |     ) | unique | ||||||
|   }} |   }} | ||||||
|  |  | ||||||
| @@ -4964,9 +4854,7 @@ matrix_synapse_container_labels_matrix_labels_enabled: "{{ not matrix_synapse_wo | |||||||
| matrix_synapse_container_labels_public_client_root_redirection_enabled: "{{ matrix_synapse_container_labels_public_client_root_redirection_url != '' }}" | matrix_synapse_container_labels_public_client_root_redirection_enabled: "{{ matrix_synapse_container_labels_public_client_root_redirection_url != '' }}" | ||||||
| matrix_synapse_container_labels_public_client_root_redirection_url: "{{ (('https://' if matrix_playbook_ssl_enabled else 'http://') + matrix_server_fqn_element) if matrix_client_element_enabled else '' }}" | matrix_synapse_container_labels_public_client_root_redirection_url: "{{ (('https://' if matrix_playbook_ssl_enabled else 'http://') + matrix_server_fqn_element) if matrix_client_element_enabled else '' }}" | ||||||
|  |  | ||||||
| matrix_synapse_container_labels_public_client_synapse_admin_api_enabled: "{{ matrix_synapse_admin_enabled or matrix_element_admin_enabled }}" | matrix_synapse_container_labels_public_client_synapse_admin_api_enabled: "{{ matrix_synapse_admin_enabled }}" | ||||||
| matrix_synapse_container_labels_internal_client_synapse_admin_api_enabled: "{{ (matrix_bot_draupnir_enabled and matrix_bot_draupnir_admin_api_enabled) }}" |  | ||||||
| matrix_synapse_container_labels_internal_client_synapse_admin_api_traefik_entrypoints: "{{ matrix_playbook_internal_matrix_client_api_traefik_entrypoint_name }}" |  | ||||||
|  |  | ||||||
| matrix_synapse_container_labels_public_federation_api_traefik_hostname: "{{ matrix_server_fqn_matrix_federation }}" | matrix_synapse_container_labels_public_federation_api_traefik_hostname: "{{ matrix_server_fqn_matrix_federation }}" | ||||||
| matrix_synapse_container_labels_public_federation_api_traefik_entrypoints: "{{ matrix_federation_traefik_entrypoint_name }}" | matrix_synapse_container_labels_public_federation_api_traefik_entrypoints: "{{ matrix_federation_traefik_entrypoint_name }}" | ||||||
| @@ -4992,7 +4880,7 @@ matrix_synapse_tls_federation_listener_enabled: false | |||||||
| matrix_synapse_tls_certificate_path: ~ | matrix_synapse_tls_certificate_path: ~ | ||||||
| matrix_synapse_tls_private_key_path: ~ | matrix_synapse_tls_private_key_path: ~ | ||||||
|  |  | ||||||
| matrix_synapse_federation_port_openid_resource_required: "{{ not matrix_synapse_federation_enabled and (matrix_dimension_enabled or matrix_ma1sd_enabled or matrix_user_verification_service_enabled or matrix_livekit_jwt_service_enabled) }}" | matrix_synapse_federation_port_openid_resource_required: "{{ not matrix_synapse_federation_enabled and (matrix_dimension_enabled or matrix_ma1sd_enabled or matrix_user_verification_service_enabled) }}" | ||||||
|  |  | ||||||
| matrix_synapse_metrics_enabled: "{{ prometheus_enabled or matrix_metrics_exposure_enabled }}" | matrix_synapse_metrics_enabled: "{{ prometheus_enabled or matrix_metrics_exposure_enabled }}" | ||||||
|  |  | ||||||
| @@ -5021,7 +4909,7 @@ matrix_synapse_systemd_required_services_list_auto: | | |||||||
|     + |     + | ||||||
|     (['matrix-goofys.service'] if matrix_s3_media_store_enabled else []) |     (['matrix-goofys.service'] if matrix_s3_media_store_enabled else []) | ||||||
|     + |     + | ||||||
|     (['matrix-authentication-service.service'] if (matrix_synapse_matrix_authentication_service_enabled and matrix_synapse_matrix_authentication_service_endpoint == matrix_authentication_service_http_base_container_url) else []) |     (['matrix-authentication-service.service'] if (matrix_authentication_service_enabled and matrix_synapse_experimental_features_msc3861_enabled) else []) | ||||||
|   }} |   }} | ||||||
|  |  | ||||||
| matrix_synapse_systemd_wanted_services_list_auto: | | matrix_synapse_systemd_wanted_services_list_auto: | | ||||||
| @@ -5042,34 +4930,29 @@ matrix_synapse_app_service_config_files_auto: "{{ matrix_homeserver_app_service_ | |||||||
| # Disable creation of media repository Synapse worker when using media-repo | # Disable creation of media repository Synapse worker when using media-repo | ||||||
| matrix_synapse_ext_media_repo_enabled: "{{ matrix_media_repo_enabled }}" | matrix_synapse_ext_media_repo_enabled: "{{ matrix_media_repo_enabled }}" | ||||||
|  |  | ||||||
| matrix_synapse_ext_synapse_http_antispam_enabled: "{{ matrix_bot_draupnir_config_web_synapseHTTPAntispam_enabled }}" |  | ||||||
| matrix_synapse_ext_synapse_http_antispam_config_base_url: "{{ matrix_bot_draupnir_synapse_http_antispam_config_base_url if matrix_bot_draupnir_config_web_synapseHTTPAntispam_enabled else '' }}" |  | ||||||
| matrix_synapse_ext_synapse_http_antispam_config_authorization: "{{ matrix_bot_draupnir_config_web_synapseHTTPAntispam_authorization if matrix_bot_draupnir_config_web_synapseHTTPAntispam_enabled else '' }}" |  | ||||||
| matrix_synapse_ext_synapse_http_antispam_config_enabled_callbacks: "{{ matrix_bot_draupnir_synapse_http_antispam_config_enabled_callbacks if matrix_bot_draupnir_config_web_synapseHTTPAntispam_enabled else [] }}" |  | ||||||
| matrix_synapse_ext_synapse_http_antispam_config_fail_open: "{{ matrix_bot_draupnir_synapse_http_antispam_config_fail_open if matrix_bot_draupnir_config_web_synapseHTTPAntispam_enabled else {} }}" |  | ||||||
| matrix_synapse_ext_synapse_http_antispam_config_async: "{{ matrix_bot_draupnir_synapse_http_antispam_config_async if matrix_bot_draupnir_config_web_synapseHTTPAntispam_enabled else {} }}" |  | ||||||
|  |  | ||||||
| # Enable Synapse statistics reporting when using synapse-usage-exporter | # Enable Synapse statistics reporting when using synapse-usage-exporter | ||||||
| matrix_synapse_report_stats: "{{ matrix_synapse_usage_exporter_enabled }}" | matrix_synapse_report_stats: "{{ matrix_synapse_usage_exporter_enabled }}" | ||||||
| matrix_synapse_report_stats_endpoint: "{{ (('http://' + matrix_synapse_usage_exporter_identifier + ':' + matrix_synapse_usage_exporter_container_port | string + '/report-usage-stats/push') if matrix_synapse_usage_exporter_enabled else '') }}" | matrix_synapse_report_stats_endpoint: "{{ (('http://' + matrix_synapse_usage_exporter_identifier + ':' + matrix_synapse_usage_exporter_container_port | string + '/report-usage-stats/push') if matrix_synapse_usage_exporter_enabled else '') }}" | ||||||
|  |  | ||||||
| matrix_synapse_experimental_features_msc3266_enabled: "{{ matrix_rtc_enabled }}" | matrix_synapse_experimental_features_msc3266_enabled: "{{ matrix_element_call_enabled }}" | ||||||
|  |  | ||||||
| matrix_synapse_matrix_authentication_service_enabled: "{{ matrix_authentication_service_enabled }}" | matrix_synapse_experimental_features_msc3861_enabled: "{{ matrix_authentication_service_enabled and not matrix_authentication_service_migration_in_progress }}" | ||||||
| matrix_synapse_matrix_authentication_service_endpoint: "{{ matrix_authentication_service_http_base_container_url if matrix_authentication_service_enabled else '' }}" | matrix_synapse_experimental_features_msc3861_issuer: "{{ matrix_authentication_service_http_base_container_url if matrix_authentication_service_enabled else '' }}" | ||||||
| matrix_synapse_matrix_authentication_service_secret: "{{ matrix_authentication_service_config_matrix_secret if matrix_authentication_service_enabled else '' }}" | matrix_synapse_experimental_features_msc3861_client_secret: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'syn.ngauth.cs', rounds=655555) | to_uuid }}" | ||||||
|  | matrix_synapse_experimental_features_msc3861_admin_token: "{{ matrix_authentication_service_config_matrix_secret if matrix_authentication_service_enabled else '' }}" | ||||||
|  | matrix_synapse_experimental_features_msc3861_account_management_url: "{{ matrix_authentication_service_account_management_url if matrix_authentication_service_enabled else '' }}" | ||||||
|  |  | ||||||
| matrix_synapse_experimental_features_msc4108_enabled: "{{ matrix_authentication_service_enabled and not matrix_authentication_service_migration_in_progress }}" | matrix_synapse_experimental_features_msc4108_enabled: "{{ matrix_authentication_service_enabled and not matrix_authentication_service_migration_in_progress }}" | ||||||
|  |  | ||||||
| matrix_synapse_experimental_features_msc4140_enabled: "{{ matrix_rtc_enabled }}" | matrix_synapse_experimental_features_msc4140_enabled: "{{ matrix_element_call_enabled }}" | ||||||
|  |  | ||||||
| matrix_synapse_experimental_features_msc4222_enabled: "{{ matrix_rtc_enabled }}" | matrix_synapse_experimental_features_msc4222_enabled: "{{ matrix_element_call_enabled }}" | ||||||
|  |  | ||||||
| # Disable password authentication when delegating authentication to Matrix Authentication Service. | # Disable password authentication when delegating authentication to Matrix Authentication Service. | ||||||
| # Unless this is done, Synapse fails on startup with: | # Unless this is done, Synapse fails on startup with: | ||||||
| # > Error in configuration at 'password_config.enabled': | # > Error in configuration at 'password_config.enabled': | ||||||
| # > Password auth cannot be enabled when OAuth delegation is enabled | # > Password auth cannot be enabled when OAuth delegation is enabled | ||||||
| matrix_synapse_password_config_enabled: "{{ not matrix_synapse_matrix_authentication_service_enabled }}" | matrix_synapse_password_config_enabled: "{{ not matrix_synapse_experimental_features_msc3861_enabled }}" | ||||||
|  |  | ||||||
| matrix_synapse_register_user_script_matrix_authentication_service_path: "{{ matrix_authentication_service_bin_path }}/register-user" | matrix_synapse_register_user_script_matrix_authentication_service_path: "{{ matrix_authentication_service_bin_path }}/register-user" | ||||||
|  |  | ||||||
| @@ -5096,7 +4979,7 @@ matrix_synapse_auto_compressor_postgres_image: "{{ postgres_container_image_to_u | |||||||
|  |  | ||||||
| matrix_synapse_auto_compressor_container_image_registry_prefix_upstream: "{{ matrix_container_global_registry_prefix_override if matrix_container_global_registry_prefix_override else matrix_synapse_auto_compressor_container_image_registry_prefix_upstream_default }}" | matrix_synapse_auto_compressor_container_image_registry_prefix_upstream: "{{ matrix_container_global_registry_prefix_override if matrix_container_global_registry_prefix_override else matrix_synapse_auto_compressor_container_image_registry_prefix_upstream_default }}" | ||||||
|  |  | ||||||
| matrix_synapse_auto_compressor_container_image_self_build: "{{ matrix_architecture not in ['arm64', 'amd64'] }}" | matrix_synapse_auto_compressor_container_image_self_build: "{{ matrix_architecture not in ['amd64'] }}" | ||||||
|  |  | ||||||
| matrix_synapse_auto_compressor_container_network: "{{ (postgres_container_network if (postgres_enabled and matrix_synapse_auto_compressor_database_hostname == matrix_synapse_database_host and matrix_synapse_database_host == postgres_connection_hostname) else 'matrix-synapse-auto-compressor') }}" | matrix_synapse_auto_compressor_container_network: "{{ (postgres_container_network if (postgres_enabled and matrix_synapse_auto_compressor_database_hostname == matrix_synapse_database_host and matrix_synapse_database_host == postgres_connection_hostname) else 'matrix-synapse-auto-compressor') }}" | ||||||
|  |  | ||||||
| @@ -5158,9 +5041,6 @@ matrix_synapse_reverse_proxy_companion_container_labels_traefik_compression_midd | |||||||
| matrix_synapse_reverse_proxy_companion_container_labels_public_client_synapse_client_api_enabled: "{{ matrix_synapse_container_labels_public_client_synapse_client_api_enabled }}" | matrix_synapse_reverse_proxy_companion_container_labels_public_client_synapse_client_api_enabled: "{{ matrix_synapse_container_labels_public_client_synapse_client_api_enabled }}" | ||||||
| matrix_synapse_reverse_proxy_companion_container_labels_public_client_synapse_admin_api_enabled: "{{ matrix_synapse_container_labels_public_client_synapse_admin_api_enabled }}" | matrix_synapse_reverse_proxy_companion_container_labels_public_client_synapse_admin_api_enabled: "{{ matrix_synapse_container_labels_public_client_synapse_admin_api_enabled }}" | ||||||
|  |  | ||||||
| matrix_synapse_reverse_proxy_companion_container_labels_internal_client_synapse_admin_api_enabled: "{{ matrix_synapse_container_labels_internal_client_synapse_admin_api_enabled }}" |  | ||||||
| matrix_synapse_reverse_proxy_companion_container_labels_internal_client_synapse_admin_api_traefik_entrypoints: "{{ matrix_playbook_internal_matrix_client_api_traefik_entrypoint_name }}" |  | ||||||
|  |  | ||||||
| matrix_synapse_reverse_proxy_companion_container_labels_public_federation_api_traefik_entrypoints: "{{ matrix_synapse_container_labels_public_federation_api_traefik_entrypoints }}" | matrix_synapse_reverse_proxy_companion_container_labels_public_federation_api_traefik_entrypoints: "{{ matrix_synapse_container_labels_public_federation_api_traefik_entrypoints }}" | ||||||
| matrix_synapse_reverse_proxy_companion_container_labels_public_federation_api_traefik_tls: "{{ matrix_synapse_container_labels_public_federation_api_traefik_tls }}" | matrix_synapse_reverse_proxy_companion_container_labels_public_federation_api_traefik_tls: "{{ matrix_synapse_container_labels_public_federation_api_traefik_tls }}" | ||||||
|  |  | ||||||
| @@ -5216,8 +5096,6 @@ matrix_synapse_admin_container_labels_traefik_docker_network: "{{ matrix_playboo | |||||||
| matrix_synapse_admin_container_labels_traefik_entrypoints: "{{ traefik_entrypoint_primary }}" | matrix_synapse_admin_container_labels_traefik_entrypoints: "{{ traefik_entrypoint_primary }}" | ||||||
| matrix_synapse_admin_container_labels_traefik_tls_certResolver: "{{ traefik_certResolver_primary }}" | matrix_synapse_admin_container_labels_traefik_tls_certResolver: "{{ traefik_certResolver_primary }}" | ||||||
|  |  | ||||||
| matrix_synapse_admin_config_externalAuthProvider: "{{ matrix_authentication_service_enabled | default(false) or matrix_synapse_ext_password_provider_ldap_enabled | default(false) }}" |  | ||||||
|  |  | ||||||
| matrix_synapse_admin_config_asManagedUsers_auto: | | matrix_synapse_admin_config_asManagedUsers_auto: | | ||||||
|   {{ |   {{ | ||||||
|     ([ |     ([ | ||||||
| @@ -5353,7 +5231,7 @@ matrix_synapse_admin_config_asManagedUsers_auto: | | |||||||
|     + |     + | ||||||
|     ([ |     ([ | ||||||
|       '^@'+(matrix_mautrix_telegram_appservice_bot_username | default('') | regex_escape)+':'+(matrix_domain | regex_escape)+'$', |       '^@'+(matrix_mautrix_telegram_appservice_bot_username | default('') | regex_escape)+':'+(matrix_domain | regex_escape)+'$', | ||||||
|       '^@'+(matrix_mautrix_telegram_username_template | regex_escape | replace('{userid}', '.+'))+':'+(matrix_domain | regex_escape)+'$', |       '^@telegram_[a-zA-Z0-9]+:'+(matrix_domain | regex_escape)+'$', | ||||||
|     ] if matrix_mautrix_telegram_enabled else []) |     ] if matrix_mautrix_telegram_enabled else []) | ||||||
|     + |     + | ||||||
|     ([ |     ([ | ||||||
| @@ -5405,11 +5283,6 @@ matrix_synapse_admin_config_asManagedUsers_auto: | | |||||||
|       '^@'+(matrix_wechat_appservice_bot_username | default('') | regex_escape)+':'+(matrix_domain | regex_escape)+'$', |       '^@'+(matrix_wechat_appservice_bot_username | default('') | regex_escape)+':'+(matrix_domain | regex_escape)+'$', | ||||||
|       '^@_wechat_[a-zA-Z0-9]+:'+(matrix_domain | regex_escape)+'$', |       '^@_wechat_[a-zA-Z0-9]+:'+(matrix_domain | regex_escape)+'$', | ||||||
|     ] if matrix_wechat_enabled else []) |     ] if matrix_wechat_enabled else []) | ||||||
|     + |  | ||||||
|     ([ |  | ||||||
|       '^@'+(matrix_steam_bridge_appservice_bot_username | default('') | regex_escape)+':'+(matrix_domain | regex_escape)+'$', |  | ||||||
|       '^@steam_[a-zA-Z0-9]+:'+(matrix_domain | regex_escape)+'$', |  | ||||||
|     ] if matrix_steam_bridge_enabled else []) |  | ||||||
|   }} |   }} | ||||||
|  |  | ||||||
| ###################################################################### | ###################################################################### | ||||||
| @@ -5460,7 +5333,7 @@ prometheus_node_exporter_gid: "{{ matrix_user_gid }}" | |||||||
|  |  | ||||||
| prometheus_node_exporter_hostname: "{{ matrix_server_fqn_matrix }}" | prometheus_node_exporter_hostname: "{{ matrix_server_fqn_matrix }}" | ||||||
|  |  | ||||||
| prometheus_node_exporter_container_image_registry_prefix_upstream: "{{ matrix_container_global_registry_prefix_override if matrix_container_global_registry_prefix_override else prometheus_node_exporter_container_image_registry_prefix_upstream_default }}" | prometheus_node_exporter_docker_image_registry_prefix_upstream: "{{ matrix_container_global_registry_prefix_override if matrix_container_global_registry_prefix_override else prometheus_node_exporter_docker_image_registry_prefix_upstream_default }}" | ||||||
|  |  | ||||||
| prometheus_node_exporter_container_network: "{{ matrix_monitoring_container_network }}" | prometheus_node_exporter_container_network: "{{ matrix_monitoring_container_network }}" | ||||||
|  |  | ||||||
| @@ -5498,7 +5371,7 @@ prometheus_postgres_exporter_gid: "{{ matrix_user_gid }}" | |||||||
|  |  | ||||||
| prometheus_postgres_exporter_hostname: "{{ matrix_server_fqn_matrix }}" | prometheus_postgres_exporter_hostname: "{{ matrix_server_fqn_matrix }}" | ||||||
|  |  | ||||||
| prometheus_postgres_exporter_container_image_registry_prefix_upstream: "{{ matrix_container_global_registry_prefix_override if matrix_container_global_registry_prefix_override else prometheus_postgres_exporter_container_image_registry_prefix_upstream_default }}" | prometheus_postgres_exporter_docker_image_registry_prefix_upstream: "{{ matrix_container_global_registry_prefix_override if matrix_container_global_registry_prefix_override else prometheus_postgres_exporter_docker_image_registry_prefix_upstream_default }}" | ||||||
|  |  | ||||||
| prometheus_postgres_exporter_container_network: "{{ matrix_monitoring_container_network }}" | prometheus_postgres_exporter_container_network: "{{ matrix_monitoring_container_network }}" | ||||||
|  |  | ||||||
| @@ -5721,7 +5594,7 @@ grafana_container_labels_traefik_tls_certResolver: "{{ traefik_certResolver_prim | |||||||
|  |  | ||||||
| grafana_container_http_host_bind_port: "{{ (matrix_playbook_service_host_bind_interface_prefix ~ '3000') if matrix_playbook_service_host_bind_interface_prefix else '' }}" | grafana_container_http_host_bind_port: "{{ (matrix_playbook_service_host_bind_interface_prefix ~ '3000') if matrix_playbook_service_host_bind_interface_prefix else '' }}" | ||||||
|  |  | ||||||
| grafana_provisioning_datasources_datasources: | | grafana_provisioning_datasources: | | ||||||
|   {{ |   {{ | ||||||
|     ([{ |     ([{ | ||||||
|       'name': (matrix_server_fqn_matrix + ' - Prometheus'), |       'name': (matrix_server_fqn_matrix + ' - Prometheus'), | ||||||
| @@ -5764,7 +5637,6 @@ grafana_default_home_dashboard_path: |- | |||||||
|       'dendrite': ('/etc/grafana/dashboards/node-exporter-full.json' if prometheus_node_exporter_enabled else ''), |       'dendrite': ('/etc/grafana/dashboards/node-exporter-full.json' if prometheus_node_exporter_enabled else ''), | ||||||
|       'conduit': ('/etc/grafana/dashboards/node-exporter-full.json' if prometheus_node_exporter_enabled else ''), |       'conduit': ('/etc/grafana/dashboards/node-exporter-full.json' if prometheus_node_exporter_enabled else ''), | ||||||
|       'conduwuit': ('/etc/grafana/dashboards/node-exporter-full.json' if prometheus_node_exporter_enabled else ''), |       'conduwuit': ('/etc/grafana/dashboards/node-exporter-full.json' if prometheus_node_exporter_enabled else ''), | ||||||
|       'continuwuity': ('/etc/grafana/dashboards/node-exporter-full.json' if prometheus_node_exporter_enabled else ''), |  | ||||||
|     }[matrix_homeserver_implementation] |     }[matrix_homeserver_implementation] | ||||||
|   }} |   }} | ||||||
|  |  | ||||||
| @@ -5825,7 +5697,6 @@ matrix_registration_shared_secret: |- | |||||||
|       'dendrite': matrix_dendrite_client_api_registration_shared_secret | default (''), |       'dendrite': matrix_dendrite_client_api_registration_shared_secret | default (''), | ||||||
|       'conduit': '', |       'conduit': '', | ||||||
|       'conduwuit': '', |       'conduwuit': '', | ||||||
|       'continuwuity': '', |  | ||||||
|     }[matrix_homeserver_implementation] |     }[matrix_homeserver_implementation] | ||||||
|   }} |   }} | ||||||
|  |  | ||||||
| @@ -6103,58 +5974,6 @@ matrix_conduwuit_self_check_validate_certificates: "{{ matrix_playbook_ssl_enabl | |||||||
| ###################################################################### | ###################################################################### | ||||||
|  |  | ||||||
|  |  | ||||||
| ###################################################################### |  | ||||||
| # |  | ||||||
| # matrix-continuwuity |  | ||||||
| # |  | ||||||
| ###################################################################### |  | ||||||
|  |  | ||||||
| matrix_continuwuity_enabled: "{{ matrix_homeserver_implementation == 'continuwuity' }}" |  | ||||||
|  |  | ||||||
| matrix_continuwuity_hostname: "{{ matrix_server_fqn_matrix }}" |  | ||||||
|  |  | ||||||
| matrix_continuwuity_config_allow_federation: "{{ matrix_homeserver_federation_enabled }}" |  | ||||||
|  |  | ||||||
| matrix_continuwuity_docker_image_registry_prefix_upstream: "{{ matrix_container_global_registry_prefix_override if matrix_container_global_registry_prefix_override else matrix_continuwuity_docker_image_registry_prefix_upstream_default }}" |  | ||||||
|  |  | ||||||
| matrix_continuwuity_container_network: "{{ matrix_homeserver_container_network }}" |  | ||||||
|  |  | ||||||
| matrix_continuwuity_container_additional_networks_auto: | |  | ||||||
|   {{ |  | ||||||
|     ( |  | ||||||
|       ([matrix_playbook_reverse_proxyable_services_additional_network] if matrix_continuwuity_container_labels_traefik_enabled and matrix_playbook_reverse_proxyable_services_additional_network else []) |  | ||||||
|     ) | unique |  | ||||||
|   }} |  | ||||||
|  |  | ||||||
| matrix_continuwuity_container_labels_traefik_enabled: "{{ matrix_playbook_reverse_proxy_type in ['playbook-managed-traefik', 'other-traefik-container'] and not matrix_synapse_workers_enabled }}" |  | ||||||
| matrix_continuwuity_container_labels_traefik_docker_network: "{{ matrix_playbook_reverse_proxyable_services_additional_network }}" |  | ||||||
| matrix_continuwuity_container_labels_traefik_entrypoints: "{{ traefik_entrypoint_primary }}" |  | ||||||
| matrix_continuwuity_container_labels_traefik_tls_certResolver: "{{ traefik_certResolver_primary }}" |  | ||||||
|  |  | ||||||
| matrix_continuwuity_container_labels_public_client_root_redirection_enabled: "{{ matrix_continuwuity_container_labels_public_client_root_redirection_url != '' }}" |  | ||||||
| matrix_continuwuity_container_labels_public_client_root_redirection_url: "{{ (('https://' if matrix_playbook_ssl_enabled else 'http://') + matrix_server_fqn_element) if matrix_client_element_enabled else '' }}" |  | ||||||
|  |  | ||||||
| matrix_continuwuity_container_labels_public_federation_api_traefik_hostname: "{{ matrix_server_fqn_matrix_federation }}" |  | ||||||
| matrix_continuwuity_container_labels_public_federation_api_traefik_entrypoints: "{{ matrix_federation_traefik_entrypoint_name }}" |  | ||||||
| matrix_continuwuity_container_labels_public_federation_api_traefik_tls: "{{ matrix_federation_traefik_entrypoint_tls }}" |  | ||||||
|  |  | ||||||
| matrix_continuwuity_container_labels_internal_client_api_enabled: "{{ matrix_playbook_internal_matrix_client_api_traefik_entrypoint_enabled }}" |  | ||||||
| matrix_continuwuity_container_labels_internal_client_api_traefik_entrypoints: "{{ matrix_playbook_internal_matrix_client_api_traefik_entrypoint_name }}" |  | ||||||
|  |  | ||||||
| matrix_continuwuity_config_turn_uris: "{{ matrix_coturn_turn_uris if matrix_coturn_enabled else [] }}" |  | ||||||
| matrix_continuwuity_config_turn_secret: "{{ matrix_coturn_turn_static_auth_secret if (matrix_coturn_enabled and matrix_coturn_authentication_method == 'auth-secret') else '' }}" |  | ||||||
| matrix_continuwuity_config_turn_username: "{{ matrix_coturn_lt_cred_mech_username if (matrix_coturn_enabled and matrix_coturn_authentication_method == 'lt-cred-mech') else '' }}" |  | ||||||
| matrix_continuwuity_config_turn_password: "{{ matrix_coturn_lt_cred_mech_password if (matrix_coturn_enabled and matrix_coturn_authentication_method == 'lt-cred-mech') else '' }}" |  | ||||||
|  |  | ||||||
| matrix_continuwuity_self_check_validate_certificates: "{{ matrix_playbook_ssl_enabled }}" |  | ||||||
|  |  | ||||||
| ###################################################################### |  | ||||||
| # |  | ||||||
| # /matrix-continuwuity |  | ||||||
| # |  | ||||||
| ###################################################################### |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ###################################################################### | ###################################################################### | ||||||
| # | # | ||||||
| # matrix-user-creator | # matrix-user-creator | ||||||
| @@ -6214,7 +6033,7 @@ matrix_user_creator_users_auto: | | |||||||
|     ([{ |     ([{ | ||||||
|       'username': matrix_bot_draupnir_login, |       'username': matrix_bot_draupnir_login, | ||||||
|       'initial_password': matrix_bot_draupnir_password, |       'initial_password': matrix_bot_draupnir_password, | ||||||
|       'initial_type': ('admin' if matrix_bot_draupnir_admin_api_enabled else 'bot'), |       'initial_type': 'bot', | ||||||
|     }] if matrix_bot_draupnir_enabled and matrix_bot_draupnir_password else []) |     }] if matrix_bot_draupnir_enabled and matrix_bot_draupnir_password else []) | ||||||
|   }} |   }} | ||||||
|  |  | ||||||
| @@ -6265,7 +6084,7 @@ matrix_user_verification_service_container_url: "http://{{  matrix_user_verifica | |||||||
| matrix_user_verification_service_uvs_homeserver_url: "{{ matrix_addons_homeserver_client_api_url }}" | matrix_user_verification_service_uvs_homeserver_url: "{{ matrix_addons_homeserver_client_api_url }}" | ||||||
|  |  | ||||||
| # We connect via the container network (private IPs), so we need to disable IP checks | # We connect via the container network (private IPs), so we need to disable IP checks | ||||||
| matrix_user_verification_service_uvs_disable_ip_blacklist: "{{ matrix_synapse_enabled }}" | matrix_user_verification_service_uvs_disable_ip_blacklist: "{{'true' if matrix_synapse_enabled else 'false'}}" | ||||||
|  |  | ||||||
| matrix_user_verification_service_uvs_auth_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'uvs.auth.token', rounds=655555) | to_uuid }}" | matrix_user_verification_service_uvs_auth_token: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'uvs.auth.token', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| @@ -6309,7 +6128,7 @@ matrix_static_files_file_matrix_client_property_org_matrix_msc3575_proxy_url: "{ | |||||||
|  |  | ||||||
| matrix_static_files_file_matrix_client_property_org_matrix_msc2965_authentication_enabled: "{{ matrix_authentication_service_enabled }}" | matrix_static_files_file_matrix_client_property_org_matrix_msc2965_authentication_enabled: "{{ matrix_authentication_service_enabled }}" | ||||||
| matrix_static_files_file_matrix_client_property_org_matrix_msc2965_authentication_issuer: "{{ matrix_authentication_service_config_http_issuer if matrix_authentication_service_enabled else '' }}" | matrix_static_files_file_matrix_client_property_org_matrix_msc2965_authentication_issuer: "{{ matrix_authentication_service_config_http_issuer if matrix_authentication_service_enabled else '' }}" | ||||||
| matrix_static_files_file_matrix_client_property_org_matrix_msc2965_authentication_account: "{{ matrix_authentication_service_account_management_url if matrix_authentication_service_enabled else '' }}" | matrix_static_files_file_matrix_client_property_org_matrix_msc2965_authentication_account: "{{ matrix_authentication_service_account_management_url }}" | ||||||
|  |  | ||||||
| matrix_static_files_file_matrix_client_property_m_tile_server_entries_enabled: "{{ matrix_client_element_location_sharing_enabled }}" | matrix_static_files_file_matrix_client_property_m_tile_server_entries_enabled: "{{ matrix_client_element_location_sharing_enabled }}" | ||||||
| matrix_static_files_file_matrix_client_property_m_tile_server_map_style_url: "{{ ('https://' if matrix_playbook_ssl_enabled else 'http://') + matrix_server_fqn_element }}/map_style.json" | matrix_static_files_file_matrix_client_property_m_tile_server_map_style_url: "{{ ('https://' if matrix_playbook_ssl_enabled else 'http://') + matrix_server_fqn_element }}/map_style.json" | ||||||
| @@ -6318,7 +6137,7 @@ matrix_static_files_file_matrix_client_property_m_tile_server_map_style_url: "{{ | |||||||
| # See: https://github.com/etkecc/synapse-admin/pull/126 | # See: https://github.com/etkecc/synapse-admin/pull/126 | ||||||
| matrix_static_files_file_matrix_client_property_cc_etke_synapse_admin_auto: "{{ matrix_synapse_admin_configuration if matrix_homeserver_implementation == 'synapse' else {} }}" | matrix_static_files_file_matrix_client_property_cc_etke_synapse_admin_auto: "{{ matrix_synapse_admin_configuration if matrix_homeserver_implementation == 'synapse' else {} }}" | ||||||
|  |  | ||||||
| matrix_static_files_file_matrix_client_property_org_matrix_msc4143_rtc_foci_enabled: "{{ matrix_livekit_jwt_service_enabled }}" | matrix_static_files_file_matrix_client_property_org_matrix_msc4143_rtc_foci_enabled: "{{ matrix_element_call_enabled }}" | ||||||
| matrix_static_files_file_matrix_client_property_org_matrix_msc4143_rtc_foci_auto: |- | matrix_static_files_file_matrix_client_property_org_matrix_msc4143_rtc_foci_auto: |- | ||||||
|   {{ |   {{ | ||||||
|     ( |     ( | ||||||
| @@ -6328,6 +6147,8 @@ matrix_static_files_file_matrix_client_property_org_matrix_msc4143_rtc_foci_auto | |||||||
|  |  | ||||||
| matrix_static_files_file_matrix_server_property_m_server: "{{ matrix_server_fqn_matrix_federation }}:{{ matrix_federation_public_port }}" | matrix_static_files_file_matrix_server_property_m_server: "{{ matrix_server_fqn_matrix_federation }}:{{ matrix_federation_public_port }}" | ||||||
|  |  | ||||||
|  | matrix_static_files_file_element_element_json_property_call_widget_url: "{{ matrix_element_call_public_url if matrix_element_call_enabled else '' }}" | ||||||
|  |  | ||||||
| matrix_static_files_scheme: "{{ 'https' if matrix_playbook_ssl_enabled else 'http' }}" | matrix_static_files_scheme: "{{ 'https' if matrix_playbook_ssl_enabled else 'http' }}" | ||||||
|  |  | ||||||
| matrix_static_files_self_check_hostname_matrix: "{{ matrix_server_fqn_matrix }}" | matrix_static_files_self_check_hostname_matrix: "{{ matrix_server_fqn_matrix }}" | ||||||
| @@ -6441,45 +6262,6 @@ traefik_certs_dumper_container_image_registry_prefix_upstream: "{{ matrix_contai | |||||||
| #                                                                      # | #                                                                      # | ||||||
| ######################################################################## | ######################################################################## | ||||||
|  |  | ||||||
| ######################################################################## |  | ||||||
| #                                                                      # |  | ||||||
| # matrix-element-admin                                                 # |  | ||||||
| #                                                                      # |  | ||||||
| ######################################################################## |  | ||||||
|  |  | ||||||
| # We don't enable this by default. |  | ||||||
| matrix_element_admin_enabled: false |  | ||||||
|  |  | ||||||
| matrix_element_admin_scheme: "{{ 'https' if matrix_playbook_ssl_enabled else 'http' }}" |  | ||||||
|  |  | ||||||
| matrix_element_admin_container_image_registry_prefix_upstream: "{{ matrix_container_global_registry_prefix_override if matrix_container_global_registry_prefix_override else matrix_element_admin_container_image_registry_prefix_upstream_default }}" |  | ||||||
|  |  | ||||||
| matrix_element_admin_container_image_self_build: "{{ matrix_architecture not in ['amd64', 'arm64'] }}" |  | ||||||
|  |  | ||||||
| matrix_element_admin_container_network: "{{ matrix_addons_container_network }}" |  | ||||||
|  |  | ||||||
| matrix_element_admin_container_additional_networks_auto: |- |  | ||||||
|   {{ |  | ||||||
|     ( |  | ||||||
|       ([] if matrix_addons_homeserver_container_network == '' else [matrix_addons_homeserver_container_network]) |  | ||||||
|       + |  | ||||||
|       ([matrix_playbook_reverse_proxyable_services_additional_network] if (matrix_playbook_reverse_proxyable_services_additional_network and matrix_element_admin_container_labels_traefik_enabled) else []) |  | ||||||
|     ) | unique |  | ||||||
|   }} |  | ||||||
|  |  | ||||||
| matrix_element_admin_container_labels_traefik_enabled: "{{ matrix_playbook_reverse_proxy_type in ['playbook-managed-traefik', 'other-traefik-container'] }}" |  | ||||||
| matrix_element_admin_container_labels_traefik_docker_network: "{{ matrix_playbook_reverse_proxyable_services_additional_network }}" |  | ||||||
| matrix_element_admin_container_labels_traefik_entrypoints: "{{ traefik_entrypoint_primary }}" |  | ||||||
| matrix_element_admin_container_labels_traefik_tls_certResolver: "{{ traefik_certResolver_primary }}" |  | ||||||
|  |  | ||||||
| matrix_element_admin_systemd_required_services_list_auto: "{{ matrix_addons_homeserver_systemd_services_list }}" |  | ||||||
|  |  | ||||||
| ###################################################################### |  | ||||||
| #                                                                     # |  | ||||||
| # /matrix-element-admin                                               # |  | ||||||
| #                                                                     # |  | ||||||
| ###################################################################### |  | ||||||
|  |  | ||||||
|  |  | ||||||
| ######################################################################## | ######################################################################## | ||||||
| #                                                                      # | #                                                                      # | ||||||
| @@ -6493,8 +6275,6 @@ matrix_element_call_scheme: "{{ 'https' if matrix_playbook_ssl_enabled else 'htt | |||||||
|  |  | ||||||
| matrix_element_call_container_network: "{{ matrix_addons_container_network }}" | matrix_element_call_container_network: "{{ matrix_addons_container_network }}" | ||||||
|  |  | ||||||
| matrix_element_call_container_image_registry_prefix_upstream: "{{ matrix_container_global_registry_prefix_override if matrix_container_global_registry_prefix_override else matrix_element_call_container_image_registry_prefix_upstream_default }}" |  | ||||||
|  |  | ||||||
| matrix_element_call_container_additional_networks_auto: "{{ [matrix_playbook_reverse_proxyable_services_additional_network] if (matrix_element_call_container_labels_traefik_enabled and matrix_playbook_reverse_proxyable_services_additional_network) else [] }}" | matrix_element_call_container_additional_networks_auto: "{{ [matrix_playbook_reverse_proxyable_services_additional_network] if (matrix_element_call_container_labels_traefik_enabled and matrix_playbook_reverse_proxyable_services_additional_network) else [] }}" | ||||||
|  |  | ||||||
| matrix_element_call_container_labels_traefik_enabled: "{{ matrix_playbook_reverse_proxy_type in ['playbook-managed-traefik', 'other-traefik-container'] }}" | matrix_element_call_container_labels_traefik_enabled: "{{ matrix_playbook_reverse_proxy_type in ['playbook-managed-traefik', 'other-traefik-container'] }}" | ||||||
| @@ -6516,7 +6296,7 @@ matrix_element_call_config_livekit_livekit_service_url: "{{ matrix_livekit_jwt_s | |||||||
| #                                                                      # | #                                                                      # | ||||||
| ######################################################################## | ######################################################################## | ||||||
|  |  | ||||||
| livekit_server_enabled: "{{ matrix_rtc_enabled }}" | livekit_server_enabled: "{{ matrix_element_call_enabled }}" | ||||||
|  |  | ||||||
| livekit_server_identifier: matrix-livekit-server | livekit_server_identifier: matrix-livekit-server | ||||||
|  |  | ||||||
| @@ -6530,43 +6310,14 @@ livekit_server_path_prefix: "/livekit-server" | |||||||
|  |  | ||||||
| livekit_server_container_image_self_build: "{{ matrix_architecture not in ['arm64', 'amd64'] }}" | livekit_server_container_image_self_build: "{{ matrix_architecture not in ['arm64', 'amd64'] }}" | ||||||
|  |  | ||||||
| livekit_server_container_image_registry_prefix_upstream: "{{ matrix_container_global_registry_prefix_override if matrix_container_global_registry_prefix_override else livekit_server_container_image_registry_prefix_upstream_default }}" |  | ||||||
|  |  | ||||||
| livekit_server_container_network: "{{ matrix_addons_container_network }}" | livekit_server_container_network: "{{ matrix_addons_container_network }}" | ||||||
| livekit_server_container_additional_networks_auto: "{{ [matrix_playbook_reverse_proxyable_services_additional_network] if (livekit_server_container_labels_traefik_enabled and matrix_playbook_reverse_proxyable_services_additional_network) else [] }}" | livekit_server_container_additional_networks_auto: "{{ [matrix_playbook_reverse_proxyable_services_additional_network] if (livekit_server_container_labels_traefik_enabled and matrix_playbook_reverse_proxyable_services_additional_network) else [] }}" | ||||||
|  |  | ||||||
| livekit_server_container_additional_volumes_auto: | |  | ||||||
|   {{ |  | ||||||
|     ( |  | ||||||
|       [ |  | ||||||
|        { |  | ||||||
|          'src': (traefik_certs_dumper_dumped_certificates_dir_path +  '/' + livekit_server_config_turn_domain + '/certificate.crt'), |  | ||||||
|          'dst': livekit_server_config_turn_cert_file, |  | ||||||
|          'options': 'ro', |  | ||||||
|        }, |  | ||||||
|        { |  | ||||||
|          'src': (traefik_certs_dumper_dumped_certificates_dir_path +  '/' + livekit_server_config_turn_domain + '/privatekey.key'), |  | ||||||
|          'dst': livekit_server_config_turn_key_file, |  | ||||||
|          'options': 'ro', |  | ||||||
|        }, |  | ||||||
|       ] if (matrix_playbook_reverse_proxy_type in ['playbook-managed-traefik', 'other-traefik-container'] and traefik_certs_dumper_enabled and livekit_server_config_turn_enabled and (livekit_server_config_turn_cert_file and livekit_server_config_turn_key_file)) else [] |  | ||||||
|     ) |  | ||||||
|   }} |  | ||||||
|  |  | ||||||
| livekit_server_container_labels_traefik_enabled: "{{ matrix_playbook_reverse_proxy_type in ['playbook-managed-traefik', 'other-traefik-container'] }}" | livekit_server_container_labels_traefik_enabled: "{{ matrix_playbook_reverse_proxy_type in ['playbook-managed-traefik', 'other-traefik-container'] }}" | ||||||
| livekit_server_container_labels_traefik_docker_network: "{{ matrix_playbook_reverse_proxyable_services_additional_network }}" | livekit_server_container_labels_traefik_docker_network: "{{ matrix_playbook_reverse_proxyable_services_additional_network }}" | ||||||
| livekit_server_container_labels_traefik_entrypoints: "{{ traefik_entrypoint_primary }}" | livekit_server_container_labels_traefik_entrypoints: "{{ traefik_entrypoint_primary }}" | ||||||
| livekit_server_container_labels_traefik_tls_certResolver: "{{ traefik_certResolver_primary }}" | livekit_server_container_labels_traefik_tls_certResolver: "{{ traefik_certResolver_primary }}" | ||||||
|  |  | ||||||
| livekit_server_container_labels_public_metrics_middleware_basic_auth_enabled: "{{ matrix_metrics_exposure_http_basic_auth_enabled }}" |  | ||||||
| livekit_server_container_labels_public_metrics_middleware_basic_auth_users: "{{ matrix_metrics_exposure_http_basic_auth_users }}" |  | ||||||
|  |  | ||||||
| livekit_server_metrics_proxying_enabled: "{{ livekit_server_config_prometheus_enabled and matrix_metrics_exposure_enabled }}" |  | ||||||
| livekit_server_metrics_proxying_hostname: "{{ matrix_metrics_exposure_hostname }}" |  | ||||||
| livekit_server_metrics_proxying_path_prefix: "{{ matrix_metrics_exposure_path_prefix }}/livekit-server" |  | ||||||
|  |  | ||||||
| livekit_server_config_prometheus_enabled: "{{ prometheus_enabled or matrix_metrics_exposure_enabled }}" |  | ||||||
|  |  | ||||||
| livekit_server_config_keys_auto: |- | livekit_server_config_keys_auto: |- | ||||||
|   {{ |   {{ | ||||||
|     {} |     {} | ||||||
| @@ -6576,15 +6327,6 @@ livekit_server_config_keys_auto: |- | |||||||
|     ) |     ) | ||||||
|   }} |   }} | ||||||
|  |  | ||||||
| # We only wish for matrix-livekit-jwt-service to create rooms, only for users on trusted homeservers. |  | ||||||
| # See `matrix_livekit_jwt_service_environment_variable_livekit_full_access_homeservers`. |  | ||||||
| # |  | ||||||
| # Ref: |  | ||||||
| # - https://github.com/element-hq/lk-jwt-service/releases/tag/v0.3.0 |  | ||||||
| # - https://github.com/livekit/livekit/blob/5e483e7554e5afbf254acf84e3ec0aa6e108e758/config-sample.yaml#L168-L170 |  | ||||||
| # - https://github.com/mother-of-all-self-hosting/ansible-role-livekit-server/commit/2a1b04552634097bdd26d472502a8f5bf1b8528f |  | ||||||
| livekit_server_config_room_auto_create: false |  | ||||||
|  |  | ||||||
| # The playbook intentionally uses a non-standard port than the default used by the role (5349), | # The playbook intentionally uses a non-standard port than the default used by the role (5349), | ||||||
| # because Coturn is already using that port. | # because Coturn is already using that port. | ||||||
| # Note that TURN is not enabled by default. See `livekit_server_config_turn_enabled`. | # Note that TURN is not enabled by default. See `livekit_server_config_turn_enabled`. | ||||||
| @@ -6595,33 +6337,6 @@ livekit_server_config_turn_tls_port: 5350 | |||||||
| # Note that TURN is not enabled by default. See `livekit_server_config_turn_enabled`. | # Note that TURN is not enabled by default. See `livekit_server_config_turn_enabled`. | ||||||
| livekit_server_config_turn_udp_port: 3479 | livekit_server_config_turn_udp_port: 3479 | ||||||
|  |  | ||||||
| # LiveKit's TURN implementation requires SSL certificates. |  | ||||||
| # We only enable it if we can provide them automatically via Traefik + Traefik Certs Dumper. |  | ||||||
| livekit_server_config_turn_enabled: "{{ matrix_playbook_reverse_proxy_type in ['playbook-managed-traefik', 'other-traefik-container'] and traefik_certs_dumper_enabled }}" |  | ||||||
|  |  | ||||||
| livekit_server_config_turn_cert_file: |- |  | ||||||
|   {{ |  | ||||||
|     { |  | ||||||
|       'playbook-managed-traefik': ('/certificate.crt' if traefik_certs_dumper_enabled else ''), |  | ||||||
|       'other-traefik-container': ('/certificate.crt' if traefik_certs_dumper_enabled else ''), |  | ||||||
|       'none': '', |  | ||||||
|     }[matrix_playbook_reverse_proxy_type] |  | ||||||
|   }} |  | ||||||
|  |  | ||||||
| livekit_server_config_turn_key_file: |- |  | ||||||
|   {{ |  | ||||||
|     { |  | ||||||
|       'playbook-managed-traefik': ('/privatekey.key' if traefik_certs_dumper_enabled else ''), |  | ||||||
|       'other-traefik-container': ('/privatekey.key' if traefik_certs_dumper_enabled else ''), |  | ||||||
|       'none': '', |  | ||||||
|     }[matrix_playbook_reverse_proxy_type] |  | ||||||
|   }} |  | ||||||
|  |  | ||||||
| livekit_server_systemd_required_services_list_auto: | |  | ||||||
|   {{ |  | ||||||
|     ([traefik_certs_dumper_identifier + '-wait-for-domain@' + livekit_server_config_turn_domain + '.service'] if matrix_playbook_reverse_proxy_type in ['playbook-managed-traefik', 'other-traefik-container'] and traefik_certs_dumper_enabled and livekit_server_config_turn_enabled else []) |  | ||||||
|   }} |  | ||||||
|  |  | ||||||
| ######################################################################## | ######################################################################## | ||||||
| #                                                                      # | #                                                                      # | ||||||
| # /livekit-server                                                      # | # /livekit-server                                                      # | ||||||
| @@ -6635,7 +6350,7 @@ livekit_server_systemd_required_services_list_auto: | | |||||||
| #                                                                      # | #                                                                      # | ||||||
| ######################################################################## | ######################################################################## | ||||||
|  |  | ||||||
| matrix_livekit_jwt_service_enabled: "{{ matrix_rtc_enabled and livekit_server_enabled }}" | matrix_livekit_jwt_service_enabled: "{{ matrix_element_call_enabled and livekit_server_enabled }}" | ||||||
|  |  | ||||||
| matrix_livekit_jwt_service_scheme: "{{ 'https' if matrix_playbook_ssl_enabled else 'http' }}" | matrix_livekit_jwt_service_scheme: "{{ 'https' if matrix_playbook_ssl_enabled else 'http' }}" | ||||||
|  |  | ||||||
| @@ -6644,8 +6359,6 @@ matrix_livekit_jwt_service_path_prefix: "/livekit-jwt-service" | |||||||
|  |  | ||||||
| matrix_livekit_jwt_service_container_image_self_build: "{{ matrix_architecture not in ['amd64', 'arm64'] }}" | matrix_livekit_jwt_service_container_image_self_build: "{{ matrix_architecture not in ['amd64', 'arm64'] }}" | ||||||
|  |  | ||||||
| matrix_livekit_jwt_service_container_image_registry_prefix_upstream: "{{ matrix_container_global_registry_prefix_override if matrix_container_global_registry_prefix_override else matrix_livekit_jwt_service_container_image_registry_prefix_upstream_default }}" |  | ||||||
|  |  | ||||||
| matrix_livekit_jwt_service_container_network: "{{ matrix_addons_container_network }}" | matrix_livekit_jwt_service_container_network: "{{ matrix_addons_container_network }}" | ||||||
|  |  | ||||||
| matrix_livekit_jwt_service_container_additional_networks_auto: | | matrix_livekit_jwt_service_container_additional_networks_auto: | | ||||||
| @@ -6664,8 +6377,6 @@ matrix_livekit_jwt_service_environment_variable_livekit_key: "{{ '%s' | format(m | |||||||
|  |  | ||||||
| matrix_livekit_jwt_service_environment_variable_livekit_secret: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'lk.secret', rounds=655555) | to_uuid }}" | matrix_livekit_jwt_service_environment_variable_livekit_secret: "{{ '%s' | format(matrix_homeserver_generic_secret_key) | password_hash('sha512', 'lk.secret', rounds=655555) | to_uuid }}" | ||||||
|  |  | ||||||
| matrix_livekit_jwt_service_environment_variable_livekit_full_access_homeservers_list: ["{{ matrix_domain }}"] |  | ||||||
|  |  | ||||||
| ######################################################################## | ######################################################################## | ||||||
| #                                                                      # | #                                                                      # | ||||||
| # /matrix-livekit-jwt-service                                          # | # /matrix-livekit-jwt-service                                          # | ||||||
|   | |||||||
| @@ -20,7 +20,7 @@ Currently, we support translation of: | |||||||
| Organization of this `i18n` directory is as follows: | Organization of this `i18n` directory is as follows: | ||||||
|  |  | ||||||
| - [PUBLISHED_LANGUAGES](PUBLISHED_LANGUAGES): a list of languages that we publish translations for (in the [translations/](translations/) directory) | - [PUBLISHED_LANGUAGES](PUBLISHED_LANGUAGES): a list of languages that we publish translations for (in the [translations/](translations/) directory) | ||||||
| - [.gitignore](.gitignore): a list of files and directories to ignore in the `i18n` directory. We intentionally ignore translated results (`translations/<language>` directories) for languages that are still in progress. We only [publish translations in a new language](#publish-translations-in-a-new-language) when the translation progresses beyond a certain threshold. | - [.gitignore](.gitignore): a list of files and directories to ignore in the `i18n` directory. We intentionaly ignore translated results (`translations/<language>` directories) for languages taht are still in progress. We only [publish translations in a new language](#publish-translations-in-a-new-language) when the translation progresses beyond a certain threshold. | ||||||
| - [justfile](justfile): a list of recipes for [just](https://github.com/casey/just) command runner | - [justfile](justfile): a list of recipes for [just](https://github.com/casey/just) command runner | ||||||
| - [requirements.txt](requirements.txt): a list of Python packages required to work with translations | - [requirements.txt](requirements.txt): a list of Python packages required to work with translations | ||||||
| - [translation-templates/](translation-templates/): a list of English translation templates - strings extracted from Markdown files | - [translation-templates/](translation-templates/): a list of English translation templates - strings extracted from Markdown files | ||||||
|   | |||||||
| @@ -1,134 +0,0 @@ | |||||||
| # SOME DESCRIPTIVE TITLE. |  | ||||||
| # Copyright (C) 2018-2025, Slavi Pantaleev, Aine Etke, MDAD community |  | ||||||
| # members |  | ||||||
| # This file is distributed under the same license as the |  | ||||||
| # matrix-docker-ansible-deploy package. |  | ||||||
| # FIRST AUTHOR <EMAIL@ADDRESS>, 2025. |  | ||||||
| # |  | ||||||
| #, fuzzy |  | ||||||
| msgid "" |  | ||||||
| msgstr "" |  | ||||||
| "Project-Id-Version: matrix-docker-ansible-deploy \n" |  | ||||||
| "Report-Msgid-Bugs-To: \n" |  | ||||||
| "POT-Creation-Date: 2025-01-27 09:54+0200\n" |  | ||||||
| "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" |  | ||||||
| "Last-Translator: FULL NAME <EMAIL@ADDRESS>\n" |  | ||||||
| "Language: bg\n" |  | ||||||
| "Language-Team: bg <LL@li.org>\n" |  | ||||||
| "Plural-Forms: nplurals=2; plural=(n != 1);\n" |  | ||||||
| "MIME-Version: 1.0\n" |  | ||||||
| "Content-Type: text/plain; charset=utf-8\n" |  | ||||||
| "Content-Transfer-Encoding: 8bit\n" |  | ||||||
| "Generated-By: Babel 2.16.0\n" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:1 |  | ||||||
| msgid "Configuring continuwuity (optional)" |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:3 |  | ||||||
| msgid "The playbook can install and configure the [continuwuity](https://continuwuity.org/) Matrix server for you." |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:5 |  | ||||||
| msgid "See the project's [documentation](https://continuwuity.org/) to learn what it does and why it might be useful to you." |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:7 |  | ||||||
| msgid "By default, the playbook installs [Synapse](https://github.com/element-hq/synapse) as it's the only full-featured Matrix server at the moment. If that's okay, you can skip this document." |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:9 |  | ||||||
| msgid "💡 **Note**: continuwuity is a fork of [conduwuit](./configuring-playbook-conduwuit.md), which the playbook also supports." |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:11 |  | ||||||
| msgid "⚠️ **Warnings**:" |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:13 |  | ||||||
| msgid "**You can't switch an existing Matrix server's implementation** (e.g. Synapse -> continuwuity). Proceed below only if you're OK with losing data or you're dealing with a server on a new domain name, which hasn't participated in the Matrix federation yet." |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:15 |  | ||||||
| msgid "**Homeserver implementations other than Synapse may not be fully functional**. The playbook may also not assist you in an optimal way (like it does with Synapse). Make yourself familiar with the downsides before proceeding" |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:17 |  | ||||||
| msgid "Adjusting the playbook configuration" |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:19 |  | ||||||
| msgid "To use continuwuity, you **generally** need to adjust the `matrix_homeserver_implementation: synapse` configuration on your `inventory/host_vars/matrix.example.com/vars.yml` file as below:" |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:33 |  | ||||||
| msgid "Extending the configuration" |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:35 |  | ||||||
| msgid "There are some additional things you may wish to configure about the server." |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:37 |  | ||||||
| msgid "Take a look at:" |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:39 |  | ||||||
| msgid "`roles/custom/matrix-continuwuity/defaults/main.yml` for some variables that you can customize via your `vars.yml` file" |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:40 |  | ||||||
| msgid "`roles/custom/matrix-continuwuity/templates/continuwuity.toml.j2` for the server's default configuration" |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:42 |  | ||||||
| msgid "There are various Ansible variables that control settings in the `continuwuity.toml` file." |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:44 |  | ||||||
| msgid "If a specific setting you'd like to change does not have a dedicated Ansible variable, you can either submit a PR to us to add it, or you can [override the setting using an environment variable](https://continuwuity.org/configuration#environment-variables) using `matrix_continuwuity_environment_variables_extension`. For example:" |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:52 |  | ||||||
| msgid "Creating the first user account" |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:54 |  | ||||||
| msgid "Unlike other homeserver implementations (like Synapse and Dendrite), continuwuity does not support creating users via the command line or via the playbook." |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:56 |  | ||||||
| msgid "If you followed the instructions above (see [Adjusting the playbook configuration](#adjusting-the-playbook-configuration)), you should have registration enabled and protected by a registration token." |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:58 |  | ||||||
| msgid "This should allow you to create the first user account via any client (like [Element Web](./configuring-playbook-client-element-web.md)) which supports creating users." |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:60 |  | ||||||
| msgid "The **first user account that you create will be marked as an admin** and **will be automatically invited to an admin room**." |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:63 |  | ||||||
| msgid "Configuring bridges / appservices" |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:65 |  | ||||||
| msgid "For other homeserver implementations (like Synapse and Dendrite), the playbook automatically registers appservices (for bridges, bots, etc.) with the homeserver." |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:67 |  | ||||||
| msgid "For continuwuity, you will have to manually register appservices using the [`!admin appservices register` command](https://continuwuity.org/appservices#set-up-the-appservice---general-instructions) sent to the server bot account." |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:69 |  | ||||||
| msgid "The server's bot account has a Matrix ID of `@conduit:example.com` (not `@continuwuity:example.com`!) due to continuwuity's historical legacy. Your first user account would already have been invited to an admin room with this bot." |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:72 |  | ||||||
| msgid "Find the appservice file you'd like to register. This can be any `registration.yaml` file found in the `/matrix` directory, for example `/matrix/mautrix-signal/bridge/registration.yaml`." |  | ||||||
| msgstr "" |  | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-continuwuity.md:74 |  | ||||||
| msgid "Then, send its content to the existing admin room:" |  | ||||||
| msgstr "" |  | ||||||
| @@ -435,7 +435,7 @@ msgid "We **don't** ask you to [run the `syn2mas` migration advisor command](htt | |||||||
| msgstr "" | msgstr "" | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-matrix-authentication-service.md:340 | #: ../../../docs/configuring-playbook-matrix-authentication-service.md:340 | ||||||
| msgid "You can invoke the `syn2mas` tool via the playbook by running the playbook's `matrix-authentication-service-mas-cli-syn2mas` tag. We recommend first doing a [dry-run](#performing-a-syn2mas-dry-run) and then a [real migration](#performing-a-real-syn2mas-migration)." | msgid "You can invoke the `syn2mas` tool via the playbook by running the playbook's `matrix-authentication-service-syn2mas` tag. We recommend first doing a [dry-run](#performing-a-syn2mas-dry-run) and then a [real migration](#performing-a-real-syn2mas-migration)." | ||||||
| msgstr "" | msgstr "" | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-matrix-authentication-service.md:342 | #: ../../../docs/configuring-playbook-matrix-authentication-service.md:342 | ||||||
| @@ -535,7 +535,7 @@ msgid "you've performed a [syn2mas dry-run](#performing-a-syn2mas-dry-run) and d | |||||||
| msgstr "" | msgstr "" | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-matrix-authentication-service.md:401 | #: ../../../docs/configuring-playbook-matrix-authentication-service.md:401 | ||||||
| msgid "To perform a real migration, run the `matrix-authentication-service-mas-cli-syn2mas` tag **without** the `matrix_authentication_service_syn2mas_migrate_dry_run` variable:" | msgid "To perform a real migration, run the `matrix-authentication-service-syn2mas` tag **without** the `matrix_authentication_service_syn2mas_dry_run` variable:" | ||||||
| msgstr "" | msgstr "" | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-matrix-authentication-service.md:407 | #: ../../../docs/configuring-playbook-matrix-authentication-service.md:407 | ||||||
|   | |||||||
| @@ -434,7 +434,7 @@ msgid "We **don't** ask you to [run the `syn2mas` migration advisor command](htt | |||||||
| msgstr "" | msgstr "" | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-matrix-authentication-service.md:340 | #: ../../../docs/configuring-playbook-matrix-authentication-service.md:340 | ||||||
| msgid "You can invoke the `syn2mas` tool via the playbook by running the playbook's `matrix-authentication-service-mas-cli-syn2mas` tag. We recommend first doing a [dry-run](#performing-a-syn2mas-dry-run) and then a [real migration](#performing-a-real-syn2mas-migration)." | msgid "You can invoke the `syn2mas` tool via the playbook by running the playbook's `matrix-authentication-service-syn2mas` tag. We recommend first doing a [dry-run](#performing-a-syn2mas-dry-run) and then a [real migration](#performing-a-real-syn2mas-migration)." | ||||||
| msgstr "" | msgstr "" | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-matrix-authentication-service.md:342 | #: ../../../docs/configuring-playbook-matrix-authentication-service.md:342 | ||||||
| @@ -534,7 +534,7 @@ msgid "you've performed a [syn2mas dry-run](#performing-a-syn2mas-dry-run) and d | |||||||
| msgstr "" | msgstr "" | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-matrix-authentication-service.md:401 | #: ../../../docs/configuring-playbook-matrix-authentication-service.md:401 | ||||||
| msgid "To perform a real migration, run the `matrix-authentication-service-mas-cli-syn2mas` tag **without** the `matrix_authentication_service_syn2mas_migrate_dry_run` variable:" | msgid "To perform a real migration, run the `matrix-authentication-service-syn2mas` tag **without** the `matrix_authentication_service_syn2mas_dry_run` variable:" | ||||||
| msgstr "" | msgstr "" | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-matrix-authentication-service.md:407 | #: ../../../docs/configuring-playbook-matrix-authentication-service.md:407 | ||||||
|   | |||||||
| @@ -1,26 +1,26 @@ | |||||||
| alabaster==1.0.0 | alabaster==1.0.0 | ||||||
| babel==2.17.0 | babel==2.17.0 | ||||||
| certifi==2025.10.5 | certifi==2025.1.31 | ||||||
| charset-normalizer==3.4.4 | charset-normalizer==3.4.1 | ||||||
| click==8.3.0 | click==8.1.8 | ||||||
| docutils==0.22.2 | docutils==0.21.2 | ||||||
| idna==3.11 | idna==3.10 | ||||||
| imagesize==1.4.1 | imagesize==1.4.1 | ||||||
| Jinja2==3.1.6 | Jinja2==3.1.6 | ||||||
| linkify-it-py==2.0.3 | linkify-it-py==2.0.3 | ||||||
| markdown-it-py==4.0.0 | markdown-it-py==3.0.0 | ||||||
| MarkupSafe==3.0.3 | MarkupSafe==3.0.2 | ||||||
| mdit-py-plugins==0.5.0 | mdit-py-plugins==0.4.2 | ||||||
| mdurl==0.1.2 | mdurl==0.1.2 | ||||||
| myst-parser==4.0.1 | myst-parser==4.0.1 | ||||||
| packaging==25.0 | packaging==24.2 | ||||||
| Pygments==2.19.2 | Pygments==2.19.1 | ||||||
| PyYAML==6.0.3 | PyYAML==6.0.2 | ||||||
| requests==2.32.5 | requests==2.32.3 | ||||||
| setuptools==80.9.0 | setuptools==76.0.0 | ||||||
| snowballstemmer==3.0.1 | snowballstemmer==2.2.0 | ||||||
| Sphinx==8.2.3 | Sphinx==8.2.3 | ||||||
| sphinx-intl==2.3.2 | sphinx-intl==2.3.1 | ||||||
| sphinx-markdown-builder==0.6.8 | sphinx-markdown-builder==0.6.8 | ||||||
| sphinxcontrib-applehelp==2.0.0 | sphinxcontrib-applehelp==2.0.0 | ||||||
| sphinxcontrib-devhelp==2.0.0 | sphinxcontrib-devhelp==2.0.0 | ||||||
| @@ -30,4 +30,4 @@ sphinxcontrib-qthelp==2.0.0 | |||||||
| sphinxcontrib-serializinghtml==2.0.0 | sphinxcontrib-serializinghtml==2.0.0 | ||||||
| tabulate==0.9.0 | tabulate==0.9.0 | ||||||
| uc-micro-py==1.0.3 | uc-micro-py==1.0.3 | ||||||
| urllib3==2.5.0 | urllib3==2.3.0 | ||||||
|   | |||||||
| @@ -430,7 +430,7 @@ msgid "We **don't** ask you to [run the `syn2mas` migration advisor command](htt | |||||||
| msgstr "" | msgstr "" | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-matrix-authentication-service.md:340 | #: ../../../docs/configuring-playbook-matrix-authentication-service.md:340 | ||||||
| msgid "You can invoke the `syn2mas` tool via the playbook by running the playbook's `matrix-authentication-service-mas-cli-syn2mas` tag. We recommend first doing a [dry-run](#performing-a-syn2mas-dry-run) and then a [real migration](#performing-a-real-syn2mas-migration)." | msgid "You can invoke the `syn2mas` tool via the playbook by running the playbook's `matrix-authentication-service-syn2mas` tag. We recommend first doing a [dry-run](#performing-a-syn2mas-dry-run) and then a [real migration](#performing-a-real-syn2mas-migration)." | ||||||
| msgstr "" | msgstr "" | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-matrix-authentication-service.md:342 | #: ../../../docs/configuring-playbook-matrix-authentication-service.md:342 | ||||||
| @@ -530,7 +530,7 @@ msgid "you've performed a [syn2mas dry-run](#performing-a-syn2mas-dry-run) and d | |||||||
| msgstr "" | msgstr "" | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-matrix-authentication-service.md:401 | #: ../../../docs/configuring-playbook-matrix-authentication-service.md:401 | ||||||
| msgid "To perform a real migration, run the `matrix-authentication-service-mas-cli-syn2mas` tag **without** the `matrix_authentication_service_syn2mas_migrate_dry_run` variable:" | msgid "To perform a real migration, run the `matrix-authentication-service-syn2mas` tag **without** the `matrix_authentication_service_syn2mas_dry_run` variable:" | ||||||
| msgstr "" | msgstr "" | ||||||
|  |  | ||||||
| #: ../../../docs/configuring-playbook-matrix-authentication-service.md:407 | #: ../../../docs/configuring-playbook-matrix-authentication-service.md:407 | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user