|
|
@ -1,71 +1,4 @@
|
|
|
|
# vim:ft=yaml
|
|
|
|
# vim:ft=yaml
|
|
|
|
# PEM-encoded X509 certificate for TLS.
|
|
|
|
|
|
|
|
# This certificate, as of Synapse 1.0, will need to be a valid and verifiable
|
|
|
|
|
|
|
|
# certificate, signed by a recognised Certificate Authority.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# See 'ACME support' below to enable auto-provisioning this certificate via
|
|
|
|
|
|
|
|
# Let's Encrypt.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
tls_certificate_path: "{{ matrix_synapse_tls_certificate_path }}"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# PEM-encoded private key for TLS
|
|
|
|
|
|
|
|
tls_private_key_path: "{{ matrix_synapse_tls_private_key_path }}"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# ACME support: This will configure Synapse to request a valid TLS certificate
|
|
|
|
|
|
|
|
# for your configured `server_name` via Let's Encrypt.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# Note that provisioning a certificate in this way requires port 80 to be
|
|
|
|
|
|
|
|
# routed to Synapse so that it can complete the http-01 ACME challenge.
|
|
|
|
|
|
|
|
# By default, if you enable ACME support, Synapse will attempt to listen on
|
|
|
|
|
|
|
|
# port 80 for incoming http-01 challenges - however, this will likely fail
|
|
|
|
|
|
|
|
# with 'Permission denied' or a similar error.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# There are a couple of potential solutions to this:
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# * If you already have an Apache, Nginx, or similar listening on port 80,
|
|
|
|
|
|
|
|
# you can configure Synapse to use an alternate port, and have your web
|
|
|
|
|
|
|
|
# server forward the requests. For example, assuming you set 'port: 8009'
|
|
|
|
|
|
|
|
# below, on Apache, you would write:
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# ProxyPass /.well-known/acme-challenge http://localhost:8009/.well-known/acme-challenge
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# * Alternatively, you can use something like `authbind` to give Synapse
|
|
|
|
|
|
|
|
# permission to listen on port 80.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
acme:
|
|
|
|
|
|
|
|
# ACME support is disabled by default. Uncomment the following line
|
|
|
|
|
|
|
|
# to enable it.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# enabled: true
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Endpoint to use to request certificates. If you only want to test,
|
|
|
|
|
|
|
|
# use Let's Encrypt's staging url:
|
|
|
|
|
|
|
|
# https://acme-staging.api.letsencrypt.org/directory
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# url: https://acme-v01.api.letsencrypt.org/directory
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Port number to listen on for the HTTP-01 challenge. Change this if
|
|
|
|
|
|
|
|
# you are forwarding connections through Apache/Nginx/etc.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# port: 80
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Local addresses to listen on for incoming connections.
|
|
|
|
|
|
|
|
# Again, you may want to change this if you are forwarding connections
|
|
|
|
|
|
|
|
# through Apache/Nginx/etc.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# bind_addresses: ['::', '0.0.0.0']
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# How many days remaining on a certificate before it is renewed.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# reprovision_threshold: 30
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# If your server runs behind a reverse-proxy which terminates TLS connections
|
|
|
|
|
|
|
|
# (for both client and federation connections), it may be useful to disable
|
|
|
|
|
|
|
|
# All TLS support for incoming connections. Setting no_tls to True will
|
|
|
|
|
|
|
|
# do so (and avoid the need to give synapse a TLS private key).
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
no_tls: {{ matrix_synapse_no_tls|to_json }}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## Server ##
|
|
|
|
## Server ##
|
|
|
|
|
|
|
|
|
|
|
|
# The domain name of the server, with optional explicit port.
|
|
|
|
# The domain name of the server, with optional explicit port.
|
|
|
@ -100,16 +33,16 @@ pid_file: /homeserver.pid
|
|
|
|
#
|
|
|
|
#
|
|
|
|
# cpu_affinity: 0xFFFFFFFF
|
|
|
|
# cpu_affinity: 0xFFFFFFFF
|
|
|
|
|
|
|
|
|
|
|
|
# Whether to serve a web client from the HTTP/HTTPS root resource.
|
|
|
|
# The path to the web client which will be served at /_matrix/client/
|
|
|
|
web_client: False
|
|
|
|
# if 'webclient' is configured under the 'listeners' configuration.
|
|
|
|
|
|
|
|
#
|
|
|
|
# The root directory to server for the above web client.
|
|
|
|
|
|
|
|
# If left undefined, synapse will serve the matrix-angular-sdk web client.
|
|
|
|
|
|
|
|
# Make sure matrix-angular-sdk is installed with pip if web_client is True
|
|
|
|
|
|
|
|
# and web_client_location is undefined
|
|
|
|
|
|
|
|
# web_client_location: "/path/to/web/root"
|
|
|
|
# web_client_location: "/path/to/web/root"
|
|
|
|
|
|
|
|
|
|
|
|
# The public-facing base URL for the client API (not including _matrix/...)
|
|
|
|
# The public-facing base URL that clients use to access this HS
|
|
|
|
|
|
|
|
# (not including _matrix/...). This is the same URL a user would
|
|
|
|
|
|
|
|
# enter into the 'custom HS URL' field on their client. If you
|
|
|
|
|
|
|
|
# use synapse with a reverse proxy, this should be the URL to reach
|
|
|
|
|
|
|
|
# synapse via the proxy.
|
|
|
|
public_baseurl: https://{{ hostname_matrix }}/
|
|
|
|
public_baseurl: https://{{ hostname_matrix }}/
|
|
|
|
|
|
|
|
|
|
|
|
# Set the soft limit on the number of file descriptors synapse can use
|
|
|
|
# Set the soft limit on the number of file descriptors synapse can use
|
|
|
@ -148,6 +81,64 @@ federation_domain_whitelist: {{ matrix_synapse_federation_domain_whitelist|to_js
|
|
|
|
|
|
|
|
|
|
|
|
# List of ports that Synapse should listen on, their purpose and their
|
|
|
|
# List of ports that Synapse should listen on, their purpose and their
|
|
|
|
# configuration.
|
|
|
|
# configuration.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# Options for each listener include:
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# port: the TCP port to bind to
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# bind_addresses: a list of local addresses to listen on. The default is
|
|
|
|
|
|
|
|
# 'all local interfaces'.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# type: the type of listener. Normally 'http', but other valid options are:
|
|
|
|
|
|
|
|
# 'manhole' (see docs/manhole.md),
|
|
|
|
|
|
|
|
# 'metrics' (see docs/metrics-howto.rst),
|
|
|
|
|
|
|
|
# 'replication' (see docs/workers.rst).
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# tls: set to true to enable TLS for this listener. Will use the TLS
|
|
|
|
|
|
|
|
# key/cert specified in tls_private_key_path / tls_certificate_path.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# x_forwarded: Only valid for an 'http' listener. Set to true to use the
|
|
|
|
|
|
|
|
# X-Forwarded-For header as the client IP. Useful when Synapse is
|
|
|
|
|
|
|
|
# behind a reverse-proxy.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# resources: Only valid for an 'http' listener. A list of resources to host
|
|
|
|
|
|
|
|
# on this port. Options for each resource are:
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# names: a list of names of HTTP resources. See below for a list of
|
|
|
|
|
|
|
|
# valid resource names.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# compress: set to true to enable HTTP comression for this resource.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# additional_resources: Only valid for an 'http' listener. A map of
|
|
|
|
|
|
|
|
# additional endpoints which should be loaded via dynamic modules.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# Valid resource names are:
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# client: the client-server API (/_matrix/client). Also implies 'media' and
|
|
|
|
|
|
|
|
# 'static'.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# consent: user consent forms (/_matrix/consent). See
|
|
|
|
|
|
|
|
# docs/consent_tracking.md.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# federation: the server-server API (/_matrix/federation). Also implies
|
|
|
|
|
|
|
|
# 'media', 'keys', 'openid'
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# keys: the key discovery API (/_matrix/keys).
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# media: the media API (/_matrix/media).
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# metrics: the metrics interface. See docs/metrics-howto.rst.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# openid: OpenID authentication.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# replication: the HTTP replication API (/_synapse/replication). See
|
|
|
|
|
|
|
|
# docs/workers.rst.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# static: static resources under synapse/static (/_matrix/static). (Mostly
|
|
|
|
|
|
|
|
# useful for 'fallback authentication'.)
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# webclient: A web client. Requires web_client_location to be set.
|
|
|
|
|
|
|
|
#
|
|
|
|
listeners:
|
|
|
|
listeners:
|
|
|
|
{% if matrix_synapse_metrics_enabled %}
|
|
|
|
{% if matrix_synapse_metrics_enabled %}
|
|
|
|
- type: metrics
|
|
|
|
- type: metrics
|
|
|
@ -157,47 +148,24 @@ listeners:
|
|
|
|
{% endif %}
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
|
|
|
|
{% if matrix_synapse_federation_enabled and matrix_synapse_tls_federation_listener_enabled %}
|
|
|
|
{% if matrix_synapse_federation_enabled and matrix_synapse_tls_federation_listener_enabled %}
|
|
|
|
# Main HTTPS listener
|
|
|
|
# TLS-enabled listener: for when matrix traffic is sent directly to synapse.
|
|
|
|
# For when matrix traffic is sent directly to synapse.
|
|
|
|
- port: 8448
|
|
|
|
-
|
|
|
|
|
|
|
|
# The port to listen for HTTPS requests on.
|
|
|
|
|
|
|
|
port: 8448
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Local addresses to listen on.
|
|
|
|
|
|
|
|
# On Linux and Mac OS, `::` will listen on all IPv4 and IPv6
|
|
|
|
|
|
|
|
# addresses by default. For most other OSes, this will only listen
|
|
|
|
|
|
|
|
# on IPv6.
|
|
|
|
|
|
|
|
bind_addresses: ['::']
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# This is a 'http' listener, allows us to specify 'resources'.
|
|
|
|
|
|
|
|
type: http
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
tls: true
|
|
|
|
tls: true
|
|
|
|
|
|
|
|
bind_addresses: ['::']
|
|
|
|
# Use the X-Forwarded-For (XFF) header as the client IP and not the
|
|
|
|
type: http
|
|
|
|
# actual client IP.
|
|
|
|
|
|
|
|
x_forwarded: false
|
|
|
|
x_forwarded: false
|
|
|
|
|
|
|
|
|
|
|
|
# List of HTTP resources to serve on this listener.
|
|
|
|
|
|
|
|
resources:
|
|
|
|
resources:
|
|
|
|
- names: [federation] # Federation APIs
|
|
|
|
- names: [federation]
|
|
|
|
compress: false
|
|
|
|
compress: false
|
|
|
|
|
|
|
|
|
|
|
|
# optional list of additional endpoints which can be loaded via
|
|
|
|
|
|
|
|
# dynamic modules
|
|
|
|
|
|
|
|
# additional_resources:
|
|
|
|
|
|
|
|
# "/_matrix/my/custom/endpoint":
|
|
|
|
|
|
|
|
# module: my_module.CustomRequestHandler
|
|
|
|
|
|
|
|
# config: {}
|
|
|
|
|
|
|
|
{% endif %}
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
|
|
|
|
# Unsecure HTTP listener for the Client API,
|
|
|
|
# Unsecure HTTP listener (Client API): for when matrix traffic passes through a reverse proxy
|
|
|
|
# For when matrix traffic passes through loadbalancer that unwraps TLS.
|
|
|
|
# that unwraps TLS.
|
|
|
|
- port: 8008
|
|
|
|
- port: 8008
|
|
|
|
tls: false
|
|
|
|
tls: false
|
|
|
|
bind_addresses: ['::']
|
|
|
|
bind_addresses: ['::']
|
|
|
|
type: http
|
|
|
|
type: http
|
|
|
|
|
|
|
|
|
|
|
|
x_forwarded: true
|
|
|
|
x_forwarded: true
|
|
|
|
|
|
|
|
|
|
|
|
resources:
|
|
|
|
resources:
|
|
|
@ -205,13 +173,12 @@ listeners:
|
|
|
|
compress: false
|
|
|
|
compress: false
|
|
|
|
|
|
|
|
|
|
|
|
{% if matrix_synapse_federation_enabled %}
|
|
|
|
{% if matrix_synapse_federation_enabled %}
|
|
|
|
# Unsecure HTTP listener for the Federation API,
|
|
|
|
# Unsecure HTTP listener (Federation API): for when matrix traffic passes through a reverse proxy
|
|
|
|
# For when matrix traffic passes through loadbalancer that unwraps TLS.
|
|
|
|
# that unwraps TLS.
|
|
|
|
- port: 8048
|
|
|
|
- port: 8048
|
|
|
|
tls: false
|
|
|
|
tls: false
|
|
|
|
bind_addresses: ['::']
|
|
|
|
bind_addresses: ['::']
|
|
|
|
type: http
|
|
|
|
type: http
|
|
|
|
|
|
|
|
|
|
|
|
x_forwarded: true
|
|
|
|
x_forwarded: true
|
|
|
|
|
|
|
|
|
|
|
|
resources:
|
|
|
|
resources:
|
|
|
@ -225,31 +192,132 @@ listeners:
|
|
|
|
# bind_addresses: ['::1', '127.0.0.1']
|
|
|
|
# bind_addresses: ['::1', '127.0.0.1']
|
|
|
|
# type: manhole
|
|
|
|
# type: manhole
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Homeserver blocking
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# How to reach the server admin, used in ResourceLimitError
|
|
|
|
|
|
|
|
# admin_contact: 'mailto:admin@server.com'
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# Global block config
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# hs_disabled: False
|
|
|
|
|
|
|
|
# hs_disabled_message: 'Human readable reason for why the HS is blocked'
|
|
|
|
|
|
|
|
# hs_disabled_limit_type: 'error code(str), to help clients decode reason'
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# Monthly Active User Blocking
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# Enables monthly active user checking
|
|
|
|
|
|
|
|
# limit_usage_by_mau: False
|
|
|
|
|
|
|
|
# max_mau_value: 50
|
|
|
|
|
|
|
|
# mau_trial_days: 2
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# If enabled, the metrics for the number of monthly active users will
|
|
|
|
|
|
|
|
# be populated, however no one will be limited. If limit_usage_by_mau
|
|
|
|
|
|
|
|
# is true, this is implied to be true.
|
|
|
|
|
|
|
|
# mau_stats_only: False
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# Sometimes the server admin will want to ensure certain accounts are
|
|
|
|
|
|
|
|
# never blocked by mau checking. These accounts are specified here.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# mau_limit_reserved_threepids:
|
|
|
|
|
|
|
|
# - medium: 'email'
|
|
|
|
|
|
|
|
# address: 'reserved_user@example.com'
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# Room searching
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# If disabled, new messages will not be indexed for searching and users
|
|
|
|
|
|
|
|
# will receive errors when searching for messages. Defaults to enabled.
|
|
|
|
|
|
|
|
# enable_search: true
|
|
|
|
|
|
|
|
|
|
|
|
# Homeserver blocking
|
|
|
|
|
|
|
|
|
|
|
|
## TLS ##
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# PEM-encoded X509 certificate for TLS.
|
|
|
|
|
|
|
|
# This certificate, as of Synapse 1.0, will need to be a valid and verifiable
|
|
|
|
|
|
|
|
# certificate, signed by a recognised Certificate Authority.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# See 'ACME support' below to enable auto-provisioning this certificate via
|
|
|
|
|
|
|
|
# Let's Encrypt.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
tls_certificate_path: {{ matrix_synapse_tls_certificate_path|to_json }}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# PEM-encoded private key for TLS
|
|
|
|
|
|
|
|
tls_private_key_path: {{ matrix_synapse_tls_private_key_path|to_json }}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# ACME support: This will configure Synapse to request a valid TLS certificate
|
|
|
|
|
|
|
|
# for your configured `server_name` via Let's Encrypt.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# Note that provisioning a certificate in this way requires port 80 to be
|
|
|
|
|
|
|
|
# routed to Synapse so that it can complete the http-01 ACME challenge.
|
|
|
|
|
|
|
|
# By default, if you enable ACME support, Synapse will attempt to listen on
|
|
|
|
|
|
|
|
# port 80 for incoming http-01 challenges - however, this will likely fail
|
|
|
|
|
|
|
|
# with 'Permission denied' or a similar error.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# There are a couple of potential solutions to this:
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# * If you already have an Apache, Nginx, or similar listening on port 80,
|
|
|
|
|
|
|
|
# you can configure Synapse to use an alternate port, and have your web
|
|
|
|
|
|
|
|
# server forward the requests. For example, assuming you set 'port: 8009'
|
|
|
|
|
|
|
|
# below, on Apache, you would write:
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# ProxyPass /.well-known/acme-challenge http://localhost:8009/.well-known/acme-challenge
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# * Alternatively, you can use something like `authbind` to give Synapse
|
|
|
|
|
|
|
|
# permission to listen on port 80.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
acme:
|
|
|
|
|
|
|
|
# ACME support is disabled by default. Uncomment the following line
|
|
|
|
|
|
|
|
# (and tls_certificate_path and tls_private_key_path above) to enable it.
|
|
|
|
#
|
|
|
|
#
|
|
|
|
# How to reach the server admin, used in ResourceLimitError
|
|
|
|
# enabled: true
|
|
|
|
# admin_contact: 'mailto:admin@server.com'
|
|
|
|
|
|
|
|
|
|
|
|
# Endpoint to use to request certificates. If you only want to test,
|
|
|
|
|
|
|
|
# use Let's Encrypt's staging url:
|
|
|
|
|
|
|
|
# https://acme-staging.api.letsencrypt.org/directory
|
|
|
|
#
|
|
|
|
#
|
|
|
|
# Global block config
|
|
|
|
# url: https://acme-v01.api.letsencrypt.org/directory
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Port number to listen on for the HTTP-01 challenge. Change this if
|
|
|
|
|
|
|
|
# you are forwarding connections through Apache/Nginx/etc.
|
|
|
|
#
|
|
|
|
#
|
|
|
|
# hs_disabled: False
|
|
|
|
# port: 80
|
|
|
|
# hs_disabled_message: 'Human readable reason for why the HS is blocked'
|
|
|
|
|
|
|
|
# hs_disabled_limit_type: 'error code(str), to help clients decode reason'
|
|
|
|
# Local addresses to listen on for incoming connections.
|
|
|
|
|
|
|
|
# Again, you may want to change this if you are forwarding connections
|
|
|
|
|
|
|
|
# through Apache/Nginx/etc.
|
|
|
|
#
|
|
|
|
#
|
|
|
|
# Monthly Active User Blocking
|
|
|
|
# bind_addresses: ['::', '0.0.0.0']
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# How many days remaining on a certificate before it is renewed.
|
|
|
|
#
|
|
|
|
#
|
|
|
|
# Enables monthly active user checking
|
|
|
|
# reprovision_threshold: 30
|
|
|
|
# limit_usage_by_mau: False
|
|
|
|
|
|
|
|
# max_mau_value: 50
|
|
|
|
# List of allowed TLS fingerprints for this server to publish along
|
|
|
|
# mau_trial_days: 2
|
|
|
|
# with the signing keys for this server. Other matrix servers that
|
|
|
|
#
|
|
|
|
# make HTTPS requests to this server will check that the TLS
|
|
|
|
# Sometimes the server admin will want to ensure certain accounts are
|
|
|
|
# certificates returned by this server match one of the fingerprints.
|
|
|
|
# never blocked by mau checking. These accounts are specified here.
|
|
|
|
#
|
|
|
|
#
|
|
|
|
# Synapse automatically adds the fingerprint of its own certificate
|
|
|
|
# mau_limit_reserved_threepids:
|
|
|
|
# to the list. So if federation traffic is handled directly by synapse
|
|
|
|
# - medium: 'email'
|
|
|
|
# then no modification to the list is required.
|
|
|
|
# address: 'reserved_user@example.com'
|
|
|
|
#
|
|
|
|
|
|
|
|
# If synapse is run behind a load balancer that handles the TLS then it
|
|
|
|
|
|
|
|
# will be necessary to add the fingerprints of the certificates used by
|
|
|
|
|
|
|
|
# the loadbalancers to this list if they are different to the one
|
|
|
|
|
|
|
|
# synapse is using.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# Homeservers are permitted to cache the list of TLS fingerprints
|
|
|
|
|
|
|
|
# returned in the key responses up to the "valid_until_ts" returned in
|
|
|
|
|
|
|
|
# key. It may be necessary to publish the fingerprints of a new
|
|
|
|
|
|
|
|
# certificate and wait until the "valid_until_ts" of the previous key
|
|
|
|
|
|
|
|
# responses have passed before deploying it.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# You can calculate a fingerprint from a given TLS listener via:
|
|
|
|
|
|
|
|
# openssl s_client -connect $host:$port < /dev/null 2> /dev/null |
|
|
|
|
|
|
|
|
# openssl x509 -outform DER | openssl sha256 -binary | base64 | tr -d '='
|
|
|
|
|
|
|
|
# or by checking matrix.org/federationtester/api/report?server_name=$host
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
tls_fingerprints: []
|
|
|
|
|
|
|
|
# tls_fingerprints: [{"sha256": "<base64_encoded_sha256_fingerprint>"}]
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -483,16 +551,21 @@ enable_registration: {{ matrix_synapse_enable_registration|to_json }}
|
|
|
|
# - email
|
|
|
|
# - email
|
|
|
|
# - msisdn
|
|
|
|
# - msisdn
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Explicitly disable asking for MSISDNs from the registration
|
|
|
|
|
|
|
|
# flow (overrides registrations_require_3pid if MSISDNs are set as required)
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# disable_msisdn_registration = True
|
|
|
|
|
|
|
|
|
|
|
|
# Mandate that users are only allowed to associate certain formats of
|
|
|
|
# Mandate that users are only allowed to associate certain formats of
|
|
|
|
# 3PIDs with accounts on this server.
|
|
|
|
# 3PIDs with accounts on this server.
|
|
|
|
#
|
|
|
|
#
|
|
|
|
# allowed_local_3pids:
|
|
|
|
# allowed_local_3pids:
|
|
|
|
# - medium: email
|
|
|
|
# - medium: email
|
|
|
|
# pattern: ".*@matrix\.org"
|
|
|
|
# pattern: '.*@matrix\.org'
|
|
|
|
# - medium: email
|
|
|
|
# - medium: email
|
|
|
|
# pattern: ".*@vector\.im"
|
|
|
|
# pattern: '.*@vector\.im'
|
|
|
|
# - medium: msisdn
|
|
|
|
# - medium: msisdn
|
|
|
|
# pattern: "\+44"
|
|
|
|
# pattern: '\+44'
|
|
|
|
|
|
|
|
|
|
|
|
# If set, allows registration by anyone who also has the shared
|
|
|
|
# If set, allows registration by anyone who also has the shared
|
|
|
|
# secret, even if registration is otherwise disabled.
|
|
|
|
# secret, even if registration is otherwise disabled.
|
|
|
@ -510,8 +583,19 @@ bcrypt_rounds: 12
|
|
|
|
# accessible to anonymous users.
|
|
|
|
# accessible to anonymous users.
|
|
|
|
allow_guest_access: False
|
|
|
|
allow_guest_access: False
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# The identity server which we suggest that clients should use when users log
|
|
|
|
|
|
|
|
# in on this server.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# (By default, no suggestion is made, so it is left up to the client.
|
|
|
|
|
|
|
|
# This setting is ignored unless public_baseurl is also set.)
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# default_identity_server: https://matrix.org
|
|
|
|
|
|
|
|
|
|
|
|
# The list of identity servers trusted to verify third party
|
|
|
|
# The list of identity servers trusted to verify third party
|
|
|
|
# identifiers by this server.
|
|
|
|
# identifiers by this server.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# Also defines the ID server which will be called when an account is
|
|
|
|
|
|
|
|
# deactivated (one will be picked arbitrarily).
|
|
|
|
{% if matrix_synapse_trusted_third_party_id_servers|length > 0 %}
|
|
|
|
{% if matrix_synapse_trusted_third_party_id_servers|length > 0 %}
|
|
|
|
trusted_third_party_id_servers:
|
|
|
|
trusted_third_party_id_servers:
|
|
|
|
{{ matrix_synapse_trusted_third_party_id_servers|to_nice_yaml }}
|
|
|
|
{{ matrix_synapse_trusted_third_party_id_servers|to_nice_yaml }}
|
|
|
@ -534,7 +618,6 @@ auto_join_rooms:
|
|
|
|
autocreate_auto_join_rooms: {{ matrix_synapse_autocreate_auto_join_rooms }}
|
|
|
|
autocreate_auto_join_rooms: {{ matrix_synapse_autocreate_auto_join_rooms }}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## Metrics ###
|
|
|
|
## Metrics ###
|
|
|
|
|
|
|
|
|
|
|
|
# Enable collection and rendering of performance metrics
|
|
|
|
# Enable collection and rendering of performance metrics
|
|
|
@ -549,20 +632,29 @@ room_invite_state_types:
|
|
|
|
- "m.room.join_rules"
|
|
|
|
- "m.room.join_rules"
|
|
|
|
- "m.room.canonical_alias"
|
|
|
|
- "m.room.canonical_alias"
|
|
|
|
- "m.room.avatar"
|
|
|
|
- "m.room.avatar"
|
|
|
|
|
|
|
|
- "m.room.encryption"
|
|
|
|
- "m.room.name"
|
|
|
|
- "m.room.name"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# A list of application service config file to use
|
|
|
|
# A list of application service config file to use
|
|
|
|
app_service_config_files: {{ matrix_synapse_app_service_config_files }}
|
|
|
|
app_service_config_files: {{ matrix_synapse_app_service_config_files }}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Whether or not to track application service IP addresses. Implicitly
|
|
|
|
|
|
|
|
# enables MAU tracking for application service users.
|
|
|
|
|
|
|
|
track_appservice_user_ips: False
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# a secret which is used to sign access tokens. If none is specified,
|
|
|
|
|
|
|
|
# the registration_shared_secret is used, if one is given; otherwise,
|
|
|
|
|
|
|
|
# a secret key is derived from the signing key.
|
|
|
|
macaroon_secret_key: {{ matrix_synapse_macaroon_secret_key|to_json }}
|
|
|
|
macaroon_secret_key: {{ matrix_synapse_macaroon_secret_key|to_json }}
|
|
|
|
|
|
|
|
|
|
|
|
# Used to enable access token expiration.
|
|
|
|
# Used to enable access token expiration.
|
|
|
|
expire_access_token: False
|
|
|
|
expire_access_token: False
|
|
|
|
|
|
|
|
|
|
|
|
# a secret which is used to calculate HMACs for form values, to stop
|
|
|
|
# a secret which is used to calculate HMACs for form values, to stop
|
|
|
|
# falsification of values
|
|
|
|
# falsification of values. Must be specified for the User Consent
|
|
|
|
|
|
|
|
# forms to work.
|
|
|
|
form_secret: {{ matrix_synapse_form_secret|to_json }}
|
|
|
|
form_secret: {{ matrix_synapse_form_secret|to_json }}
|
|
|
|
|
|
|
|
|
|
|
|
## Signing Keys ##
|
|
|
|
## Signing Keys ##
|
|
|
@ -595,15 +687,48 @@ perspectives:
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Enable SAML2 for registration and login. Uses pysaml2
|
|
|
|
# Enable SAML2 for registration and login. Uses pysaml2.
|
|
|
|
# config_path: Path to the sp_conf.py configuration file
|
|
|
|
#
|
|
|
|
# idp_redirect_url: Identity provider URL which will redirect
|
|
|
|
# saml2_config:
|
|
|
|
# the user back to /login/saml2 with proper info.
|
|
|
|
#
|
|
|
|
# See pysaml2 docs for format of config.
|
|
|
|
# # The following is the configuration for the pysaml2 Service Provider.
|
|
|
|
#saml2_config:
|
|
|
|
# # See pysaml2 docs for format of config.
|
|
|
|
# enabled: true
|
|
|
|
# #
|
|
|
|
# config_path: "/data/sp_conf.py"
|
|
|
|
# # Default values will be used for the 'entityid' and 'service' settings,
|
|
|
|
# idp_redirect_url: "http://{{ hostname_matrix }}/idp"
|
|
|
|
# # so it is not normally necessary to specify them unless you need to
|
|
|
|
|
|
|
|
# # override them.
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# sp_config:
|
|
|
|
|
|
|
|
# # point this to the IdP's metadata. You can use either a local file or
|
|
|
|
|
|
|
|
# # (preferably) a URL.
|
|
|
|
|
|
|
|
# metadata:
|
|
|
|
|
|
|
|
# # local: ["saml2/idp.xml"]
|
|
|
|
|
|
|
|
# remote:
|
|
|
|
|
|
|
|
# - url: https://our_idp/metadata.xml
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# # The following is just used to generate our metadata xml, and you
|
|
|
|
|
|
|
|
# # may well not need it, depending on your setup. Alternatively you
|
|
|
|
|
|
|
|
# # may need a whole lot more detail - see the pysaml2 docs!
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# description: ["My awesome SP", "en"]
|
|
|
|
|
|
|
|
# name: ["Test SP", "en"]
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# organization:
|
|
|
|
|
|
|
|
# name: Example com
|
|
|
|
|
|
|
|
# display_name:
|
|
|
|
|
|
|
|
# - ["Example co", "en"]
|
|
|
|
|
|
|
|
# url: "http://example.com"
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# contact_person:
|
|
|
|
|
|
|
|
# - given_name: Bob
|
|
|
|
|
|
|
|
# sur_name: "the Sysadmin"
|
|
|
|
|
|
|
|
# email_address": ["admin@example.com"]
|
|
|
|
|
|
|
|
# contact_type": technical
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
# # Instead of putting the config inline as above, you can specify a
|
|
|
|
|
|
|
|
# # separate pysaml2 configuration file:
|
|
|
|
|
|
|
|
# #
|
|
|
|
|
|
|
|
# # config_path: "/data/sp_conf.py"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -710,6 +835,7 @@ password_providers:
|
|
|
|
{% endif %}
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Clients requesting push notifications can either have the body of
|
|
|
|
# Clients requesting push notifications can either have the body of
|
|
|
|
# the message sent in the notification poke along with other details
|
|
|
|
# the message sent in the notification poke along with other details
|
|
|
|
# like the sender, or just the event ID and room ID (`event_id_only`).
|
|
|
|
# like the sender, or just the event ID and room ID (`event_id_only`).
|
|
|
|