Synapse 1.26.0rc1 (2021-01-20)
============================== This release brings a new schema version for Synapse and rolling back to a previous verious is not trivial. Please review [UPGRADE.rst](UPGRADE.rst) for more details on these changes and for general upgrade guidance. Features -------- - Add support for multiple SSO Identity Providers. ([\#9015](https://github.com/matrix-org/synapse/issues/9015), [\#9017](https://github.com/matrix-org/synapse/issues/9017), [\#9036](https://github.com/matrix-org/synapse/issues/9036), [\#9067](https://github.com/matrix-org/synapse/issues/9067), [\#9081](https://github.com/matrix-org/synapse/issues/9081), [\#9082](https://github.com/matrix-org/synapse/issues/9082), [\#9105](https://github.com/matrix-org/synapse/issues/9105), [\#9107](https://github.com/matrix-org/synapse/issues/9107), [\#9109](https://github.com/matrix-org/synapse/issues/9109), [\#9110](https://github.com/matrix-org/synapse/issues/9110), [\#9127](https://github.com/matrix-org/synapse/issues/9127), [\#9153](https://github.com/matrix-org/synapse/issues/9153), [\#9154](https://github.com/matrix-org/synapse/issues/9154), [\#9177](https://github.com/matrix-org/synapse/issues/9177)) - During user-interactive authentication via single-sign-on, give a better error if the user uses the wrong account on the SSO IdP. ([\#9091](https://github.com/matrix-org/synapse/issues/9091)) - Give the `public_baseurl` a default value, if it is not explicitly set in the configuration file. ([\#9159](https://github.com/matrix-org/synapse/issues/9159)) - Improve performance when calculating ignored users in large rooms. ([\#9024](https://github.com/matrix-org/synapse/issues/9024)) - Implement [MSC2176](https://github.com/matrix-org/matrix-doc/pull/2176) in an experimental room version. ([\#8984](https://github.com/matrix-org/synapse/issues/8984)) - Add an admin API for protecting local media from quarantine. ([\#9086](https://github.com/matrix-org/synapse/issues/9086)) - Remove a user's avatar URL and display name when deactivated with the Admin API. ([\#8932](https://github.com/matrix-org/synapse/issues/8932)) - Update `/_synapse/admin/v1/users/<user_id>/joined_rooms` to work for both local and remote users. ([\#8948](https://github.com/matrix-org/synapse/issues/8948)) - Add experimental support for handling to-device messages on worker processes. ([\#9042](https://github.com/matrix-org/synapse/issues/9042), [\#9043](https://github.com/matrix-org/synapse/issues/9043), [\#9044](https://github.com/matrix-org/synapse/issues/9044), [\#9130](https://github.com/matrix-org/synapse/issues/9130)) - Add experimental support for handling `/keys/claim` and `/room_keys` APIs on worker processes. ([\#9068](https://github.com/matrix-org/synapse/issues/9068)) - Add experimental support for handling `/devices` API on worker processes. ([\#9092](https://github.com/matrix-org/synapse/issues/9092)) - Add experimental support for moving off receipts and account data persistence off master. ([\#9104](https://github.com/matrix-org/synapse/issues/9104), [\#9166](https://github.com/matrix-org/synapse/issues/9166)) Bugfixes -------- - Fix a long-standing issue where an internal server error would occur when requesting a profile over federation that did not include a display name / avatar URL. ([\#9023](https://github.com/matrix-org/synapse/issues/9023)) - Fix a long-standing bug where some caches could grow larger than configured. ([\#9028](https://github.com/matrix-org/synapse/issues/9028)) - Fix error handling during insertion of client IPs into the database. ([\#9051](https://github.com/matrix-org/synapse/issues/9051)) - Fix bug where we didn't correctly record CPU time spent in `on_new_event` block. ([\#9053](https://github.com/matrix-org/synapse/issues/9053)) - Fix a minor bug which could cause confusing error messages from invalid configurations. ([\#9054](https://github.com/matrix-org/synapse/issues/9054)) - Fix incorrect exit code when there is an error at startup. ([\#9059](https://github.com/matrix-org/synapse/issues/9059)) - Fix `JSONDecodeError` spamming the logs when sending transactions to remote servers. ([\#9070](https://github.com/matrix-org/synapse/issues/9070)) - Fix "Failed to send request" errors when a client provides an invalid room alias. ([\#9071](https://github.com/matrix-org/synapse/issues/9071)) - Fix bugs in federation catchup logic that caused outbound federation to be delayed for large servers after start up. Introduced in v1.8.0 and v1.21.0. ([\#9114](https://github.com/matrix-org/synapse/issues/9114), [\#9116](https://github.com/matrix-org/synapse/issues/9116)) - Fix corruption of `pushers` data when a postgres bouncer is used. ([\#9117](https://github.com/matrix-org/synapse/issues/9117)) - Fix minor bugs in handling the `clientRedirectUrl` parameter for SSO login. ([\#9128](https://github.com/matrix-org/synapse/issues/9128)) - Fix "Unhandled error in Deferred: BodyExceededMaxSize" errors when .well-known files that are too large. ([\#9108](https://github.com/matrix-org/synapse/issues/9108)) - Fix "UnboundLocalError: local variable 'length' referenced before assignment" errors when the response body exceeds the expected size. This bug was introduced in v1.25.0. ([\#9145](https://github.com/matrix-org/synapse/issues/9145)) - Fix a long-standing bug "ValueError: invalid literal for int() with base 10" when `/publicRooms` is requested with an invalid `server` parameter. ([\#9161](https://github.com/matrix-org/synapse/issues/9161)) Improved Documentation ---------------------- - Add some extra docs for getting Synapse running on macOS. ([\#8997](https://github.com/matrix-org/synapse/issues/8997)) - Correct a typo in the `systemd-with-workers` documentation. ([\#9035](https://github.com/matrix-org/synapse/issues/9035)) - Correct a typo in `INSTALL.md`. ([\#9040](https://github.com/matrix-org/synapse/issues/9040)) - Add missing `user_mapping_provider` configuration to the Keycloak OIDC example. Contributed by @chris-ruecker. ([\#9057](https://github.com/matrix-org/synapse/issues/9057)) - Quote `pip install` packages when extras are used to avoid shells interpreting bracket characters. ([\#9151](https://github.com/matrix-org/synapse/issues/9151)) Deprecations and Removals ------------------------- - Remove broken and unmaintained `demo/webserver.py` script. ([\#9039](https://github.com/matrix-org/synapse/issues/9039)) Internal Changes ---------------- - Improve efficiency of large state resolutions. ([\#8868](https://github.com/matrix-org/synapse/issues/8868), [\#9029](https://github.com/matrix-org/synapse/issues/9029), [\#9115](https://github.com/matrix-org/synapse/issues/9115), [\#9118](https://github.com/matrix-org/synapse/issues/9118), [\#9124](https://github.com/matrix-org/synapse/issues/9124)) - Various clean-ups to the structured logging and logging context code. ([\#8939](https://github.com/matrix-org/synapse/issues/8939)) - Ensure rejected events get added to some metadata tables. ([\#9016](https://github.com/matrix-org/synapse/issues/9016)) - Ignore date-rotated homeserver logs saved to disk. ([\#9018](https://github.com/matrix-org/synapse/issues/9018)) - Remove an unused column from `access_tokens` table. ([\#9025](https://github.com/matrix-org/synapse/issues/9025)) - Add a `-noextras` factor to `tox.ini`, to support running the tests with no optional dependencies. ([\#9030](https://github.com/matrix-org/synapse/issues/9030)) - Fix running unit tests when optional dependencies are not installed. ([\#9031](https://github.com/matrix-org/synapse/issues/9031)) - Allow bumping schema version when using split out state database. ([\#9033](https://github.com/matrix-org/synapse/issues/9033)) - Configure the linters to run on a consistent set of files. ([\#9038](https://github.com/matrix-org/synapse/issues/9038)) - Various cleanups to device inbox store. ([\#9041](https://github.com/matrix-org/synapse/issues/9041)) - Drop unused database tables. ([\#9055](https://github.com/matrix-org/synapse/issues/9055)) - Remove unused `SynapseService` class. ([\#9058](https://github.com/matrix-org/synapse/issues/9058)) - Remove unnecessary declarations in the tests for the admin API. ([\#9063](https://github.com/matrix-org/synapse/issues/9063)) - Remove `SynapseRequest.get_user_agent`. ([\#9069](https://github.com/matrix-org/synapse/issues/9069)) - Remove redundant `Homeserver.get_ip_from_request` method. ([\#9080](https://github.com/matrix-org/synapse/issues/9080)) - Add type hints to media repository. ([\#9093](https://github.com/matrix-org/synapse/issues/9093)) - Fix the wrong arguments being passed to `BlacklistingAgentWrapper` from `MatrixFederationAgent`. Contributed by Timothy Leung. ([\#9098](https://github.com/matrix-org/synapse/issues/9098)) - Reduce the scope of caught exceptions in `BlacklistingAgentWrapper`. ([\#9106](https://github.com/matrix-org/synapse/issues/9106)) - Improve `UsernamePickerTestCase`. ([\#9112](https://github.com/matrix-org/synapse/issues/9112)) - Remove dependency on `distutils`. ([\#9125](https://github.com/matrix-org/synapse/issues/9125)) - Enforce that replication HTTP clients are called with keyword arguments only. ([\#9144](https://github.com/matrix-org/synapse/issues/9144)) - Fix the Python 3.5 / old dependencies build in CI. ([\#9146](https://github.com/matrix-org/synapse/issues/9146)) - Replace the old `perspectives` option in the Synapse docker config file template with `trusted_key_servers`. ([\#9157](https://github.com/matrix-org/synapse/issues/9157)) -----BEGIN PGP SIGNATURE----- iQIzBAABCAAdFiEEF3tZXk38tRDFVnUIM/xY9qcRMEgFAmAIVFkACgkQM/xY9qcR MEhLfQ//Z4xnP5Icx732k2xpdR+JaXX6heNVFm/UuLNd6wq+uXjO/Dgc9IKQ5LXD kfG+/OnNGDr/eUk4mQ5s/ccBvaTrOid2IIemJd4lUBy/Q5LvPvfKIp08QFr72WJT 7Y4Ma54nNSSMUAdESgj/aFAHjATbfHhxPOZ5OdQHGLAuJ/OUwR2ksasVNCuINbgh 8vrxrzjeYn1Zl3UTBrsdCcat7AFqYjxK/Y0i6JxfSgRwDZjUbW4M2C4OGWZJPUrU 2YTPHangxd+22+HObE2KDEzaHDdCR/Kj4dhCiJBynZ5iucuHSS+mgf39RtbjqWML 01cmXXUV+FH7rnCilmF9rYdmHZ6L9BJxtrQDQU4dB106BX9G7hKR6rYHc9Z6tjOh 3tg0cKWYMXOsTNnvRqiFNh2q0yBKS228HRAwyGosW/6NiYj43ArtYP6knX7dQyBX 0mYNkfry2dyX6Kj5el0i9MOTHYQxfc8apsBm2M3OTNYukgQKA0NhbAquibaAxEEW 2qIqbSp4CUlGPvM7+u+ZGTu0hEbVKKNjqMfXhuY8A4/BWiV2mSqKcEirR5cE/LqY mq5Ac7vbO4Uh+1xiRw/G9ITi1dqAjYIzhBawlhdUPOh+aINWTUikYYzjUSmm4PbN H9BTPLA9iAdVRfuWJ9um2G0DdS8Qpx/aIRh3MScXVly6cGCC6Do= =kgqn -----END PGP SIGNATURE----- Merge tag 'v1.26.0rc1' into develop Synapse 1.26.0rc1 (2021-01-20) ============================== This release brings a new schema version for Synapse and rolling back to a previous verious is not trivial. Please review [UPGRADE.rst](UPGRADE.rst) for more details on these changes and for general upgrade guidance. Features -------- - Add support for multiple SSO Identity Providers. ([\#9015](https://github.com/matrix-org/synapse/issues/9015), [\#9017](https://github.com/matrix-org/synapse/issues/9017), [\#9036](https://github.com/matrix-org/synapse/issues/9036), [\#9067](https://github.com/matrix-org/synapse/issues/9067), [\#9081](https://github.com/matrix-org/synapse/issues/9081), [\#9082](https://github.com/matrix-org/synapse/issues/9082), [\#9105](https://github.com/matrix-org/synapse/issues/9105), [\#9107](https://github.com/matrix-org/synapse/issues/9107), [\#9109](https://github.com/matrix-org/synapse/issues/9109), [\#9110](https://github.com/matrix-org/synapse/issues/9110), [\#9127](https://github.com/matrix-org/synapse/issues/9127), [\#9153](https://github.com/matrix-org/synapse/issues/9153), [\#9154](https://github.com/matrix-org/synapse/issues/9154), [\#9177](https://github.com/matrix-org/synapse/issues/9177)) - During user-interactive authentication via single-sign-on, give a better error if the user uses the wrong account on the SSO IdP. ([\#9091](https://github.com/matrix-org/synapse/issues/9091)) - Give the `public_baseurl` a default value, if it is not explicitly set in the configuration file. ([\#9159](https://github.com/matrix-org/synapse/issues/9159)) - Improve performance when calculating ignored users in large rooms. ([\#9024](https://github.com/matrix-org/synapse/issues/9024)) - Implement [MSC2176](https://github.com/matrix-org/matrix-doc/pull/2176) in an experimental room version. ([\#8984](https://github.com/matrix-org/synapse/issues/8984)) - Add an admin API for protecting local media from quarantine. ([\#9086](https://github.com/matrix-org/synapse/issues/9086)) - Remove a user's avatar URL and display name when deactivated with the Admin API. ([\#8932](https://github.com/matrix-org/synapse/issues/8932)) - Update `/_synapse/admin/v1/users/<user_id>/joined_rooms` to work for both local and remote users. ([\#8948](https://github.com/matrix-org/synapse/issues/8948)) - Add experimental support for handling to-device messages on worker processes. ([\#9042](https://github.com/matrix-org/synapse/issues/9042), [\#9043](https://github.com/matrix-org/synapse/issues/9043), [\#9044](https://github.com/matrix-org/synapse/issues/9044), [\#9130](https://github.com/matrix-org/synapse/issues/9130)) - Add experimental support for handling `/keys/claim` and `/room_keys` APIs on worker processes. ([\#9068](https://github.com/matrix-org/synapse/issues/9068)) - Add experimental support for handling `/devices` API on worker processes. ([\#9092](https://github.com/matrix-org/synapse/issues/9092)) - Add experimental support for moving off receipts and account data persistence off master. ([\#9104](https://github.com/matrix-org/synapse/issues/9104), [\#9166](https://github.com/matrix-org/synapse/issues/9166)) Bugfixes -------- - Fix a long-standing issue where an internal server error would occur when requesting a profile over federation that did not include a display name / avatar URL. ([\#9023](https://github.com/matrix-org/synapse/issues/9023)) - Fix a long-standing bug where some caches could grow larger than configured. ([\#9028](https://github.com/matrix-org/synapse/issues/9028)) - Fix error handling during insertion of client IPs into the database. ([\#9051](https://github.com/matrix-org/synapse/issues/9051)) - Fix bug where we didn't correctly record CPU time spent in `on_new_event` block. ([\#9053](https://github.com/matrix-org/synapse/issues/9053)) - Fix a minor bug which could cause confusing error messages from invalid configurations. ([\#9054](https://github.com/matrix-org/synapse/issues/9054)) - Fix incorrect exit code when there is an error at startup. ([\#9059](https://github.com/matrix-org/synapse/issues/9059)) - Fix `JSONDecodeError` spamming the logs when sending transactions to remote servers. ([\#9070](https://github.com/matrix-org/synapse/issues/9070)) - Fix "Failed to send request" errors when a client provides an invalid room alias. ([\#9071](https://github.com/matrix-org/synapse/issues/9071)) - Fix bugs in federation catchup logic that caused outbound federation to be delayed for large servers after start up. Introduced in v1.8.0 and v1.21.0. ([\#9114](https://github.com/matrix-org/synapse/issues/9114), [\#9116](https://github.com/matrix-org/synapse/issues/9116)) - Fix corruption of `pushers` data when a postgres bouncer is used. ([\#9117](https://github.com/matrix-org/synapse/issues/9117)) - Fix minor bugs in handling the `clientRedirectUrl` parameter for SSO login. ([\#9128](https://github.com/matrix-org/synapse/issues/9128)) - Fix "Unhandled error in Deferred: BodyExceededMaxSize" errors when .well-known files that are too large. ([\#9108](https://github.com/matrix-org/synapse/issues/9108)) - Fix "UnboundLocalError: local variable 'length' referenced before assignment" errors when the response body exceeds the expected size. This bug was introduced in v1.25.0. ([\#9145](https://github.com/matrix-org/synapse/issues/9145)) - Fix a long-standing bug "ValueError: invalid literal for int() with base 10" when `/publicRooms` is requested with an invalid `server` parameter. ([\#9161](https://github.com/matrix-org/synapse/issues/9161)) Improved Documentation ---------------------- - Add some extra docs for getting Synapse running on macOS. ([\#8997](https://github.com/matrix-org/synapse/issues/8997)) - Correct a typo in the `systemd-with-workers` documentation. ([\#9035](https://github.com/matrix-org/synapse/issues/9035)) - Correct a typo in `INSTALL.md`. ([\#9040](https://github.com/matrix-org/synapse/issues/9040)) - Add missing `user_mapping_provider` configuration to the Keycloak OIDC example. Contributed by @chris-ruecker. ([\#9057](https://github.com/matrix-org/synapse/issues/9057)) - Quote `pip install` packages when extras are used to avoid shells interpreting bracket characters. ([\#9151](https://github.com/matrix-org/synapse/issues/9151)) Deprecations and Removals ------------------------- - Remove broken and unmaintained `demo/webserver.py` script. ([\#9039](https://github.com/matrix-org/synapse/issues/9039)) Internal Changes ---------------- - Improve efficiency of large state resolutions. ([\#8868](https://github.com/matrix-org/synapse/issues/8868), [\#9029](https://github.com/matrix-org/synapse/issues/9029), [\#9115](https://github.com/matrix-org/synapse/issues/9115), [\#9118](https://github.com/matrix-org/synapse/issues/9118), [\#9124](https://github.com/matrix-org/synapse/issues/9124)) - Various clean-ups to the structured logging and logging context code. ([\#8939](https://github.com/matrix-org/synapse/issues/8939)) - Ensure rejected events get added to some metadata tables. ([\#9016](https://github.com/matrix-org/synapse/issues/9016)) - Ignore date-rotated homeserver logs saved to disk. ([\#9018](https://github.com/matrix-org/synapse/issues/9018)) - Remove an unused column from `access_tokens` table. ([\#9025](https://github.com/matrix-org/synapse/issues/9025)) - Add a `-noextras` factor to `tox.ini`, to support running the tests with no optional dependencies. ([\#9030](https://github.com/matrix-org/synapse/issues/9030)) - Fix running unit tests when optional dependencies are not installed. ([\#9031](https://github.com/matrix-org/synapse/issues/9031)) - Allow bumping schema version when using split out state database. ([\#9033](https://github.com/matrix-org/synapse/issues/9033)) - Configure the linters to run on a consistent set of files. ([\#9038](https://github.com/matrix-org/synapse/issues/9038)) - Various cleanups to device inbox store. ([\#9041](https://github.com/matrix-org/synapse/issues/9041)) - Drop unused database tables. ([\#9055](https://github.com/matrix-org/synapse/issues/9055)) - Remove unused `SynapseService` class. ([\#9058](https://github.com/matrix-org/synapse/issues/9058)) - Remove unnecessary declarations in the tests for the admin API. ([\#9063](https://github.com/matrix-org/synapse/issues/9063)) - Remove `SynapseRequest.get_user_agent`. ([\#9069](https://github.com/matrix-org/synapse/issues/9069)) - Remove redundant `Homeserver.get_ip_from_request` method. ([\#9080](https://github.com/matrix-org/synapse/issues/9080)) - Add type hints to media repository. ([\#9093](https://github.com/matrix-org/synapse/issues/9093)) - Fix the wrong arguments being passed to `BlacklistingAgentWrapper` from `MatrixFederationAgent`. Contributed by Timothy Leung. ([\#9098](https://github.com/matrix-org/synapse/issues/9098)) - Reduce the scope of caught exceptions in `BlacklistingAgentWrapper`. ([\#9106](https://github.com/matrix-org/synapse/issues/9106)) - Improve `UsernamePickerTestCase`. ([\#9112](https://github.com/matrix-org/synapse/issues/9112)) - Remove dependency on `distutils`. ([\#9125](https://github.com/matrix-org/synapse/issues/9125)) - Enforce that replication HTTP clients are called with keyword arguments only. ([\#9144](https://github.com/matrix-org/synapse/issues/9144)) - Fix the Python 3.5 / old dependencies build in CI. ([\#9146](https://github.com/matrix-org/synapse/issues/9146)) - Replace the old `perspectives` option in the Synapse docker config file template with `trusted_key_servers`. ([\#9157](https://github.com/matrix-org/synapse/issues/9157))pull/9180/head
						commit
						f81d02d75b
					
				|  | @ -1,11 +1,16 @@ | |||
| Synapse 1.26.0rc1 (2021-01-20) | ||||
| ============================== | ||||
| 
 | ||||
| This release brings a new schema version for Synapse and rolling back to a previous | ||||
| verious is not trivial.  Please review [UPGRADE.rst](UPGRADE.rst) for more details | ||||
| on these changes  and for general upgrade guidance. | ||||
| 
 | ||||
| Features | ||||
| -------- | ||||
| 
 | ||||
| - Add support for multiple SSO Identity Providers. ([\#9015](https://github.com/matrix-org/synapse/issues/9015), [\#9017](https://github.com/matrix-org/synapse/issues/9017), [\#9036](https://github.com/matrix-org/synapse/issues/9036), [\#9067](https://github.com/matrix-org/synapse/issues/9067), [\#9081](https://github.com/matrix-org/synapse/issues/9081), [\#9082](https://github.com/matrix-org/synapse/issues/9082), [\#9105](https://github.com/matrix-org/synapse/issues/9105), [\#9107](https://github.com/matrix-org/synapse/issues/9107), [\#9109](https://github.com/matrix-org/synapse/issues/9109), [\#9110](https://github.com/matrix-org/synapse/issues/9110), [\#9127](https://github.com/matrix-org/synapse/issues/9127), [\#9153](https://github.com/matrix-org/synapse/issues/9153)) | ||||
| - Add support for multiple SSO Identity Providers. ([\#9015](https://github.com/matrix-org/synapse/issues/9015), [\#9017](https://github.com/matrix-org/synapse/issues/9017), [\#9036](https://github.com/matrix-org/synapse/issues/9036), [\#9067](https://github.com/matrix-org/synapse/issues/9067), [\#9081](https://github.com/matrix-org/synapse/issues/9081), [\#9082](https://github.com/matrix-org/synapse/issues/9082), [\#9105](https://github.com/matrix-org/synapse/issues/9105), [\#9107](https://github.com/matrix-org/synapse/issues/9107), [\#9109](https://github.com/matrix-org/synapse/issues/9109), [\#9110](https://github.com/matrix-org/synapse/issues/9110), [\#9127](https://github.com/matrix-org/synapse/issues/9127), [\#9153](https://github.com/matrix-org/synapse/issues/9153), [\#9154](https://github.com/matrix-org/synapse/issues/9154), [\#9177](https://github.com/matrix-org/synapse/issues/9177)) | ||||
| - During user-interactive authentication via single-sign-on, give a better error if the user uses the wrong account on the SSO IdP. ([\#9091](https://github.com/matrix-org/synapse/issues/9091)) | ||||
| - Give the `public_baseurl` a default value, if it is not explicitly set in the configuration file. ([\#9159](https://github.com/matrix-org/synapse/issues/9159)) | ||||
| - Improve performance when calculating ignored users in large rooms. ([\#9024](https://github.com/matrix-org/synapse/issues/9024)) | ||||
| - Implement [MSC2176](https://github.com/matrix-org/matrix-doc/pull/2176) in an experimental room version. ([\#8984](https://github.com/matrix-org/synapse/issues/8984)) | ||||
| - Add an admin API for protecting local media from quarantine. ([\#9086](https://github.com/matrix-org/synapse/issues/9086)) | ||||
|  |  | |||
							
								
								
									
										50
									
								
								UPGRADE.rst
								
								
								
								
							
							
						
						
									
										50
									
								
								UPGRADE.rst
								
								
								
								
							|  | @ -85,6 +85,56 @@ for example: | |||
|      wget https://packages.matrix.org/debian/pool/main/m/matrix-synapse-py3/matrix-synapse-py3_1.3.0+stretch1_amd64.deb | ||||
|      dpkg -i matrix-synapse-py3_1.3.0+stretch1_amd64.deb | ||||
| 
 | ||||
| Upgrading to v1.26.0 | ||||
| ==================== | ||||
| 
 | ||||
| Rolling back to v1.25.0 after a failed upgrade | ||||
| ---------------------------------------------- | ||||
| 
 | ||||
| v1.26.0 includes a lot of large changes. If something problematic occurs, you | ||||
| may want to roll-back to a previous version of Synapse. Because v1.26.0 also | ||||
| includes a new database schema version, reverting that version is also required | ||||
| alongside the generic rollback instructions mentioned above. In short, to roll | ||||
| back to v1.25.0 you need to: | ||||
| 
 | ||||
| 1. Stop the server | ||||
| 2. Decrease the schema version in the database: | ||||
| 
 | ||||
|    .. code:: sql | ||||
| 
 | ||||
|       UPDATE schema_version SET version = 58; | ||||
| 
 | ||||
| 3. Delete the ignored users & chain cover data: | ||||
| 
 | ||||
|    .. code:: sql | ||||
| 
 | ||||
|       DROP TABLE IF EXISTS ignored_users; | ||||
|       UPDATE rooms SET has_auth_chain_index = false; | ||||
| 
 | ||||
|    For PostgreSQL run: | ||||
| 
 | ||||
|    .. code:: sql | ||||
| 
 | ||||
|       TRUNCATE event_auth_chain_links; | ||||
|       TRUNCATE event_auth_chains; | ||||
| 
 | ||||
|    For SQLite run: | ||||
| 
 | ||||
|    .. code:: sql | ||||
| 
 | ||||
|       DELETE FROM event_auth_chain_links; | ||||
|       DELETE FROM event_auth_chains; | ||||
| 
 | ||||
| 4. Mark the deltas as not run (so they will re-run on upgrade). | ||||
| 
 | ||||
|    .. code:: sql | ||||
| 
 | ||||
|       DELETE FROM applied_schema_deltas WHERE version = 59 AND file = "59/01ignored_user.py"; | ||||
|       DELETE FROM applied_schema_deltas WHERE version = 59 AND file = "59/06chain_cover_index.sql"; | ||||
| 
 | ||||
| 5. Downgrade Synapse by following the instructions for your installation method | ||||
|    in the "Rolling back to older versions" section above. | ||||
| 
 | ||||
| Upgrading to v1.25.0 | ||||
| ==================== | ||||
| 
 | ||||
|  |  | |||
|  | @ -1 +0,0 @@ | |||
| Give the `public_baseurl` a default value, if it is not explicitly set in the configuration file. | ||||
|  | @ -1726,6 +1726,10 @@ saml2_config: | |||
| #   idp_name: A user-facing name for this identity provider, which is used to | ||||
| #       offer the user a choice of login mechanisms. | ||||
| # | ||||
| #   idp_icon: An optional icon for this identity provider, which is presented | ||||
| #       by identity picker pages. If given, must be an MXC URI of the format | ||||
| #       mxc://<server-name>/<media-id> | ||||
| # | ||||
| #   discover: set to 'false' to disable the use of the OIDC discovery mechanism | ||||
| #       to discover endpoints. Defaults to true. | ||||
| # | ||||
|  |  | |||
							
								
								
									
										1
									
								
								mypy.ini
								
								
								
								
							
							
						
						
									
										1
									
								
								mypy.ini
								
								
								
								
							|  | @ -100,6 +100,7 @@ files = | |||
|   synapse/util/async_helpers.py, | ||||
|   synapse/util/caches, | ||||
|   synapse/util/metrics.py, | ||||
|   synapse/util/stringutils.py, | ||||
|   tests/replication, | ||||
|   tests/test_utils, | ||||
|   tests/handlers/test_password_providers.py, | ||||
|  |  | |||
|  | @ -23,6 +23,7 @@ from synapse.config._util import validate_config | |||
| from synapse.python_dependencies import DependencyException, check_requirements | ||||
| from synapse.types import Collection, JsonDict | ||||
| from synapse.util.module_loader import load_module | ||||
| from synapse.util.stringutils import parse_and_validate_mxc_uri | ||||
| 
 | ||||
| from ._base import Config, ConfigError | ||||
| 
 | ||||
|  | @ -66,6 +67,10 @@ class OIDCConfig(Config): | |||
|         #   idp_name: A user-facing name for this identity provider, which is used to | ||||
|         #       offer the user a choice of login mechanisms. | ||||
|         # | ||||
|         #   idp_icon: An optional icon for this identity provider, which is presented | ||||
|         #       by identity picker pages. If given, must be an MXC URI of the format | ||||
|         #       mxc://<server-name>/<media-id> | ||||
|         # | ||||
|         #   discover: set to 'false' to disable the use of the OIDC discovery mechanism | ||||
|         #       to discover endpoints. Defaults to true. | ||||
|         # | ||||
|  | @ -207,6 +212,7 @@ OIDC_PROVIDER_CONFIG_SCHEMA = { | |||
|     "properties": { | ||||
|         "idp_id": {"type": "string", "minLength": 1, "maxLength": 128}, | ||||
|         "idp_name": {"type": "string"}, | ||||
|         "idp_icon": {"type": "string"}, | ||||
|         "discover": {"type": "boolean"}, | ||||
|         "issuer": {"type": "string"}, | ||||
|         "client_id": {"type": "string"}, | ||||
|  | @ -325,20 +331,37 @@ def _parse_oidc_config_dict( | |||
|             config_path + ("user_mapping_provider", "module"), | ||||
|         ) | ||||
| 
 | ||||
|     # MSC2858 will appy certain limits in what can be used as an IdP id, so let's | ||||
|     # MSC2858 will apply certain limits in what can be used as an IdP id, so let's | ||||
|     # enforce those limits now. | ||||
|     # TODO: factor out this stuff to a generic function | ||||
|     idp_id = oidc_config.get("idp_id", "oidc") | ||||
|     valid_idp_chars = set(string.ascii_letters + string.digits + "-._~") | ||||
|     valid_idp_chars = set(string.ascii_lowercase + string.digits + "-._") | ||||
| 
 | ||||
|     if any(c not in valid_idp_chars for c in idp_id): | ||||
|         raise ConfigError( | ||||
|             'idp_id may only contain A-Z, a-z, 0-9, "-", ".", "_", "~"', | ||||
|             'idp_id may only contain a-z, 0-9, "-", ".", "_"', | ||||
|             config_path + ("idp_id",), | ||||
|         ) | ||||
| 
 | ||||
|     if idp_id[0] not in string.ascii_lowercase: | ||||
|         raise ConfigError( | ||||
|             "idp_id must start with a-z", config_path + ("idp_id",), | ||||
|         ) | ||||
| 
 | ||||
|     # MSC2858 also specifies that the idp_icon must be a valid MXC uri | ||||
|     idp_icon = oidc_config.get("idp_icon") | ||||
|     if idp_icon is not None: | ||||
|         try: | ||||
|             parse_and_validate_mxc_uri(idp_icon) | ||||
|         except ValueError as e: | ||||
|             raise ConfigError( | ||||
|                 "idp_icon must be a valid MXC URI", config_path + ("idp_icon",) | ||||
|             ) from e | ||||
| 
 | ||||
|     return OidcProviderConfig( | ||||
|         idp_id=idp_id, | ||||
|         idp_name=oidc_config.get("idp_name", "OIDC"), | ||||
|         idp_icon=idp_icon, | ||||
|         discover=oidc_config.get("discover", True), | ||||
|         issuer=oidc_config["issuer"], | ||||
|         client_id=oidc_config["client_id"], | ||||
|  | @ -366,6 +389,9 @@ class OidcProviderConfig: | |||
|     # user-facing name for this identity provider. | ||||
|     idp_name = attr.ib(type=str) | ||||
| 
 | ||||
|     # Optional MXC URI for icon for this IdP. | ||||
|     idp_icon = attr.ib(type=Optional[str]) | ||||
| 
 | ||||
|     # whether the OIDC discovery mechanism is used to discover endpoints | ||||
|     discover = attr.ib(type=bool) | ||||
| 
 | ||||
|  |  | |||
|  | @ -26,7 +26,7 @@ import yaml | |||
| from netaddr import IPSet | ||||
| 
 | ||||
| from synapse.api.room_versions import KNOWN_ROOM_VERSIONS | ||||
| from synapse.http.endpoint import parse_and_validate_server_name | ||||
| from synapse.util.stringutils import parse_and_validate_server_name | ||||
| 
 | ||||
| from ._base import Config, ConfigError | ||||
| 
 | ||||
|  |  | |||
|  | @ -49,7 +49,6 @@ from synapse.events import EventBase | |||
| from synapse.federation.federation_base import FederationBase, event_from_pdu_json | ||||
| from synapse.federation.persistence import TransactionActions | ||||
| from synapse.federation.units import Edu, Transaction | ||||
| from synapse.http.endpoint import parse_server_name | ||||
| from synapse.http.servlet import assert_params_in_dict | ||||
| from synapse.logging.context import ( | ||||
|     make_deferred_yieldable, | ||||
|  | @ -66,6 +65,7 @@ from synapse.types import JsonDict, get_domain_from_id | |||
| from synapse.util import glob_to_regex, json_decoder, unwrapFirstError | ||||
| from synapse.util.async_helpers import Linearizer, concurrently_execute | ||||
| from synapse.util.caches.response_cache import ResponseCache | ||||
| from synapse.util.stringutils import parse_server_name | ||||
| 
 | ||||
| if TYPE_CHECKING: | ||||
|     from synapse.server import HomeServer | ||||
|  |  | |||
|  | @ -28,7 +28,6 @@ from synapse.api.urls import ( | |||
|     FEDERATION_V1_PREFIX, | ||||
|     FEDERATION_V2_PREFIX, | ||||
| ) | ||||
| from synapse.http.endpoint import parse_and_validate_server_name | ||||
| from synapse.http.server import JsonResource | ||||
| from synapse.http.servlet import ( | ||||
|     parse_boolean_from_args, | ||||
|  | @ -45,6 +44,7 @@ from synapse.logging.opentracing import ( | |||
| ) | ||||
| from synapse.server import HomeServer | ||||
| from synapse.types import ThirdPartyInstanceID, get_domain_from_id | ||||
| from synapse.util.stringutils import parse_and_validate_server_name | ||||
| from synapse.util.versionstring import get_version_string | ||||
| 
 | ||||
| logger = logging.getLogger(__name__) | ||||
|  |  | |||
|  | @ -80,6 +80,10 @@ class CasHandler: | |||
|         # user-facing name of this auth provider | ||||
|         self.idp_name = "CAS" | ||||
| 
 | ||||
|         # we do not currently support icons for CAS auth, but this is required by | ||||
|         # the SsoIdentityProvider protocol type. | ||||
|         self.idp_icon = None | ||||
| 
 | ||||
|         self._sso_handler = hs.get_sso_handler() | ||||
| 
 | ||||
|         self._sso_handler.register_identity_provider(self) | ||||
|  |  | |||
|  | @ -271,6 +271,9 @@ class OidcProvider: | |||
|         # user-facing name of this auth provider | ||||
|         self.idp_name = provider.idp_name | ||||
| 
 | ||||
|         # MXC URI for icon for this auth provider | ||||
|         self.idp_icon = provider.idp_icon | ||||
| 
 | ||||
|         self._sso_handler = hs.get_sso_handler() | ||||
| 
 | ||||
|         self._sso_handler.register_identity_provider(self) | ||||
|  |  | |||
|  | @ -38,7 +38,6 @@ from synapse.api.filtering import Filter | |||
| from synapse.api.room_versions import KNOWN_ROOM_VERSIONS, RoomVersion | ||||
| from synapse.events import EventBase | ||||
| from synapse.events.utils import copy_power_levels_contents | ||||
| from synapse.http.endpoint import parse_and_validate_server_name | ||||
| from synapse.storage.state import StateFilter | ||||
| from synapse.types import ( | ||||
|     JsonDict, | ||||
|  | @ -55,6 +54,7 @@ from synapse.types import ( | |||
| from synapse.util import stringutils | ||||
| from synapse.util.async_helpers import Linearizer | ||||
| from synapse.util.caches.response_cache import ResponseCache | ||||
| from synapse.util.stringutils import parse_and_validate_server_name | ||||
| from synapse.visibility import filter_events_for_client | ||||
| 
 | ||||
| from ._base import BaseHandler | ||||
|  |  | |||
|  | @ -78,6 +78,10 @@ class SamlHandler(BaseHandler): | |||
|         # user-facing name of this auth provider | ||||
|         self.idp_name = "SAML" | ||||
| 
 | ||||
|         # we do not currently support icons for SAML auth, but this is required by | ||||
|         # the SsoIdentityProvider protocol type. | ||||
|         self.idp_icon = None | ||||
| 
 | ||||
|         # a map from saml session id to Saml2SessionData object | ||||
|         self._outstanding_requests_dict = {}  # type: Dict[str, Saml2SessionData] | ||||
| 
 | ||||
|  |  | |||
|  | @ -75,6 +75,11 @@ class SsoIdentityProvider(Protocol): | |||
|     def idp_name(self) -> str: | ||||
|         """User-facing name for this provider""" | ||||
| 
 | ||||
|     @property | ||||
|     def idp_icon(self) -> Optional[str]: | ||||
|         """Optional MXC URI for user-facing icon""" | ||||
|         return None | ||||
| 
 | ||||
|     @abc.abstractmethod | ||||
|     async def handle_redirect_request( | ||||
|         self, | ||||
|  |  | |||
|  | @ -1,79 +0,0 @@ | |||
| # -*- coding: utf-8 -*- | ||||
| # Copyright 2014-2016 OpenMarket Ltd | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| import logging | ||||
| import re | ||||
| 
 | ||||
| logger = logging.getLogger(__name__) | ||||
| 
 | ||||
| 
 | ||||
| def parse_server_name(server_name): | ||||
|     """Split a server name into host/port parts. | ||||
| 
 | ||||
|     Args: | ||||
|         server_name (str): server name to parse | ||||
| 
 | ||||
|     Returns: | ||||
|         Tuple[str, int|None]: host/port parts. | ||||
| 
 | ||||
|     Raises: | ||||
|         ValueError if the server name could not be parsed. | ||||
|     """ | ||||
|     try: | ||||
|         if server_name[-1] == "]": | ||||
|             # ipv6 literal, hopefully | ||||
|             return server_name, None | ||||
| 
 | ||||
|         domain_port = server_name.rsplit(":", 1) | ||||
|         domain = domain_port[0] | ||||
|         port = int(domain_port[1]) if domain_port[1:] else None | ||||
|         return domain, port | ||||
|     except Exception: | ||||
|         raise ValueError("Invalid server name '%s'" % server_name) | ||||
| 
 | ||||
| 
 | ||||
| VALID_HOST_REGEX = re.compile("\\A[0-9a-zA-Z.-]+\\Z") | ||||
| 
 | ||||
| 
 | ||||
| def parse_and_validate_server_name(server_name): | ||||
|     """Split a server name into host/port parts and do some basic validation. | ||||
| 
 | ||||
|     Args: | ||||
|         server_name (str): server name to parse | ||||
| 
 | ||||
|     Returns: | ||||
|         Tuple[str, int|None]: host/port parts. | ||||
| 
 | ||||
|     Raises: | ||||
|         ValueError if the server name could not be parsed. | ||||
|     """ | ||||
|     host, port = parse_server_name(server_name) | ||||
| 
 | ||||
|     # these tests don't need to be bulletproof as we'll find out soon enough | ||||
|     # if somebody is giving us invalid data. What we *do* need is to be sure | ||||
|     # that nobody is sneaking IP literals in that look like hostnames, etc. | ||||
| 
 | ||||
|     # look for ipv6 literals | ||||
|     if host[0] == "[": | ||||
|         if host[-1] != "]": | ||||
|             raise ValueError("Mismatched [...] in server name '%s'" % (server_name,)) | ||||
|         return host, port | ||||
| 
 | ||||
|     # otherwise it should only be alphanumerics. | ||||
|     if not VALID_HOST_REGEX.match(host): | ||||
|         raise ValueError( | ||||
|             "Server name '%s' contains invalid characters" % (server_name,) | ||||
|         ) | ||||
| 
 | ||||
|     return host, port | ||||
|  | @ -17,6 +17,9 @@ | |||
|                     <li> | ||||
|                         <input type="radio" name="idp" id="prov{{loop.index}}" value="{{p.idp_id}}"> | ||||
|                         <label for="prov{{loop.index}}">{{p.idp_name | e}}</label> | ||||
| {% if p.idp_icon %} | ||||
|                         <img src="{{p.idp_icon | mxc_to_http(32, 32)}}"/> | ||||
| {% endif %} | ||||
|                     </li> | ||||
| {% endfor %} | ||||
|                 </ul> | ||||
|  |  | |||
|  | @ -32,7 +32,6 @@ from synapse.api.errors import ( | |||
| ) | ||||
| from synapse.api.filtering import Filter | ||||
| from synapse.events.utils import format_event_for_client_v2 | ||||
| from synapse.http.endpoint import parse_and_validate_server_name | ||||
| from synapse.http.servlet import ( | ||||
|     RestServlet, | ||||
|     assert_params_in_dict, | ||||
|  | @ -47,7 +46,7 @@ from synapse.storage.state import StateFilter | |||
| from synapse.streams.config import PaginationConfig | ||||
| from synapse.types import RoomAlias, RoomID, StreamToken, ThirdPartyInstanceID, UserID | ||||
| from synapse.util import json_decoder | ||||
| from synapse.util.stringutils import random_string | ||||
| from synapse.util.stringutils import parse_and_validate_server_name, random_string | ||||
| 
 | ||||
| if TYPE_CHECKING: | ||||
|     import synapse.server | ||||
|  |  | |||
|  | @ -16,7 +16,6 @@ | |||
| 
 | ||||
| import collections | ||||
| import logging | ||||
| import re | ||||
| from abc import abstractmethod | ||||
| from enum import Enum | ||||
| from typing import Any, Dict, List, Optional, Tuple | ||||
|  | @ -30,6 +29,7 @@ from synapse.storage.databases.main.search import SearchStore | |||
| from synapse.types import JsonDict, ThirdPartyInstanceID | ||||
| from synapse.util import json_encoder | ||||
| from synapse.util.caches.descriptors import cached | ||||
| from synapse.util.stringutils import MXC_REGEX | ||||
| 
 | ||||
| logger = logging.getLogger(__name__) | ||||
| 
 | ||||
|  | @ -660,8 +660,6 @@ class RoomWorkerStore(SQLBaseStore): | |||
|             The local and remote media as a lists of tuples where the key is | ||||
|             the hostname and the value is the media ID. | ||||
|         """ | ||||
|         mxc_re = re.compile("^mxc://([^/]+)/([^/#?]+)") | ||||
| 
 | ||||
|         sql = """ | ||||
|             SELECT stream_ordering, json FROM events | ||||
|             JOIN event_json USING (room_id, event_id) | ||||
|  | @ -688,7 +686,7 @@ class RoomWorkerStore(SQLBaseStore): | |||
|                 for url in (content_url, thumbnail_url): | ||||
|                     if not url: | ||||
|                         continue | ||||
|                     matches = mxc_re.match(url) | ||||
|                     matches = MXC_REGEX.match(url) | ||||
|                     if matches: | ||||
|                         hostname = matches.group(1) | ||||
|                         media_id = matches.group(2) | ||||
|  |  | |||
|  | @ -37,7 +37,7 @@ from signedjson.key import decode_verify_key_bytes | |||
| from unpaddedbase64 import decode_base64 | ||||
| 
 | ||||
| from synapse.api.errors import Codes, SynapseError | ||||
| from synapse.http.endpoint import parse_and_validate_server_name | ||||
| from synapse.util.stringutils import parse_and_validate_server_name | ||||
| 
 | ||||
| if TYPE_CHECKING: | ||||
|     from synapse.appservice.api import ApplicationService | ||||
|  |  | |||
|  | @ -18,6 +18,7 @@ import random | |||
| import re | ||||
| import string | ||||
| from collections.abc import Iterable | ||||
| from typing import Optional, Tuple | ||||
| 
 | ||||
| from synapse.api.errors import Codes, SynapseError | ||||
| 
 | ||||
|  | @ -26,6 +27,15 @@ _string_with_symbols = string.digits + string.ascii_letters + ".,;:^&*-_+=#~@" | |||
| # https://matrix.org/docs/spec/client_server/r0.6.0#post-matrix-client-r0-register-email-requesttoken | ||||
| client_secret_regex = re.compile(r"^[0-9a-zA-Z\.\=\_\-]+$") | ||||
| 
 | ||||
| # https://matrix.org/docs/spec/client_server/r0.6.1#matrix-content-mxc-uris, | ||||
| # together with https://github.com/matrix-org/matrix-doc/issues/2177 which basically | ||||
| # says "there is no grammar for media ids" | ||||
| # | ||||
| # The server_name part of this is purposely lax: use parse_and_validate_mxc for | ||||
| # additional validation. | ||||
| # | ||||
| MXC_REGEX = re.compile("^mxc://([^/]+)/([^/#?]+)$") | ||||
| 
 | ||||
| # random_string and random_string_with_symbols are used for a range of things, | ||||
| # some cryptographically important, some less so. We use SystemRandom to make sure | ||||
| # we get cryptographically-secure randoms. | ||||
|  | @ -59,6 +69,88 @@ def assert_valid_client_secret(client_secret): | |||
|         ) | ||||
| 
 | ||||
| 
 | ||||
| def parse_server_name(server_name: str) -> Tuple[str, Optional[int]]: | ||||
|     """Split a server name into host/port parts. | ||||
| 
 | ||||
|     Args: | ||||
|         server_name: server name to parse | ||||
| 
 | ||||
|     Returns: | ||||
|         host/port parts. | ||||
| 
 | ||||
|     Raises: | ||||
|         ValueError if the server name could not be parsed. | ||||
|     """ | ||||
|     try: | ||||
|         if server_name[-1] == "]": | ||||
|             # ipv6 literal, hopefully | ||||
|             return server_name, None | ||||
| 
 | ||||
|         domain_port = server_name.rsplit(":", 1) | ||||
|         domain = domain_port[0] | ||||
|         port = int(domain_port[1]) if domain_port[1:] else None | ||||
|         return domain, port | ||||
|     except Exception: | ||||
|         raise ValueError("Invalid server name '%s'" % server_name) | ||||
| 
 | ||||
| 
 | ||||
| VALID_HOST_REGEX = re.compile("\\A[0-9a-zA-Z.-]+\\Z") | ||||
| 
 | ||||
| 
 | ||||
| def parse_and_validate_server_name(server_name: str) -> Tuple[str, Optional[int]]: | ||||
|     """Split a server name into host/port parts and do some basic validation. | ||||
| 
 | ||||
|     Args: | ||||
|         server_name: server name to parse | ||||
| 
 | ||||
|     Returns: | ||||
|         host/port parts. | ||||
| 
 | ||||
|     Raises: | ||||
|         ValueError if the server name could not be parsed. | ||||
|     """ | ||||
|     host, port = parse_server_name(server_name) | ||||
| 
 | ||||
|     # these tests don't need to be bulletproof as we'll find out soon enough | ||||
|     # if somebody is giving us invalid data. What we *do* need is to be sure | ||||
|     # that nobody is sneaking IP literals in that look like hostnames, etc. | ||||
| 
 | ||||
|     # look for ipv6 literals | ||||
|     if host[0] == "[": | ||||
|         if host[-1] != "]": | ||||
|             raise ValueError("Mismatched [...] in server name '%s'" % (server_name,)) | ||||
|         return host, port | ||||
| 
 | ||||
|     # otherwise it should only be alphanumerics. | ||||
|     if not VALID_HOST_REGEX.match(host): | ||||
|         raise ValueError( | ||||
|             "Server name '%s' contains invalid characters" % (server_name,) | ||||
|         ) | ||||
| 
 | ||||
|     return host, port | ||||
| 
 | ||||
| 
 | ||||
| def parse_and_validate_mxc_uri(mxc: str) -> Tuple[str, Optional[int], str]: | ||||
|     """Parse the given string as an MXC URI | ||||
| 
 | ||||
|     Checks that the "server name" part is a valid server name | ||||
| 
 | ||||
|     Args: | ||||
|         mxc: the (alleged) MXC URI to be checked | ||||
|     Returns: | ||||
|         hostname, port, media id | ||||
|     Raises: | ||||
|         ValueError if the URI cannot be parsed | ||||
|     """ | ||||
|     m = MXC_REGEX.match(mxc) | ||||
|     if not m: | ||||
|         raise ValueError("mxc URI %r did not match expected format" % (mxc,)) | ||||
|     server_name = m.group(1) | ||||
|     media_id = m.group(2) | ||||
|     host, port = parse_and_validate_server_name(server_name) | ||||
|     return host, port, media_id | ||||
| 
 | ||||
| 
 | ||||
| def shortstr(iterable: Iterable, maxitems: int = 5) -> str: | ||||
|     """If iterable has maxitems or fewer, return the stringification of a list | ||||
|     containing those items. | ||||
|  |  | |||
|  | @ -12,7 +12,7 @@ | |||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| from synapse.http.endpoint import parse_and_validate_server_name, parse_server_name | ||||
| from synapse.util.stringutils import parse_and_validate_server_name, parse_server_name | ||||
| 
 | ||||
| from tests import unittest | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Patrick Cloke
						Patrick Cloke