-
Erik Johnston authoredErik Johnston authored
Synapse 1.67.0 (2022-09-13)
This release removes using the deprecated direct TCP replication configuration for workers. Server admins should use Redis instead. See the upgrade notes.
The minimum version of poetry
supported for managing source checkouts is now
1.2.0.
Notice: from the next major release (1.68.0) installing Synapse from a source
checkout will require a recent Rust compiler. Those using packages or
pip install matrix-synapse
will not be affected. See the upgrade
notes.
Notice: from the next major release (1.68.0), running Synapse with a SQLite database will require SQLite version 3.27.0 or higher. (The current minimum version is SQLite 3.22.0.) See #12983 and the upgrade notes for more details.
No significant changes since 1.67.0rc1.
Synapse 1.67.0rc1 (2022-09-06)
Features
- Support setting the registration shared secret in a file, via a new
registration_shared_secret_path
configuration option. (#13614) - Change the default startup behaviour so that any missing "additional" configuration files (signing key, etc) are generated automatically. (#13615)
- Improve performance of sending messages in rooms with thousands of local users. (#13634)
Bugfixes
- Fix a bug introduced in Synapse 1.13 where the List Rooms admin API would return integers instead of booleans for the
federatable
andpublic
fields when using a Sqlite database. (#13509) - Fix bug that user cannot
/forget
rooms after the last member has left the room. (#13546) - Faster Room Joins: fix
/make_knock
blocking indefinitely when the room in question is a partial-stated room. (#13583) - Fix loading the current stream position behind the actual position. (#13585)
- Fix a longstanding bug in
register_new_matrix_user
which meant it was always necessary to explicitly give a server URL. (#13616) - Fix the running of MSC1763 retention purge_jobs in deployments with background jobs running on a worker by forcing them back onto the main worker. Contributed by Brad @ Beeper. (#13632)
- Fix a long-standing bug that downloaded media for URL previews was not deleted while database background updates were running. (#13657)
- Fix MSC3030
/timestamp_to_event
endpoint to return the correct next event when the events have the same timestamp. (#13658) - Fix bug where we wedge media plugins if clients disconnect early. Introduced in v1.22.0. (#13660)
- Fix a long-standing bug which meant that keys for unwhitelisted servers were not returned by
/_matrix/key/v2/query
. (#13683) - Fix a bug introduced in Synapse v1.20.0 that would cause the unstable unread counts from MSC2654 to be calculated even if the feature is disabled. (#13694)
Updates to the Docker image
- Update docker image to use a stable version of poetry. (#13688)
Improved Documentation
- Improve the description of the "chain cover index" used internally by Synapse. (#13602)
- Document how "monthly active users" is calculated and used. (#13617)
- Improve documentation around user registration. (#13640)
- Remove documentation of legacy
frontend_proxy
worker app. (#13645) - Clarify documentation that HTTP replication traffic can be protected with a shared secret. (#13656)
- Remove unintentional colons from config manual headers. (#13665)
- Update docs to make enabling metrics more clear. (#13678)
- Clarify
(room_id, event_id)
global uniqueness and how we should scope our database schemas. (#13701)
Deprecations and Removals
- Drop support for calling
/_matrix/client/v3/rooms/{roomId}/invite
without anid_access_token
, which was not permitted by the spec. Contributed by @Vetchu. (#13241) - Remove redundant
_get_joined_users_from_context
cache. Contributed by Nick @ Beeper (@fizzadar). (#13569) - Remove the ability to use direct TCP replication with workers. Direct TCP replication was deprecated in Synapse v1.18.0. Workers now require using Redis. (#13647)
- Remove support for unstable private read receipts. (#13653, #13692)
Internal Changes
- Extend the release script to wait for GitHub Actions to finish and to be usable as a guide for the whole process. (#13483)
- Add experimental configuration option to allow disabling legacy Prometheus metric names. (#13540)
- Cache user IDs instead of profiles to reduce cache memory usage. Contributed by Nick @ Beeper (@fizzadar). (#13573, #13600)
- Optimize how Synapse calculates domains to fetch from during backfill. (#13575)
- Comment about a better future where we can get the state diff between two events. (#13586)
- Instrument
_check_sigs_and_hash_and_fetch
to trace time spent in child concurrent calls for understandable traces in Jaeger. (#13588) - Improve performance of
@cachedList
. (#13591) - Minor speed up of fetching large numbers of push rules. (#13592)
- Optimise push action fetching queries. Contributed by Nick @ Beeper (@fizzadar). (#13597)
- Rename
event_map
tounpersisted_events
when computing the auth differences. (#13603) - Refactor
get_users_in_room(room_id)
mis-use with dedicatedget_current_hosts_in_room(room_id)
function. (#13605) - Use dedicated
get_local_users_in_room(room_id)
function to find local users when calculatingjoin_authorised_via_users_server
of a/make_join
request. (#13606) - Refactor
get_users_in_room(room_id)
mis-use to lookup single local user with dedicatedcheck_local_user_in_room(...)
function. (#13608) - Drop unused column
application_services_state.last_txn
. (#13627) - Improve readability of Complement CI logs by printing failure results last. (#13639)
- Generalise the
@cancellable
annotation so it can be used on functions other than just servlet methods. (#13662) - Introduce a
CommonUsageMetrics
class to share some usage metrics between the Prometheus exporter and the phone home stats. (#13671) - Add some logging to help track down #13444. (#13679)
- Update poetry lock file for v1.2.0. (#13689)
- Add cache to
is_partial_state_room
. (#13693) - Update the Grafana dashboard that is included with Synapse in the
contrib
directory. (#13697) - Only run trial CI on all python versions on non-PRs. (#13698)
- Fix typechecking with latest types-jsonschema. (#13712)
- Reduce number of CI checks we run for PRs. (#13713)
Synapse 1.66.0 (2022-08-31)
No significant changes since 1.66.0rc2.
This release removes the ability for homeservers to delegate email ownership verification and password reset confirmation to identity servers. This removal was originally planned for Synapse 1.64, but was later deferred until now. See the upgrade notes for more details.
Deployments with multiple workers should note that the direct TCP replication
configuration was deprecated in Synapse v1.18.0 and will be removed in Synapse
v1.67.0. In particular, the TCP replication
listener
type (not to be confused with the replication
resource on the http
listener
type) and the worker_replication_port
config option will be removed .
To migrate to Redis, add the redis
config,
then remove the TCP replication
listener from config of the master and
worker_replication_port
from worker config. Note that a HTTP listener with a
replication
resource is still required. See the
worker documentation
for more details.
Synapse 1.66.0rc2 (2022-08-30)
Bugfixes
- Fix a bug introduced in Synapse 1.66.0rc1 where the new rate limit metrics were misreported (
synapse_rate_limit_sleep_affected_hosts
,synapse_rate_limit_reject_affected_hosts
). (#13649)
Synapse 1.66.0rc1 (2022-08-23)
Features
- Improve validation of request bodies for the following client-server API endpoints:
/account/password
,/account/password/email/requestToken
,/account/deactivate
and/account/3pid/email/requestToken
. (#13188, #13563) - Add forgotten status to Room Details Admin API. (#13503)
- Add an experimental implementation for MSC3852 (Expose user agents on
Device
). (#13549) - Add
org.matrix.msc2716v4
experimental room version with updated content fields. Part of MSC2716 (Importing history). (#13551) - Add support for compression to federation responses. (#13537)
- Improve performance of sending messages in rooms with thousands of local users. (#13522, #13547)
Bugfixes
- Faster room joins: make
/joined_members
block whilst the room is partial stated. (#13514) - Fix a bug introduced in Synapse 1.21.0 where the
/event_reports
Admin API could return a total count which was larger than the number of results you can actually query for. (#13525) - Fix a bug introduced in Synapse 1.52.0 where sending server notices fails if
max_avatar_size
orallowed_avatar_mimetypes
is set and notsystem_mxid_avatar_url
. (#13566) - Fix a bug where the
opentracing.force_tracing_for_users
config option would not apply to/sendToDevice
and/keys/upload
requests. (#13574)
Improved Documentation
- Add
openssl
example for generating registration HMAC digest. (#13472) - Tidy up Synapse's README. (#13491)
- Document that event purging related to the
redaction_retention_period
config option is executed only every 5 minutes. (#13492) - Add a warning to retention documentation regarding the possibility of database corruption. (#13497)
- Document that the
DOCKER_BUILDKIT=1
flag is needed to build the docker image. (#13515) - Add missing links in
user_consent
section of configuration manual. (#13536) - Fix the doc and some warnings that were referring to the nonexistent
custom_templates_directory
setting (instead ofcustom_template_directory
). (#13538)
Deprecations and Removals
- Remove the ability for homeservers to delegate email ownership verification and password reset confirmation to identity servers. See upgrade notes for more details.
Internal Changes
Faster room joins
- Update the rejected state of events during de-partial-stating. (#13459)
- Avoid blocking lazy-loading
/sync
s during partial joins due to remote memberships. Pull remote memberships from auth events instead of the room state. (#13477) - Refuse to start when faster joins is enabled on a deployment with workers, since worker configurations are not currently supported. (#13531)
Metrics and tracing
- Allow use of both
@trace
and@tag_args
stacked on the same function. (#13453) - Instrument the federation/backfill part of
/messages
for understandable traces in Jaeger. (#13489) - Instrument
FederationStateIdsServlet
(/state_ids
) for understandable traces in Jaeger. (#13499, #13554) - Track HTTP response times over 10 seconds from
/messages
(synapse_room_message_list_rest_servlet_response_time_seconds
). (#13533) - Add metrics to track how the rate limiter is affecting requests (sleep/reject). (#13534, #13541)
- Add metrics to time how long it takes us to do backfill processing (
synapse_federation_backfill_processing_before_time_seconds
,synapse_federation_backfill_processing_after_time_seconds
). (#13535, #13584) - Add metrics to track rate limiter queue timing (
synapse_rate_limit_queue_wait_time_seconds
). (#13544) - Update metrics to track
/messages
response time by room size. (#13545)
Everything else
- Refactor methods in
synapse.api.auth.Auth
to useRequester
objects everywhere instead of user IDs. (#13024) - Clean-up tests for notifications. (#13471)
- Add some miscellaneous comments to document sync, especially around
compute_state_delta
. (#13474) - Use literals in place of
HTTPStatus
constants in tests. (#13479, #13488) - Add comments about how event push actions are rotated. (#13485)
- Modify HTML template content to better support mobile devices' screen sizes. (#13493)
- Add a linter script which will reject non-strict types in Pydantic models. (#13502)
- Reduce the number of tests using legacy TCP replication. (#13543)
- Allow specifying additional request fields when using the
HomeServerTestCase.login
helper method. (#13549) - Make
HomeServerTestCase
load any configured homeserver modules automatically. (#13558)
Synapse 1.65.0 (2022-08-16)
No significant changes since 1.65.0rc2.
Synapse 1.65.0rc2 (2022-08-11)
Internal Changes
- Revert 'Remove the unspecced
room_id
field in the/hierarchy
response. (#13365)' to give more time for clients to update. (#13501)
Synapse 1.65.0rc1 (2022-08-09)
Features
- Add support for stable prefixes for MSC2285 (private read receipts). (#13273)
- Add new unstable error codes
ORG.MATRIX.MSC3848.ALREADY_JOINED
,ORG.MATRIX.MSC3848.NOT_JOINED
, andORG.MATRIX.MSC3848.INSUFFICIENT_POWER
described in MSC3848. (#13343) - Use stable prefixes for MSC3827. (#13370)
- Add a new module API method to translate a room alias into a room ID. (#13428)
- Add a new module API method to create a room. (#13429)
- Add remote join capability to the module API's
update_room_membership
method (in a backwards compatible manner). (#13441)
Bugfixes
- Update the version of the LDAP3 auth provider module included in the
matrixdotorg/synapse
DockerHub images and the Debian packages hosted on packages.matrix.org to 0.2.2. This version fixes a regression in the module. (#13470) - Fix a bug introduced in Synapse v1.41.0 where the
/hierarchy
API returned non-standard information (aroom_id
field under each entry inchildren_state
) (this was reverted in v1.65.0rc2, see changelog notes above). (#13365) - Fix a bug introduced in Synapse 0.24.0 that would respond with the wrong error status code to
/joined_members
requests when the requester is not a current member of the room. Contributed by @andrewdoh. (#13374) - Fix bug in handling of typing events for appservices. Contributed by Nick @ Beeper (@fizzadar). (#13392)
- Fix a bug introduced in Synapse 1.57.0 where rooms listed in
exclude_rooms_from_sync
in the configuration file would not be properly excluded from incremental syncs. (#13408) - Fix a bug in the experimental faster-room-joins support which could cause it to get stuck in an infinite loop. (#13353)
- Faster room joins: fix a bug which caused rejected events to become un-rejected during state syncing. (#13413)
- Faster room joins: fix error when running out of servers to sync partial state with, so that Synapse raises the intended error instead. (#13432)
Updates to the Docker image
- Make Docker images build on armv7 by installing cryptography dependencies in the 'requirements' stage. Contributed by Jasper Spaans. (#13372)
Improved Documentation
- Update the 'registration tokens' page to acknowledge that the relevant MSC was merged into version 1.2 of the Matrix specification. Contributed by @moan0s. (#11897)
- Document which HTTP resources support gzip compression. (#13221)
- Add steps describing how to elevate an existing user to administrator by manipulating the database. (#13230)
- Fix wrong headline for
url_preview_accept_language
in documentation. (#13437) - Remove redundant 'Contents' section from the Configuration Manual. Contributed by @dklimpel. (#13438)
- Update documentation for config setting
macaroon_secret_key
. (#13443) - Update outdated information on
sso_mapping_providers
documentation. (#13449) - Fix example code in module documentation of
password_auth_provider_callbacks
. (#13450) - Make the configuration for the cache clearer. (#13481)
Internal Changes
- Extend the release script to automatically push a new SyTest branch, rather than having that be a manual process. (#12978)
- Make minor clarifications to the error messages given when we fail to join a room via any server. (#13160)
- Enable Complement CI tests in the 'latest deps' test run. (#13213)
- Fix long-standing bugged logic which was never hit in
get_pdu
asking every remote destination even after it finds an event. (#13346) - Faster room joins: avoid blocking when pulling events with partially missing prev events. (#13355)
- Instrument
/messages
for understandable traces in Jaeger. (#13368) - Remove an unused argument to
get_relations_for_event
. (#13383) - Add a
merge-back
command to the release script, which automates merging the correct branches after a release. (#13393) - Adding missing type hints to tests. (#13397)
- Faster Room Joins: don't leave a stuck room partial state flag if the join fails. (#13403)
- Refactor
_resolve_state_at_missing_prevs
to compute anEventContext
instead. (#13404, #13431) - Faster Room Joins: prevent Synapse from answering federated join requests for a room which it has not fully joined yet. (#13416)
- Re-enable running Complement tests against Synapse with workers. (#13420)
- Prevent unnecessary lookups to any external
get_event
cache. Contributed by Nick @ Beeper (@fizzadar). (#13435) - Add some tracing to give more insight into local room joins. (#13439)
- Rename class
RateLimitConfig
toRatelimitSettings
andFederationRateLimitConfig
toFederationRatelimitSettings
. (#13442) - Add some comments about how event push actions are stored. (#13445, #13455)
- Improve rebuild speed for the "synapse-workers" docker image. (#13447)
- Fix
@tag_args
being off-by-one with the arguments when tagging a span (tracing). (#13452) - Update type of
EventContext.rejected
. (#13460) - Use literals in place of
HTTPStatus
constants in tests. (#13463, #13469) - Correct a misnamed argument in state res v2 internals. (#13467)
Synapse 1.64.0 (2022-08-02)
No significant changes since 1.64.0rc2.
Deprecation Warning
Synapse v1.66.0 will remove the ability to delegate the tasks of verifying email address ownership, and password reset confirmation, to an identity server.
If you require your homeserver to verify e-mail addresses or to support password resets via e-mail, please configure your homeserver with SMTP access so that it can send e-mails on its own behalf. Consult the configuration documentation for more information.
Synapse 1.64.0rc2 (2022-07-29)
This RC reintroduces support for account_threepid_delegates.email
, which was removed in 1.64.0rc1. It remains deprecated and will be removed altogether in Synapse v1.66.0. (#13406)
Synapse 1.64.0rc1 (2022-07-26)
This RC removed the ability to delegate the tasks of verifying email address ownership, and password reset confirmation, to an identity server.
We have also stopped building .deb
packages for Ubuntu 21.10 as it is no longer an active version of Ubuntu.
Features
- Improve error messages when media thumbnails cannot be served. (#13038)
- Allow pagination from remote event after discovering it from MSC3030
/timestamp_to_event
. (#13205) - Add a
room_type
field in the responses for the list room and room details admin APIs. Contributed by @andrewdoh. (#13208) - Add support for room version 10. (#13220)
- Add per-room rate limiting for room joins. For each room, Synapse now monitors the rate of join events in that room, and throttles additional joins if that rate grows too large. (#13253, #13254, #13255, #13276)
- Support Implicit TLS (TLS without using a STARTTLS upgrade, typically on port 465) for sending emails, enabled by the new option
force_tls
. Contributed by Jan Schär. (#13317)
Bugfixes
- Fix a bug introduced in Synapse 1.15.0 where adding a user through the Synapse Admin API with a phone number would fail if the
enable_email_notifs
andemail_notifs_for_new_users
options were enabled. Contributed by @thomasweston12. (#13263) - Fix a bug introduced in Synapse 1.40.0 where a user invited to a restricted room would be briefly unable to join. (#13270)
- Fix a long-standing bug where, in rare instances, Synapse could store the incorrect state for a room after a state resolution. (#13278)
- Fix a bug introduced in v1.18.0 where the
synapse_pushers
metric would overcount pushers when they are replaced. (#13296) - Disable autocorrection and autocapitalisation on the username text field shown during registration when using SSO. (#13350)
- Update locked version of
frozendict
to 2.3.3, which has fixes for memory leaks affecting/sync
. (#13284, #13352)
Improved Documentation
- Provide an example of using the Admin API. Contributed by @jejo86. (#13231)
- Move the documentation for how URL previews work to the URL preview module. (#13233, #13261)
- Add another
contrib
script to help set up worker processes. Contributed by @villepeh. (#13271) - Document that certain config options were added or changed in Synapse 1.62. Contributed by @behrmann. (#13314)
- Document the new
rc_invites.per_issuer
throttling option added in Synapse 1.63. (#13333) - Mention that BuildKit is needed when building Docker images for tests. (#13338)
- Improve Caddy reverse proxy documentation. (#13344)
Deprecations and Removals
- Drop tables that were formerly used for groups/communities. (#12967)
- Drop support for delegating email verification to an external server. (#13192)
- Drop support for calling
/_matrix/client/v3/account/3pid/bind
without anid_access_token
, which was not permitted by the spec. Contributed by @Vetchu. (#13239) - Stop building
.deb
packages for Ubuntu 21.10 (Impish Indri), which has reached end of life. (#13326)
Internal Changes
- Use lower transaction isolation level when purging rooms to avoid serialization errors. Contributed by Nick @ Beeper. (#12942)
- Remove code which incorrectly attempted to reconcile state with remote servers when processing incoming events. (#12943)
- Make the AS login method call
Auth.get_user_by_req
for checking the AS token. (#13094) - Always use a version of canonicaljson that supports the C implementation of frozendict. (#13172)
- Add prometheus counters for ephemeral events and to device messages pushed to app services. Contributed by Brad @ Beeper. (#13175)
- Refactor receipts servlet logic to avoid duplicated code. (#13198)
- Preparation for database schema simplifications: populate
state_key
andrejection_reason
for existing rows in theevents
table. (#13215) - Remove unused database table
event_reference_hashes
. (#13218) - Further reduce queries used sending events when creating new rooms. Contributed by Nick @ Beeper (@fizzadar). (#13224)
- Call the v2 identity service
/3pid/unbind
endpoint, rather than v1. Contributed by @Vetchu. (#13240) - Use an asynchronous cache wrapper for the get event cache. Contributed by Nick @ Beeper (@fizzadar). (#13242, #13308)
- Optimise federation sender and appservice pusher event stream processing queries. Contributed by Nick @ Beeper (@fizzadar). (#13251)
- Log the stack when waiting for an entire room to be un-partial stated. (#13257)
- Fix spurious warning when fetching state after a missing prev event. (#13258)
- Clean-up tests for notifications. (#13260)
- Do not fail build if complement with workers fails. (#13266)
- Don't pull out state in
compute_event_context
for unconflicted state. (#13267, #13274) - Reduce the rebuild time for the complement-synapse docker image. (#13279)
- Don't pull out the full state when creating an event. (#13281, #13307)
- Upgrade from Poetry 1.1.12 to 1.1.14, to fix bugs when locking packages. (#13285)
- Make
DictionaryCache
expire full entries if they haven't been queried in a while, even if specific keys have been queried recently. (#13292) - Use
HTTPStatus
constants in place of literals in tests. (#13297) - Improve performance of query
_get_subset_users_in_room_with_profiles
. (#13299) - Up batch size of
bulk_get_push_rules
and_get_joined_profiles_from_event_ids
. (#13300) - Remove unnecessary
json.dumps
from tests. (#13303) - Reduce memory usage of sending dummy events. (#13310)
- Prevent formatting changes of #3679 from appearing in
git blame
. (#13311) - Change
get_users_in_room
andget_rooms_for_user
caches to enable pruning of old entries. (#13313) - Validate federation destinations and log an error if a destination is invalid. (#13318)
- Fix
FederationClient.get_pdu()
returning events from the cache asoutliers
instead of original events we saw over federation. (#13320) - Reduce memory usage of state caches. (#13323)
- Reduce the amount of state we store in the
state_cache
. (#13324) - Add missing type hints to open tracing module. (#13328, #13345, #13362)
- Remove old base slaved store and de-duplicate cache ID generators. Contributed by Nick @ Beeper (@fizzadar). (#13329, #13349)
- When reporting metrics is enabled, use ~8x less data to describe DB transaction metrics. (#13342)
- Faster room joins: skip soft fail checks while Synapse only has partial room state, since the current membership of event senders may not be accurately known. (#13354)
Synapse 1.63.1 (2022-07-20)
Bugfixes
- Fix a bug introduced in Synapse 1.63.0 where push actions were incorrectly calculated for appservice users. This caused performance issues on servers with large numbers of appservices. (#13332)
Synapse 1.63.0 (2022-07-19)
Improved Documentation
- Clarify that homeserver server names are included in the reported data when the
report_stats
config option is enabled. (#13321)
Synapse 1.63.0rc1 (2022-07-12)
Features
- Add a rate limit for local users sending invites. (#13125)
- Implement MSC3827: Filtering of
/publicRooms
by room type. (#13031) - Improve validation logic in the account data REST endpoints. (#13148)
Bugfixes
- Fix a long-standing bug where application services were not able to join remote federated rooms without a profile. (#13131)
- Fix a long-standing bug where
_get_state_map_for_room
might raise errors when third party event rules callbacks are present. (#13174) - Fix a long-standing bug where the
synapse_port_db
script could fail to copy rows with negative row ids. (#13226) - Fix a bug introduced in 1.54.0 where appservices would not receive room-less EDUs, like presence, when both MSC2409 and MSC3202 are enabled. (#13236)
- Fix a bug introduced in 1.62.0 where rows were not deleted from
event_push_actions
table on large servers. (#13194) - Fix a bug introduced in 1.62.0 where notification counts would get stuck after a highlighted message. (#13223)
- Fix exception when using experimental MSC3030
/timestamp_to_event
endpoint to look for remote federated imported events before room creation. (#13197) - Fix MSC3202-enabled appservices not receiving to-device messages, preventing messages from being decrypted. (#13235)
Updates to the Docker image
- Bump the version of
lxml
in matrix.org Docker images Debian packages from 4.8.0 to 4.9.1. (#13207)
Improved Documentation
- Add an explanation of the
--report-stats
argument to the docs. (#13029) - Add a helpful example bash script to the contrib directory for creating multiple worker configuration files of the same type. Contributed by @villepeh. (#13032)
- Add missing links to config options. (#13166)
- Add documentation for homeserver usage statistics collection. (#13086)
- Add documentation for the existing
databases
option in the homeserver configuration manual. (#13212) - Clean up references to sample configuration and redirect users to the configuration manual instead. (#13077, #13139)
- Document how the Synapse team does reviews. (#13132)
- Fix wrong section header for
allow_public_rooms_over_federation
in the homeserver config documentation. (#13116)
Deprecations and Removals
- Remove obsolete and for 8 years unused
RoomEventsStoreTestCase
. Contributed by @arkamar. (#13200)
Internal Changes
- Add type annotations to
synapse.logging
,tests.server
andtests.utils
. (#13028, #13103, #13159, #13136) - Enforce type annotations for
tests.test_server
. (#13135) - Support temporary experimental return values for spam checker module callbacks. (#13044)
- Add support to
complement.sh
for skipping the docker build. (#13143, #13158) - Add support to
complement.sh
for setting the log level using theSYNAPSE_TEST_LOG_LEVEL
environment variable. (#13152) - Enable Complement testing in the 'Twisted Trunk' CI runs. (#13079, #13157)
- Improve startup times in Complement test runs against workers, particularly in CPU-constrained environments. (#13127)
- Update config used by Complement to allow device name lookup over federation. (#13167)
- Faster room joins: handle race between persisting an event and un-partial stating a room. (#13100)
- Faster room joins: fix race in recalculation of current room state. (#13151)
- Faster room joins: skip waiting for full state when processing incoming events over federation. (#13144)
- Raise a
DependencyError
on missing dependencies instead of aConfigError
. (#13113) - Avoid stripping line breaks from SQL sent to the database. (#13129)
- Apply ratelimiting earlier in processing of
/send
requests. (#13134) - Improve exception handling when processing events received over federation. (#13145)
- Check that
auto_vacuum
is disabled when porting a SQLite database to Postgres, asVACUUM
s must not be performed between runs of the script. (#13195) - Reduce DB usage of
/sync
when a large number of unread messages have recently been sent in a room. (#13119, #13153) - Reduce memory consumption when processing incoming events in large rooms. (#13078, #13222)
- Reduce number of queries used to get profile information. Contributed by Nick @ Beeper (@fizzadar). (#13209)
- Reduce number of events queried during room creation. Contributed by Nick @ Beeper (@fizzadar). (#13210)
- More aggressively rotate push actions. (#13211)
- Add
max_line_length
setting for Python files to the.editorconfig
. Contributed by @sumnerevans @ Beeper. (#13228)
Synapse 1.62.0 (2022-07-05)
No significant changes since 1.62.0rc3.
Authors of spam-checker plugins should consult the upgrade notes to learn about the enriched signatures for spam checker callbacks, which are supported with this release of Synapse.
Security advisory
The following issue is fixed in 1.62.0.
-
GHSA-jhjh-776m-4765 / CVE-2022-31152
Synapse instances prior to 1.62.0 did not implement the Matrix event authorization rules correctly. An attacker could craft events which would be accepted by Synapse but not a spec-conformant server, potentially causing divergence in the room state between servers.
Homeservers with federation disabled via the
federation_domain_whitelist
config option are unaffected.Administrators of homeservers with federation enabled are advised to upgrade to v1.62.0 or higher.
Synapse 1.62.0rc3 (2022-07-04)
Bugfixes
- Update the version of the ldap3 plugin included in the
matrixdotorg/synapse
DockerHub images and the Debian packages hosted onpackages.matrix.org
to 0.2.1. This fixes a bug with usernames containing uppercase characters. (#13156) - Fix a bug introduced in Synapse 1.62.0rc1 affecting unread counts for users on small servers. (#13168)
Synapse 1.62.0rc2 (2022-07-01)
Bugfixes
- Fix unread counts for users on large servers. Introduced in v1.62.0rc1. (#13140)
- Fix DB performance when deleting old push notifications. Introduced in v1.62.0rc1. (#13141)
Synapse 1.62.0rc1 (2022-06-28)
Features
- Port the spam-checker API callbacks to a new, richer API. This is part of an ongoing change to let spam-checker modules inform users of the reason their event or operation is rejected. (#12857, #13047)
- Allow server admins to customise the response of the
/.well-known/matrix/client
endpoint. (#13035) - Add metrics measuring the CPU and DB time spent in state resolution. (#13036)
- Speed up fetching of device list changes in
/sync
and/keys/changes
. (#13045, #13098) - Improve URL previews for sites which only provide Twitter Card metadata, e.g. LWN.net. (#13056)
Bugfixes
- Update MSC3786 implementation to check
state_key
. (#12939) - Fix a bug introduced in Synapse 1.58 where Synapse would not report full version information when installed from a git checkout. This is a best-effort affair and not guaranteed to be stable. (#12973)
- Fix a bug introduced in Synapse 1.60 where Synapse would fail to start if the
sqlite3
module was not available. (#12979) - Fix a bug where non-standard information was required when requesting the
/hierarchy
API over federation. Introduced in Synapse v1.41.0. (#12991) - Fix a long-standing bug which meant that rate limiting was not restrictive enough in some cases. (#13018)
- Fix a bug introduced in Synapse 1.58 where profile requests for a malformed user ID would ccause an internal error. Synapse now returns 400 Bad Request in this situation. (#13041)
- Fix some inconsistencies in the event authentication code. (#13087, #13088)
- Fix a long-standing bug where room directory requests would cause an internal server error if given a malformed room alias. (#13106)
Improved Documentation
- Add documentation for how to configure Synapse with Workers using Docker Compose. Includes example worker config and docker-compose.yaml. Contributed by @Thumbscrew. (#12737)
- Ensure the Poetry cheat sheet is available in the online documentation. (#13022)
- Mention removed community/group worker endpoints in upgrade.md. Contributed by @olmari. (#13023)
- Add instructions for running Complement with
gotestfmt
-formatted output locally. (#13073) - Update OpenTracing docs to reference the configuration manual rather than the configuration file. (#13076)
- Update information on downstream Debian packages. (#13095)
- Remove documentation for the Delete Group Admin API which no longer exists. (#13112)
Deprecations and Removals
- Remove the unspecced
DELETE /directory/list/room/{roomId}
endpoint, which hid rooms from the public room directory. Instead,PUT
to the same URL with a visibility of"private"
. (#13123)
Internal Changes
- Add tests for cancellation of
GET /rooms/$room_id/members
andGET /rooms/$room_id/state
requests. (#12674) - Report login failures due to unknown third party identifiers in the same way as failures due to invalid passwords. This prevents an attacker from using the error response to determine if the identifier exists. Contributed by Daniel Aloni. (#12738)
- Merge the Complement testing Docker images into a single, multi-purpose image. (#12881, #13075)
- Simplify the database schema for
event_edges
. (#12893) - Clean up the test code for client disconnection. (#12929)
- Remove code generating comments in configuration. (#12941)
- Add
Cross-Origin-Resource-Policy: cross-origin
header to content repository's thumbnail and download endpoints. (#12944) - Replace noop background updates with
DELETE
delta. (#12954, #13050) - Use lower isolation level when inserting read receipts to avoid serialization errors. Contributed by Nick @ Beeper. (#12957)
- Reduce the amount of state we pull from the DB. (#12963)
- Enable testing against PostgreSQL databases in Complement CI. (#12965, #13034)
- Fix an inaccurate comment. (#12969)
- Remove the
delete_device
method and always calldelete_devices
. (#12970) - Use a GitHub form for issues rather than a hard-to-read, easy-to-ignore template. (#12982)
- Move MSC3715 behind an experimental config flag. (#12984)
- Add type hints to tests. (#12985, #13099)
- Refactor macaroon tokens generation and move the unsubscribe link in notification emails to
/_synapse/client/unsubscribe
. (#12986) - Fix documentation for running complement tests. (#12990)
- Faster joins: add issue links to the TODO comments in the code. (#13004)
- Reduce DB usage of
/sync
when a large number of unread messages have recently been sent in a room. (#13005, #13096, #13118) - Replaced usage of PyJWT with methods from Authlib in
org.matrix.login.jwt
. Contributed by Hannes Lerchl. (#13011) - Modernize the
contrib/graph/
scripts. (#13013) - Remove redundant
room_version
parameters from event auth functions. (#13017) - Decouple
synapse.api.auth_blocking.AuthBlocking
fromsynapse.api.auth.Auth
. (#13021) - Add type annotations to
synapse.storage.databases.main.devices
. (#13025) - Set default
sync_response_cache_duration
to two minutes. (#13042) - Rename CI test runs. (#13046)
- Increase timeout of complement CI test runs. (#13048)
- Refactor entry points so that they all have a
main
function. (#13052) - Refactor the Dockerfile-workers configuration script to use Jinja2 templates in Synapse workers' Supervisord blocks. (#13054)
- Add headers to individual options in config documentation to allow for linking. (#13055)
- Make Complement CI logs easier to read. (#13057, #13058, #13069)
- Don't instantiate modules with keyword arguments. (#13060)
- Fix type checking errors against Twisted trunk. (#13061)
- Allow MSC3030
timestamp_to_event
calls from anyone on world-readable rooms. (#13062) - Add a CI job to check that schema deltas are in the correct folder. (#13063)
- Avoid rechecking event auth rules which are independent of room state. (#13065)
- Reduce the duplication of code that invokes the rate limiter. (#13070)
- Add a Subject Alternative Name to the certificate generated for Complement tests. (#13071)
- Add more tests for room upgrades. (#13074)
- Pin dependencies maintained by matrix.org to semantic version bounds. (#13082)
- Correctly report prometheus DB stats for
get_earliest_token_for_stats
. (#13085) - Fix a long-standing bug where a finished logging context would be re-started when Synapse failed to persist an event from federation. (#13089)
- Simplify the alias deletion logic as an application service. (#13093)
- Add type annotations to
tests.test_server
. (#13124)
Synapse 1.61.1 (2022-06-28)
This patch release fixes a security issue regarding URL previews, affecting all prior versions of Synapse. Server administrators are encouraged to update Synapse as soon as possible. We are not aware of these vulnerabilities being exploited in the wild.
Server administrators who are unable to update Synapse may use the workarounds described in the linked GitHub Security Advisory below.
Security advisory
The following issue is fixed in 1.61.1.
-
GHSA-22p3-qrh9-cx32 / CVE-2022-31052
Synapse instances with the
url_preview_enabled
homeserver config option set totrue
are affected. URL previews of some web pages can lead to unbounded recursion, causing the request to either fail, or in some cases crash the running Synapse process.Requesting URL previews requires authentication. Nevertheless, it is possible to exploit this maliciously, either by malicious users on the homeserver, or by remote users sending URLs that a local user's client may automatically request a URL preview for.
Homeservers with the
url_preview_enabled
configuration option set tofalse
(the default) are unaffected. Instances with theenable_media_repo
configuration option set tofalse
are also unaffected, as this also disables URL preview functionality.Fixed by fa1308061802ac7b7d20e954ba7372c5ac292333.
Synapse 1.61.0 (2022-06-14)
This release removes support for the non-standard feature known both as 'groups' and as 'communities', which have been superseded by Spaces.
See the upgrade notes for more details.
Improved Documentation
- Mention removed community/group worker endpoints in the upgrade notes. Contributed by @olmari. (#13023)
Synapse 1.61.0rc1 (2022-06-07)
Features
- Add new
media_retention
options to the homeserver config for routinely cleaning up non-recently accessed media. (#12732, #12972, #12977) - Experimental support for MSC3772: Push rule for mutually related events. (#12740, #12859)
- Update to the
check_event_for_spam
module callback: Deprecate the current callback signature, replace it with a new signature that is both less ambiguous (replacing booleans with explicit allow/block) and more powerful (ability to return explicit error codes). (#12808) - Add storage and module API methods to get monthly active users (and their corresponding appservices) within an optionally specified time range. (#12838, #12917)
- Support the new error code
ORG.MATRIX.MSC3823.USER_ACCOUNT_SUSPENDED
from MSC3823. (#12845, #12923) - Add a configurable background job to delete stale devices. (#12855)
- Improve URL previews for pages with empty elements. (#12951)
- Allow updating a user's password using the admin API without logging out their devices. Contributed by @jcgruenhage. (#12952)
Bugfixes
- Always send an
access_token
in/thirdparty/
requests to appservices, as required by the Application Service API specification. (#12746) - Implement MSC3816: sending the root event in a thread should count as having 'participated' in it. (#12766)
- Delete events from the
federation_inbound_events_staging
table when a room is purged through the admin API. (#12784) - Fix a bug where we did not correctly handle invalid device list updates over federation. Contributed by Carl Bordum Hansen. (#12829)
- Fix a bug which allowed multiple async operations to access database locks concurrently. Contributed by @sumnerevans @ Beeper. (#12832)
- Fix an issue introduced in Synapse 0.34 where the
/notifications
endpoint would only return notifications if a user registered at least one pusher. Contributed by Famedly. (#12840) - Fix a bug where servers using a Postgres database would fail to backfill from an insertion event when MSC2716 is enabled (
experimental_features.msc2716_enabled
). (#12843) - Fix MSC3787 rooms being omitted from room directory, room summary and space hierarchy responses. (#12858)
- Fix a bug introduced in Synapse 1.54.0 which could sometimes cause exceptions when handling federated traffic. (#12877)
- Fix a bug introduced in Synapse 1.59.0 which caused room deletion to fail with a foreign key violation error. (#12889)
- Fix a long-standing bug which caused the
/messages
endpoint to return an incorrectend
attribute when there were no more events. Contributed by @Vetchu. (#12903) - Fix a bug introduced in Synapse 1.58.0 where
/sync
would fail if the most recent event in a room was a redaction of an event that has since been purged. (#12905) - Fix a potential memory leak when generating thumbnails. (#12932)
- Fix a long-standing bug where a URL preview would break if the image failed to download. (#12950)
Improved Documentation
- Fix typographical errors in documentation. (#12863)
- Fix documentation incorrectly stating the
sendToDevice
endpoint can be directed at generic workers. Contributed by Nick @ Beeper. (#12867)
Deprecations and Removals
- Remove support for the non-standard groups/communities feature from Synapse. (#12553, #12558, #12563, #12895, #12897, #12899, #12900, #12936, #12966)
- Remove contributed
kick_users.py
script. This is broken under Python 3, and is not added to the environment whenpip install
ing Synapse. (#12908) - Remove
contrib/jitsimeetbridge
. This was an unused experiment that hasn't been meaningfully changed since 2014. (#12909) - Remove unused
contrib/experiements/cursesio.py
script, which fails to run under Python 3. (#12910) - Remove unused
contrib/experiements/test_messaging.py
script. This fails to run on Python 3. (#12911)
Internal Changes
- Test Synapse against Complement with workers. (#12810, #12933)
- Reduce the amount of state we pull from the DB. (#12811, #12964)
- Try other homeservers when re-syncing state for rooms with partial state. (#12812)
- Resume state re-syncing for rooms with partial state after a Synapse restart. (#12813)
- Remove Mutual Rooms' (MSC2666) endpoint dependency on the User Directory. (#12836)
- Experimental: expand
check_event_for_spam
with ability to return additional fields. This enables spam-checker implementations to experiment with mechanisms to give users more information about why they are blocked and whether any action is needed from them to be unblocked. (#12846) - Remove
dont_notify
from the.m.rule.room.server_acl
rule. (#12849) - Remove the unstable
/hierarchy
endpoint from MSC2946. (#12851) - Pull out less state when handling gaps in room DAG. (#12852, #12904)
- Clean-up the push rules datastore. (#12856)
- Correct a type annotation in the URL preview source code. (#12860)
- Update
pyjwt
dependency to 2.4.0. (#12865) - Enable the
/account/whoami
endpoint on synapse worker processes. Contributed by Nick @ Beeper. (#12866) - Enable the
batch_send
endpoint on synapse worker processes. Contributed by Nick @ Beeper. (#12868) - Don't generate empty AS transactions when the AS is flagged as down. Contributed by Nick @ Beeper. (#12869)
- Fix up the variable
state_store
naming. (#12871) - Faster room joins: when querying the current state of the room, wait for state to be populated. (#12872)
- Avoid running queries which will never result in deletions. (#12879)
- Use constants for EDU types. (#12884)
- Reduce database load of
/sync
when presence is enabled. (#12885) - Refactor
have_seen_events
to reduce memory consumed when processing federation traffic. (#12886) - Refactor receipt linearization code. (#12888)
- Add type annotations to
synapse.logging.opentracing
. (#12894) - Remove PyNaCl occurrences directly used in Synapse code. (#12902)
- Bump types-jsonschema from 4.4.1 to 4.4.6. (#12912)
- Rename storage classes. (#12913)
- Preparation for database schema simplifications: stop reading from
event_edges.room_id
. (#12914) - Check if we are in a virtual environment before overriding the
PYTHONPATH
environment variable in the demo script. (#12916) - Improve the logging when signature checks on events fail. (#12925)
Synapse 1.60.0 (2022-05-31)
This release of Synapse adds a unique index to the state_group_edges
table, in
order to prevent accidentally introducing duplicate information (for example,
because a database backup was restored multiple times). If your Synapse database
already has duplicate rows in this table, this could fail with an error and
require manual remediation.
Additionally, the signature of the check_event_for_spam
module callback has changed.
The previous signature has been deprecated and remains working for now. Module authors
should update their modules to use the new signature where possible.
See the upgrade notes for more details.
Bugfixes
- Fix a bug introduced in Synapse 1.60.0rc1 that would break some imports from
synapse.module_api
. (#12918)