ce34ffacb1 
								
							
								 
							
						 
						
							
							
								
								Merge remote-tracking branch 'origin/master' into develop  
							
							
							
						 
						
							2022-02-04 10:47:55 +00:00  
				
					
						
							
							
								 
						
							
							
								119edf51eb 
								
									
								
							
								 
							
						 
						
							
							
								
								Remove support for the webclient listener. ( #11895 )  
							
							... 
							
							
							
							Also remove support for non-HTTP(S) web_client_location. 
							
						 
						
							2022-02-03 18:36:49 +00:00  
				
					
						
							
							
								 
						
							
							
								6b1c265c21 
								
									
								
							
								 
							
						 
						
							
							
								
								Fix typo: unpind -> unbind ( #11859 )  
							
							... 
							
							
							
							Co-authored-by: reivilibre <olivier@librepush.net> 
							
						 
						
							2022-02-03 17:20:44 +00:00  
				
					
						
							
							
								 
						
							
							
								d80d39b035 
								
									
								
							
								 
							
						 
						
							
							
								
								Add a ratelimiter for 3pid invite ( #11892 )  
							
							
							
						 
						
							2022-02-03 14:28:15 +01:00  
				
					
						
							
							
								 
						
							
							
								833247553f 
								
									
								
							
								 
							
						 
						
							
							
								
								Allow specifying the application service-specific `user_id` parameter in the `join` test helper. ( #11616 )  
							
							
							
						 
						
							2022-02-03 13:09:22 +00:00  
				
					
						
							
							
								 
						
							
							
								964f5b9324 
								
									
								
							
								 
							
						 
						
							
							
								
								Improve opentracing for federation requests ( #11870 )  
							
							... 
							
							
							
							The idea here is to set the parent span for incoming federation requests to the
*outgoing* span on the other end. That means that you can see (most of) the
full end-to-end flow when you have a process that includes federation requests.
However, in order not to lose information, we still want a link to the
`incoming-federation-request` span from the servlet, so we have to create
another span to do exactly that. 
							
						 
						
							2022-02-03 12:29:16 +00:00  
				
					
						
							
							
								 
						
							
							
								31b554c297 
								
									
								
							
								 
							
						 
						
							
							
								
								Fixes for opentracing scopes ( #11869 )  
							
							... 
							
							
							
							`start_active_span` was inconsistent as to whether it would activate the span
immediately, or wait for `scope.__enter__` to happen (it depended on whether
the current logcontext already had an associated scope). The inconsistency was
rather confusing if you were hoping to set up a couple of separate spans before
activating either.
Looking at the other implementations of opentracing `ScopeManager`s, the
intention is that it *should* be activated immediately, as the name
implies. Indeed, the idea is that you don't have to use the scope as a
contextmanager at all - you can just call `.close` on the result. Hence, our
cleanup has to happen in `.close` rather than `.__exit__`.
So, the main change here is to ensure that `start_active_span` does activate
the span, and that `scope.close()` does close the scope.
We also add some tests, which requires a `tracer` param so that we don't have
to rely on the global variable in unit tests. 
							
						 
						
							2022-02-02 22:41:57 +00:00  
				
					
						
							
							
								 
						
							
							
								a8da046907 
								
									
								
							
								 
							
						 
						
							
							
								
								Invalidate the get_users_in_room{_with_profile} caches only when necessary. ( #11878 )  
							
							... 
							
							
							
							The get_users_in_room and get_users_in_room_with_profiles
are now only invalidated when the  membership of a room changes,
instead of during any state change in the room. 
							
						 
						
							2022-02-02 12:24:07 -05:00  
				
					
						
							
							
								 
						
							
							
								41818cda1f 
								
									
								
							
								 
							
						 
						
							
							
								
								Fix type errors introduced by new annotations in the Prometheus Client library. ( #11832 )  
							
							... 
							
							
							
							Co-authored-by: David Robertson <davidr@element.io> 
							
						 
						
							2022-02-02 16:51:00 +00:00  
				
					
						
							
							
								 
						
							
							
								dd7f825118 
								
									
								
							
								 
							
						 
						
							
							
								
								Fix losing incoming EDUs if debug logging enabled ( #11890 )  
							
							... 
							
							
							
							* Fix losing incoming EDUs if debug logging enabled
Fixes  #11889 . Homeservers should only be affected if the
`synapse.8631_debug` logger was enabled for DEBUG mode.
I am not sure if this merits a bugfix release: I think the logging can
be disabled in config if anyone is affected? But it is still pretty bad. 
							
						 
						
							2022-02-02 16:25:17 +00:00  
				
					
						
							
							
								 
						
							
							
								23a698f5e6 
								
									
								
							
								 
							
						 
						
							
							
								
								Disable coverage calculation for olddeps build. ( #11888 )  
							
							... 
							
							
							
							We disabled coverage calculation for most of CI in #11017 , but the olddeps
build uses a separate script and got forgotten. 
							
						 
						
							2022-02-02 15:59:33 +00:00  
				
					
						
							
							
								 
						
							
							
								f510fba4ba 
								
									
								
							
								 
							
						 
						
							
							
								
								Describe `prune_unread_entries` in docstrings ( #11876 )  
							
							... 
							
							
							
							Should have been caught in #10826 . 
							
						 
						
							2022-02-02 15:11:23 +00:00  
				
					
						
							
							
								 
						
							
							
								acda9f07c8 
								
									
								
							
								 
							
						 
						
							
							
								
								Revert experimental push rules from  #7997 . ( #11884 )  
							
							... 
							
							
							
							Manually reverts the merge from cdbb8e6d6e 
							
						 
						
							2022-02-02 09:49:31 -05:00  
				
					
						
							
							
								 
						
							
							
								af795173be 
								
									
								
							
								 
							
						 
						
							
							
								
								Add a background database update to purge account data for deactivated users. ( #11655 )  
							
							
							
						 
						
							2022-02-02 11:37:18 +00:00  
				
					
						
							
							
								 
						
							
							
								513913cc6b 
								
									
								
							
								 
							
						 
						
							
							
								
								Expose the registered device ID from the `register_appservice_user` test helper. ( #11615 )  
							
							
							
						 
						
							2022-02-02 09:59:55 +00:00  
				
					
						
							
							
								 
						
							
							
								3f72c2a322 
								
									
								
							
								 
							
						 
						
							
							
								
								Convert `ApplicationServiceTestCase` to use `simple_async_mock` ( #11880 )  
							
							
							
						 
						
							2022-02-01 17:45:13 +00:00  
				
					
						
							
							
								 
						
							
							
								5c16c33021 
								
									
								
							
								 
							
						 
						
							
							
								
								Allow modules to retrieve server and worker names ( #11868 )  
							
							... 
							
							
							
							Fixes  #10701  
						
							2022-02-01 16:23:55 +01:00  
				
					
						
							
							
								 
						
							
							
								64ec45fc1b 
								
									
								
							
								 
							
						 
						
							
							
								
								Send to-device messages to application services ( #11215 )  
							
							... 
							
							
							
							Co-authored-by: Richard van der Hoff <1389908+richvdh@users.noreply.github.com> 
							
						 
						
							2022-02-01 14:13:38 +00:00  
				
					
						
							
							
								 
						
							
							
								b7282fe7d1 
								
									
								
							
								 
							
						 
						
							
							
								
								Don't mention 3.6 EOL under misc  
							
							... 
							
							
							
							It's already under deps & removals 
							
						 
						
							2022-02-01 11:07:12 +00:00  
				
					
						
							
							
								 
						
							
							
								a35e9db9be 
								
									
								
							
								 
							
						 
						
							
							
								
								1.52.0rc1  
							
							
							
						 
						
							2022-02-01 11:04:17 +00:00  
				
					
						
							
							
								 
						
							
							
								901b264c0c 
								
									
								
							
								 
							
						 
						
							
							
								
								Add type hints to `tests/rest/admin` ( #11851 )  
							
							
							
						 
						
							2022-01-31 14:20:05 -05:00  
				
					
						
							
							
								 
						
							
							
								0da2301b21 
								
									
								
							
								 
							
						 
						
							
							
								
								Consolidate the `access_token` information in the admin api ( #11861 )  
							
							... 
							
							
							
							Co-authored-by: reivilibre <olivier@librepush.net> 
							
						 
						
							2022-01-31 16:24:29 +00:00  
				
					
						
							
							
								 
						
							
							
								02755c3188 
								
									
								
							
								 
							
						 
						
							
							
								
								Remove the obsolete MSC1849 configuration flag. ( #11843 )  
							
							... 
							
							
							
							MSC1849 was replaced by MSC2675, which was merged.
The configuration flag, which defaulted to true, is no
longer useful. 
							
						 
						
							2022-01-31 10:13:32 -05:00  
				
					
						
							
							
								 
						
							
							
								7eb198ddc8 
								
									
								
							
								 
							
						 
						
							
							
								
								Remove not needed old table of contents in documentation ( #11860 )  
							
							
							
						 
						
							2022-01-31 14:40:20 +00:00  
				
					
						
							
							
								 
						
							
							
								bf60da1a60 
								
									
								
							
								 
							
						 
						
							
							
								
								Configurable limits on avatars ( #11846 )  
							
							... 
							
							
							
							Only allow files which file size and content types match configured
limits to be set as avatar.
Most of the inspiration from the non-test code comes from matrix-org/synapse-dinsic#19  
							
						 
						
							2022-01-28 15:41:33 +01:00  
				
					
						
							
							
								 
						
							
							
								6d482ba259 
								
									
								
							
								 
							
						 
						
							
							
								
								Pass `isolation_level` to `runWithConnection` ( #11847 )  
							
							... 
							
							
							
							This was missed in https://github.com/matrix-org/synapse/pull/11799  
							
						 
						
							2022-01-27 17:45:39 +00:00  
				
					
						
							
							
								 
						
							
							
								57e4786e90 
								
									
								
							
								 
							
						 
						
							
							
								
								Create singletons for `StateFilter.{all,none}()` ( #11836 )  
							
							... 
							
							
							
							No point recreating these for each call, since they are frozen 
							
						 
						
							2022-01-27 10:54:27 +00:00  
				
					
						
							
							
								 
						
							
							
								fd65139714 
								
									
								
							
								 
							
						 
						
							
							
								
								Fix some indentation inconsistencies in the sample config (modules) ( #11838 )  
							
							
							
						 
						
							2022-01-27 10:06:29 +00:00  
				
					
						
							
							
								 
						
							
							
								ec07062e31 
								
									
								
							
								 
							
						 
						
							
							
								
								Update installation docs to indicate that we support Python 3.10 ( #11820 )  
							
							
							
						 
						
							2022-01-26 16:05:29 -08:00  
				
					
						
							
							
								 
						
							
							
								cef0d5d90a 
								
									
								
							
								 
							
						 
						
							
							
								
								Include `prev_content` field in AS events ( #11798 )  
							
							... 
							
							
							
							* Include 'prev_content' field in AS events
Signed-off-by: Vaishnav Nair <nairvaishnav007@icloud.com>
Co-authored-by: Brendan Abolivier <babolivier@matrix.org> 
							
						 
						
							2022-01-26 14:48:27 +00:00  
				
					
						
							
							
								 
						
							
							
								2d3bd9aa67 
								
									
								
							
								 
							
						 
						
							
							
								
								Add a module callback to set username at registration ( #11790 )  
							
							... 
							
							
							
							This is in the context of mainlining the Tchap fork of Synapse. Currently in Tchap usernames are derived from the user's email address (extracted from the UIA results, more specifically the m.login.email.identity step).
This change also exports the check_username method from the registration handler as part of the module API, so that a module can check if the username it's trying to generate is correct and doesn't conflict with an existing one, and fallback gracefully if not.
Co-authored-by: David Robertson <davidr@element.io> 
							
						 
						
							2022-01-26 14:21:13 +00:00  
				
					
						
							
							
								 
						
							
							
								2897fb6b4f 
								
									
								
							
								 
							
						 
						
							
							
								
								Improvements to bundling aggregations. ( #11815 )  
							
							... 
							
							
							
							This is some odds and ends found during the review of #11791 
and while continuing to work in this code:
* Return attrs classes instead of dictionaries from some methods
  to improve type safety.
* Call `get_bundled_aggregations` fewer times.
* Adds a missing assertion in the tests.
* Do not return empty bundled aggregations for an event (preferring
  to not include the bundle at all, as the docstring states). 
							
						 
						
							2022-01-26 08:27:04 -05:00  
				
					
						
							
							
								 
						
							
							
								d8df8e6c14 
								
									
								
							
								 
							
						 
						
							
							
								
								Don't print HTTPStatus.* in "Processed..." logs ( #11827 )  
							
							... 
							
							
							
							* Don't print HTTPStatus.* in "Processed..." logs
Fixes  #11812 . See also #7118  and
https://github.com/matrix-org/synapse/pull/7188#r401719326  in
particular.
Co-authored-by: Brendan Abolivier <babolivier@matrix.org> 
							
						 
						
							2022-01-26 12:47:34 +00:00  
				
					
						
							
							
								 
						
							
							
								c5815567a4 
								
									
								
							
								 
							
						 
						
							
							
								
								Avoid type annotation problems in prom-client ( #11834 )  
							
							
							
						 
						
							2022-01-26 12:06:56 +00:00  
				
					
						
							
							
								 
						
							
							
								95b3f952fa 
								
									
								
							
								 
							
						 
						
							
							
								
								Add a config flag to inhibit `M_USER_IN_USE` during registration ( #11743 )  
							
							... 
							
							
							
							This is mostly motivated by the tchap use case, where usernames are automatically generated from the user's email address (in a way that allows figuring out the email address from the username). Therefore, it's an issue if we respond to requests on /register and /register/available with M_USER_IN_USE, because it can potentially leak email addresses (which include the user's real name and place of work).
This commit adds a flag to inhibit the M_USER_IN_USE errors that are raised both by /register/available, and when providing a username early into the registration process. This error will still be raised if the user completes the registration process but the username conflicts. This is particularly useful when using modules (https://github.com/matrix-org/synapse/pull/11790  adds a module callback to set the username of users at registration) or SSO, since they can ensure the username is unique.
More context is available in the PR that introduced this behaviour to synapse-dinsic: matrix-org/synapse-dinsic#48  - as well as the issue in the matrix-dinsic repo: matrix-org/matrix-dinsic#476  
							
						 
						
							2022-01-26 13:02:54 +01:00  
				
					
						
							
							
								 
						
							
							
								74e4419eb4 
								
									
								
							
								 
							
						 
						
							
							
								
								Fix another jsonschema typecheck error ( #11830 )  
							
							... 
							
							
							
							Similar to #11817 .
In `_create_power_level_validator` we
- retrieve `validator`. This is a class implementing the
  `jsonschema.protocols.Validator` interface. In other words,
  `validator: Type[jsonschema.protocols.Validator]`.
- we then create an second validator class by modifying the original
  `validator`. We return that class, which is also of type
  `Type[jsonschema.protocols.Validator]`.
So the original annotation was incorrect: it claimed we were returning
an instance of jsonSchema.Draft7Validator, not the class (or a subclass)
itself. (Strictly speaking this is incorrect, because `POWER_LEVELS_SCHEMA`
isn't pinned to a particular version of JSON Schema. But there are other
complications with the type stubs if you try to fix this; I felt like
the change herein was a decent compromise that better expresses intent).
(I suspect/hope the typeshed project would welcome an effort to improve
the jsonschema stubs. Let's see if I get some spare time.) 
							
						 
						
							2022-01-25 15:29:28 -05:00  
				
					
						
							
							
								 
						
							
							
								b8bf600700 
								
									
								
							
								 
							
						 
						
							
							
								
								Check that `gc` method is available before using in `synapse/app/_base`  ( #11816 )  
							
							... 
							
							
							
							* add check that gc.freeze is available before calling
* newsfragment
* lint
* Update comment
Co-authored-by: Dan Callahan <danc@element.io>
Co-authored-by: Dan Callahan <danc@element.io> 
							
						 
						
							2022-01-25 10:35:18 -08:00  
				
					
						
							
							
								 
						
							
							
								6a72c910f1 
								
									
								
							
								 
							
						 
						
							
							
								
								Add admin API to get a list of federated rooms ( #11658 )  
							
							
							
						 
						
							2022-01-25 16:11:40 +00:00  
				
					
						
							
							
								 
						
							
							
								0938f32e93 
								
									
								
							
								 
							
						 
						
							
							
								
								CI: run Complement on the VM, not inside Docker ( #11811 )  
							
							... 
							
							
							
							* CI: run Complement on the VM, not inside Docker
This requires https://github.com/matrix-org/complement/pull/289 
We now run Complement on the VM instead of inside a Docker container.
This is to allow Complement to bind to any high-numbered port when it
starts up its own federation servers. We want to do this to allow for
more concurrency when running complement tests. Previously, Complement
only ever bound to `:8448` when running its own federation server. This
prevented multiple federation tests running at the same time as they would
fight each other on the port. This did however allow Complement to run
in Docker, as the host could just port forward `:8448` to allow homeserver
containers to communicate to Complement. Now that we are using random
ports however, we cannot use Docker to run Complement. This ends up
being a good thing because:
 - Running Complement tests locally is closer to how they run in CI.
 - Allows the `CI` env var to be removed in Complement.
 - Slightly speeds up runs as we don't need to pull down the Complement
   image prior to running tests. This assumes GHA caches actions sensibly.
* Changelog
* Full stop
* Update .github/workflows/tests.yml
Co-authored-by: Richard van der Hoff <1389908+richvdh@users.noreply.github.com>
* Review comments
* Update .github/workflows/tests.yml
Co-authored-by: Richard van der Hoff <1389908+richvdh@users.noreply.github.com>
Co-authored-by: Richard van der Hoff <1389908+richvdh@users.noreply.github.com> 
							
						 
						
							2022-01-25 15:05:22 +00:00  
				
					
						
							
							
								 
						
							
							
								1d5f7b2cc6 
								
									
								
							
								 
							
						 
						
							
							
								
								Log modules at startup ( #11813 )  
							
							
							
						 
						
							2022-01-25 15:35:35 +01:00  
				
					
						
							
							
								 
						
							
							
								b59d285f7c 
								
									
								
							
								 
							
						 
						
							
							
								
								Db txn set isolation level ( #11799 )  
							
							... 
							
							
							
							Co-authored-by: Brendan Abolivier <babolivier@matrix.org> 
							
						 
						
							2022-01-25 15:14:46 +01:00  
				
					
						
							
							
								 
						
							
							
								fc8598bc87 
								
									
								
							
								 
							
						 
						
							
							
								
								Minor updates, and docs, for schema delta files ( #11823 )  
							
							... 
							
							
							
							* Make functions in python deltas optional
It's annoying to always have to write stubs for these.
* Documentation for delta files
* changelog 
							
						 
						
							2022-01-25 14:11:13 +00:00  
				
					
						
							
							
								 
						
							
							
								4210143f53 
								
									
								
							
								 
							
						 
						
							
							
								
								Docs: add missing PR submission process how-tos ( #11821 )  
							
							... 
							
							
							
							* Docs: add missing PR submission process how-tos
The documentation says that in order to submit a pull request you have to run the linter and links to [Run the linters](https://matrix-org.github.io/synapse/latest/development/contributing_guide.html#run-the-linters ).  IMO "Run the linters" should explain that development dependencies are a pre-requisite.
I also included `pip install wheel`  which I had to run inside my virtual environment on ubuntu before I `pip install -e ".[all,dev]"` would succeed. 
							
						 
						
							2022-01-25 14:09:56 +00:00  
				
					
						
							
							
								 
						
							
							
								4e09d727b6 
								
									
								
							
								 
							
						 
						
							
							
								
								Use changelog from develop  
							
							... 
							
							
							
							It had already accounted for 1.50.2 (ordered chronologically rather than
sem-ver-ically); it just seems this wasn't merged into master when we
released 1.50.2. 
							
						 
						
							2022-01-25 12:53:29 +00:00  
				
					
						
							
							
								 
						
							
							
								6911604a0f 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge branch 'master' into develop  
							
							
							
						 
						
							2022-01-25 12:52:27 +00:00  
				
					
						
							
							
								 
						
							
							
								8e45dfbe25 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge branch 'release-v1.51'  
							
							
							
						 
						
							2022-01-25 12:35:30 +00:00  
				
					
						
							
							
								 
						
							
							
								b500fcbc0c 
								
							
								 
							
						 
						
							
							
								
								Synapse 1.51.0 (2022-01-25)  
							
							... 
							
							
							
							===========================
 
 No significant changes since 1.51.0rc2.
 
 Synapse 1.51.0 deprecates `webclient` listeners and non-HTTP(S) `web_client_location`s. Support for these will be removed in Synapse 1.53.0, at which point Synapse will not be capable of directly serving a web client for Matrix.
 
 Synapse 1.51.0rc2 (2022-01-24)
 ==============================
 
 Bugfixes
 --------
 
 - Fix a bug introduced in Synapse 1.40.0 that caused Synapse to fail to process incoming federation traffic after handling a large amount of events in a v1 room. ([\#11806](https://github.com/matrix-org/synapse/issues/11806 ))
 
 Synapse 1.51.0rc1 (2022-01-21)
 ==============================
 
 Features
 --------
 
 - Add `track_puppeted_user_ips` config flag to record client IP addresses against puppeted users, and include the puppeted users in monthly active user counts. ([\#11561](https://github.com/matrix-org/synapse/issues/11561 ), [\#11749](https://github.com/matrix-org/synapse/issues/11749 ), [\#11757](https://github.com/matrix-org/synapse/issues/11757 ))
 - Include whether the requesting user has participated in a thread when generating a summary for [MSC3440](https://github.com/matrix-org/matrix-doc/pull/3440 ). ([\#11577](https://github.com/matrix-org/synapse/issues/11577 ))
 - Return an `M_FORBIDDEN` error code instead of `M_UNKNOWN` when a spam checker module prevents a user from creating a room. ([\#11672](https://github.com/matrix-org/synapse/issues/11672 ))
 - Add a flag to the `synapse_review_recent_signups` script to ignore and filter appservice users. ([\#11675](https://github.com/matrix-org/synapse/issues/11675 ), [\#11770](https://github.com/matrix-org/synapse/issues/11770 ))
 
 Bugfixes
 --------
 
 - Fix a long-standing issue which could cause Synapse to incorrectly accept data in the unsigned field of events
   received over federation. ([\#11530](https://github.com/matrix-org/synapse/issues/11530 ))
 - Fix a long-standing bug where Synapse wouldn't cache a response indicating that a remote user has no devices. ([\#11587](https://github.com/matrix-org/synapse/issues/11587 ))
 - Fix an error that occurs whilst trying to get the federation status of a destination server that was working normally. This admin API was newly introduced in Synapse v1.49.0. ([\#11593](https://github.com/matrix-org/synapse/issues/11593 ))
 - Fix bundled aggregations not being included in the `/sync` response, per [MSC2675](https://github.com/matrix-org/matrix-doc/pull/2675 ). ([\#11612](https://github.com/matrix-org/synapse/issues/11612 ), [\#11659](https://github.com/matrix-org/synapse/issues/11659 ), [\#11791](https://github.com/matrix-org/synapse/issues/11791 ))
 - Fix the `/_matrix/client/v1/room/{roomId}/hierarchy` endpoint returning incorrect fields which have been present since Synapse 1.49.0. ([\#11667](https://github.com/matrix-org/synapse/issues/11667 ))
 - Fix preview of some GIF URLs (like tenor.com). Contributed by Philippe Daouadi. ([\#11669](https://github.com/matrix-org/synapse/issues/11669 ))
 - Fix a bug where only the first 50 rooms from a space were returned from the `/hierarchy` API. This has existed since the introduction of the API in Synapse v1.41.0. ([\#11695](https://github.com/matrix-org/synapse/issues/11695 ))
 - Fix a bug introduced in Synapse v1.18.0 where password reset and address validation emails would not be sent if their subject was configured to use the 'app' template variable. Contributed by @br4nnigan. ([\#11710](https://github.com/matrix-org/synapse/issues/11710 ), [\#11745](https://github.com/matrix-org/synapse/issues/11745 ))
 - Make the 'List Rooms' Admin API sort stable. Contributed by Daniël Sonck. ([\#11737](https://github.com/matrix-org/synapse/issues/11737 ))
 - Fix a long-standing bug where space hierarchy over federation would only work correctly some of the time. ([\#11775](https://github.com/matrix-org/synapse/issues/11775 ))
 - Fix a bug introduced in Synapse v1.46.0 that prevented `on_logged_out` module callbacks from being correctly awaited by Synapse. ([\#11786](https://github.com/matrix-org/synapse/issues/11786 ))
 
 Improved Documentation
 ----------------------
 
 - Warn against using a Let's Encrypt certificate for TLS/DTLS TURN server client connections, and suggest using ZeroSSL certificate instead. This works around client-side connectivity errors caused by WebRTC libraries that reject Let's Encrypt certificates. Contibuted by @AndrewFerr. ([\#11686](https://github.com/matrix-org/synapse/issues/11686 ))
 - Document the new `SYNAPSE_TEST_PERSIST_SQLITE_DB` environment variable in the contributing guide. ([\#11715](https://github.com/matrix-org/synapse/issues/11715 ))
 - Document that the minimum supported PostgreSQL version is now 10. ([\#11725](https://github.com/matrix-org/synapse/issues/11725 ))
 - Fix typo in demo docs: differnt. ([\#11735](https://github.com/matrix-org/synapse/issues/11735 ))
 - Update room spec URL in config files. ([\#11739](https://github.com/matrix-org/synapse/issues/11739 ))
 - Mention `python3-venv` and `libpq-dev` dependencies in the contribution guide. ([\#11740](https://github.com/matrix-org/synapse/issues/11740 ))
 - Update documentation for configuring login with Facebook. ([\#11755](https://github.com/matrix-org/synapse/issues/11755 ))
 - Update installation instructions to note that Python 3.6 is no longer supported. ([\#11781](https://github.com/matrix-org/synapse/issues/11781 ))
 
 Deprecations and Removals
 -------------------------
 
 - Remove the unstable `/send_relation` endpoint. ([\#11682](https://github.com/matrix-org/synapse/issues/11682 ))
 - Remove `python_twisted_reactor_pending_calls` Prometheus metric. ([\#11724](https://github.com/matrix-org/synapse/issues/11724 ))
 - Remove the `password_hash` field from the response dictionaries of the [Users Admin API](https://matrix-org.github.io/synapse/latest/admin_api/user_admin_api.html ). ([\#11576](https://github.com/matrix-org/synapse/issues/11576 ))
 - **Deprecate support for `webclient` listeners and non-HTTP(S) `web_client_location` configuration. ([\#11774](https://github.com/matrix-org/synapse/issues/11774 ), [\#11783](https://github.com/matrix-org/synapse/issues/11783 ))**
 
 Internal Changes
 ----------------
 
 - Run `pyupgrade --py37-plus --keep-percent-format` on Synapse. ([\#11685](https://github.com/matrix-org/synapse/issues/11685 ))
 - Use buildkit's cache feature to speed up docker builds. ([\#11691](https://github.com/matrix-org/synapse/issues/11691 ))
 - Use `auto_attribs` and native type hints for attrs classes. ([\#11692](https://github.com/matrix-org/synapse/issues/11692 ), [\#11768](https://github.com/matrix-org/synapse/issues/11768 ))
 - Remove debug logging for #4422 , which has been closed since Synapse 0.99. ([\#11693](https://github.com/matrix-org/synapse/issues/11693 ))
 - Remove fallback code for Python 2. ([\#11699](https://github.com/matrix-org/synapse/issues/11699 ))
 - Add a test for [an edge case](https://github.com/matrix-org/synapse/pull/11532#discussion_r769104461 ) in the `/sync` logic. ([\#11701](https://github.com/matrix-org/synapse/issues/11701 ))
 - Add the option to write SQLite test dbs to disk when running tests. ([\#11702](https://github.com/matrix-org/synapse/issues/11702 ))
 - Improve Complement test output for Gitub Actions. ([\#11707](https://github.com/matrix-org/synapse/issues/11707 ))
 - Fix docstring on `add_account_data_for_user`. ([\#11716](https://github.com/matrix-org/synapse/issues/11716 ))
 - Complement environment variable name change and update `.gitignore`. ([\#11718](https://github.com/matrix-org/synapse/issues/11718 ))
 - Simplify calculation of Prometheus metrics for garbage collection. ([\#11723](https://github.com/matrix-org/synapse/issues/11723 ))
 - Improve accuracy of `python_twisted_reactor_tick_time` Prometheus metric. ([\#11724](https://github.com/matrix-org/synapse/issues/11724 ), [\#11771](https://github.com/matrix-org/synapse/issues/11771 ))
 - Minor efficiency improvements when inserting many values into the database. ([\#11742](https://github.com/matrix-org/synapse/issues/11742 ))
 - Invite PR authors to give themselves credit in the changelog. ([\#11744](https://github.com/matrix-org/synapse/issues/11744 ))
 - Add optional debugging to investigate [issue 8631](https://github.com/matrix-org/synapse/issues/8631 ). ([\#11760](https://github.com/matrix-org/synapse/issues/11760 ))
 - Remove `log_function` utility function and its uses. ([\#11761](https://github.com/matrix-org/synapse/issues/11761 ))
 - Add a unit test that checks both `client` and `webclient` resources will function when simultaneously enabled. ([\#11765](https://github.com/matrix-org/synapse/issues/11765 ))
 - Allow overriding complement commit using `COMPLEMENT_REF`. ([\#11766](https://github.com/matrix-org/synapse/issues/11766 ))
 - Add some comments and type annotations for `_update_outliers_txn`. ([\#11776](https://github.com/matrix-org/synapse/issues/11776 ))
 -----BEGIN PGP SIGNATURE-----
 
 iQIzBAABCAAdFiEE1508oLYUKainYFJakD7OEIo53t0FAmHv5K8ACgkQkD7OEIo5
 3t0TOg/+LQAWWi2RFUiezajSJS5LH5n7FNVs0XPAahKsrU6Xc6NHPHCQ5TpUSfKu
 MxLE5E4+5rsXpcHkb4NqNhyl5sEXPVWatmPkD+o9eo3LXBh42CHjcfOrboPaBRBJ
 DkmPYE3DhL++RBtdYoTRTLfVwq6L35Yi9CNjc19IMDAecqayC9Yl2E4ilcFZpS0R
 RB1ZULeNBa5oQmQEWbceGgAxhjAKgI/zkadSH2jsVWMxMUoh8zk1OzOc8DOaImRv
 yNr/8kB7wyCLLTRIR3AgcwI5nQHYCaYmnuoOP1+Y0axf1IVuQneo0kSNQJ9bf3Ob
 8/ICIb3e9qqbYKYiy4aCV41n9F4fhGRUoD+2s6S+QWC49hIVIrBoW1d6J8xNlV3r
 CbwKRuif1hIR4MTec+wjOBZScucpTDFx7wn94ivFtGlJmI58wikTunGKseczWTJN
 ujzdF6oPQc/qlJGG8zKIUgn11795RkZfFTFRJTrHaSWYmnMzSX6wEtXBp8ChoaFY
 X4fGdZqkgTjAt/wcReKI5cbhfmoigpwAPZQIGuvt/1E3YlkTl1VPiO7nxx3fNZEY
 SPNG0UtCaQ3IXOzqQy20cGb8lE8DeaGG3WrN2QeNczxeytoqymKFBq5DBoYXviBw
 D4zr0VpRQpDQUqf7EnreAhN+ZZMvYllK/zDeIFk+5ap2nrj8/9A=
 =b1tp
 -----END PGP SIGNATURE-----
gpgsig -----BEGIN PGP SIGNATURE-----
 
 iQIzBAABCAAdFiEE1508oLYUKainYFJakD7OEIo53t0FAmHv7oIACgkQkD7OEIo5
 3t2qVw//YPSUAdcW3+MSFJLobheMB/tdycNUd3xoyTYcDQJPmyuoVBrsjibCpojK
 aifZfEqP9r2PLplJIAiS/7Z7F5DixdZ//KBOcHHJWBeIxCtEEPnk/pT9n4bDBx8w
 mGPajpq7JFail0oktmotx+xLHjnK1YdO0XXXOs1Haqz1/TB8OfMzVSKfWv/zI4eT
 ovsGIUiSLuVeOHl1QBHIBoerfyCHegYZf1B00cp9vMDwzIzMFY1oAzSMu//nGW2i
 4hqWMt4y2wPJz9ez0o5sBtLxj91fZGeqAEuvVNb2IkUjtclJpGbLnXXL6LtIqTHq
 ZH+HXNehEzVDtisq1mfSfczFa4Ma7bwFaizcOB8uuc9w8S2r1mxPSRv3u1CEpCIh
 leOPPXdlGlJ4jbOeV7IPj5Hie3AdFBeX6Sd6ivtzmvWvPWVketRiUUKww4X0oi+6
 0/qSdLiE60meleDJa2dB8vMSG8JKk8Swx1FR/T3e53Q3JmU+wZmwHgfl51ou8Ofe
 W1GhycT3Sb8Ei1XmttxxfE4+aikSu2JpUAu8MnizGPPJX9VCRPFYjTv5aMYxlX02
 XQw2TB8xwusNfWs4I84002FTg2Q/hLgloe5wZQOhHICBfYDuKETGF2LcASpMld53
 jS0vm0pp+Jlj8K3faIcHu+KrMFB2DwhDEORiU0QGeZTobckUzOA=
 =vMwg
 -----END PGP SIGNATURE-----
Merge tag 'v1.51.0'
Synapse 1.51.0 (2022-01-25)
===========================
No significant changes since 1.51.0rc2.
Synapse 1.51.0 deprecates `webclient` listeners and non-HTTP(S) `web_client_location`s. Support for these will be removed in Synapse 1.53.0, at which point Synapse will not be capable of directly serving a web client for Matrix.
Synapse 1.51.0rc2 (2022-01-24)
==============================
Bugfixes
--------
- Fix a bug introduced in Synapse 1.40.0 that caused Synapse to fail to process incoming federation traffic after handling a large amount of events in a v1 room. ([\#11806](https://github.com/matrix-org/synapse/issues/11806 ))
Synapse 1.51.0rc1 (2022-01-21)
==============================
Features
--------
- Add `track_puppeted_user_ips` config flag to record client IP addresses against puppeted users, and include the puppeted users in monthly active user counts. ([\#11561](https://github.com/matrix-org/synapse/issues/11561 ), [\#11749](https://github.com/matrix-org/synapse/issues/11749 ), [\#11757](https://github.com/matrix-org/synapse/issues/11757 ))
- Include whether the requesting user has participated in a thread when generating a summary for [MSC3440](https://github.com/matrix-org/matrix-doc/pull/3440 ). ([\#11577](https://github.com/matrix-org/synapse/issues/11577 ))
- Return an `M_FORBIDDEN` error code instead of `M_UNKNOWN` when a spam checker module prevents a user from creating a room. ([\#11672](https://github.com/matrix-org/synapse/issues/11672 ))
- Add a flag to the `synapse_review_recent_signups` script to ignore and filter appservice users. ([\#11675](https://github.com/matrix-org/synapse/issues/11675 ), [\#11770](https://github.com/matrix-org/synapse/issues/11770 ))
Bugfixes
--------
- Fix a long-standing issue which could cause Synapse to incorrectly accept data in the unsigned field of events
  received over federation. ([\#11530](https://github.com/matrix-org/synapse/issues/11530 ))
- Fix a long-standing bug where Synapse wouldn't cache a response indicating that a remote user has no devices. ([\#11587](https://github.com/matrix-org/synapse/issues/11587 ))
- Fix an error that occurs whilst trying to get the federation status of a destination server that was working normally. This admin API was newly introduced in Synapse v1.49.0. ([\#11593](https://github.com/matrix-org/synapse/issues/11593 ))
- Fix bundled aggregations not being included in the `/sync` response, per [MSC2675](https://github.com/matrix-org/matrix-doc/pull/2675 ). ([\#11612](https://github.com/matrix-org/synapse/issues/11612 ), [\#11659](https://github.com/matrix-org/synapse/issues/11659 ), [\#11791](https://github.com/matrix-org/synapse/issues/11791 ))
- Fix the `/_matrix/client/v1/room/{roomId}/hierarchy` endpoint returning incorrect fields which have been present since Synapse 1.49.0. ([\#11667](https://github.com/matrix-org/synapse/issues/11667 ))
- Fix preview of some GIF URLs (like tenor.com). Contributed by Philippe Daouadi. ([\#11669](https://github.com/matrix-org/synapse/issues/11669 ))
- Fix a bug where only the first 50 rooms from a space were returned from the `/hierarchy` API. This has existed since the introduction of the API in Synapse v1.41.0. ([\#11695](https://github.com/matrix-org/synapse/issues/11695 ))
- Fix a bug introduced in Synapse v1.18.0 where password reset and address validation emails would not be sent if their subject was configured to use the 'app' template variable. Contributed by @br4nnigan. ([\#11710](https://github.com/matrix-org/synapse/issues/11710 ), [\#11745](https://github.com/matrix-org/synapse/issues/11745 ))
- Make the 'List Rooms' Admin API sort stable. Contributed by Daniël Sonck. ([\#11737](https://github.com/matrix-org/synapse/issues/11737 ))
- Fix a long-standing bug where space hierarchy over federation would only work correctly some of the time. ([\#11775](https://github.com/matrix-org/synapse/issues/11775 ))
- Fix a bug introduced in Synapse v1.46.0 that prevented `on_logged_out` module callbacks from being correctly awaited by Synapse. ([\#11786](https://github.com/matrix-org/synapse/issues/11786 ))
Improved Documentation
----------------------
- Warn against using a Let's Encrypt certificate for TLS/DTLS TURN server client connections, and suggest using ZeroSSL certificate instead. This works around client-side connectivity errors caused by WebRTC libraries that reject Let's Encrypt certificates. Contibuted by @AndrewFerr. ([\#11686](https://github.com/matrix-org/synapse/issues/11686 ))
- Document the new `SYNAPSE_TEST_PERSIST_SQLITE_DB` environment variable in the contributing guide. ([\#11715](https://github.com/matrix-org/synapse/issues/11715 ))
- Document that the minimum supported PostgreSQL version is now 10. ([\#11725](https://github.com/matrix-org/synapse/issues/11725 ))
- Fix typo in demo docs: differnt. ([\#11735](https://github.com/matrix-org/synapse/issues/11735 ))
- Update room spec URL in config files. ([\#11739](https://github.com/matrix-org/synapse/issues/11739 ))
- Mention `python3-venv` and `libpq-dev` dependencies in the contribution guide. ([\#11740](https://github.com/matrix-org/synapse/issues/11740 ))
- Update documentation for configuring login with Facebook. ([\#11755](https://github.com/matrix-org/synapse/issues/11755 ))
- Update installation instructions to note that Python 3.6 is no longer supported. ([\#11781](https://github.com/matrix-org/synapse/issues/11781 ))
Deprecations and Removals
-------------------------
- Remove the unstable `/send_relation` endpoint. ([\#11682](https://github.com/matrix-org/synapse/issues/11682 ))
- Remove `python_twisted_reactor_pending_calls` Prometheus metric. ([\#11724](https://github.com/matrix-org/synapse/issues/11724 ))
- Remove the `password_hash` field from the response dictionaries of the [Users Admin API](https://matrix-org.github.io/synapse/latest/admin_api/user_admin_api.html ). ([\#11576](https://github.com/matrix-org/synapse/issues/11576 ))
- **Deprecate support for `webclient` listeners and non-HTTP(S) `web_client_location` configuration. ([\#11774](https://github.com/matrix-org/synapse/issues/11774 ), [\#11783](https://github.com/matrix-org/synapse/issues/11783 ))**
Internal Changes
----------------
- Run `pyupgrade --py37-plus --keep-percent-format` on Synapse. ([\#11685](https://github.com/matrix-org/synapse/issues/11685 ))
- Use buildkit's cache feature to speed up docker builds. ([\#11691](https://github.com/matrix-org/synapse/issues/11691 ))
- Use `auto_attribs` and native type hints for attrs classes. ([\#11692](https://github.com/matrix-org/synapse/issues/11692 ), [\#11768](https://github.com/matrix-org/synapse/issues/11768 ))
- Remove debug logging for #4422 , which has been closed since Synapse 0.99. ([\#11693](https://github.com/matrix-org/synapse/issues/11693 ))
- Remove fallback code for Python 2. ([\#11699](https://github.com/matrix-org/synapse/issues/11699 ))
- Add a test for [an edge case](https://github.com/matrix-org/synapse/pull/11532#discussion_r769104461 ) in the `/sync` logic. ([\#11701](https://github.com/matrix-org/synapse/issues/11701 ))
- Add the option to write SQLite test dbs to disk when running tests. ([\#11702](https://github.com/matrix-org/synapse/issues/11702 ))
- Improve Complement test output for Gitub Actions. ([\#11707](https://github.com/matrix-org/synapse/issues/11707 ))
- Fix docstring on `add_account_data_for_user`. ([\#11716](https://github.com/matrix-org/synapse/issues/11716 ))
- Complement environment variable name change and update `.gitignore`. ([\#11718](https://github.com/matrix-org/synapse/issues/11718 ))
- Simplify calculation of Prometheus metrics for garbage collection. ([\#11723](https://github.com/matrix-org/synapse/issues/11723 ))
- Improve accuracy of `python_twisted_reactor_tick_time` Prometheus metric. ([\#11724](https://github.com/matrix-org/synapse/issues/11724 ), [\#11771](https://github.com/matrix-org/synapse/issues/11771 ))
- Minor efficiency improvements when inserting many values into the database. ([\#11742](https://github.com/matrix-org/synapse/issues/11742 ))
- Invite PR authors to give themselves credit in the changelog. ([\#11744](https://github.com/matrix-org/synapse/issues/11744 ))
- Add optional debugging to investigate [issue 8631](https://github.com/matrix-org/synapse/issues/8631 ). ([\#11760](https://github.com/matrix-org/synapse/issues/11760 ))
- Remove `log_function` utility function and its uses. ([\#11761](https://github.com/matrix-org/synapse/issues/11761 ))
- Add a unit test that checks both `client` and `webclient` resources will function when simultaneously enabled. ([\#11765](https://github.com/matrix-org/synapse/issues/11765 ))
- Allow overriding complement commit using `COMPLEMENT_REF`. ([\#11766](https://github.com/matrix-org/synapse/issues/11766 ))
- Add some comments and type annotations for `_update_outliers_txn`. ([\#11776](https://github.com/matrix-org/synapse/issues/11776 )) 
							
						 
						
							2022-01-25 12:35:11 +00:00  
				
					
						
							
							
								 
						
							
							
								105fbce55c 
								
									
								
							
								 
							
						 
						
							
							
								
								Point to upgrade notes in changelog  
							
							
							
						 
						
							2022-01-25 12:28:30 +00:00  
				
					
						
							
							
								 
						
							
							
								0d6cfea9b8 
								
									
								
							
								 
							
						 
						
							
							
								
								Add admin API to reset connection timeouts for remote server ( #11639 )  
							
							... 
							
							
							
							* Fix get federation status of destination if no error occured 
							
						 
						
							2022-01-25 12:06:29 +00:00  
				
					
						
							
							
								 
						
							
							
								343d4f13d8 
								
									
								
							
								 
							
						 
						
							
							
								
								Correct version number  
							
							
							
						 
						
							2022-01-25 11:42:32 +00:00