mirror of
				https://github.com/spantaleev/matrix-docker-ansible-deploy.git
				synced 2025-10-25 01:23:24 +00:00 
			
		
		
		
	Get matrix-corporal to play nicely with a Synapse worker setup
We do this by creating one more layer of indirection. First we reach some generic vhost handling matrix.DOMAIN. A bunch of override rules are added there (capturing traffic to send to ma1sd, etc). nginx-status and similar generic things also live there. We then proxy to the homeserver on some other vhost (only Synapse being available right now, but repointing this to Dendrite or other will be possible in the future). Then that homeserver-specific vhost does its thing to proxy to the homeserver. It may or may not use workers, etc. Without matrix-corporal, the flow is now: 1. matrix.DOMAIN (matrix-nginx-proxy/matrix-domain.conf) 2. matrix-nginx-proxy/matrix-synapse.conf 3. matrix-synapse With matrix-corporal enabled, it becomes: 1. matrix.DOMAIN (matrix-nginx-proxy/matrix-domain.conf) 2. matrix-corporal 3. matrix-nginx-proxy/matrix-synapse.conf 4. matrix-synapse (matrix-corporal gets injected at step 2).
This commit is contained in:
		| @@ -0,0 +1,70 @@ | ||||
| #jinja2: lstrip_blocks: "True" | ||||
|  | ||||
| {% macro render_vhost_directives() %} | ||||
| 	root /nginx-data/matrix-domain; | ||||
|  | ||||
| 	gzip on; | ||||
| 	gzip_types text/plain application/json; | ||||
| 	{% for configuration_block in matrix_nginx_proxy_proxy_domain_additional_server_configuration_blocks %} | ||||
| 		{{- configuration_block }} | ||||
| 	{% endfor %} | ||||
|  | ||||
| 	location /.well-known/matrix { | ||||
| 		root {{ matrix_static_files_base_path }}; | ||||
| 		{# | ||||
| 			A somewhat long expires value is used to prevent outages | ||||
| 			in case this is unreachable due to network failure. | ||||
| 		#} | ||||
| 		expires 4h; | ||||
| 		default_type application/json; | ||||
| 		add_header Access-Control-Allow-Origin *; | ||||
| 	} | ||||
| {% endmacro %} | ||||
|  | ||||
| server { | ||||
| 	listen {{ 8080 if matrix_nginx_proxy_enabled else 80 }}; | ||||
|  | ||||
| 	server_name {{ matrix_nginx_proxy_base_domain_hostname }}; | ||||
| 	server_tokens off; | ||||
|  | ||||
| 	{% if matrix_nginx_proxy_https_enabled %} | ||||
| 		location /.well-known/acme-challenge { | ||||
| 			{% if matrix_nginx_proxy_enabled %} | ||||
| 				{# Use the embedded DNS resolver in Docker containers to discover the service #} | ||||
| 				resolver 127.0.0.11 valid=5s; | ||||
| 				set $backend "matrix-certbot:8080"; | ||||
| 				proxy_pass http://$backend; | ||||
| 			{% else %} | ||||
| 				{# Generic configuration for use outside of our container setup #} | ||||
| 				proxy_pass http://127.0.0.1:{{ matrix_ssl_lets_encrypt_certbot_standalone_http_port }}; | ||||
| 			{% endif %} | ||||
| 		} | ||||
|  | ||||
| 		location / { | ||||
| 			return 301 https://$http_host$request_uri; | ||||
| 		} | ||||
| 	{% else %} | ||||
| 		{{ render_vhost_directives() }} | ||||
| 	{% endif %} | ||||
| } | ||||
|  | ||||
| {% if matrix_nginx_proxy_https_enabled %} | ||||
| server { | ||||
| 	listen {{ 8443 if matrix_nginx_proxy_enabled else 443 }} ssl http2; | ||||
| 	listen [::]:{{ 8443 if matrix_nginx_proxy_enabled else 443 }} ssl http2; | ||||
|  | ||||
| 	server_name {{ matrix_nginx_proxy_base_domain_hostname }}; | ||||
| 	server_tokens off; | ||||
|  | ||||
| 	ssl_certificate {{ matrix_ssl_config_dir_path }}/live/{{ matrix_nginx_proxy_base_domain_hostname }}/fullchain.pem; | ||||
| 	ssl_certificate_key {{ matrix_ssl_config_dir_path }}/live/{{ matrix_nginx_proxy_base_domain_hostname }}/privkey.pem; | ||||
|  | ||||
| 	ssl_protocols {{ matrix_nginx_proxy_ssl_protocols }}; | ||||
| 	{% if matrix_nginx_proxy_ssl_ciphers != '' %} | ||||
| 	ssl_ciphers {{ matrix_nginx_proxy_ssl_ciphers }}; | ||||
| 	{% endif %} | ||||
| 	ssl_prefer_server_ciphers {{ matrix_nginx_proxy_ssl_prefer_server_ciphers }}; | ||||
|  | ||||
| 	{{ render_vhost_directives() }} | ||||
| } | ||||
| {% endif %} | ||||
| @@ -1,31 +1,148 @@ | ||||
| #jinja2: lstrip_blocks: "True" | ||||
| {% macro render_nginx_status_location_block(addresses) %} | ||||
| 	{# Empty first line to make indentation prettier. #} | ||||
|  | ||||
| 	location /nginx_status { | ||||
| 		stub_status on; | ||||
| 		access_log off; | ||||
| 		{% for address in addresses %} | ||||
| 		allow {{ address }}; | ||||
| 		{% endfor %} | ||||
| 		deny all; | ||||
| 	} | ||||
| {% endmacro %} | ||||
|  | ||||
|  | ||||
| {% macro render_vhost_directives() %} | ||||
| 	root /nginx-data/matrix-domain; | ||||
|  | ||||
| 	gzip on; | ||||
| 	gzip_types text/plain application/json; | ||||
| 	{% for configuration_block in matrix_nginx_proxy_proxy_domain_additional_server_configuration_blocks %} | ||||
| 		{{- configuration_block }} | ||||
| 	{% endfor %} | ||||
|  | ||||
| 	location /.well-known/matrix { | ||||
| 		root {{ matrix_static_files_base_path }}; | ||||
| 		{# | ||||
| 			A somewhat long expires value is used to prevent outages | ||||
| 			in case this is unreachable due to network failure. | ||||
| 			in case this is unreachable due to network failure or | ||||
| 			due to the base domain's server completely dying. | ||||
| 		#} | ||||
| 		expires 4h; | ||||
| 		default_type application/json; | ||||
| 		add_header Access-Control-Allow-Origin *; | ||||
| 	} | ||||
|  | ||||
| 	{% if matrix_nginx_proxy_proxy_matrix_nginx_status_enabled %} | ||||
| 		{{ render_nginx_status_location_block(matrix_nginx_proxy_proxy_matrix_nginx_status_allowed_addresses) }} | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{% if matrix_nginx_proxy_proxy_matrix_corporal_api_enabled %} | ||||
| 	location ^~ /_matrix/corporal { | ||||
| 		{% if matrix_nginx_proxy_enabled %} | ||||
| 			{# Use the embedded DNS resolver in Docker containers to discover the service #} | ||||
| 			resolver 127.0.0.11 valid=5s; | ||||
| 			set $backend "{{ matrix_nginx_proxy_proxy_matrix_corporal_api_addr_with_container }}"; | ||||
| 			proxy_pass http://$backend; | ||||
| 		{% else %} | ||||
| 			{# Generic configuration for use outside of our container setup #} | ||||
| 			proxy_pass http://{{ matrix_nginx_proxy_proxy_matrix_corporal_api_addr_sans_container }}; | ||||
| 		{% endif %} | ||||
|  | ||||
| 		proxy_set_header Host $host; | ||||
| 		proxy_set_header X-Forwarded-For $remote_addr; | ||||
| 	} | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{% if matrix_nginx_proxy_proxy_matrix_identity_api_enabled %} | ||||
| 	location ^~ /_matrix/identity { | ||||
| 		{% if matrix_nginx_proxy_enabled %} | ||||
| 			{# Use the embedded DNS resolver in Docker containers to discover the service #} | ||||
| 			resolver 127.0.0.11 valid=5s; | ||||
| 			set $backend "{{ matrix_nginx_proxy_proxy_matrix_identity_api_addr_with_container }}"; | ||||
| 			proxy_pass http://$backend; | ||||
| 		{% else %} | ||||
| 			{# Generic configuration for use outside of our container setup #} | ||||
| 			proxy_pass http://{{ matrix_nginx_proxy_proxy_matrix_identity_api_addr_sans_container }}; | ||||
| 		{% endif %} | ||||
|  | ||||
| 		proxy_set_header Host $host; | ||||
| 		proxy_set_header X-Forwarded-For $remote_addr; | ||||
| 	} | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{% if matrix_nginx_proxy_proxy_matrix_user_directory_search_enabled %} | ||||
| 	location ^~ /_matrix/client/r0/user_directory/search { | ||||
| 		{% if matrix_nginx_proxy_enabled %} | ||||
| 			{# Use the embedded DNS resolver in Docker containers to discover the service #} | ||||
| 			resolver 127.0.0.11 valid=5s; | ||||
| 			set $backend "{{ matrix_nginx_proxy_proxy_matrix_user_directory_search_addr_with_container }}"; | ||||
| 			proxy_pass http://$backend; | ||||
| 		{% else %} | ||||
| 			{# Generic configuration for use outside of our container setup #} | ||||
| 			proxy_pass http://{{ matrix_nginx_proxy_proxy_matrix_user_directory_search_addr_sans_container }}; | ||||
| 		{% endif %} | ||||
|  | ||||
| 		proxy_set_header Host $host; | ||||
| 		proxy_set_header X-Forwarded-For $remote_addr; | ||||
| 	} | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{% if matrix_nginx_proxy_proxy_matrix_3pid_registration_enabled %} | ||||
| 	location ~ ^/_matrix/client/r0/register/(email|msisdn)/requestToken$ { | ||||
| 		{% if matrix_nginx_proxy_enabled %} | ||||
| 			{# Use the embedded DNS resolver in Docker containers to discover the service #} | ||||
| 			resolver 127.0.0.11 valid=5s; | ||||
| 			set $backend "{{ matrix_nginx_proxy_proxy_matrix_3pid_registration_addr_with_container }}"; | ||||
| 			proxy_pass http://$backend; | ||||
| 		{% else %} | ||||
| 			{# Generic configuration for use outside of our container setup #} | ||||
| 			proxy_pass http://{{ matrix_nginx_proxy_proxy_matrix_3pid_registration_addr_sans_container }}; | ||||
| 		{% endif %} | ||||
|  | ||||
| 		proxy_set_header Host $host; | ||||
| 		proxy_set_header X-Forwarded-For $remote_addr; | ||||
| 	} | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{% for configuration_block in matrix_nginx_proxy_proxy_matrix_additional_server_configuration_blocks %} | ||||
| 		{{- configuration_block }} | ||||
| 	{% endfor %} | ||||
|  | ||||
| 	{# | ||||
| 		This handles the Matrix Client API only. | ||||
| 		The Matrix Federation API is handled by a separate vhost. | ||||
| 	#} | ||||
| 	location ~* ^({{ matrix_nginx_proxy_proxy_matrix_client_api_forwarded_location_prefix_regexes|join('|') }}) { | ||||
| 		{% if matrix_nginx_proxy_enabled %} | ||||
| 			{# Use the embedded DNS resolver in Docker containers to discover the service #} | ||||
| 			resolver 127.0.0.11 valid=5s; | ||||
| 			set $backend "{{ matrix_nginx_proxy_proxy_matrix_client_api_addr_with_container }}"; | ||||
| 			proxy_pass http://$backend; | ||||
| 		{% else %} | ||||
| 			{# Generic configuration for use outside of our container setup #} | ||||
| 			proxy_pass http://{{ matrix_nginx_proxy_proxy_matrix_client_api_addr_sans_container }}; | ||||
| 		{% endif %} | ||||
|  | ||||
| 		proxy_set_header Host $host; | ||||
| 		proxy_set_header X-Forwarded-For $remote_addr; | ||||
|  | ||||
| 		client_body_buffer_size 25M; | ||||
| 		client_max_body_size {{ matrix_nginx_proxy_proxy_matrix_client_api_client_max_body_size_mb }}M; | ||||
| 		proxy_max_temp_file_size 0; | ||||
| 	} | ||||
|  | ||||
| 	location / { | ||||
| 		{% if matrix_nginx_proxy_proxy_matrix_client_redirect_root_uri_to_domain %} | ||||
| 			return 302 $scheme://{{ matrix_nginx_proxy_proxy_matrix_client_redirect_root_uri_to_domain }}$request_uri; | ||||
| 		{% else %} | ||||
| 			rewrite ^/$ /_matrix/static/ last; | ||||
| 		{% endif %} | ||||
| 	} | ||||
| {% endmacro %} | ||||
|  | ||||
| server { | ||||
| 	listen {{ 8080 if matrix_nginx_proxy_enabled else 80 }}; | ||||
| 	server_name {{ matrix_nginx_proxy_proxy_matrix_hostname }}; | ||||
|  | ||||
| 	server_name {{ matrix_nginx_proxy_base_domain_hostname }}; | ||||
| 	server_tokens off; | ||||
| 	root /dev/null; | ||||
|  | ||||
| 	{% if matrix_nginx_proxy_https_enabled %} | ||||
| 		location /.well-known/acme-challenge { | ||||
| @@ -40,6 +157,10 @@ server { | ||||
| 			{% endif %} | ||||
| 		} | ||||
|  | ||||
| 		{% if matrix_nginx_proxy_proxy_matrix_nginx_status_enabled %} | ||||
| 			{{ render_nginx_status_location_block(matrix_nginx_proxy_proxy_matrix_nginx_status_allowed_addresses) }} | ||||
| 		{% endif %} | ||||
|  | ||||
| 		location / { | ||||
| 			return 301 https://$http_host$request_uri; | ||||
| 		} | ||||
| @@ -53,11 +174,13 @@ server { | ||||
| 	listen {{ 8443 if matrix_nginx_proxy_enabled else 443 }} ssl http2; | ||||
| 	listen [::]:{{ 8443 if matrix_nginx_proxy_enabled else 443 }} ssl http2; | ||||
|  | ||||
| 	server_name {{ matrix_nginx_proxy_base_domain_hostname }}; | ||||
| 	server_tokens off; | ||||
| 	server_name {{ matrix_nginx_proxy_proxy_matrix_hostname }}; | ||||
|  | ||||
| 	ssl_certificate {{ matrix_ssl_config_dir_path }}/live/{{ matrix_nginx_proxy_base_domain_hostname }}/fullchain.pem; | ||||
| 	ssl_certificate_key {{ matrix_ssl_config_dir_path }}/live/{{ matrix_nginx_proxy_base_domain_hostname }}/privkey.pem; | ||||
| 	server_tokens off; | ||||
| 	root /dev/null; | ||||
|  | ||||
| 	ssl_certificate {{ matrix_ssl_config_dir_path }}/live/{{ matrix_nginx_proxy_proxy_matrix_hostname }}/fullchain.pem; | ||||
| 	ssl_certificate_key {{ matrix_ssl_config_dir_path }}/live/{{ matrix_nginx_proxy_proxy_matrix_hostname }}/privkey.pem; | ||||
|  | ||||
| 	ssl_protocols {{ matrix_nginx_proxy_ssl_protocols }}; | ||||
| 	{% if matrix_nginx_proxy_ssl_ciphers != '' %} | ||||
| @@ -68,3 +191,56 @@ server { | ||||
| 	{{ render_vhost_directives() }} | ||||
| } | ||||
| {% endif %} | ||||
|  | ||||
| {% if matrix_nginx_proxy_proxy_matrix_federation_api_enabled %} | ||||
| {# | ||||
| 	This federation vhost is a little special. | ||||
| 	It serves federation over HTTP or HTTPS, depending on `matrix_nginx_proxy_https_enabled`. | ||||
| #} | ||||
| server { | ||||
| 	{% if matrix_nginx_proxy_https_enabled %} | ||||
| 		listen 8448 ssl http2; | ||||
| 		listen [::]:8448 ssl http2; | ||||
| 	{% else %} | ||||
| 		listen 8448; | ||||
| 	{% endif %} | ||||
|  | ||||
| 	server_name {{ matrix_nginx_proxy_proxy_matrix_hostname }}; | ||||
| 	server_tokens off; | ||||
|  | ||||
| 	root /dev/null; | ||||
|  | ||||
| 	gzip on; | ||||
| 	gzip_types text/plain application/json; | ||||
|  | ||||
| 	{% if matrix_nginx_proxy_https_enabled %} | ||||
| 		ssl_certificate {{ matrix_nginx_proxy_proxy_matrix_federation_api_ssl_certificate }}; | ||||
| 		ssl_certificate_key {{ matrix_nginx_proxy_proxy_matrix_federation_api_ssl_certificate_key }}; | ||||
|  | ||||
| 		ssl_protocols {{ matrix_nginx_proxy_ssl_protocols }}; | ||||
| 		{% if matrix_nginx_proxy_ssl_ciphers != '' %} | ||||
| 			ssl_ciphers {{ matrix_nginx_proxy_ssl_ciphers }}; | ||||
| 		{% endif %} | ||||
| 		ssl_prefer_server_ciphers {{ matrix_nginx_proxy_ssl_prefer_server_ciphers }}; | ||||
| 	{% endif %} | ||||
|  | ||||
| 	location / { | ||||
| 		{% if matrix_nginx_proxy_enabled %} | ||||
| 			{# Use the embedded DNS resolver in Docker containers to discover the service #} | ||||
| 			resolver 127.0.0.11 valid=5s; | ||||
| 			set $backend "{{ matrix_nginx_proxy_proxy_matrix_federation_api_addr_with_container }}"; | ||||
| 			proxy_pass http://$backend; | ||||
| 		{% else %} | ||||
| 			{# Generic configuration for use outside of our container setup #} | ||||
| 			proxy_pass http://{{ matrix_nginx_proxy_proxy_matrix_federation_api_addr_sans_container }}; | ||||
| 		{% endif %} | ||||
|  | ||||
| 		proxy_set_header Host $host; | ||||
| 		proxy_set_header X-Forwarded-For $remote_addr; | ||||
|  | ||||
| 		client_body_buffer_size 25M; | ||||
| 		client_max_body_size {{ matrix_nginx_proxy_proxy_matrix_federation_api_client_max_body_size_mb }}M; | ||||
| 		proxy_max_temp_file_size 0; | ||||
| 	} | ||||
| } | ||||
| {% endif %} | ||||
|   | ||||
| @@ -1,109 +1,59 @@ | ||||
| #jinja2: lstrip_blocks: "True" | ||||
| {% macro render_nginx_status_location_block(addresses) %} | ||||
| 	{# Empty first line to make indentation prettier. #} | ||||
|  | ||||
| 	location /nginx_status { | ||||
| 		stub_status on; | ||||
| 		access_log off; | ||||
| 		{% for address in addresses %} | ||||
| 		allow {{ address }}; | ||||
| {% set generic_workers = matrix_nginx_proxy_synapse_workers_list|selectattr('type', 'equalto', 'generic_worker')|list %} | ||||
| {% set media_repository_workers = matrix_nginx_proxy_synapse_workers_list|selectattr('type', 'equalto', 'media_repository')|list %} | ||||
| {% set user_dir_workers = matrix_nginx_proxy_synapse_workers_list|selectattr('type', 'equalto', 'user_dir')|list %} | ||||
| {% set frontend_proxy_workers = matrix_nginx_proxy_synapse_workers_list|selectattr('type', 'equalto', 'frontend_proxy')|list %} | ||||
| {% if matrix_nginx_proxy_synapse_workers_enabled %} | ||||
| 	# Round Robin "upstream" pools for workers | ||||
|  | ||||
| 	{% if generic_workers %} | ||||
| 	upstream generic_worker_upstream { | ||||
| 		# ensures that requests from the same client will always be passed | ||||
| 		# to the same server (except when this server is unavailable) | ||||
| 		ip_hash; | ||||
|  | ||||
| 		{% for worker in generic_workers %} | ||||
| 		server "matrix-synapse:{{ worker.port }}"; | ||||
| 		{% endfor %} | ||||
| 		deny all; | ||||
| 	} | ||||
| {% endmacro %} | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{% if frontend_proxy_workers %} | ||||
| 	upstream frontend_proxy_upstream { | ||||
| 		{% for worker in frontend_proxy_workers %} | ||||
| 		server "matrix-synapse:{{ worker.port }}"; | ||||
| 		{% endfor %} | ||||
| 	} | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{% if media_repository_workers %} | ||||
| 	upstream media_repository_upstream { | ||||
| 		{% for worker in media_repository_workers %} | ||||
| 		server "matrix-synapse:{{ worker.port }}"; | ||||
| 		{% endfor %} | ||||
| 	} | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{% if user_dir_workers %} | ||||
| 	upstream user_dir_upstream { | ||||
| 		{% for worker in user_dir_workers %} | ||||
| 		server "matrix-synapse:{{ worker.port }}"; | ||||
| 		{% endfor %} | ||||
| 	} | ||||
| 	{% endif %} | ||||
| {% endif %} | ||||
|  | ||||
| server { | ||||
| 	listen 12080; | ||||
| 	server_name {{ matrix_nginx_proxy_proxy_synapse_hostname }}; | ||||
|  | ||||
| 	server_tokens off; | ||||
| 	root /dev/null; | ||||
|  | ||||
| {% macro render_vhost_directives() %} | ||||
| 	gzip on; | ||||
| 	gzip_types text/plain application/json; | ||||
|  | ||||
| 	location /.well-known/matrix { | ||||
| 		root {{ matrix_static_files_base_path }}; | ||||
| 		{# | ||||
| 			A somewhat long expires value is used to prevent outages | ||||
| 			in case this is unreachable due to network failure or | ||||
| 			due to the base domain's server completely dying. | ||||
| 		#} | ||||
| 		expires 4h; | ||||
| 		default_type application/json; | ||||
| 		add_header Access-Control-Allow-Origin *; | ||||
| 	} | ||||
|  | ||||
| 	{% if matrix_nginx_proxy_proxy_matrix_nginx_status_enabled %} | ||||
| 		{{ render_nginx_status_location_block(matrix_nginx_proxy_proxy_matrix_nginx_status_allowed_addresses) }} | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{% if matrix_nginx_proxy_proxy_matrix_corporal_api_enabled %} | ||||
| 	location ^~ /_matrix/corporal { | ||||
| 		{% if matrix_nginx_proxy_enabled %} | ||||
| 			{# Use the embedded DNS resolver in Docker containers to discover the service #} | ||||
| 			resolver 127.0.0.11 valid=5s; | ||||
| 			set $backend "{{ matrix_nginx_proxy_proxy_matrix_corporal_api_addr_with_container }}"; | ||||
| 			proxy_pass http://$backend; | ||||
| 		{% else %} | ||||
| 			{# Generic configuration for use outside of our container setup #} | ||||
| 			proxy_pass http://{{ matrix_nginx_proxy_proxy_matrix_corporal_api_addr_sans_container }}; | ||||
| 		{% endif %} | ||||
|  | ||||
| 		proxy_set_header Host $host; | ||||
| 		proxy_set_header X-Forwarded-For $remote_addr; | ||||
| 	} | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{% if matrix_nginx_proxy_proxy_matrix_identity_api_enabled %} | ||||
| 	location ^~ /_matrix/identity { | ||||
| 		{% if matrix_nginx_proxy_enabled %} | ||||
| 			{# Use the embedded DNS resolver in Docker containers to discover the service #} | ||||
| 			resolver 127.0.0.11 valid=5s; | ||||
| 			set $backend "{{ matrix_nginx_proxy_proxy_matrix_identity_api_addr_with_container }}"; | ||||
| 			proxy_pass http://$backend; | ||||
| 		{% else %} | ||||
| 			{# Generic configuration for use outside of our container setup #} | ||||
| 			proxy_pass http://{{ matrix_nginx_proxy_proxy_matrix_identity_api_addr_sans_container }}; | ||||
| 		{% endif %} | ||||
|  | ||||
| 		proxy_set_header Host $host; | ||||
| 		proxy_set_header X-Forwarded-For $remote_addr; | ||||
| 	} | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{% if matrix_nginx_proxy_proxy_matrix_user_directory_search_enabled %} | ||||
| 	# NOTE: This redirects user lookup requests to the identity server instead of | ||||
| 	# synapse, so user_dir_workers endpoints listed further down in this file will | ||||
| 	# not be reached and workers of this kind should be disabled for consistency. | ||||
| 	location ^~ /_matrix/client/r0/user_directory/search { | ||||
| 		{% if matrix_nginx_proxy_enabled %} | ||||
| 			{# Use the embedded DNS resolver in Docker containers to discover the service #} | ||||
| 			resolver 127.0.0.11 valid=5s; | ||||
| 			set $backend "{{ matrix_nginx_proxy_proxy_matrix_user_directory_search_addr_with_container }}"; | ||||
| 			proxy_pass http://$backend; | ||||
| 		{% else %} | ||||
| 			{# Generic configuration for use outside of our container setup #} | ||||
| 			proxy_pass http://{{ matrix_nginx_proxy_proxy_matrix_user_directory_search_addr_sans_container }}; | ||||
| 		{% endif %} | ||||
|  | ||||
| 		proxy_set_header Host $host; | ||||
| 		proxy_set_header X-Forwarded-For $remote_addr; | ||||
| 	} | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{% if matrix_nginx_proxy_proxy_matrix_3pid_registration_enabled %} | ||||
| 	location ~ ^/_matrix/client/r0/register/(email|msisdn)/requestToken$ { | ||||
| 		{% if matrix_nginx_proxy_enabled %} | ||||
| 			{# Use the embedded DNS resolver in Docker containers to discover the service #} | ||||
| 			resolver 127.0.0.11 valid=5s; | ||||
| 			set $backend "{{ matrix_nginx_proxy_proxy_matrix_3pid_registration_addr_with_container }}"; | ||||
| 			proxy_pass http://$backend; | ||||
| 		{% else %} | ||||
| 			{# Generic configuration for use outside of our container setup #} | ||||
| 			proxy_pass http://{{ matrix_nginx_proxy_proxy_matrix_3pid_registration_addr_sans_container }}; | ||||
| 		{% endif %} | ||||
|  | ||||
| 		proxy_set_header Host $host; | ||||
| 		proxy_set_header X-Forwarded-For $remote_addr; | ||||
| 	} | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{% if matrix_nginx_proxy_synapse_workers_enabled %} | ||||
| 		{# Workers redirects BEGIN #} | ||||
|  | ||||
| @@ -167,7 +117,7 @@ | ||||
| 	{% endif %} | ||||
|  | ||||
|  | ||||
| 	{% for configuration_block in matrix_nginx_proxy_proxy_matrix_additional_server_configuration_blocks %} | ||||
| 	{% for configuration_block in matrix_nginx_proxy_proxy_synapse_additional_server_configuration_blocks %} | ||||
| 		{{- configuration_block }} | ||||
| 	{% endfor %} | ||||
|  | ||||
| @@ -193,19 +143,16 @@ | ||||
| 	} | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{# | ||||
| 		This handles the Matrix Client API only. | ||||
| 		The Matrix Federation API is handled by a separate vhost. | ||||
| 	#} | ||||
| 	location ~* ^({{ matrix_nginx_proxy_proxy_matrix_client_api_forwarded_location_prefix_regexes|join('|') }}) { | ||||
| 	{# Everything else just goes to the API server ##} | ||||
| 	location / { | ||||
| 		{% if matrix_nginx_proxy_enabled %} | ||||
| 			{# Use the embedded DNS resolver in Docker containers to discover the service #} | ||||
| 			resolver 127.0.0.11 valid=5s; | ||||
| 			set $backend "{{ matrix_nginx_proxy_proxy_matrix_client_api_addr_with_container }}"; | ||||
| 			set $backend "{{ matrix_nginx_proxy_proxy_synapse_client_api_addr_with_container }}"; | ||||
| 			proxy_pass http://$backend; | ||||
| 		{% else %} | ||||
| 			{# Generic configuration for use outside of our container setup #} | ||||
| 			proxy_pass http://{{ matrix_nginx_proxy_proxy_matrix_client_api_addr_sans_container }}; | ||||
| 			proxy_pass http://{{ matrix_nginx_proxy_proxy_synapse_client_api_addr_sans_container }}; | ||||
| 		{% endif %} | ||||
|  | ||||
| 		proxy_set_header Host $host; | ||||
| @@ -215,129 +162,13 @@ | ||||
| 		client_max_body_size {{ matrix_nginx_proxy_proxy_matrix_client_api_client_max_body_size_mb }}M; | ||||
| 		proxy_max_temp_file_size 0; | ||||
| 	} | ||||
|  | ||||
| 	location / { | ||||
| 		{% if matrix_nginx_proxy_proxy_matrix_client_redirect_root_uri_to_domain %} | ||||
| 			return 302 $scheme://{{ matrix_nginx_proxy_proxy_matrix_client_redirect_root_uri_to_domain }}$request_uri; | ||||
| 		{% else %} | ||||
| 			rewrite ^/$ /_matrix/static/ last; | ||||
| 		{% endif %} | ||||
| 	} | ||||
| {% endmacro %} | ||||
|  | ||||
| {% set generic_workers = matrix_nginx_proxy_synapse_workers_list|selectattr('type', 'equalto', 'generic_worker')|list %} | ||||
| {% set media_repository_workers = matrix_nginx_proxy_synapse_workers_list|selectattr('type', 'equalto', 'media_repository')|list %} | ||||
| {% set user_dir_workers = matrix_nginx_proxy_synapse_workers_list|selectattr('type', 'equalto', 'user_dir')|list %} | ||||
| {% set frontend_proxy_workers = matrix_nginx_proxy_synapse_workers_list|selectattr('type', 'equalto', 'frontend_proxy')|list %} | ||||
| {% if matrix_nginx_proxy_synapse_workers_enabled %} | ||||
| 	# Round Robin "upstream" pools for workers | ||||
|  | ||||
| 	{% if generic_workers %} | ||||
| 	upstream generic_worker_upstream { | ||||
| 		# ensures that requests from the same client will always be passed | ||||
| 		# to the same server (except when this server is unavailable) | ||||
| 		ip_hash; | ||||
|  | ||||
| 		{% for worker in generic_workers %} | ||||
| 		server "matrix-synapse:{{ worker.port }}"; | ||||
| 		{% endfor %} | ||||
| 	} | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{% if frontend_proxy_workers %} | ||||
| 	upstream frontend_proxy_upstream { | ||||
| 		{% for worker in frontend_proxy_workers %} | ||||
| 		server "matrix-synapse:{{ worker.port }}"; | ||||
| 		{% endfor %} | ||||
| 	} | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{% if media_repository_workers %} | ||||
| 	upstream media_repository_upstream { | ||||
| 		{% for worker in media_repository_workers %} | ||||
| 		server "matrix-synapse:{{ worker.port }}"; | ||||
| 		{% endfor %} | ||||
| 	} | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{% if user_dir_workers %} | ||||
| 	upstream user_dir_upstream { | ||||
| 		{% for worker in user_dir_workers %} | ||||
| 		server "matrix-synapse:{{ worker.port }}"; | ||||
| 		{% endfor %} | ||||
| 	} | ||||
| 	{% endif %} | ||||
| {% endif %} | ||||
|  | ||||
| server { | ||||
| 	listen {{ 8080 if matrix_nginx_proxy_enabled else 80 }}; | ||||
| 	server_name {{ matrix_nginx_proxy_proxy_matrix_hostname }}; | ||||
|  | ||||
| 	server_tokens off; | ||||
| 	root /dev/null; | ||||
|  | ||||
| 	{% if matrix_nginx_proxy_https_enabled %} | ||||
| 		location /.well-known/acme-challenge { | ||||
| 			{% if matrix_nginx_proxy_enabled %} | ||||
| 				{# Use the embedded DNS resolver in Docker containers to discover the service #} | ||||
| 				resolver 127.0.0.11 valid=5s; | ||||
| 				set $backend "matrix-certbot:8080"; | ||||
| 				proxy_pass http://$backend; | ||||
| 			{% else %} | ||||
| 				{# Generic configuration for use outside of our container setup #} | ||||
| 				proxy_pass http://127.0.0.1:{{ matrix_ssl_lets_encrypt_certbot_standalone_http_port }}; | ||||
| 			{% endif %} | ||||
| 		} | ||||
|  | ||||
| 		{% if matrix_nginx_proxy_proxy_matrix_nginx_status_enabled %} | ||||
| 			{{ render_nginx_status_location_block(matrix_nginx_proxy_proxy_matrix_nginx_status_allowed_addresses) }} | ||||
| 		{% endif %} | ||||
|  | ||||
| 		location / { | ||||
| 			return 301 https://$http_host$request_uri; | ||||
| 		} | ||||
| 	{% else %} | ||||
| 		{{ render_vhost_directives() }} | ||||
| 	{% endif %} | ||||
| } | ||||
|  | ||||
| {% if matrix_nginx_proxy_https_enabled %} | ||||
| {% if matrix_nginx_proxy_proxy_synapse_federation_api_enabled %} | ||||
| server { | ||||
| 	listen {{ 8443 if matrix_nginx_proxy_enabled else 443 }} ssl http2; | ||||
| 	listen [::]:{{ 8443 if matrix_nginx_proxy_enabled else 443 }} ssl http2; | ||||
| 	listen 12088; | ||||
|  | ||||
| 	server_name {{ matrix_nginx_proxy_proxy_matrix_hostname }}; | ||||
|  | ||||
| 	server_tokens off; | ||||
| 	root /dev/null; | ||||
|  | ||||
| 	ssl_certificate {{ matrix_ssl_config_dir_path }}/live/{{ matrix_nginx_proxy_proxy_matrix_hostname }}/fullchain.pem; | ||||
| 	ssl_certificate_key {{ matrix_ssl_config_dir_path }}/live/{{ matrix_nginx_proxy_proxy_matrix_hostname }}/privkey.pem; | ||||
|  | ||||
| 	ssl_protocols {{ matrix_nginx_proxy_ssl_protocols }}; | ||||
| 	{% if matrix_nginx_proxy_ssl_ciphers != '' %} | ||||
| 	ssl_ciphers {{ matrix_nginx_proxy_ssl_ciphers }}; | ||||
| 	{% endif %} | ||||
| 	ssl_prefer_server_ciphers {{ matrix_nginx_proxy_ssl_prefer_server_ciphers }}; | ||||
|  | ||||
| 	{{ render_vhost_directives() }} | ||||
| } | ||||
| {% endif %} | ||||
|  | ||||
| {% if matrix_nginx_proxy_proxy_matrix_federation_api_enabled %} | ||||
| {# | ||||
| 	This federation vhost is a little special. | ||||
| 	It serves federation over HTTP or HTTPS, depending on `matrix_nginx_proxy_https_enabled`. | ||||
| #} | ||||
| server { | ||||
| 	{% if matrix_nginx_proxy_https_enabled %} | ||||
| 		listen 8448 ssl http2; | ||||
| 		listen [::]:8448 ssl http2; | ||||
| 	{% else %} | ||||
| 		listen 8448; | ||||
| 	{% endif %} | ||||
|  | ||||
| 	server_name {{ matrix_nginx_proxy_proxy_matrix_hostname }}; | ||||
| 	server_name {{ matrix_nginx_proxy_proxy_synapse_hostname }}; | ||||
| 	server_tokens off; | ||||
|  | ||||
| 	root /dev/null; | ||||
| @@ -345,18 +176,6 @@ server { | ||||
| 	gzip on; | ||||
| 	gzip_types text/plain application/json; | ||||
|  | ||||
| 	{% if matrix_nginx_proxy_https_enabled %} | ||||
| 		ssl_certificate {{ matrix_nginx_proxy_proxy_matrix_federation_api_ssl_certificate }}; | ||||
| 		ssl_certificate_key {{ matrix_nginx_proxy_proxy_matrix_federation_api_ssl_certificate_key }}; | ||||
|  | ||||
| 	ssl_protocols {{ matrix_nginx_proxy_ssl_protocols }}; | ||||
| 	{% if matrix_nginx_proxy_ssl_ciphers != '' %} | ||||
| 	ssl_ciphers {{ matrix_nginx_proxy_ssl_ciphers }}; | ||||
| 	{% endif %} | ||||
| 	ssl_prefer_server_ciphers {{ matrix_nginx_proxy_ssl_prefer_server_ciphers }}; | ||||
|  | ||||
| 	{% endif %} | ||||
|  | ||||
| 	{% if matrix_nginx_proxy_synapse_workers_enabled %} | ||||
| 		{% if generic_workers %} | ||||
| 			# https://github.com/matrix-org/synapse/blob/master/docs/workers.md#synapseappgeneric_worker | ||||
| @@ -367,7 +186,6 @@ server { | ||||
| 				proxy_set_header X-Forwarded-For $remote_addr; | ||||
| 			} | ||||
| 			{% endfor %} | ||||
| 			# FIXME: add GET ^/_matrix/federation/v1/groups/ | ||||
| 		{% endif %} | ||||
| 		{% if media_repository_workers %} | ||||
| 			# https://github.com/matrix-org/synapse/blob/master/docs/workers.md#synapseappmedia_repository | ||||
| @@ -389,11 +207,11 @@ server { | ||||
| 		{% if matrix_nginx_proxy_enabled %} | ||||
| 			{# Use the embedded DNS resolver in Docker containers to discover the service #} | ||||
| 			resolver 127.0.0.11 valid=5s; | ||||
| 			set $backend "{{ matrix_nginx_proxy_proxy_matrix_federation_api_addr_with_container }}"; | ||||
| 			set $backend "{{ matrix_nginx_proxy_proxy_synapse_federation_api_addr_with_container }}"; | ||||
| 			proxy_pass http://$backend; | ||||
| 		{% else %} | ||||
| 			{# Generic configuration for use outside of our container setup #} | ||||
| 			proxy_pass http://{{ matrix_nginx_proxy_proxy_matrix_federation_api_addr_sans_container }}; | ||||
| 			proxy_pass http://{{ matrix_nginx_proxy_proxy_synapse_federation_api_addr_sans_container }}; | ||||
| 		{% endif %} | ||||
|  | ||||
| 		proxy_set_header Host $host; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user