Compare commits
	
		
			158 Commits
		
	
	
		
			v0.10.3-et
			...
			v0.11.1-et
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 3b61e6e02c | ||
|   | a4e4d37413 | ||
|   | 4127954c1d | ||
|   | 554d2cd132 | ||
|   | d2326a4cf3 | ||
|   | 7c0c9f922d | ||
|   | 4dd3aa2375 | ||
|   | 05d3740b80 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | e425efa26a | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | cd8e35ba27 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 710cc57c4f | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 249bc4d0c2 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | aa6567a490 | ||
|   | f40cb4839e | ||
|   | d5df57b7ec | ||
|   | 5f89026db3 | ||
|   | 10aaef98b0 | ||
|   | c323e170ac | ||
|   | 797b924a62 | ||
|   | f1023ebc64 | ||
|   | e15411a04c | ||
|   | 3902dcd3d1 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 9c911abfb7 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 23c39cede8 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 50e62f0b6c | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | d7d1d3c5b5 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 16d339c6f3 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 9b0786f699 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | fc1b20e95b | ||
|   | ef8ae9b38f | ||
|   | 7a286ad506 | ||
|   | c82d8653fd | ||
|   | 949c2e8809 | ||
|   | 20a1cec358 | ||
|   | 21240b8ada | ||
|   | f218363e97 | ||
|   | 1a5fd713da | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 3d6202f335 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 9161e26d3a | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | b00d810fae | ||
|   | 9a4b995d09 | ||
|   | c97405b622 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | b5ebd9173e | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | a1ff4dc9ef | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 2298fee054 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | e236126a30 | ||
|   | 7da5265575 | ||
|   | 62fc97a417 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | fa3f2437a3 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 8dc5238fcb | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 238350b940 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 99bf7b1889 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | d72c91644d | ||
|   | 5bec4c71ea | ||
|   | 245dadc470 | ||
|   | 08cde13fd4 | ||
|   | 765456d233 | ||
|   | b6bc4a2d43 | ||
|   | 851478bbcb | ||
|   | ff8e43631a | ||
|   | 7b8a43b835 | ||
|   | bc0c186242 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | d5b9981bf0 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 7a8977a00c | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 5297e56eca | ||
|   | 82ff610b89 | ||
|   | 263f25303e | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 2aa7cdcb97 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | e3e8f028f4 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | f18523e0f2 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 3533cbed93 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | bf1cec2796 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 7005d08c7e | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | e15b45bcf9 | ||
|   | 603737b2ad | ||
|   | eebc7a4fab | ||
|   | 3725b01fe5 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 6c41aab463 | ||
|   | e8987607ff | ||
|   | 9c440024bb | ||
|   | aa10df711e | ||
|   | 51aca16e2f | ||
|   | 4f1b9c2bfa | ||
|   | a801957194 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 8f527eeb85 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 92632f81f8 | ||
|   | e76809fb37 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 03d142a47c | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | f589427b3c | ||
|   | 16d78b577e | ||
|   | 649450f7ee | ||
|   | a64705c28c | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 5d775ca08b | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | b2289e5776 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 607abc003b | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 210623b39e | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 8c72dbbd9a | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 5779ce6301 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 664573d65e | ||
|   | cfcc3f5a73 | ||
|   | 8c303b7940 | ||
|   | 785be9187d | ||
|   | 69b04736d6 | ||
|   | 4051631244 | ||
|   | e8e28b5df1 | ||
|   | d5c10b6e02 | ||
|   | 3085b9ffa0 | ||
|   | b2a3fb0f87 | ||
|   | 1e8b4cc885 | ||
|   | 4d1a9cc147 | ||
|   | 1b8b702270 | ||
|   | 61c32fb473 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | ad876bb790 | ||
|   | b941b4c787 | ||
|   | 45b5213c8c | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 2524848dae | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 669c1f3079 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 590f673167 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 307793f000 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 96f549fe42 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 3de4332477 | ||
|   | 3167b55430 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | cc44b5581f | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 30615eaf02 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 4e88f03aab | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 9bc2788560 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | a65eb56098 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 1c95995478 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | d4c07980d5 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 96946186c9 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 742106071d | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | ce79eb330c | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 04d07f5eb3 | ||
|   | de7930f472 | ||
|   | 2a66988807 | ||
|   | 5bfa98d3a1 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | ea41f929a6 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 037dc09da6 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | b9ad596f38 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | c83e61af2c | ||
|   | 2752716497 | ||
|   | 64f9d8b48c | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 81fb008e59 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | cede7c611b | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 8d66dca068 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 26620966ab | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 29cb61bf47 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 6b5863e257 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 5a2c6ec326 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | f52bce55a8 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 76d3f42017 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 5bfd330f08 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 6d8ea12c5a | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 399b37f57e | ||
|   | e6f3d15b45 | ||
|   | 75e4cfa0c4 | ||
|   | ce3337c46f | ||
|   | 54b67b3b48 | 
							
								
								
									
										63
									
								
								.github/CONTRIBUTING.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								.github/CONTRIBUTING.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,63 @@ | |||||||
