2018-02-03 22:30:08 +03:00
|
|
|
# vim:ft=yaml
|
|
|
|
|
|
|
|
## TLS ##
|
|
|
|
|
|
|
|
tls_certificate_path: "/data/{{ SYNAPSE_SERVER_NAME }}.tls.crt"
|
|
|
|
tls_private_key_path: "/data/{{ SYNAPSE_SERVER_NAME }}.tls.key"
|
|
|
|
tls_dh_params_path: "/data/{{ SYNAPSE_SERVER_NAME }}.tls.dh"
|
|
|
|
no_tls: {{ "True" if SYNAPSE_NO_TLS else "False" }}
|
|
|
|
tls_fingerprints: []
|
|
|
|
|
|
|
|
## Server ##
|
|
|
|
|
|
|
|
server_name: "{{ SYNAPSE_SERVER_NAME }}"
|
|
|
|
pid_file: /homeserver.pid
|
2018-02-08 22:43:45 +03:00
|
|
|
web_client: False
|
2018-02-03 22:30:08 +03:00
|
|
|
soft_file_limit: 0
|
|
|
|
|
|
|
|
## Ports ##
|
|
|
|
|
|
|
|
listeners:
|
|
|
|
{% if not SYNAPSE_NO_TLS %}
|
|
|
|
-
|
|
|
|
port: 8448
|
|
|
|
bind_addresses: ['0.0.0.0']
|
|
|
|
type: http
|
|
|
|
tls: true
|
|
|
|
x_forwarded: false
|
|
|
|
resources:
|
2018-02-08 22:43:45 +03:00
|
|
|
- names: [client]
|
2018-02-03 22:30:08 +03:00
|
|
|
compress: true
|
|
|
|
- names: [federation] # Federation APIs
|
|
|
|
compress: false
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
- port: 8008
|
|
|
|
tls: false
|
|
|
|
bind_addresses: ['0.0.0.0']
|
|
|
|
type: http
|
|
|
|
x_forwarded: false
|
|
|
|
|
|
|
|
resources:
|
2018-02-08 22:43:45 +03:00
|
|
|
- names: [client]
|
2018-02-03 22:30:08 +03:00
|
|
|
compress: true
|
|
|
|
- names: [federation]
|
|
|
|
compress: false
|
|
|
|
|
|
|
|
## Database ##
|
|
|
|
|
2018-02-04 17:04:26 +03:00
|
|
|
{% if POSTGRES_PASSWORD %}
|
2018-02-04 14:20:29 +03:00
|
|
|
database:
|
|
|
|
name: "psycopg2"
|
|
|
|
args:
|
2018-02-08 22:42:57 +03:00
|
|
|
user: "{{ POSTGRES_USER or "synapse" }}"
|
2018-02-04 17:04:26 +03:00
|
|
|
password: "{{ POSTGRES_PASSWORD }}"
|
2018-02-08 22:42:57 +03:00
|
|
|
database: "{{ POSTGRES_DB or "synapse" }}"
|
2018-02-04 17:04:26 +03:00
|
|
|
host: "{{ POSTGRES_HOST or "db" }}"
|
|
|
|
port: "{{ POSTGRES_PORT or "5432" }}"
|
2018-02-04 14:20:29 +03:00
|
|
|
cp_min: 5
|
|
|
|
cp_max: 10
|
2018-02-03 22:30:08 +03:00
|
|
|
{% else %}
|
|
|
|
database:
|
|
|
|
name: "sqlite3"
|
|
|
|
args:
|
|
|
|
database: "/data/homeserver.db"
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
## Performance ##
|
|
|
|
|
|
|
|
event_cache_size: "{{ SYNAPSE_EVENT_CACHE_SIZE or "10K" }}"
|
|
|
|
verbose: 0
|
|
|
|
log_file: "/data/homeserver.log"
|
|
|
|
log_config: "/data/{{ SYNAPSE_SERVER_NAME }}.log.config"
|
|
|
|
|
|
|
|
## 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"
|
|
|
|
max_upload_size: "10M"
|
|
|
|
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 23:28:15 +03: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 22:30:08 +03: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 23:28:15 +03:00
|
|
|
{% endif %}
|
2018-02-03 22:30:08 +03:00
|
|
|
|
|
|
|
## Turn ##
|
|
|
|
|
2018-02-05 23:53:53 +03:00
|
|
|
{% if SYNAPSE_TURN_URIS %}
|
|
|
|
turn_uris:
|
2018-02-06 01:13:27 +03:00
|
|
|
{% for uri in SYNAPSE_TURN_URIS.split(',') %} - "{{ uri }}"
|
2018-02-05 23:53:53 +03:00
|
|
|
{% endfor %}
|
|
|
|
turn_shared_secret: "{{ SYNAPSE_TURN_SECRET }}"
|
|
|
|
turn_user_lifetime: "1h"
|
|
|
|
turn_allow_guests: True
|
|
|
|
{% else %}
|
2018-02-03 22:30:08 +03:00
|
|
|
turn_uris: []
|
|
|
|
turn_shared_secret: "YOUR_SHARED_SECRET"
|
|
|
|
turn_user_lifetime: "1h"
|
|
|
|
turn_allow_guests: True
|
2018-02-05 23:53:53 +03:00
|
|
|
{% endif %}
|
2018-02-03 22:30:08 +03: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" }}
|
|
|
|
|
|
|
|
# The list of identity servers trusted to verify third party
|
|
|
|
# identifiers by this server.
|
|
|
|
trusted_third_party_id_servers:
|
|
|
|
- matrix.org
|
|
|
|
- vector.im
|
|
|
|
- riot.im
|
|
|
|
|
|
|
|
## Metrics ###
|
|
|
|
|
2018-02-08 22:46:11 +03:00
|
|
|
{% if SYNAPSE_REPORT_STATS.lower() == "yes" %}
|
|
|
|
enable_metrics: True
|
|
|
|
report_stats: True
|
|
|
|
{% else %}
|
2018-02-03 22:30:08 +03:00
|
|
|
enable_metrics: False
|
|
|
|
report_stats: False
|
2018-02-08 22:46:11 +03:00
|
|
|
{% endif %}
|
2018-02-03 22:30:08 +03:00
|
|
|
|
|
|
|
## API Configuration ##
|
|
|
|
|
|
|
|
room_invite_state_types:
|
|
|
|
- "m.room.join_rules"
|
|
|
|
- "m.room.canonical_alias"
|
|
|
|
- "m.room.avatar"
|
|
|
|
- "m.room.name"
|
|
|
|
|
2018-02-06 01:13:27 +03:00
|
|
|
{% if SYNAPSE_APPSERVICES %}
|
|
|
|
app_service_config_files:
|
|
|
|
{% for appservice in SYNAPSE_APPSERVICES %} - "{{ appservice }}"
|
|
|
|
{% endfor %}
|
|
|
|
{% else %}
|
2018-02-03 22:30:08 +03:00
|
|
|
app_service_config_files: []
|
2018-02-06 01:13:27 +03:00
|
|
|
{% endif %}
|
|
|
|
|
2018-02-03 22:30:08 +03: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
|
|
|
|
|
|
|
|
#email:
|
|
|
|
# enable_notifs: false
|
|
|
|
# smtp_host: "localhost"
|
|
|
|
# smtp_port: 25
|
|
|
|
# smtp_user: "exampleusername"
|
|
|
|
# smtp_pass: "examplepassword"
|
|
|
|
# require_transport_security: False
|
|
|
|
# notif_from: "Your Friendly %(app)s Home Server <noreply@example.com>"
|
|
|
|
# app_name: Matrix
|
|
|
|
# template_dir: res/templates
|
|
|
|
# notif_template_html: notif_mail.html
|
|
|
|
# notif_template_text: notif_mail.txt
|
|
|
|
# notif_for_new_users: True
|
|
|
|
# riot_base_url: "http://localhost/riot"
|
|
|
|
|
|
|
|
enable_group_creation: true
|