3
0
mirror of https://github.com/spantaleev/matrix-docker-ansible-deploy.git synced 2025-10-25 17:43:23 +00:00
Files
matrix-docker-ansible-deploy/docs/configuring-playbook-continuwuity.md
2025-07-05 09:52:44 +02:00

5.7 KiB

Configuring Continuwuity (optional)

The playbook can install and configure the Continuwuity Matrix server for you.

See the project's documentation to learn what it does and why it might be useful to you.

By default, the playbook installs 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, 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:

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 using matrix_continuwuity_environment_variables_extension. For example:

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), 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) 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 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, 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 by logging in to the server with SSH and running journalctl -fu matrix-continuwuity.