|  | # Contribution Guidelines | ||||||
|  |  | ||||||
|  | Table of Contents: | ||||||
|  |  | ||||||
|  | <!-- vim-markdown-toc GFM --> | ||||||
|  |  | ||||||
|  | * [Did you find a bug?](#did-you-find-a-bug) | ||||||
|  |   * [Is it a Security Vulnerability?](#is-it-a-security-vulnerability) | ||||||
|  |   * [Is it already a known issue?](#is-it-already-a-known-issue) | ||||||
|  |   * [Reporting a Bug](#reporting-a-bug) | ||||||
|  |   * [Is there a patch for the bug?](#is-there-a-patch-for-the-bug) | ||||||
|  | * [Do you want to add a new feature?](#do-you-want-to-add-a-new-feature) | ||||||
|  |   * [Is it just an idea?](#is-it-just-an-idea) | ||||||
|  |   * [Is there a patch for the feature?](#is-there-a-patch-for-the-feature) | ||||||
|  | * [Do you have questions about the Synapse Admin project or need guidance?](#do-you-have-questions-about-the-synapse-admin-project-or-need-guidance) | ||||||
|  |  | ||||||
|  | <!-- vim-markdown-toc --> | ||||||
|  |  | ||||||
|  | ## Did you find a bug? | ||||||
|  |  | ||||||
|  | ### Is it a Security Vulnerability? | ||||||
|  |  | ||||||
|  | Please follow the [Security Policy](https://github.com/etkecc/synapse-admin/blob/main/.github/SECURITY.md) for reporting | ||||||
|  | security vulnerabilities. | ||||||
|  |  | ||||||
|  | ### Is it already a known issue? | ||||||
|  |  | ||||||
|  | Please ensure the bug was not already reported by searching [the Issues section](https://github.com/etkecc/synapse-admin/issues). | ||||||
|  |  | ||||||
|  | ### Reporting a Bug | ||||||
|  |  | ||||||
|  | If you think you have found a bug in Synapse Admin, it is not a security vulnerability, and it is not already reported, | ||||||
|  | please open [a new issue](https://github.com/etkecc/synapse-admin/issues/new) with: | ||||||
|  |     * A proper title and clear description of the problem. | ||||||
|  |     * As much relevant information as possible: | ||||||
|  |         * The version of Synapse Admin you are using. | ||||||
|  |         * The version of Synapse you are using. | ||||||
|  |         * Any relevant browser console logs, failed requests details, and error messages. | ||||||
|  |  | ||||||
|  | ### Is there a patch for the bug? | ||||||
|  |  | ||||||
|  | If you already have a patch for the bug, please open a pull request with the patch, | ||||||
|  | and mention the issue number in the pull request description. | ||||||
|  |  | ||||||
|  | ## Do you want to add a new feature? | ||||||
|  |  | ||||||
|  | ### Is it just an idea? | ||||||
|  |  | ||||||
|  | Please open [a new issue](https://github.com/etkecc/synapse-admin/issues/new) with: | ||||||
|  |     * A proper title and clear description of the requested feature. | ||||||
|  |     * Any relevant information about the feature: | ||||||
|  |         * Why do you think this feature is needed? | ||||||
|  |         * How do you think it should work? (provide Synapse Admin API endpoint) | ||||||
|  |         * Any relevant screenshots or mockups. | ||||||
|  |  | ||||||
|  | ### Is there a patch for the feature? | ||||||
|  |  | ||||||
|  | If you already have a patch for the feature, please open a pull request with the patch, | ||||||
|  | and mention the issue number in the pull request description. | ||||||
|  |  | ||||||
|  | ## Do you have questions about the Synapse Admin project or need guidance? | ||||||
|  |  | ||||||
|  | Please use the official community Matrix room: [#synapse-admin:etke.cc](https://matrix.to/#/#synapse-admin:etke.cc) | ||||||
							
								
								
									
										34
									
								
								.github/ISSUE_TEMPLATE/bug_report.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								.github/ISSUE_TEMPLATE/bug_report.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | |||||||
|  | --- | ||||||
|  | name: Bug report | ||||||
|  | about: Report a Synapse Admin bug | ||||||
|  | title: '' | ||||||
|  | labels: bug | ||||||
|  | assignees: '' | ||||||
|  |  | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | **Describe the bug** | ||||||
|  | A clear and concise description of what the bug is. | ||||||
|  |  | ||||||
|  | **To Reproduce** | ||||||
|  | Steps to reproduce the behavior: | ||||||
|  | 1. Go to '...' | ||||||
|  | 2. Click on '....' | ||||||
|  | 3. Scroll down to '....' | ||||||
|  | 4. See error | ||||||
|  |  | ||||||
|  | **Expected behavior** | ||||||
|  | A clear and concise description of what you expected to happen. | ||||||
|  |  | ||||||
|  | **Screenshots** | ||||||
|  | If applicable, add screenshots to help explain your problem. | ||||||
|  |  | ||||||
|  | **Browser console logs** | ||||||
|  | If applicable, add the browser console's log | ||||||
|  |  | ||||||
|  | **Instance configuration:** | ||||||
|  |  - Synapse Admin version: [e.g. v0.10.3-etke39] | ||||||
|  |  - Synapse version [v1.127.1] | ||||||
|  |  | ||||||
|  | **Additional context** | ||||||
|  | Add any other context about the problem here. | ||||||
							
								
								
									
										23
									
								
								.github/ISSUE_TEMPLATE/feature_request.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								.github/ISSUE_TEMPLATE/feature_request.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,23 @@ | |||||||
|  | --- | ||||||
|  | name: Feature request | ||||||
|  | about: Suggest an idea for Synapse Admin | ||||||
|  | title: '' | ||||||
|  | labels: enhancement | ||||||
|  | assignees: '' | ||||||
|  |  | ||||||
|  | --- | ||||||
|  |  | ||||||
|  | **Is your feature request related to a problem? Please describe.** | ||||||
|  | A clear and concise description of what the problem is. Ex. I'm always frustrated when [...] | ||||||
|  |  | ||||||
|  | **Describe the solution you'd like** | ||||||
|  | A clear and concise description of what you want to happen. | ||||||
|  |  | ||||||
|  | **Describe alternatives you've considered** | ||||||
|  | A clear and concise description of any alternative solutions or features you've considered. | ||||||
|  |  | ||||||
|  | **Provide related Synapse Admin API endpoints** | ||||||
|  | If applicable, provide links to the Synapse Admin API's endpoints that could be used to implement that feature | ||||||
|  |  | ||||||
|  | **Additional context** | ||||||
|  | Add any other context or screenshots about the feature request here. | ||||||
							
								
								
									
										14
									
								
								.github/SECURITY.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								.github/SECURITY.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | # Security Policy | ||||||
|  |  | ||||||
|  | ## Supported Versions | ||||||
|  |  | ||||||
|  | Only [the last published version](https://github.com/etkecc/synapse-admin/releases/latest) of the project is supported. | ||||||
|  | This means that only the latest version will receive security updates. | ||||||
|  | If you are using an older version, you are strongly encouraged to upgrade to the latest version. | ||||||
|  |  | ||||||
|  | ## Reporting a Vulnerability | ||||||
|  |  | ||||||
|  | Please contact us using the [#synapse-admin:etke.cc](https://matrix.to/#/#synapse-admin:etke.cc) Matrix room. | ||||||
|  | The Synapse Admin project is a static JS UI for the Synapse server, | ||||||
|  | so it is unlikely that there are (or will be) any impactful security vulnerabilities in the project itself. | ||||||
|  | However, we do not rule out the possibility of such cases, so we will be happy to receive any reports! | ||||||
							
								
								
									
										16
									
								
								.github/workflows/workflow.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										16
									
								
								.github/workflows/workflow.yml
									
									
									
									
										vendored
									
									
								
							| @@ -48,25 +48,31 @@ jobs: | |||||||
|           name: dist |           name: dist | ||||||
|           path: dist/ |           path: dist/ | ||||||
|       - name: Set up Docker Buildx |       - name: Set up Docker Buildx | ||||||
|         uses: docker/setup-buildx-action@v3 |         uses: docker/setup-buildx-action@b5ca514318bd6ebac0fb2aedd5d36ec1b5c232a2 # v3.10.0 | ||||||
|       - name: Login to ghcr.io |       - name: Login to ghcr.io | ||||||
|         uses: docker/login-action@v3 |         uses: docker/login-action@74a5d142397b4f367a81961eba4e8cd7edddf772 # v3.4.0 | ||||||
|         with: |         with: | ||||||
|           registry: ghcr.io |           registry: ghcr.io | ||||||
|           username: ${{ github.actor }} |           username: ${{ github.actor }} | ||||||
|           password: ${{ secrets.GITHUB_TOKEN }} |           password: ${{ secrets.GITHUB_TOKEN }} | ||||||
|  |       - name: Login to hub.docker.com | ||||||
|  |         uses: docker/login-action@74a5d142397b4f367a81961eba4e8cd7edddf772 # v3.4.0 | ||||||
|  |         with: | ||||||
|  |           username: etkecc | ||||||
|  |           password: ${{ secrets.DOCKERHUB_TOKEN }} | ||||||
|       - name: Extract metadata (tags, labels) for Docker |       - name: Extract metadata (tags, labels) for Docker | ||||||
|         id: meta |         id: meta | ||||||
|         uses: docker/metadata-action@v5 |         uses: docker/metadata-action@902fa8ec7d6ecbf8d84d538b9b233a880e428804 # v5.7.0 | ||||||
|         with: |         with: | ||||||
|           images: | |           images: | | ||||||
|  |             ${{ github.repository }} | ||||||
|             ghcr.io/${{ github.repository }} |             ghcr.io/${{ github.repository }} | ||||||
|             registry.etke.cc/${{ github.repository }} |             registry.etke.cc/${{ github.repository }} | ||||||
|           tags: | |           tags: | | ||||||
|             type=raw,value=latest,enable=${{ github.ref_name == 'main' }} |             type=raw,value=latest,enable=${{ github.ref_name == 'main' }} | ||||||
|             type=semver,pattern={{raw}} |             type=semver,pattern={{raw}} | ||||||
|       - name: Build and push |       - name: Build and push | ||||||
|         uses: docker/build-push-action@v6 |         uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0 | ||||||
|         with: |         with: | ||||||
|           platforms: linux/amd64,linux/arm64 |           platforms: linux/amd64,linux/arm64 | ||||||
|           context: . |           context: . | ||||||
| @@ -106,7 +112,7 @@ jobs: | |||||||
|         run: | |         run: | | ||||||
|           mv dist synapse-admin |           mv dist synapse-admin | ||||||
|           tar chvzf synapse-admin.tar.gz synapse-admin |           tar chvzf synapse-admin.tar.gz synapse-admin | ||||||
|       - uses: softprops/action-gh-release@v2 |       - uses: softprops/action-gh-release@da05d552573ad5aba039eaac05058a918a7bf631 # v2.2.2 | ||||||
|         with: |         with: | ||||||
|           files: synapse-admin.tar.gz |           files: synapse-admin.tar.gz | ||||||
|           generate_release_notes: true |           generate_release_notes: true | ||||||
|   | |||||||
							
								
								
									
										893
									
								
								.yarn/releases/yarn-4.1.1.cjs
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										893
									
								
								.yarn/releases/yarn-4.1.1.cjs
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										925
									
								
								.yarn/releases/yarn-4.4.1.cjs
									
									
									
									
										vendored
									
									
										Executable file
									
								
							
							
						
						
									
										925
									
								
								.yarn/releases/yarn-4.4.1.cjs
									
									
									
									
										vendored
									
									
										Executable file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										10
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								README.md
									
									
									
									
									
								
							| @@ -55,7 +55,7 @@ The full list is described below in the [Changes](#changes) section. | |||||||
| * As a core/default component on [etke.cc](https://etke.cc/?utm_source=github&utm_medium=readme&utm_campaign=synapse-admin) | * As a core/default component on [etke.cc](https://etke.cc/?utm_source=github&utm_medium=readme&utm_campaign=synapse-admin) | ||||||
| * As a standalone app on [admin.etke.cc](https://admin.etke.cc) | * As a standalone app on [admin.etke.cc](https://admin.etke.cc) | ||||||
| * As a prebuilt distribution on [GitHub Releases](https://github.com/etkecc/synapse-admin/releases) | * As a prebuilt distribution on [GitHub Releases](https://github.com/etkecc/synapse-admin/releases) | ||||||
| * As a Docker container on [GitHub Container Registry](https://github.com/etkecc/synapse-admin/pkgs/container/synapse-admin) | * As a Docker container on [Docker Hub](https://hub.docker.com/r/etkecc/synapse-admin) and [GitHub Container Registry](https://github.com/etkecc/synapse-admin/pkgs/container/synapse-admin) | ||||||
| * As a component in [Matrix-Docker-Ansible-Deploy Playbook](https://github.com/spantaleev/matrix-docker-ansible-deploy/blob/master/docs/configuring-playbook-synapse-admin.md) | * As a component in [Matrix-Docker-Ansible-Deploy Playbook](https://github.com/spantaleev/matrix-docker-ansible-deploy/blob/master/docs/configuring-playbook-synapse-admin.md) | ||||||
|  |  | ||||||
| ### Changes | ### Changes | ||||||
| @@ -109,10 +109,10 @@ The following changes are already implemented: | |||||||
| * 📞 [Support E.164-based Matrix IDs (MSC4009)](https://github.com/etkecc/synapse-admin/pull/214) | * 📞 [Support E.164-based Matrix IDs (MSC4009)](https://github.com/etkecc/synapse-admin/pull/214) | ||||||
| * 🛑 [Add support for Account Suspension (MSC3823)](https://github.com/etkecc/synapse-admin/pull/195) | * 🛑 [Add support for Account Suspension (MSC3823)](https://github.com/etkecc/synapse-admin/pull/195) | ||||||
| * 🗑️ [Add "Purge Remote Media" button](https://github.com/etkecc/synapse-admin/pull/237) | * 🗑️ [Add "Purge Remote Media" button](https://github.com/etkecc/synapse-admin/pull/237) | ||||||
| * [Respect base url (`BASE_PATH` / `vite build --base`) when loading `config.json`](https://github.com/etkecc/synapse-admin/pull/274) | * 📁 [Respect base url (`BASE_PATH` / `vite build --base`) when loading `config.json`](https://github.com/etkecc/synapse-admin/pull/274) | ||||||
| * [Add Users' Account Data tab](https://github.com/etkecc/synapse-admin/pull/276) | * 🗂️ [Add Users' Account Data tab](https://github.com/etkecc/synapse-admin/pull/276) | ||||||
| * [Make bulk registration CSV import more user-friendly](https://github.com/etkecc/synapse-admin/pull/411) | * 🧾 [Make bulk registration CSV import more user-friendly](https://github.com/etkecc/synapse-admin/pull/411) | ||||||
| * [Configurable CORS Credentials](https://github.com/etkecc/synapse-admin/pull/456) | * 🌐 [Configurable CORS Credentials](https://github.com/etkecc/synapse-admin/pull/456) | ||||||
|  |  | ||||||
| #### exclusive for [etke.cc](https://etke.cc) customers | #### exclusive for [etke.cc](https://etke.cc) customers | ||||||
|  |  | ||||||
|   | |||||||
| @@ -17,6 +17,7 @@ Table of contents: | |||||||
|  |  | ||||||
| Specific configuration options: | Specific configuration options: | ||||||
|  |  | ||||||
|  | * [Customizing CORS credentials](./cors-credentials.md) | ||||||
| * [Restricting available homeserver](./restrict-hs.md) | * [Restricting available homeserver](./restrict-hs.md) | ||||||
| * [System / Appservice-managed Users](./system-users.md) | * [System / Appservice-managed Users](./system-users.md) | ||||||
| * [Custom Menu Items](./custom-menu.md) | * [Custom Menu Items](./custom-menu.md) | ||||||
| @@ -33,6 +34,10 @@ they are not available for any other Synapse Admin deployments. | |||||||
|  |  | ||||||
| * [Server Status icon](../src/components/etke.cc/README.md#server-status-icon) | * [Server Status icon](../src/components/etke.cc/README.md#server-status-icon) | ||||||
| * [Server Status page](../src/components/etke.cc/README.md#server-status-page) | * [Server Status page](../src/components/etke.cc/README.md#server-status-page) | ||||||
|  | * [Server Actions page](../src/components/etke.cc/README.md#server-actions-page) | ||||||
|  | * [Server Commands Panel](../src/components/etke.cc/README.md#server-commands-panel) | ||||||
|  | * [Server Notifications icon](../src/components/etke.cc/README.md#server-notifications-icon) | ||||||
|  | * [Server Notifications page](../src/components/etke.cc/README.md#server-notifications-page) | ||||||
|  |  | ||||||
| ## Deployment | ## Deployment | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								justfile
									
									
									
									
									
								
							
							
						
						
									
										3
									
								
								justfile
									
									
									
									
									
								
							| @@ -6,6 +6,9 @@ default: | |||||||
| build: __install | build: __install | ||||||
|     @yarn run build --base=./ |     @yarn run build --base=./ | ||||||
|  |  | ||||||
|  | update: | ||||||
|  |     yarn upgrade-interactive --latest | ||||||
|  |  | ||||||
| # run the app in a development mode | # run the app in a development mode | ||||||
| run: | run: | ||||||
|     @yarn start --host 0.0.0.0 |     @yarn start --host 0.0.0.0 | ||||||
|   | |||||||
							
								
								
									
										54
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										54
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "synapse-admin", |   "name": "synapse-admin", | ||||||
|   "version": "0.10.3", |   "version": "0.11.1", | ||||||
|   "description": "Admin GUI for the Matrix.org server Synapse", |   "description": "Admin GUI for the Matrix.org server Synapse", | ||||||
|   "type": "module", |   "type": "module", | ||||||
|   "author": "etke.cc (originally by Awesome Technologies Innovationslabor GmbH)", |   "author": "etke.cc (originally by Awesome Technologies Innovationslabor GmbH)", | ||||||
| @@ -11,35 +11,35 @@ | |||||||
|     "url": "https://github.com/etkecc/synapse-admin" |     "url": "https://github.com/etkecc/synapse-admin" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@eslint/js": "^9.22.0", |     "@eslint/js": "^9.25.0", | ||||||
|     "@testing-library/dom": "^10.0.0", |     "@testing-library/dom": "^10.0.0", | ||||||
|     "@testing-library/jest-dom": "^6.6.3", |     "@testing-library/jest-dom": "^6.6.3", | ||||||
|     "@testing-library/react": "^16.3.0", |     "@testing-library/react": "^16.3.0", | ||||||
|     "@testing-library/user-event": "^14.6.1", |     "@testing-library/user-event": "^14.6.1", | ||||||
|     "@types/jest": "^29.5.14", |     "@types/jest": "^29.5.14", | ||||||
|     "@types/lodash": "^4.17.16", |     "@types/lodash": "^4.17.17", | ||||||
|     "@types/node": "^22.14.1", |     "@types/node": "^22.15.29", | ||||||
|     "@types/papaparse": "^5.3.15", |     "@types/papaparse": "^5.3.16", | ||||||
|     "@types/react": "^19.1.1", |     "@types/react": "^19.1.6", | ||||||
|     "@typescript-eslint/eslint-plugin": "^8.29.1", |     "@typescript-eslint/eslint-plugin": "^8.32.0", | ||||||
|     "@typescript-eslint/parser": "^8.29.0", |     "@typescript-eslint/parser": "^8.32.0", | ||||||
|     "@vitejs/plugin-react": "^4.3.4", |     "@vitejs/plugin-react": "^4.5.0", | ||||||
|     "eslint": "^9.24.0", |     "eslint": "^9.28.0", | ||||||
|     "eslint-config-prettier": "^10.1.2", |     "eslint-config-prettier": "^10.1.5", | ||||||
|     "eslint-plugin-import": "^2.31.0", |     "eslint-plugin-import": "^2.31.0", | ||||||
|     "eslint-plugin-jsx-a11y": "^6.10.2", |     "eslint-plugin-jsx-a11y": "^6.10.2", | ||||||
|     "eslint-plugin-prettier": "^5.2.6", |     "eslint-plugin-prettier": "^5.4.1", | ||||||
|     "eslint-plugin-unused-imports": "^4.1.4", |     "eslint-plugin-unused-imports": "^4.1.4", | ||||||
|     "jest": "^29.7.0", |     "jest": "^29.7.0", | ||||||
|     "jest-environment-jsdom": "^29.7.0", |     "jest-environment-jsdom": "^29.7.0", | ||||||
|     "jest-fetch-mock": "^3.0.3", |     "jest-fetch-mock": "^3.0.3", | ||||||
|     "prettier": "^3.5.3", |     "prettier": "^3.5.3", | ||||||
|     "react-test-renderer": "^19.1.0", |     "react-test-renderer": "^19.1.0", | ||||||
|     "ts-jest": "^29.3.2", |     "ts-jest": "^29.3.4", | ||||||
|     "ts-node": "^10.9.2", |     "ts-node": "^10.9.2", | ||||||
|     "typescript": "^5.8.3", |     "typescript": "^5.8.3", | ||||||
|     "typescript-eslint": "^8.29.1", |     "typescript-eslint": "^8.33.0", | ||||||
|     "vite": "^6.2.6", |     "vite": "^6.3.5", | ||||||
|     "vite-plugin-version-mark": "^0.1.4" |     "vite-plugin-version-mark": "^0.1.4" | ||||||
|   }, |   }, | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
| @@ -47,29 +47,29 @@ | |||||||
|     "@emotion/styled": "^11.14.0", |     "@emotion/styled": "^11.14.0", | ||||||
|     "@haleos/ra-language-german": "^1.0.0", |     "@haleos/ra-language-german": "^1.0.0", | ||||||
|     "@haxqer/ra-language-chinese": "^4.16.2", |     "@haxqer/ra-language-chinese": "^4.16.2", | ||||||
|     "@mui/icons-material": "^6.4.8", |     "@mui/icons-material": "^7.1.0", | ||||||
|     "@mui/material": "^6.4.8", |     "@mui/material": "^7.1.1", | ||||||
|     "@mui/utils": "^6.4.9", |     "@mui/utils": "^7.1.0", | ||||||
|     "@tanstack/react-query": "^5.74.0", |     "@tanstack/react-query": "^5.79.0", | ||||||
|     "history": "^5.3.0", |     "history": "^5.3.0", | ||||||
|     "jest-fixed-jsdom": "^0.0.9", |     "jest-fixed-jsdom": "^0.0.9", | ||||||
|     "lodash": "^4.17.21", |     "lodash": "^4.17.21", | ||||||
|     "papaparse": "^5.5.1", |     "papaparse": "^5.5.3", | ||||||
|     "ra-core": "^5.4.4", |     "ra-core": "^5.4.4", | ||||||
|     "ra-i18n-polyglot": "^5.4.4", |     "ra-i18n-polyglot": "^5.4.4", | ||||||
|     "ra-language-english": "^5.4.4", |     "ra-language-english": "^5.4.4", | ||||||
|     "ra-language-farsi": "^5.1.0", |     "ra-language-farsi": "^5.1.0", | ||||||
|     "ra-language-french": "^5.7.2", |     "ra-language-french": "^5.8.3", | ||||||
|     "ra-language-italian": "^3.13.1", |     "ra-language-italian": "^3.13.1", | ||||||
|     "ra-language-russian": "^5.4.3", |     "ra-language-russian": "^5.4.4", | ||||||
|     "react": "^19.1.0", |     "react": "^19.1.0", | ||||||
|     "react-admin": "^5.7.2", |     "react-admin": "^5.8.3", | ||||||
|     "react-dom": "^19.1.0", |     "react-dom": "^19.1.0", | ||||||
|     "react-hook-form": "^7.55.0", |     "react-hook-form": "^7.57.0", | ||||||
|     "react-is": "^19.1.0", |     "react-is": "^19.1.0", | ||||||
|     "ts-jest-mock-import-meta": "^1.3.0", |     "react-router": "^7.6.0", | ||||||
|     "react-router": "^7.5.0", |     "react-router-dom": "^7.6.1", | ||||||
|     "react-router-dom": "^7.5.0" |     "ts-jest-mock-import-meta": "^1.3.0" | ||||||
|   }, |   }, | ||||||
|   "scripts": { |   "scripts": { | ||||||
|     "start": "vite serve", |     "start": "vite serve", | ||||||
|   | |||||||
| @@ -1,7 +1,6 @@ | |||||||
| import { render, screen } from "@testing-library/react"; | import { render, screen } from "@testing-library/react"; | ||||||
| import polyglotI18nProvider from "ra-i18n-polyglot"; | import polyglotI18nProvider from "ra-i18n-polyglot"; | ||||||
| import { AdminContext } from "react-admin"; | import { AdminContext } from "react-admin"; | ||||||
| import { BrowserRouter } from "react-router-dom"; |  | ||||||
|  |  | ||||||
| import LoginPage from "./LoginPage"; | import LoginPage from "./LoginPage"; | ||||||
| import { AppContext } from "../Context"; | import { AppContext } from "../Context"; | ||||||
| @@ -14,11 +13,9 @@ describe("LoginForm", () => { | |||||||
|   it("renders with no restriction to homeserver", async () => { |   it("renders with no restriction to homeserver", async () => { | ||||||
|     await act(async () => { |     await act(async () => { | ||||||
|       render( |       render( | ||||||
|         <BrowserRouter> |  | ||||||
|         <AdminContext i18nProvider={i18nProvider}> |         <AdminContext i18nProvider={i18nProvider}> | ||||||
|           <LoginPage /> |           <LoginPage /> | ||||||
|         </AdminContext> |         </AdminContext> | ||||||
|         </BrowserRouter> |  | ||||||
|       ); |       ); | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
| @@ -35,7 +32,6 @@ describe("LoginForm", () => { | |||||||
|  |  | ||||||
|   it("renders with single restricted homeserver", () => { |   it("renders with single restricted homeserver", () => { | ||||||
|     render( |     render( | ||||||
|       <BrowserRouter> |  | ||||||
|       <AppContext.Provider |       <AppContext.Provider | ||||||
|         value={{ |         value={{ | ||||||
|           restrictBaseUrl: "https://matrix.example.com", |           restrictBaseUrl: "https://matrix.example.com", | ||||||
| @@ -48,7 +44,6 @@ describe("LoginForm", () => { | |||||||
|           <LoginPage /> |           <LoginPage /> | ||||||
|         </AdminContext> |         </AdminContext> | ||||||
|       </AppContext.Provider> |       </AppContext.Provider> | ||||||
|       </BrowserRouter> |  | ||||||
|     ); |     ); | ||||||
|  |  | ||||||
|     screen.getByText(englishMessages.synapseadmin.auth.welcome); |     screen.getByText(englishMessages.synapseadmin.auth.welcome); | ||||||
| @@ -73,9 +68,7 @@ describe("LoginForm", () => { | |||||||
|         }} |         }} | ||||||
|       > |       > | ||||||
|         <AdminContext i18nProvider={i18nProvider}> |         <AdminContext i18nProvider={i18nProvider}> | ||||||
|           <BrowserRouter> |  | ||||||
|           <LoginPage /> |           <LoginPage /> | ||||||
|           </BrowserRouter> |  | ||||||
|         </AdminContext> |         </AdminContext> | ||||||
|       </AppContext.Provider> |       </AppContext.Provider> | ||||||
|     ); |     ); | ||||||
|   | |||||||
| @@ -171,7 +171,7 @@ export const UserList = (props: ListProps) => ( | |||||||
|   <List |   <List | ||||||
|     {...props} |     {...props} | ||||||
|     filters={userFilters} |     filters={userFilters} | ||||||
|     filterDefaultValues={{ deactivated: false, locked: false, suspended: false }} |     filterDefaultValues={{ guests: false, deactivated: false, locked: false, suspended: false }} | ||||||
|     sort={{ field: "name", order: "ASC" }} |     sort={{ field: "name", order: "ASC" }} | ||||||
|     actions={<UserListActions />} |     actions={<UserListActions />} | ||||||
|     pagination={<UserPagination />} |     pagination={<UserPagination />} | ||||||
|   | |||||||
| @@ -190,8 +190,6 @@ const authProvider: AuthProvider = { | |||||||
|     const access_token = localStorage.getItem("access_token"); |     const access_token = localStorage.getItem("access_token"); | ||||||
|     return typeof access_token === "string" ? Promise.resolve() : Promise.reject(); |     return typeof access_token === "string" ? Promise.resolve() : Promise.reject(); | ||||||
|   }, |   }, | ||||||
|   // called when the user navigates to a new location, to check for permissions / roles |  | ||||||
|   getPermissions: () => Promise.resolve(), |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export default authProvider; | export default authProvider; | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| export const getServerAndMediaIdFromMxcUrl = (mxcUrl: string): { serverName: string; mediaId: string } => { | export const getServerAndMediaIdFromMxcUrl = (mxcUrl: string): { serverName: string; mediaId: string } => { | ||||||
|   const re = /^mxc:\/\/([^/]+)\/(\w+)/; |   const re = /^mxc:\/\/([^/]+)\/([\w-]+)$/; | ||||||
|   const ret = re.exec(mxcUrl); |   const ret = re.exec(mxcUrl); | ||||||
|   if (ret == null) { |   if (ret == null) { | ||||||
|     throw new Error("Invalid mxcUrl"); |     throw new Error("Invalid mxcUrl"); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user