* Update docs/configuring-well-known.md: remove redundant information For example, anchor links to the headers are distractive as these headers are displayed by scrolling a bit. Also: edit section headers Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> * Update docs/configuring-well-known.md: add "Support service discovery" as a type of well-known service discovery Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> * Update docs/configuring-well-known.md: recategorize the sections about installing well-known files on the base domain's server The commit merges the content of the option 2 with the section above, as both explain how to serve the base domain via the playbook and claim it is the easy way of installing well-known files, and therefore the content is repetitive. Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> * Update docs/configuring-well-known.md: create a section for types of well-known service discovery mechanism Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> * Update docs/configuring-well-known.md: add a link to the Matrix Specification, to which MSC 1929 was implemented MSC 1929 has no longer been for an early adopter. Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> * Update docs/configuring-well-known.md: iterate Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> * Update docs/configuring-playbook-base-domain-serving.md Co-authored-by: Slavi Pantaleev <slavi@devture.com> * Update docs/configuring-well-known.md Co-authored-by: Slavi Pantaleev <slavi@devture.com> * Update docs/installing.md: iterate Summary: - Try to reflect review comments - Declare that the shorter user identifier is recommended - Add a note about installing the server matrix.example.com directly, with the link to the FAQ entry Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> * Update docs/installing.md: replace the anchor link to docs/configuring-well-known.md with one to docs/howto-server-delegation.md Service Discovery via .well-known files is one of the two ways for server delegation, and it is possible to set up server delegation via a DNS SRV record instead (though it is more advanced and complicated), so it should be more proper to use the words "delegation/redirection" than "service discovery". Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> * Update docs/configuring-well-known.md: fix a typo Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> --------- Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> Co-authored-by: Suguru Hirahara <acioustick@noreply.codeberg.org> Co-authored-by: Slavi Pantaleev <slavi@devture.com>
5.0 KiB
Serving the base domain (optional)
This playbook sets up services on your Matrix server (matrix.example.com
). To have this server officially be responsible for Matrix services for the base domain (example.com
), you need to set up Server Delegation. This is normally done by configuring well-known files on the base domain.
People who don't have a separate server to dedicate to the base domain have trouble arranging this.
Usually, there are 2 options:
-
either get a separate server for the base domain, just for serving the files necessary for Server Delegation via a well-known file
-
or, arrange for the Matrix server to serve the base domain. This either involves you using your own webserver or making the integrated webserver serve the base domain for you.
This documentation page tells you how to do the latter. With some easy changes, we make it possible to serve the base domain from the Matrix server via the integrated webserver.
Just adjust your DNS records, so that your base domain is pointed to the Matrix server's IP address (using a DNS A
record) and then add the following configuration to your inventory/host_vars/matrix.example.com/vars.yml
file:
matrix_static_files_container_labels_base_domain_enabled: true
Doing this, the playbook will:
-
obtain an SSL certificate for the base domain, just like it does for all other domains (see how we handle SSL certificates)
-
serve the
/.well-known/matrix/*
files which are necessary for Federation Server Discovery (also see Server Delegation) and Client-Server discovery -
serve a simple homepage at
https://example.com
with contentHello from example.com
(configurable via thematrix_static_files_file_index_html_template
variable). You can also serve a more complicated static website.
Serving a static website at the base domain
By default, when "serving the base domain" is enabled, the playbook hosts a simple index.html
webpage at /matrix/static-files/public/index.html
. The content of this page is taken from the matrix_static_files_file_index_html_template
variable.
If you'd like to host your own static website (more than a single index.html
page) at the base domain, you can disable the creation of this default index.html
page like this:
# Enable base-domain serving
matrix_static_files_container_labels_base_domain_enabled: true
# Prevent the default index.html file from being installed
matrix_static_files_file_index_html_enabled: false
# Disable the automatic redirectin of `https://example.com/` to `https://matrix.example.com/`.
# This gets automatically enabled when you disable `matrix_static_files_file_index_html_enabled`, as we're doing above.
matrix_static_files_container_labels_base_domain_root_path_redirection_enabled: false
With this configuration, Ansible will no longer mess around with the /matrix/static-files/public/index.html
file.
You are then free to upload any static website files to /matrix/static-files/public
and they will get served at the base domain. You can do so manually or by using the ansible-role-aux Ansible role, which is part of this playbook already.
Serving a more complicated website at the base domain
If you'd like to serve an even more complicated (dynamic) website from the Matrix server, relying on the playbook to serve the base domain is not the best choice.
You have 2 options.
One way is to host your base domain elsewhere. This involves:
- you stopping to serve it from the Matrix server: remove
matrix_static_files_container_labels_base_domain_enabled
from your configuration - configuring Matrix Delegation via well-known
Another way is to serve the base domain from another (your own) container on the Matrix server. This involves:
- telling the playbook to only serve
example.com/.well-known/matrix
files by adjusting yourvars.yml
configuration like this:- keep
matrix_static_files_container_labels_base_domain_enabled: true
- add an extra:
matrix_static_files_container_labels_base_domain_traefik_path_prefix: /.well-known/matrix
- keep
- building and running a new container on the Matrix server:
- it should be connected to the
traefik
network, so that Traefik can reverse-proxy to it - it should have appropriate container labels, which instruct Traefik to reverse-proxy to it
- it should be connected to the
How you'll be managing building and running this container is up-to-you. You may use of the primitives from ansible-role-aux Ansible role to organize it yourself, or you can set it up in another way.