2018-02-03 14:30:08 -05:00
|
|
|
# vim:ft=yaml
|
|
|
|
|
|
|
|
## TLS ##
|
|
|
|
|
2019-02-11 17:15:08 -05:00
|
|
|
{% if not SYNAPSE_NO_TLS %}
|
2019-02-05 08:42:21 -05:00
|
|
|
|
2018-02-03 14:30:08 -05:00
|
|
|
tls_certificate_path: "/data/{{ SYNAPSE_SERVER_NAME }}.tls.crt"
|
|
|
|
tls_private_key_path: "/data/{{ SYNAPSE_SERVER_NAME }}.tls.key"
|
2019-02-05 08:42:21 -05:00
|
|
|
|
|
|
|
{% if SYNAPSE_ACME %}
|
|
|
|
acme:
|
|
|
|
enabled: true
|
|
|
|
port: 8009
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
{% endif %}
|
2018-02-03 14:30:08 -05:00
|
|
|
|
|
|
|
## Server ##
|
|
|
|
|
|
|
|
server_name: "{{ SYNAPSE_SERVER_NAME }}"
|
|
|
|
pid_file: /homeserver.pid
|
2018-02-08 14:43:45 -05:00
|
|
|
web_client: False
|
2018-02-03 14:30:08 -05:00
|
|
|
soft_file_limit: 0
|
2019-06-27 08:52:40 -04:00
|
|
|
log_config: "{{ SYNAPSE_LOG_CONFIG }}"
|
2018-02-03 14:30:08 -05:00
|
|
|
|
|
|
|
## Ports ##
|
|
|
|
|
|
|
|
listeners:
|
|
|
|
{% if not SYNAPSE_NO_TLS %}
|
|
|
|
-
|
|
|
|
port: 8448
|
2018-10-25 10:36:07 -04:00
|
|
|
bind_addresses: ['::']
|
2018-02-03 14:30:08 -05:00
|
|
|
type: http
|
|
|
|
tls: true
|
|
|
|
x_forwarded: false
|
|
|
|
resources:
|
2018-02-08 14:43:45 -05:00
|
|
|
- names: [client]
|
2018-02-03 14:30:08 -05:00
|
|
|
compress: true
|
|
|
|
- names: [federation] # Federation APIs
|
|
|
|
compress: false
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
- port: 8008
|
|
|
|
tls: false
|
2018-10-25 10:36:07 -04:00
|
|
|
bind_addresses: ['::']
|
2018-02-03 14:30:08 -05:00
|
|
|
type: http
|
|
|
|
x_forwarded: false
|
|
|
|
|
|
|
|
resources:
|
2018-02-08 14:43:45 -05:00
|
|
|
- names: [client]
|
2018-02-03 14:30:08 -05:00
|
|
|
compress: true
|
|
|
|
- names: [federation]
|
|
|
|
compress: false
|
|
|
|
|
|
|
|
## Database ##
|
|
|
|
|
2018-02-04 09:04:26 -05:00
|
|
|
{% if POSTGRES_PASSWORD %}
|
2018-02-04 06:20:29 -05:00
|
|
|
database:
|
|
|
|
name: "psycopg2"
|
|
|
|
args:
|
2018-02-08 14:42:57 -05:00
|
|
|
user: "{{ POSTGRES_USER or "synapse" }}"
|
2018-02-04 09:04:26 -05:00
|
|
|
password: "{{ POSTGRES_PASSWORD }}"
|
2018-02-08 14:42:57 -05:00
|
|
|
database: "{{ POSTGRES_DB or "synapse" }}"
|
2018-02-04 09:04:26 -05:00
|
|
|
host: "{{ POSTGRES_HOST or "db" }}"
|
|
|
|
port: "{{ POSTGRES_PORT or "5432" }}"
|
2018-02-04 06:20:29 -05:00
|
|
|
cp_min: 5
|
|
|
|
cp_max: 10
|
2018-02-03 14:30:08 -05:00
|
|
|
{% else %}
|
|
|
|
database:
|
|
|
|
name: "sqlite3"
|
|
|
|
args:
|
|
|
|
database: "/data/homeserver.db"
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
## Performance ##
|
|
|
|
|
|
|
|
event_cache_size: "{{ SYNAPSE_EVENT_CACHE_SIZE or "10K" }}"
|
|
|
|
|
|
|
|
## Ratelimiting ##
|
|
|
|
|
|
|
|
rc_messages_per_second: 0.2
|
|
|
|
rc_message_burst_count: 10.0
|
|
|
|
federation_rc_window_size: 1000
|
|
|
|
federation_rc_sleep_limit: 10
|
|
|
|
federation_rc_sleep_delay: 500
|
|
|
|
federation_rc_reject_limit: 50
|
|
|
|
federation_rc_concurrent: 3
|
|
|
|
|
|
|
|
## Files ##
|
|
|
|
|
|
|
|
media_store_path: "/data/media"
|
|
|
|
uploads_path: "/data/uploads"
|
2018-09-15 20:22:27 -04:00
|
|
|
max_upload_size: "{{ SYNAPSE_MAX_UPLOAD_SIZE or "10M" }}"
|
2018-02-03 14:30:08 -05:00
|
|
|
max_image_pixels: "32M"
|
|
|
|
dynamic_thumbnails: false
|
|
|
|
|
|
|
|
# List of thumbnail to precalculate when an image is uploaded.
|
|
|
|
thumbnail_sizes:
|
|
|
|
- width: 32
|
|
|
|
height: 32
|
|
|
|
method: crop
|
|
|
|
- width: 96
|
|
|
|
height: 96
|
|
|
|
method: crop
|
|
|
|
- width: 320
|
|
|
|
height: 240
|
|
|
|
method: scale
|
|
|
|
- width: 640
|
|
|
|
height: 480
|
|
|
|
method: scale
|
|
|
|
- width: 800
|
|
|
|
height: 600
|
|
|
|
method: scale
|
|
|
|
|
|
|
|
url_preview_enabled: False
|
|
|
|
max_spider_size: "10M"
|
|
|
|
|
|
|
|
## Captcha ##
|
|
|
|
|
2018-02-05 15:28:15 -05:00
|
|
|
{% if SYNAPSE_RECAPTCHA_PUBLIC_KEY %}
|
|
|
|
recaptcha_public_key: "{{ SYNAPSE_RECAPTCHA_PUBLIC_KEY }}"
|
|
|
|
recaptcha_private_key: "{{ SYNAPSE_RECAPTCHA_PRIVATE_KEY }}"
|
|
|
|
enable_registration_captcha: True
|
|
|
|
recaptcha_siteverify_api: "https://www.google.com/recaptcha/api/siteverify"
|
|
|
|
{% else %}
|
2018-02-03 14:30:08 -05:00
|
|
|
recaptcha_public_key: "YOUR_PUBLIC_KEY"
|
|
|
|
recaptcha_private_key: "YOUR_PRIVATE_KEY"
|
|
|
|
enable_registration_captcha: False
|
|
|
|
recaptcha_siteverify_api: "https://www.google.com/recaptcha/api/siteverify"
|
2018-02-05 15:28:15 -05:00
|
|
|
{% endif %}
|
2018-02-03 14:30:08 -05:00
|
|
|
|
|
|
|
## Turn ##
|
|
|
|
|
2018-02-05 15:53:53 -05:00
|
|
|
{% if SYNAPSE_TURN_URIS %}
|
|
|
|
turn_uris:
|
2018-02-05 17:13:27 -05:00
|
|
|
{% for uri in SYNAPSE_TURN_URIS.split(',') %} - "{{ uri }}"
|
2018-02-05 15:53:53 -05:00
|
|
|
{% endfor %}
|
|
|
|
turn_shared_secret: "{{ SYNAPSE_TURN_SECRET }}"
|
|
|
|
turn_user_lifetime: "1h"
|
|
|
|
turn_allow_guests: True
|
|
|
|
{% else %}
|
2018-02-03 14:30:08 -05:00
|
|
|
turn_uris: []
|
|
|
|
turn_shared_secret: "YOUR_SHARED_SECRET"
|
|
|
|
turn_user_lifetime: "1h"
|
|
|
|
turn_allow_guests: True
|
2018-02-05 15:53:53 -05:00
|
|
|
{% endif %}
|
2018-02-03 14:30:08 -05:00
|
|
|
|
|
|
|
## Registration ##
|
|
|
|
|
|
|
|
enable_registration: {{ "True" if SYNAPSE_ENABLE_REGISTRATION else "False" }}
|
|
|
|
registration_shared_secret: "{{ SYNAPSE_REGISTRATION_SHARED_SECRET }}"
|
|
|
|
bcrypt_rounds: 12
|
|
|
|
allow_guest_access: {{ "True" if SYNAPSE_ALLOW_GUEST else "False" }}
|
2018-02-08 14:53:12 -05:00
|
|
|
enable_group_creation: true
|
2018-02-03 14:30:08 -05:00
|
|
|
|
|
|
|
# The list of identity servers trusted to verify third party
|
|
|
|
# identifiers by this server.
|
2018-11-20 06:29:25 -05:00
|
|
|
#
|
|
|
|
# Also defines the ID server which will be called when an account is
|
|
|
|
# deactivated (one will be picked arbitrarily).
|
2018-02-03 14:30:08 -05:00
|
|
|
trusted_third_party_id_servers:
|
|
|
|
- matrix.org
|
|
|
|
- vector.im
|
|
|
|
|
|
|
|
## Metrics ###
|
|
|
|
|
2018-02-08 14:46:11 -05:00
|
|
|
{% if SYNAPSE_REPORT_STATS.lower() == "yes" %}
|
|
|
|
enable_metrics: True
|
|
|
|
report_stats: True
|
|
|
|
{% else %}
|
2018-02-03 14:30:08 -05:00
|
|
|
enable_metrics: False
|
|
|
|
report_stats: False
|
2018-02-08 14:46:11 -05:00
|
|
|
{% endif %}
|
2018-02-03 14:30:08 -05:00
|
|
|
|
|
|
|
## API Configuration ##
|
|
|
|
|
|
|
|
room_invite_state_types:
|
|
|
|
- "m.room.join_rules"
|
|
|
|
- "m.room.canonical_alias"
|
|
|
|
- "m.room.avatar"
|
|
|
|
- "m.room.name"
|
|
|
|
|
2018-02-05 17:13:27 -05:00
|
|
|
{% if SYNAPSE_APPSERVICES %}
|
|
|
|
app_service_config_files:
|
|
|
|
{% for appservice in SYNAPSE_APPSERVICES %} - "{{ appservice }}"
|
|
|
|
{% endfor %}
|
|
|
|
{% else %}
|
2018-02-03 14:30:08 -05:00
|
|
|
app_service_config_files: []
|
2018-02-05 17:13:27 -05:00
|
|
|
{% endif %}
|
|
|
|
|
2018-02-03 14:30:08 -05:00
|
|
|
macaroon_secret_key: "{{ SYNAPSE_MACAROON_SECRET_KEY }}"
|
|
|
|
expire_access_token: False
|
|
|
|
|
|
|
|
## Signing Keys ##
|
|
|
|
|
|
|
|
signing_key_path: "/data/{{ SYNAPSE_SERVER_NAME }}.signing.key"
|
|
|
|
old_signing_keys: {}
|
|
|
|
key_refresh_interval: "1d" # 1 Day.
|
|
|
|
|
|
|
|
# The trusted servers to download signing keys from.
|
|
|
|
perspectives:
|
|
|
|
servers:
|
|
|
|
"matrix.org":
|
|
|
|
verify_keys:
|
|
|
|
"ed25519:auto":
|
|
|
|
key: "Noi6WqcDj0QmPxCNQqgezwTlBKrfqehY1u2FyWP9uYw"
|
|
|
|
|
|
|
|
password_config:
|
|
|
|
enabled: true
|
|
|
|
|
2018-02-08 14:53:12 -05:00
|
|
|
{% if SYNAPSE_SMTP_HOST %}
|
|
|
|
email:
|
|
|
|
enable_notifs: false
|
|
|
|
smtp_host: "{{ SYNAPSE_SMTP_HOST }}"
|
|
|
|
smtp_port: {{ SYNAPSE_SMTP_PORT or "25" }}
|
|
|
|
smtp_user: "{{ SYNAPSE_SMTP_USER }}"
|
|
|
|
smtp_pass: "{{ SYNAPSE_SMTP_PASSWORD }}"
|
|
|
|
require_transport_security: False
|
|
|
|
notif_from: "{{ SYNAPSE_SMTP_FROM or "hostmaster@" + SYNAPSE_SERVER_NAME }}"
|
|
|
|
app_name: Matrix
|
2018-10-17 10:44:34 -04:00
|
|
|
# if template_dir is unset, uses the example templates that are part of
|
|
|
|
# the Synapse distribution.
|
|
|
|
#template_dir: res/templates
|
2018-02-08 14:53:12 -05:00
|
|
|
notif_template_html: notif_mail.html
|
|
|
|
notif_template_text: notif_mail.txt
|
|
|
|
notif_for_new_users: True
|
|
|
|
riot_base_url: "https://{{ SYNAPSE_SERVER_NAME }}"
|
|
|
|
{% endif %}
|