2024-09-17 23:06:12 +03:00
# Synapse Admin UI [![GitHub license](https://img.shields.io/github/license/Awesome-Technologies/synapse-admin)](https://github.com/Awesome-Technologies/synapse-admin/blob/master/LICENSE)
2020-01-27 16:57:27 +03:00
This project is built using [react-admin ](https://marmelab.com/react-admin/ ).
2024-08-31 14:47:33 +03:00
## Fork differences
2024-09-17 23:06:12 +03:00
With [Awesome-Technologies/synapse-admin ](https://github.com/Awesome-Technologies/synapse-admin ) as the upstream, this
fork is intended to be a more feature-rich version of the original project. The main goal is to provide a more
user-friendly interface for managing Synapse homeservers.
2024-08-31 20:27:36 +03:00
### Available via CDN
On [admin.etke.cc ](https://admin.etke.cc ) you can find the latest version of this fork.
### Changes
2024-08-31 14:47:33 +03:00
The following changes are already implemented:
* [Prevent admins from deleting themselves ](https://github.com/etkecc/synapse-admin/pull/1 )
2024-09-03 07:12:36 +03:00
* [Fix user's default tab not being shown ](https://github.com/etkecc/synapse-admin/pull/8 )
2024-09-03 10:40:27 +03:00
* [Add identifier when authorizing with password ](https://github.com/Awesome-Technologies/synapse-admin/pull/601 )
2024-09-03 11:09:46 +03:00
* [Add ability to toggle whether to show locked users ](https://github.com/Awesome-Technologies/synapse-admin/pull/573 )
2024-09-03 11:50:14 +03:00
* [Fix user's display name in header on user's page ](https://github.com/etkecc/synapse-admin/pull/9 )
2024-09-03 13:46:31 +03:00
* [Fix footer overlapping content ](https://github.com/Awesome-Technologies/synapse-admin/issues/574 )
2024-09-03 15:50:11 +03:00
* Switch from nginx to [SWS ](https://static-web-server.net/ ) for serving the app, reducing the size of the Docker image
2024-09-05 09:02:29 +03:00
* [Fix redirect URL after user creation ](https://github.com/etkecc/synapse-admin/pull/16 )
2024-09-05 21:39:39 +03:00
* [Display actual Synapse errors ](https://github.com/etkecc/synapse-admin/pull/17 )
2024-09-05 23:23:17 +03:00
* [Fix base_url being undefined on unsuccessful login ](https://github.com/etkecc/synapse-admin/pull/18 )
2024-09-06 00:15:00 +03:00
* [Put the version into manifest.json ](https://github.com/Awesome-Technologies/synapse-admin/issues/507 ) (CI only)
2024-09-06 00:23:23 +03:00
* [Federation page improvements ](https://github.com/Awesome-Technologies/synapse-admin/pull/583 ) (using theme colors)
2024-09-14 11:03:51 +03:00
* [Add UI option to block deleted rooms from being rejoined ](https://github.com/etkecc/synapse-admin/pull/26 )
2024-09-17 13:17:07 +03:00
* [Fix required fields check on Bulk registration CSV upload ](https://github.com/etkecc/synapse-admin/pull/32 )
2024-09-17 14:02:41 +03:00
* [Fix requests with invalid MXIDs on Bulk registration ](https://github.com/etkecc/synapse-admin/pull/33 )
2024-09-17 23:06:12 +03:00
* [Expose user avatar URL field in the UI ](https://github.com/etkecc/synapse-admin/pull/27 )
2024-08-31 14:47:33 +03:00
_the list will be updated as new changes are added_
2024-09-17 12:54:29 +03:00
### Development
`just run-dev` to start the development stack (depending on your system speed, you may want to re-run this command if
user creation fails)
After that open `http://localhost:5173` in your browser, login using the following credentials:
* Login: admin
* Password: admin
* Homeserver URL: http://localhost:8008
2022-04-20 11:46:19 +03:00
## Usage
### Supported Synapse
2024-05-07 14:14:15 +03:00
It needs at least [Synapse ](https://github.com/element-hq/synapse ) v1.93.0 for all functions to work as expected!
2020-07-04 20:32:45 +03:00
2020-10-26 12:08:33 +03:00
You get your server version with the request `/_synapse/admin/v1/server_version` .
2024-02-07 13:14:25 +03:00
See also [Synapse version API ](https://element-hq.github.io/synapse/latest/admin_api/version_api.html ).
2020-10-26 12:08:33 +03:00
After entering the URL on the login page of synapse-admin the server version appears below the input field.
2022-04-20 11:46:19 +03:00
### Prerequisites
2020-10-26 12:08:33 +03:00
You need access to the following endpoints:
2020-11-12 18:16:32 +03:00
2020-10-26 12:08:33 +03:00
- `/_matrix`
- `/_synapse/admin`
2024-02-07 13:14:25 +03:00
See also [Synapse administration endpoints ](https://element-hq.github.io/synapse/latest/reverse_proxy.html#synapse-administration-endpoints )
2020-10-26 12:08:33 +03:00
2022-04-20 11:46:19 +03:00
### Use without install
You can use the current version of Synapse Admin without own installation direct
via [GitHub Pages ](https://awesome-technologies.github.io/synapse-admin/ ).
**Note:**
2022-05-09 14:46:00 +03:00
If you want to use the deployment, you have to make sure that the admin endpoints (`/_synapse/admin`) are accessible for your browser.
**Remember: You have no need to expose these endpoints to the internet but to your network.**
If you want your own deployment, follow the [Step-By-Step Install Guide ](#step-by-step-install ) below.
2022-04-20 11:46:19 +03:00
### Step-By-Step install
2020-07-04 20:32:45 +03:00
2021-08-19 13:12:27 +03:00
You have three options:
2020-07-04 20:32:45 +03:00
2022-01-31 19:39:18 +03:00
1. [Download the tarball and serve with any webserver ](#steps-for-1 )
2. [Download the source code from github and run using nodejs ](#steps-for-2 )
3. [Run the Docker container ](#steps-for-3 )
2020-07-04 20:32:45 +03:00
2022-04-20 11:46:19 +03:00
#### Steps for 1)
2020-07-04 20:32:45 +03:00
2021-08-19 13:12:27 +03:00
- make sure you have a webserver installed that can serve static files (any webserver like nginx or apache will do)
- configure a vhost for synapse admin on your webserver
- download the .tar.gz from the latest release: https://github.com/Awesome-Technologies/synapse-admin/releases/latest
- unpack the .tar.gz
- move or symlink the `synapse-admin-x.x.x` into your vhosts root dir
- open the url of the vhost in your browser
2022-04-20 11:46:19 +03:00
#### Steps for 2)
2021-08-19 13:12:27 +03:00
2020-07-04 20:32:45 +03:00
- make sure you have installed the following: git, yarn, nodejs
- download the source code: `git clone https://github.com/Awesome-Technologies/synapse-admin.git`
- change into downloaded directory: `cd synapse-admin`
- download dependencies: `yarn install`
- start web server: `yarn start`
2022-04-20 11:46:19 +03:00
#### Steps for 3)
2020-07-04 20:32:45 +03:00
2021-08-17 09:22:36 +03:00
- run the Docker container from the public docker registry: `docker run -p 8080:80 awesometechnologies/synapse-admin` or use the [docker-compose.yml ](docker-compose.yml ): `docker-compose up -d`
2021-01-23 15:38:39 +03:00
> note: if you're building on an architecture other than amd64 (for example a raspberry pi), make sure to define a maximum ram for node. otherwise the build will fail.
```yml
services:
synapse-admin:
container_name: synapse-admin
hostname: synapse-admin
build:
context: https://github.com/Awesome-Technologies/synapse-admin.git
2024-04-24 16:29:06 +03:00
args:
- BUILDKIT_CONTEXT_KEEP_GIT_DIR=1
2021-01-23 15:38:39 +03:00
# - NODE_OPTIONS="--max_old_space_size=1024"
2024-04-24 17:00:55 +03:00
# - BASE_PATH="/synapse-admin"
2021-01-23 15:38:39 +03:00
ports:
- "8080:80"
restart: unless-stopped
```
2020-07-04 20:32:45 +03:00
- browse to http://localhost:8080
2024-02-05 19:32:32 +03:00
### Restricting available homeserver
You can restrict the homeserver(s), so that the user can no longer define it himself.
Edit `config.json` to restrict either to a single homeserver:
```json
{
"restrictBaseUrl": "https://your-matrixs-erver.example.com"
}
```
or to a list of homeservers:
```json
{
2024-04-22 16:36:13 +03:00
"restrictBaseUrl": ["https://your-first-matrix-server.example.com", "https://your-second-matrix-server.example.com"]
2024-02-05 19:32:32 +03:00
}
```
The `config.json` can be injected into a Docker container using a bind mount.
```yml
services:
synapse-admin:
...
volumes:
2024-04-23 20:34:46 +03:00
./config.json:/app/config.json:ro
2024-02-05 19:32:32 +03:00
...
```
2024-04-18 18:48:53 +03:00
### Serving Synapse-Admin on a different path
2024-04-24 17:00:55 +03:00
The path prefix where synapse-admin is served can only be changed during the build step.
If you downloaded the source code, use `yarn build --base=/my-prefix` to set a path prefix.
If you want to build your own Docker container, use the `BASE_PATH` argument.
We do not support directly changing the path where Synapse-Admin is served in the pre-built Docker container. Instead please use a reverse proxy if you need to move Synapse-Admin to a different base path. If you want to serve multiple applications with different paths on the same domain, you need a reverse proxy anyway.
2024-04-18 18:48:53 +03:00
Example for Traefik:
`docker-compose.yml`
```yml
services:
traefik:
image: traefik:mimolette
restart: unless-stopped
ports:
- 80:80
- 443:443
volumes:
- /var/run/docker.sock:/var/run/docker.sock:ro
synapse-admin:
image: awesometechnologies/synapse-admin:latest
restart: unless-stopped
labels:
- "traefik.enable=true"
- "traefik.http.routers.synapse-admin.rule=Host(`example.com`)&& PathPrefix(`/admin`)"
- "traefik.http.routers.synapse-admin.middlewares=admin,admin_path"
2024-04-24 17:00:55 +03:00
- "traefik.http.middlewares.admin.redirectregex.regex=^(.*)/admin/?"
- "traefik.http.middlewares.admin.redirectregex.replacement=$${1}/admin/"
- "traefik.http.middlewares.admin_path.stripprefix.prefixes=/admin"
2024-04-18 18:48:53 +03:00
```
2020-07-04 20:32:45 +03:00
## Screenshots
![Screenshots ](./screenshots.jpg )
2020-07-29 18:49:00 +03:00
## Development
2024-04-18 20:05:07 +03:00
- See https://yarnpkg.com/getting-started/editor-sdks how to setup your IDE
2024-04-22 16:36:13 +03:00
- Use `yarn lint` to run all style and linter checks
- Use `yarn test` to run all unit tests
2020-07-29 18:49:00 +03:00
- Use `yarn fix` to fix the coding style