4ac3a8c5dc 
								
									
								
							
								 
							
						 
						
							
							
								
								Fix a bug in the joined_rooms admin API ( #8643 )  
							
							... 
							
							
							
							If the user was not in any rooms then the API returned the same error
as if the user did not exist. 
							
						 
						
							2020-10-26 12:25:48 -04:00  
				
					
						
							
							
								 
						
							
							
								cf9a17a2b3 
								
							
								 
							
						 
						
							
							
								
								Synapse 1.22.0rc2 (2020-10-26)  
							
							... 
							
							
							
							==============================
 
 Bugfixes
 --------
 
 - Fix bugs where ephemeral events were not sent to appservices. Broke in v1.22.0rc1. ([\#8648](https://github.com/matrix-org/synapse/issues/8648 ), [\#8656](https://github.com/matrix-org/synapse/issues/8656 ))
 - Fix `user_daily_visits` table to not have duplicate rows per user/device due to multiple user agents. Broke in v1.22.0rc1. ([\#8654](https://github.com/matrix-org/synapse/issues/8654 ))
 -----BEGIN PGP SIGNATURE-----
 
 iQFEBAABCgAuFiEEBTGR3/RnAzBGUif3pULk7RsPrAkFAl+W6QIQHGVyaWtAbWF0
 cml4Lm9yZwAKCRClQuTtGw+sCR/EB/9Afs/QiqD7uJ7XtAASwlOxcpSrvB6xSMzU
 VIiYLrUSCvHe8SwcPG6nToy69hHmwLBPu9e8gvlQkOY4nJpW9VTGvhFcP5eCgeKd
 vDp+elVD6BPg+6S3RaI/F5hyQ7gn9qZ/WexkVixDkVs5eAL3gNlZcjw9RwaT9ei9
 fEOYlMi1CRSRzKVBPMEFCAvOpJJ8rA/iq4JK7+P0TplkhD+HydG0cYr6OoL7CmaD
 L/au565Ynp6o0hSpNpTFqW6C5W5JRvz/TyG9/N95h9+WqubZzsPPDUzh98B3eBoX
 43Wu9Qoc3mNamf0++HbHGUPI8dRV1gssxL01hs/iLUZz7CxXY+Ir
 =Z3sQ
 -----END PGP SIGNATURE-----
Merge tag 'v1.22.0rc2' into develop
Synapse 1.22.0rc2 (2020-10-26)
==============================
Bugfixes
--------
- Fix bugs where ephemeral events were not sent to appservices. Broke in v1.22.0rc1. ([\#8648](https://github.com/matrix-org/synapse/issues/8648 ), [\#8656](https://github.com/matrix-org/synapse/issues/8656 ))
- Fix `user_daily_visits` table to not have duplicate rows per user/device due to multiple user agents. Broke in v1.22.0rc1. ([\#8654](https://github.com/matrix-org/synapse/issues/8654 )) 
							
						 
						
							2020-10-26 15:23:13 +00:00  
				
					
						
							
							
								 
						
							
							
								191f2e5d5d 
								
							
								 
							
						 
						
							
							
								
								Fixup changelog  
							
							
							
						 
						
							2020-10-26 15:17:31 +00:00  
				
					
						
							
							
								 
						
							
							
								f40a4ba08e 
								
							
								 
							
						 
						
							
							
								
								Expand changelog entry  
							
							
							
						 
						
							2020-10-26 15:15:49 +00:00  
				
					
						
							
							
								 
						
							
							
								7a3adbd7af 
								
							
								 
							
						 
						
							
							
								
								1.22.0rc2  
							
							
							
						 
						
							2020-10-26 15:11:03 +00:00  
				
					
						
							
							
								 
						
							
							
								ff7f0e8a14 
								
							
								 
							
						 
						
							
							
								
								Merge branch 'release-v1.22.0' into develop  
							
							
							
						 
						
							2020-10-26 15:02:55 +00:00  
				
					
						
							
							
								 
						
							
							
								9e0f5a0ac4 
								
							
								 
							
						 
						
							
							
								
								Fix get|set_type_stream_id_for_appservice store functions ( #8648 )  
							
							
							
						 
						
							2020-10-26 15:00:56 +00:00  
				
					
						
							
							
								 
						
							
							
								e8dbbcb64c 
								
									
								
							
								 
							
						 
						
							
							
								
								Fix get|set_type_stream_id_for_appservice store functions ( #8648 )  
							
							
							
						 
						
							2020-10-26 10:51:33 -04:00  
				
					
						
							
							
								 
						
							
							
								73d8209694 
								
									
								
							
								 
							
						 
						
							
							
								
								Correct the package name in OpenID Connect install instructions ( #8634 )  
							
							... 
							
							
							
							The OpenID Connect install instructions suggested installing `synapse[oidc]`, but our PyPI package is called `matrix-synapse`. 
							
						 
						
							2020-10-26 14:45:33 +00:00  
				
					
						
							
							
								 
						
							
							
								913f8a06e4 
								
									
								
							
								 
							
						 
						
							
							
								
								Add field `total` to device list in admin API ( #8644 )  
							
							
							
						 
						
							2020-10-26 14:07:51 +00:00  
				
					
						
							
							
								 
						
							
							
								7b13780c54 
								
									
								
							
								 
							
						 
						
							
							
								
								Check status codes that profile handler returns ( #8580 )  
							
							... 
							
							
							
							Fixes  #8520 
Signed-off-by: Pavel Turinsky <pavel.turinsky@matfyz.cz>
Co-authored-by: Erik Johnston <erikj@jki.re> 
						
							2020-10-26 13:55:21 +00:00  
				
					
						
							
							
								 
						
							
							
								5eda018561 
								
									
								
							
								 
							
						 
						
							
							
								
								Properly handle presence events for application services. ( #8656 )  
							
							
							
						 
						
							2020-10-26 09:19:07 -04:00  
				
					
						
							
							
								 
						
							
							
								437a99fb99 
								
									
								
							
								 
							
						 
						
							
							
								
								Fix user_daily_visits to not have duplicate rows for UA. ( #8654 )  
							
							... 
							
							
							
							* Fix user_daily_visits to not have duplicate rows for UA.
Fixes  #8641 .
* Newsfile
* Fix typo.
Co-authored-by: Patrick Cloke <clokep@users.noreply.github.com> 
							
						 
						
							2020-10-26 13:16:32 +00:00  
				
					
						
							
							
								 
						
							
							
								2b7c180879 
								
									
								
							
								 
							
						 
						
							
							
								
								Start fewer opentracing spans ( #8640 )  
							
							... 
							
							
							
							#8567  started a span for every background process. This is good as it means all Synapse code that gets run should be in a span (unless in the sentinel logging context), but it means we generate about 15x the number of spans as we did previously.
This PR attempts to reduce that number by a) not starting one for send commands to Redis, and b) deferring starting background processes until after we're sure they're necessary.
I don't really know how much this will help. 
						
							2020-10-26 09:30:19 +00:00  
				
					
						
							
							
								 
						
							
							
								34a5696f93 
								
									
								
							
								 
							
						 
						
							
							
								
								Fix typos and spelling errors. ( #8639 )  
							
							
							
						 
						
							2020-10-23 12:38:40 -04:00  
				
					
						
							
							
								 
						
							
							
								c850dd9a8e 
								
									
								
							
								 
							
						 
						
							
							
								
								Fix handling of User-Agent headers with bad utf-8. ( #8632 )  
							
							
							
						 
						
							2020-10-23 17:12:59 +01:00  
				
					
						
							
							
								 
						
							
							
								db9ef792f0 
								
									
								
							
								 
							
						 
						
							
							
								
								Fix email notifications for invites without local state. ( #8627 )  
							
							... 
							
							
							
							This can happen if e.g. the room invited into is no longer on the
server (or if all users left the room). 
							
						 
						
							2020-10-23 10:41:32 +01:00  
				
					
						
							
							
								 
						
							
							
								f28756bb40 
								
							
								 
							
						 
						
							
							
								
								Changelog  
							
							
							
						 
						
							2020-10-22 18:33:02 +01:00  
				
					
						
							
							
								 
						
							
							
								4fb7a68a65 
								
							
								 
							
						 
						
							
							
								
								Correct the package name in authlib install instructions  
							
							
							
						 
						
							2020-10-22 18:25:58 +01:00  
				
					
						
							
							
								 
						
							
							
								054a6b9538 
								
							
								 
							
						 
						
							
							
								
								Synapse 1.22.0rc1 (2020-10-22)  
							
							... 
							
							
							
							==============================
 
 Features
 --------
 
 - Add a configuration option for always using the "userinfo endpoint" for OpenID Connect. This fixes support for some identity providers, e.g. GitLab. Contributed by Benjamin Koch. ([\#7658](https://github.com/matrix-org/synapse/issues/7658 ))
 - Add ability for `ThirdPartyEventRules` modules to query and manipulate whether a room is in the public rooms directory. ([\#8292](https://github.com/matrix-org/synapse/issues/8292 ), [\#8467](https://github.com/matrix-org/synapse/issues/8467 ))
 - Add support for olm fallback keys ([MSC2732](https://github.com/matrix-org/matrix-doc/pull/2732 )). ([\#8312](https://github.com/matrix-org/synapse/issues/8312 ), [\#8501](https://github.com/matrix-org/synapse/issues/8501 ))
 - Add support for running background tasks in a separate worker process. ([\#8369](https://github.com/matrix-org/synapse/issues/8369 ), [\#8458](https://github.com/matrix-org/synapse/issues/8458 ), [\#8489](https://github.com/matrix-org/synapse/issues/8489 ), [\#8513](https://github.com/matrix-org/synapse/issues/8513 ), [\#8544](https://github.com/matrix-org/synapse/issues/8544 ), [\#8599](https://github.com/matrix-org/synapse/issues/8599 ))
 - Add support for device dehydration ([MSC2697](https://github.com/matrix-org/matrix-doc/pull/2697 )). ([\#8380](https://github.com/matrix-org/synapse/issues/8380 ))
 - Add support for [MSC2409](https://github.com/matrix-org/matrix-doc/pull/2409 ), which allows sending typing, read receipts, and presence events to appservices. ([\#8437](https://github.com/matrix-org/synapse/issues/8437 ), [\#8590](https://github.com/matrix-org/synapse/issues/8590 ))
 - Change default room version to "6", per [MSC2788](https://github.com/matrix-org/matrix-doc/pull/2788 ). ([\#8461](https://github.com/matrix-org/synapse/issues/8461 ))
 - Add the ability to send non-membership events into a room via the `ModuleApi`. ([\#8479](https://github.com/matrix-org/synapse/issues/8479 ))
 - Increase default upload size limit from 10M to 50M. Contributed by @Akkowicz. ([\#8502](https://github.com/matrix-org/synapse/issues/8502 ))
 - Add support for modifying event content in `ThirdPartyRules` modules. ([\#8535](https://github.com/matrix-org/synapse/issues/8535 ), [\#8564](https://github.com/matrix-org/synapse/issues/8564 ))
 
 Bugfixes
 --------
 
 - Fix a longstanding bug where invalid ignored users in account data could break clients. ([\#8454](https://github.com/matrix-org/synapse/issues/8454 ))
 - Fix a bug where backfilling a room with an event that was missing the `redacts` field would break. ([\#8457](https://github.com/matrix-org/synapse/issues/8457 ))
 - Don't attempt to respond to some requests if the client has already disconnected. ([\#8465](https://github.com/matrix-org/synapse/issues/8465 ))
 - Fix message duplication if something goes wrong after persisting the event. ([\#8476](https://github.com/matrix-org/synapse/issues/8476 ))
 - Fix incremental sync returning an incorrect `prev_batch` token in timeline section, which when used to paginate returned events that were included in the incremental sync. Broken since v0.16.0. ([\#8486](https://github.com/matrix-org/synapse/issues/8486 ))
 - Expose the `uk.half-shot.msc2778.login.application_service` to clients from the login API. This feature was added in v1.21.0, but was not exposed as a potential login flow. ([\#8504](https://github.com/matrix-org/synapse/issues/8504 ))
 - Fix error code for `/profile/{userId}/displayname` to be `M_BAD_JSON`. ([\#8517](https://github.com/matrix-org/synapse/issues/8517 ))
 - Fix a bug introduced in v1.7.0 that could cause Synapse to insert values from non-state `m.room.retention` events into the `room_retention` database table. ([\#8527](https://github.com/matrix-org/synapse/issues/8527 ))
 - Fix not sending events over federation when using sharded event writers. ([\#8536](https://github.com/matrix-org/synapse/issues/8536 ))
 - Fix a long standing bug where email notifications for encrypted messages were blank. ([\#8545](https://github.com/matrix-org/synapse/issues/8545 ))
 - Fix increase in the number of `There was no active span...` errors logged when using OpenTracing. ([\#8567](https://github.com/matrix-org/synapse/issues/8567 ))
 - Fix a bug that prevented errors encountered during execution of the `synapse_port_db` from being correctly printed. ([\#8585](https://github.com/matrix-org/synapse/issues/8585 ))
 - Fix appservice transactions to only include a maximum of 100 persistent and 100 ephemeral events. ([\#8606](https://github.com/matrix-org/synapse/issues/8606 ))
 
 Updates to the Docker image
 ---------------------------
 
 - Added multi-arch support (arm64,arm/v7) for the docker images. Contributed by @maquis196. ([\#7921](https://github.com/matrix-org/synapse/issues/7921 ))
 - Add support for passing commandline args to the synapse process. Contributed by @samuel-p. ([\#8390](https://github.com/matrix-org/synapse/issues/8390 ))
 
 Improved Documentation
 ----------------------
 
 - Update the directions for using the manhole with coroutines. ([\#8462](https://github.com/matrix-org/synapse/issues/8462 ))
 - Improve readme by adding new shield.io badges. ([\#8493](https://github.com/matrix-org/synapse/issues/8493 ))
 - Added note about docker in manhole.md regarding which ip address to bind to. Contributed by @Maquis196. ([\#8526](https://github.com/matrix-org/synapse/issues/8526 ))
 - Document the new behaviour of the `allowed_lifetime_min` and `allowed_lifetime_max` settings in the room retention configuration. ([\#8529](https://github.com/matrix-org/synapse/issues/8529 ))
 
 Deprecations and Removals
 -------------------------
 
 - Drop unused `device_max_stream_id` table. ([\#8589](https://github.com/matrix-org/synapse/issues/8589 ))
 
 Internal Changes
 ----------------
 
 - Check for unreachable code with mypy. ([\#8432](https://github.com/matrix-org/synapse/issues/8432 ))
 - Add unit test for event persister sharding. ([\#8433](https://github.com/matrix-org/synapse/issues/8433 ))
 - Allow events to be sent to clients sooner when using sharded event persisters. ([\#8439](https://github.com/matrix-org/synapse/issues/8439 ), [\#8488](https://github.com/matrix-org/synapse/issues/8488 ), [\#8496](https://github.com/matrix-org/synapse/issues/8496 ), [\#8499](https://github.com/matrix-org/synapse/issues/8499 ))
 - Configure `public_baseurl` when using demo scripts. ([\#8443](https://github.com/matrix-org/synapse/issues/8443 ))
 - Add SQL logging on queries that happen during startup. ([\#8448](https://github.com/matrix-org/synapse/issues/8448 ))
 - Speed up unit tests when using PostgreSQL. ([\#8450](https://github.com/matrix-org/synapse/issues/8450 ))
 - Remove redundant database loads of stream_ordering for events we already have. ([\#8452](https://github.com/matrix-org/synapse/issues/8452 ))
 - Reduce inconsistencies between codepaths for membership and non-membership events. ([\#8463](https://github.com/matrix-org/synapse/issues/8463 ))
 - Combine `SpamCheckerApi` with the more generic `ModuleApi`. ([\#8464](https://github.com/matrix-org/synapse/issues/8464 ))
 - Additional testing for `ThirdPartyEventRules`. ([\#8468](https://github.com/matrix-org/synapse/issues/8468 ))
 - Add `-d` option to `./scripts-dev/lint.sh` to lint files that have changed since the last git commit. ([\#8472](https://github.com/matrix-org/synapse/issues/8472 ))
 - Unblacklist some sytests. ([\#8474](https://github.com/matrix-org/synapse/issues/8474 ))
 - Include the log level in the phone home stats. ([\#8477](https://github.com/matrix-org/synapse/issues/8477 ))
 - Remove outdated sphinx documentation, scripts and configuration. ([\#8480](https://github.com/matrix-org/synapse/issues/8480 ))
 - Clarify error message when plugin config parsers raise an error. ([\#8492](https://github.com/matrix-org/synapse/issues/8492 ))
 - Remove the deprecated `Handlers` object. ([\#8494](https://github.com/matrix-org/synapse/issues/8494 ))
 - Fix a threadsafety bug in unit tests. ([\#8497](https://github.com/matrix-org/synapse/issues/8497 ))
 - Add user agent to user_daily_visits table. ([\#8503](https://github.com/matrix-org/synapse/issues/8503 ))
 - Add type hints to various parts of the code base. ([\#8407](https://github.com/matrix-org/synapse/issues/8407 ), [\#8505](https://github.com/matrix-org/synapse/issues/8505 ), [\#8507](https://github.com/matrix-org/synapse/issues/8507 ), [\#8547](https://github.com/matrix-org/synapse/issues/8547 ), [\#8562](https://github.com/matrix-org/synapse/issues/8562 ), [\#8609](https://github.com/matrix-org/synapse/issues/8609 ))
 - Remove unused code from the test framework. ([\#8514](https://github.com/matrix-org/synapse/issues/8514 ))
 - Apply some internal fixes to the `HomeServer` class to make its code more idiomatic and statically-verifiable. ([\#8515](https://github.com/matrix-org/synapse/issues/8515 ))
 - Factor out common code between `RoomMemberHandler._locally_reject_invite` and `EventCreationHandler.create_event`. ([\#8537](https://github.com/matrix-org/synapse/issues/8537 ))
 - Improve database performance by executing more queries without starting transactions. ([\#8542](https://github.com/matrix-org/synapse/issues/8542 ))
 - Rename `Cache` to `DeferredCache`, to better reflect its purpose. ([\#8548](https://github.com/matrix-org/synapse/issues/8548 ))
 - Move metric registration code down into `LruCache`. ([\#8561](https://github.com/matrix-org/synapse/issues/8561 ), [\#8591](https://github.com/matrix-org/synapse/issues/8591 ))
 - Replace `DeferredCache` with the lighter-weight `LruCache` where possible. ([\#8563](https://github.com/matrix-org/synapse/issues/8563 ))
 - Add virtualenv-generated folders to `.gitignore`. ([\#8566](https://github.com/matrix-org/synapse/issues/8566 ))
 - Add `get_immediate` method to `DeferredCache`. ([\#8568](https://github.com/matrix-org/synapse/issues/8568 ))
 - Fix mypy not properly checking across the codebase, additionally, fix a typing assertion error in `handlers/auth.py`. ([\#8569](https://github.com/matrix-org/synapse/issues/8569 ))
 - Fix `synmark` benchmark runner. ([\#8571](https://github.com/matrix-org/synapse/issues/8571 ))
 - Modify `DeferredCache.get()` to return `Deferred`s instead of `ObservableDeferred`s. ([\#8572](https://github.com/matrix-org/synapse/issues/8572 ))
 - Adjust a protocol-type definition to fit `sqlite3` assertions. ([\#8577](https://github.com/matrix-org/synapse/issues/8577 ))
 - Support macOS on the `synmark` benchmark runner. ([\#8578](https://github.com/matrix-org/synapse/issues/8578 ))
 - Update `mypy` static type checker to 0.790. ([\#8583](https://github.com/matrix-org/synapse/issues/8583 ), [\#8600](https://github.com/matrix-org/synapse/issues/8600 ))
 - Re-organize the structured logging code to separate the TCP transport handling from the JSON formatting. ([\#8587](https://github.com/matrix-org/synapse/issues/8587 ))
 - Remove extraneous unittest logging decorators from unit tests. ([\#8592](https://github.com/matrix-org/synapse/issues/8592 ))
 - Minor optimisations in caching code. ([\#8593](https://github.com/matrix-org/synapse/issues/8593 ), [\#8594](https://github.com/matrix-org/synapse/issues/8594 ))
 -----BEGIN PGP SIGNATURE-----
 
 iQFEBAABCgAuFiEEBTGR3/RnAzBGUif3pULk7RsPrAkFAl+RfFAQHGVyaWtAbWF0
 cml4Lm9yZwAKCRClQuTtGw+sCZI4CACibRDTo+DFIp787ZMErW0xFc3S8DOA6K4u
 G8J2GCrBT0pfWAi7jqfQO9GySlvS5ixqbWYxud9jG0elXtnVgjIcbToSCYvNFxzH
 TDaQAaOwFVe/7fhZG6TvO2EcAXYXNfoqQKwc8xvTOcBOhObfLAzchV6t7mRTRYE4
 +C3kM8BUJUnSp+OAY0zxRrUIVjX4W280BQ/+UxvPBLIi0IUQz/BufvTtgEhRBb6B
 eK2qjDMTud3/WAzM/TYDoA/LmdAcFCogfkRRHYqDPw0gUIXm1tdHyLWdgHoV+WhX
 6p/kacnKxqonKW5/UrqheYT8J0SMA1AlkSm2niy/K+Tde3Nga+Sw
 =TLb5
 -----END PGP SIGNATURE-----
Merge tag 'v1.22.0rc1' into develop
Synapse 1.22.0rc1 (2020-10-22)
==============================
Features
--------
- Add a configuration option for always using the "userinfo endpoint" for OpenID Connect. This fixes support for some identity providers, e.g. GitLab. Contributed by Benjamin Koch. ([\#7658](https://github.com/matrix-org/synapse/issues/7658 ))
- Add ability for `ThirdPartyEventRules` modules to query and manipulate whether a room is in the public rooms directory. ([\#8292](https://github.com/matrix-org/synapse/issues/8292 ), [\#8467](https://github.com/matrix-org/synapse/issues/8467 ))
- Add support for olm fallback keys ([MSC2732](https://github.com/matrix-org/matrix-doc/pull/2732 )). ([\#8312](https://github.com/matrix-org/synapse/issues/8312 ), [\#8501](https://github.com/matrix-org/synapse/issues/8501 ))
- Add support for running background tasks in a separate worker process. ([\#8369](https://github.com/matrix-org/synapse/issues/8369 ), [\#8458](https://github.com/matrix-org/synapse/issues/8458 ), [\#8489](https://github.com/matrix-org/synapse/issues/8489 ), [\#8513](https://github.com/matrix-org/synapse/issues/8513 ), [\#8544](https://github.com/matrix-org/synapse/issues/8544 ), [\#8599](https://github.com/matrix-org/synapse/issues/8599 ))
- Add support for device dehydration ([MSC2697](https://github.com/matrix-org/matrix-doc/pull/2697 )). ([\#8380](https://github.com/matrix-org/synapse/issues/8380 ))
- Add support for [MSC2409](https://github.com/matrix-org/matrix-doc/pull/2409 ), which allows sending typing, read receipts, and presence events to appservices. ([\#8437](https://github.com/matrix-org/synapse/issues/8437 ), [\#8590](https://github.com/matrix-org/synapse/issues/8590 ))
- Change default room version to "6", per [MSC2788](https://github.com/matrix-org/matrix-doc/pull/2788 ). ([\#8461](https://github.com/matrix-org/synapse/issues/8461 ))
- Add the ability to send non-membership events into a room via the `ModuleApi`. ([\#8479](https://github.com/matrix-org/synapse/issues/8479 ))
- Increase default upload size limit from 10M to 50M. Contributed by @Akkowicz. ([\#8502](https://github.com/matrix-org/synapse/issues/8502 ))
- Add support for modifying event content in `ThirdPartyRules` modules. ([\#8535](https://github.com/matrix-org/synapse/issues/8535 ), [\#8564](https://github.com/matrix-org/synapse/issues/8564 ))
Bugfixes
--------
- Fix a longstanding bug where invalid ignored users in account data could break clients. ([\#8454](https://github.com/matrix-org/synapse/issues/8454 ))
- Fix a bug where backfilling a room with an event that was missing the `redacts` field would break. ([\#8457](https://github.com/matrix-org/synapse/issues/8457 ))
- Don't attempt to respond to some requests if the client has already disconnected. ([\#8465](https://github.com/matrix-org/synapse/issues/8465 ))
- Fix message duplication if something goes wrong after persisting the event. ([\#8476](https://github.com/matrix-org/synapse/issues/8476 ))
- Fix incremental sync returning an incorrect `prev_batch` token in timeline section, which when used to paginate returned events that were included in the incremental sync. Broken since v0.16.0. ([\#8486](https://github.com/matrix-org/synapse/issues/8486 ))
- Expose the `uk.half-shot.msc2778.login.application_service` to clients from the login API. This feature was added in v1.21.0, but was not exposed as a potential login flow. ([\#8504](https://github.com/matrix-org/synapse/issues/8504 ))
- Fix error code for `/profile/{userId}/displayname` to be `M_BAD_JSON`. ([\#8517](https://github.com/matrix-org/synapse/issues/8517 ))
- Fix a bug introduced in v1.7.0 that could cause Synapse to insert values from non-state `m.room.retention` events into the `room_retention` database table. ([\#8527](https://github.com/matrix-org/synapse/issues/8527 ))
- Fix not sending events over federation when using sharded event writers. ([\#8536](https://github.com/matrix-org/synapse/issues/8536 ))
- Fix a long standing bug where email notifications for encrypted messages were blank. ([\#8545](https://github.com/matrix-org/synapse/issues/8545 ))
- Fix increase in the number of `There was no active span...` errors logged when using OpenTracing. ([\#8567](https://github.com/matrix-org/synapse/issues/8567 ))
- Fix a bug that prevented errors encountered during execution of the `synapse_port_db` from being correctly printed. ([\#8585](https://github.com/matrix-org/synapse/issues/8585 ))
- Fix appservice transactions to only include a maximum of 100 persistent and 100 ephemeral events. ([\#8606](https://github.com/matrix-org/synapse/issues/8606 ))
Updates to the Docker image
---------------------------
- Added multi-arch support (arm64,arm/v7) for the docker images. Contributed by @maquis196. ([\#7921](https://github.com/matrix-org/synapse/issues/7921 ))
- Add support for passing commandline args to the synapse process. Contributed by @samuel-p. ([\#8390](https://github.com/matrix-org/synapse/issues/8390 ))
Improved Documentation
----------------------
- Update the directions for using the manhole with coroutines. ([\#8462](https://github.com/matrix-org/synapse/issues/8462 ))
- Improve readme by adding new shield.io badges. ([\#8493](https://github.com/matrix-org/synapse/issues/8493 ))
- Added note about docker in manhole.md regarding which ip address to bind to. Contributed by @Maquis196. ([\#8526](https://github.com/matrix-org/synapse/issues/8526 ))
- Document the new behaviour of the `allowed_lifetime_min` and `allowed_lifetime_max` settings in the room retention configuration. ([\#8529](https://github.com/matrix-org/synapse/issues/8529 ))
Deprecations and Removals
-------------------------
- Drop unused `device_max_stream_id` table. ([\#8589](https://github.com/matrix-org/synapse/issues/8589 ))
Internal Changes
----------------
- Check for unreachable code with mypy. ([\#8432](https://github.com/matrix-org/synapse/issues/8432 ))
- Add unit test for event persister sharding. ([\#8433](https://github.com/matrix-org/synapse/issues/8433 ))
- Allow events to be sent to clients sooner when using sharded event persisters. ([\#8439](https://github.com/matrix-org/synapse/issues/8439 ), [\#8488](https://github.com/matrix-org/synapse/issues/8488 ), [\#8496](https://github.com/matrix-org/synapse/issues/8496 ), [\#8499](https://github.com/matrix-org/synapse/issues/8499 ))
- Configure `public_baseurl` when using demo scripts. ([\#8443](https://github.com/matrix-org/synapse/issues/8443 ))
- Add SQL logging on queries that happen during startup. ([\#8448](https://github.com/matrix-org/synapse/issues/8448 ))
- Speed up unit tests when using PostgreSQL. ([\#8450](https://github.com/matrix-org/synapse/issues/8450 ))
- Remove redundant database loads of stream_ordering for events we already have. ([\#8452](https://github.com/matrix-org/synapse/issues/8452 ))
- Reduce inconsistencies between codepaths for membership and non-membership events. ([\#8463](https://github.com/matrix-org/synapse/issues/8463 ))
- Combine `SpamCheckerApi` with the more generic `ModuleApi`. ([\#8464](https://github.com/matrix-org/synapse/issues/8464 ))
- Additional testing for `ThirdPartyEventRules`. ([\#8468](https://github.com/matrix-org/synapse/issues/8468 ))
- Add `-d` option to `./scripts-dev/lint.sh` to lint files that have changed since the last git commit. ([\#8472](https://github.com/matrix-org/synapse/issues/8472 ))
- Unblacklist some sytests. ([\#8474](https://github.com/matrix-org/synapse/issues/8474 ))
- Include the log level in the phone home stats. ([\#8477](https://github.com/matrix-org/synapse/issues/8477 ))
- Remove outdated sphinx documentation, scripts and configuration. ([\#8480](https://github.com/matrix-org/synapse/issues/8480 ))
- Clarify error message when plugin config parsers raise an error. ([\#8492](https://github.com/matrix-org/synapse/issues/8492 ))
- Remove the deprecated `Handlers` object. ([\#8494](https://github.com/matrix-org/synapse/issues/8494 ))
- Fix a threadsafety bug in unit tests. ([\#8497](https://github.com/matrix-org/synapse/issues/8497 ))
- Add user agent to user_daily_visits table. ([\#8503](https://github.com/matrix-org/synapse/issues/8503 ))
- Add type hints to various parts of the code base. ([\#8407](https://github.com/matrix-org/synapse/issues/8407 ), [\#8505](https://github.com/matrix-org/synapse/issues/8505 ), [\#8507](https://github.com/matrix-org/synapse/issues/8507 ), [\#8547](https://github.com/matrix-org/synapse/issues/8547 ), [\#8562](https://github.com/matrix-org/synapse/issues/8562 ), [\#8609](https://github.com/matrix-org/synapse/issues/8609 ))
- Remove unused code from the test framework. ([\#8514](https://github.com/matrix-org/synapse/issues/8514 ))
- Apply some internal fixes to the `HomeServer` class to make its code more idiomatic and statically-verifiable. ([\#8515](https://github.com/matrix-org/synapse/issues/8515 ))
- Factor out common code between `RoomMemberHandler._locally_reject_invite` and `EventCreationHandler.create_event`. ([\#8537](https://github.com/matrix-org/synapse/issues/8537 ))
- Improve database performance by executing more queries without starting transactions. ([\#8542](https://github.com/matrix-org/synapse/issues/8542 ))
- Rename `Cache` to `DeferredCache`, to better reflect its purpose. ([\#8548](https://github.com/matrix-org/synapse/issues/8548 ))
- Move metric registration code down into `LruCache`. ([\#8561](https://github.com/matrix-org/synapse/issues/8561 ), [\#8591](https://github.com/matrix-org/synapse/issues/8591 ))
- Replace `DeferredCache` with the lighter-weight `LruCache` where possible. ([\#8563](https://github.com/matrix-org/synapse/issues/8563 ))
- Add virtualenv-generated folders to `.gitignore`. ([\#8566](https://github.com/matrix-org/synapse/issues/8566 ))
- Add `get_immediate` method to `DeferredCache`. ([\#8568](https://github.com/matrix-org/synapse/issues/8568 ))
- Fix mypy not properly checking across the codebase, additionally, fix a typing assertion error in `handlers/auth.py`. ([\#8569](https://github.com/matrix-org/synapse/issues/8569 ))
- Fix `synmark` benchmark runner. ([\#8571](https://github.com/matrix-org/synapse/issues/8571 ))
- Modify `DeferredCache.get()` to return `Deferred`s instead of `ObservableDeferred`s. ([\#8572](https://github.com/matrix-org/synapse/issues/8572 ))
- Adjust a protocol-type definition to fit `sqlite3` assertions. ([\#8577](https://github.com/matrix-org/synapse/issues/8577 ))
- Support macOS on the `synmark` benchmark runner. ([\#8578](https://github.com/matrix-org/synapse/issues/8578 ))
- Update `mypy` static type checker to 0.790. ([\#8583](https://github.com/matrix-org/synapse/issues/8583 ), [\#8600](https://github.com/matrix-org/synapse/issues/8600 ))
- Re-organize the structured logging code to separate the TCP transport handling from the JSON formatting. ([\#8587](https://github.com/matrix-org/synapse/issues/8587 ))
- Remove extraneous unittest logging decorators from unit tests. ([\#8592](https://github.com/matrix-org/synapse/issues/8592 ))
- Minor optimisations in caching code. ([\#8593](https://github.com/matrix-org/synapse/issues/8593 ), [\#8594](https://github.com/matrix-org/synapse/issues/8594 )) 
							
						 
						
							2020-10-22 13:37:08 +01:00  
				
					
						
							
							
								 
						
							
							
								514a240aed 
								
									
								
							
								 
							
						 
						
							
							
								
								Remove unused OPTIONS handlers. ( #8621 )  
							
							... 
							
							
							
							The handling of OPTIONS requests was consolidated in #7534 , but the endpoint
specific handlers were not removed. 
							
						 
						
							2020-10-22 08:35:55 -04:00  
				
					
						
							
							
								 
						
							
							
								5065048110 
								
							
								 
							
						 
						
							
							
								
								Fixup changelog even more  
							
							
							
						 
						
							2020-10-22 13:25:22 +01:00  
				
					
						
							
							
								 
						
							
							
								88b8b8403c 
								
							
								 
							
						 
						
							
							
								
								Fixup changelog some more  
							
							
							
						 
						
							2020-10-22 13:19:37 +01:00  
				
					
						
							
							
								 
						
							
							
								b19b63e6b4 
								
									
								
							
								 
							
						 
						
							
							
								
								Don't 500 for invalid group IDs ( #8628 )  
							
							
							
						 
						
							2020-10-22 13:19:06 +01:00  
				
					
						
							
							
								 
						
							
							
								a622e1ed9f 
								
							
								 
							
						 
						
							
							
								
								Fixup changelog  
							
							
							
						 
						
							2020-10-22 13:12:22 +01:00  
				
					
						
							
							
								 
						
							
							
								ec0e9c4695 
								
							
								 
							
						 
						
							
							
								
								1.22.0rc1  
							
							
							
						 
						
							2020-10-22 13:08:42 +01:00  
				
					
						
							
							
								 
						
							
							
								a9f90fa73a 
								
									
								
							
								 
							
						 
						
							
							
								
								Type hints for RegistrationStore ( #8615 )  
							
							
							
						 
						
							2020-10-22 11:56:58 +01:00  
				
					
						
							
							
								 
						
							
							
								2ac908f377 
								
									
								
							
								 
							
						 
						
							
							
								
								Don't instansiate Requester directly ( #8614 )  
							
							
							
						 
						
							2020-10-22 10:11:06 +01:00  
				
					
						
							
							
								 
						
							
							
								b28aaeb3a5 
								
									
								
							
								 
							
						 
						
							
							
								
								Optimise CacheDescriptor ( #8594 )  
							
							... 
							
							
							
							don't bother constricting a CacheContext unless we need one. 
							
						 
						
							2020-10-21 22:57:45 +01:00  
				
					
						
							
							
								 
						
							
							
								15d5553d9e 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #8593  from matrix-org/rav/cache_hacking/3  
							
							... 
							
							
							
							Optimisation in DeferredCache.set 
							
						 
						
							2020-10-21 22:57:23 +01:00  
				
					
						
							
							
								 
						
							
							
								c13820bcee 
								
							
								 
							
						 
						
							
							
								
								fix failure case  
							
							
							
						 
						
							2020-10-21 18:54:53 +01:00  
				
					
						
							
							
								 
						
							
							
								2b3af01791 
								
							
								 
							
						 
						
							
							
								
								optimise DeferredCache.set  
							
							
							
						 
						
							2020-10-21 17:55:53 +01:00  
				
					
						
							
							
								 
						
							
							
								9146a8a691 
								
									
								
							
								 
							
						 
						
							
							
								
								Merge pull request  #8572  from matrix-org/rav/cache_hacking/2  
							
							... 
							
							
							
							Push some deferred wrangling down into DeferredCache 
							
						 
						
							2020-10-21 17:55:04 +01:00  
				
					
						
							
							
								 
						
							
							
								6d3905c7c7 
								
							
								 
							
						 
						
							
							
								
								Add some more tests  
							
							
							
						 
						
							2020-10-21 15:39:25 +01:00  
				
					
						
							
							
								 
						
							
							
								1f4269700c 
								
							
								 
							
						 
						
							
							
								
								Push some deferred wrangling down into DeferredCache  
							
							
							
						 
						
							2020-10-21 15:39:25 +01:00  
				
					
						
							
							
								 
						
							
							
								7b71695388 
								
							
								 
							
						 
						
							
							
								
								Combine the two sets of tests for CacheDescriptor  
							
							
							
						 
						
							2020-10-21 15:38:29 +01:00  
				
					
						
							
							
								 
						
							
							
								70259d8c8c 
								
									
								
							
								 
							
						 
						
							
							
								
								Limit AS transactions to 100 events ( #8606 )  
							
							... 
							
							
							
							* Limit AS transactions to 100 events
* Update changelog.d/8606.feature
Co-authored-by: Andrew Morgan <1342360+anoadragon453@users.noreply.github.com>
* Add tests
* Update synapse/appservice/scheduler.py
Co-authored-by: Andrew Morgan <1342360+anoadragon453@users.noreply.github.com> 
							
						 
						
							2020-10-21 15:36:53 +01:00  
				
					
						
							
							
								 
						
							
							
								20a67aa70d 
								
									
								
							
								 
							
						 
						
							
							
								
								Separate the TCP and terse JSON formatting code. ( #8587 )  
							
							... 
							
							
							
							This should (theoretically) allow for using the TCP code with a different output type
and make it easier to use the JSON code with files / console. 
							
						 
						
							2020-10-21 06:59:54 -04:00  
				
					
						
							
							
								 
						
							
							
								654cc9470e 
								
									
								
							
								 
							
						 
						
							
							
								
								Pin mypy-zope for compatibility with mypy. ( #8600 )  
							
							
							
						 
						
							2020-10-21 06:45:01 -04:00  
				
					
						
							
							
								 
						
							
							
								de5cafe980 
								
									
								
							
								 
							
						 
						
							
							
								
								Add type hints to profile and base handlers. ( #8609 )  
							
							
							
						 
						
							2020-10-21 06:44:31 -04:00  
				
					
						
							
							
								 
						
							
							
								9e0f22874f 
								
									
								
							
								 
							
						 
						
							
							
								
								Consistently use wrap_as_background_task in more places ( #8599 )  
							
							
							
						 
						
							2020-10-20 11:29:38 -04:00  
				
					
						
							
							
								 
						
							
							
								84c0e46cce 
								
									
								
							
								 
							
						 
						
							
							
								
								Update mypy to 0.790, and move dependencies to extras ( #8583 )  
							
							
							
						 
						
							2020-10-20 07:55:21 -04:00  
				
					
						
							
							
								 
						
							
							
								74f29284aa 
								
									
								
							
								 
							
						 
						
							
							
								
								Remove some extraneous @unittest.INFOs on unit tests ( #8592 )  
							
							
							
						 
						
							2020-10-20 11:49:15 +01:00  
				
					
						
							
							
								 
						
							
							
								a312e890f5 
								
									
								
							
								 
							
						 
						
							
							
								
								Cast errors generated during synapse_port_db to str ( #8585 )  
							
							... 
							
							
							
							I noticed in https://github.com/matrix-org/synapse/issues/8575  that the `end_error` variable in `synapse_port_db` is set to an `Exception`, even though later we expect it to be a `str`.
This PR simply casts an exception raised to a string. I'm doing this instead of having `end_error` be of type exception as we explicitly set `end_error` to a str here:
d25eb8f370/scripts/synapse_port_db (L542-L547) 
							
						 
						
							2020-10-20 11:47:24 +01:00  
				
					
						
							
							
								 
						
							
							
								626b8f0846 
								
									
								
							
								 
							
						 
						
							
							
								
								Move schema file for as_device_stream ( #8590 )  
							
							... 
							
							
							
							* Move schema file
* Add a .
* Add matching changelog entry
* Fix sqlite 
							
						 
						
							2020-10-20 10:18:55 +01:00  
				
					
						
							
							
								 
						
							
							
								96e7d3c4a0 
								
									
								
							
								 
							
						 
						
							
							
								
								Fix 'LruCache' object has no attribute '_on_resize' ( #8591 )  
							
							... 
							
							
							
							We need to make sure we are readu for the `set_cache_factor` callback. 
							
						 
						
							2020-10-19 21:13:50 +01:00  
				
					
						
							
							
								 
						
							
							
								34c20493b9 
								
									
								
							
								 
							
						 
						
							
							
								
								Drop unused `device_max_stream_id` table ( #8589 )  
							
							... 
							
							
							
							Signed-off-by: Vasilis Gerakaris <vasilis.gerakaris@navarino.gr> 
							
						 
						
							2020-10-19 19:06:54 +01:00  
				
					
						
							
							
								 
						
							
							
								21bb50ca3f 
								
									
								
							
								 
							
						 
						
							
							
								
								Fix mypy error: auth handler "checkpw" internal function type mismatch ( #8569 )  
							
							
							
						 
						
							2020-10-19 18:32:24 +01:00  
				
					
						
							
							
								 
						
							
							
								8f27b7fde1 
								
									
								
							
								 
							
						 
						
							
							
								
								Expose the experimental appservice login flow to clients. ( #8504 )  
							
							
							
						 
						
							2020-10-19 13:03:55 -04:00  
				
					
						
							
							
								 
						
							
							
								903d11c43a 
								
									
								
							
								 
							
						 
						
							
							
								
								Add `DeferredCache.get_immediate` method ( #8568 )  
							
							... 
							
							
							
							* Add `DeferredCache.get_immediate` method
A bunch of things that are currently calling `DeferredCache.get` are only
really interested in the result if it's completed. We can optimise and simplify
this case.
* Remove unused 'default' parameter to DeferredCache.get()
* another get_immediate instance 
							
						 
						
							2020-10-19 15:00:12 +01:00