Matrix is an ambitious new ecosystem for open federated instant messaging and VoIP. It consists of servers, clients and bridge software to connect to existing messaging solutions like IRC.
The reference server implementation Synapse is available in the community repository as. Synapse does not run on Python 3 and requires version 2.7. The community package creates a synapse user.
After installation, a configuration file needs to be generated. It should be readable by the synapse user:
$ cd /var/lib/synapse $ sudo -u synapse python2 -m synapse.app.homeserver \ --server-name my.domain.name \ --config-path /etc/synapse/homeserver.yaml \ --generate-config \ --report-stats=yes
Note that this will generate corresponding SSL keys and self-signed certificates for the specified server name. You have to regenerate those if you change the server name.
The default synapse configuration enables the webclient feature. Unless you haveinstalled this will make synapse fail to start. Either disable it, or install .
A systemd service named synapse.service will be installed by the matrix-synapse package. It will start the synapse server as user synapse and use the configuration file
You need at least one user on your fresh synapse server. You may create one as your normal non-root user with the command
$ register_new_matrix_user -c /etc/synapse/homeserver.yaml https://localhost:8448
or using one of the matrix clients
To enable the webcrawler, for server generated link previews, the additional packages
url_preview_enabled: True can be set in your
To prevent the synapse server from issuing arbitrary GET requests to internal hosts the
url_preview_ip_range_blacklist: has to be set.
There are some examples that can be uncommented.
Add your local IP ranges to that list to prevent the synapse server from trying to crawl them.
After changing the
homeserver.yaml the service has to be restarted.