summary refs log tree commit diff
Commit message (Collapse)AuthorAgeFilesLines
* Cleanups and additions to the module APIRichard van der Hoff2020-01-122-6/+59
| | | | | | | | | | | Add some useful things, such as error types and logcontext handling, to the API. Make `hs` a private member to dissuade people from using it (hopefully they aren't already). Add a couple of new methods (`record_user_external_id` and `generate_short_term_login_token`).
* Allow admin users to create or modify users without a shared secret (#6495)Manuel Stahl2020-01-099-339/+655
| | | Signed-off-by: Manuel Stahl <manuel.stahl@awesome-technologies.de>
* Merge branch 'master' into developErik Johnston2020-01-095-5/+17
|\
| * Fixup changelog v1.8.0Erik Johnston2020-01-091-1/+1
| |
| * 1.8.0Erik Johnston2020-01-095-5/+17
| |
* | Merge pull request #6664 from matrix-org/erikj/media_admin_apisErik Johnston2020-01-083-120/+131
|\ \ | | | | | | Fix media repo admin APIs when using a media worker.
| * | Shuffle the codeErik Johnston2020-01-081-25/+16
| | |
| * | CommentsErik Johnston2020-01-081-0/+3
| | |
| * | Do not rely on streaming events, as media repo doesn'tErik Johnston2020-01-081-12/+26
| | |
| * | NewsfileErik Johnston2020-01-081-0/+1
| | |
| * | Import RoomStore in media worker to fix admin APIsErik Johnston2020-01-081-0/+2
| | |
| * | Move media admin store functions to worker storeErik Johnston2020-01-081-120/+120
| | |
* | | Merge pull request #6665 from matrix-org/babolivier/retention_doc_typoBrendan Abolivier2020-01-082-1/+2
|\ \ \ | | | | | | | | Fix typo in message retention policies doc
| * | | ChangelogBrendan Abolivier2020-01-081-0/+1
| | | |
| * | | Fix typo in message retention policies docBrendan Abolivier2020-01-081-1/+1
| | | |
* | | | Merge remote-tracking branch 'origin/release-v1.8.0' into developRichard van der Hoff2020-01-088-28/+184
|\ \ \ \ | |/ / / |/| | / | | |/ | |/|
| * | Fix GET request on /_synapse/admin/v2/users endpoint (#6563)Manuel Stahl2020-01-083-2/+44
| | | | | | | | | | | | Fixes #6552
| * | Back out ill-advised notary server hackery (#6657)Richard van der Hoff2020-01-085-26/+140
| |/ | | | | | | | | | | | | | | | | | | | | This was ill-advised. We can't modify verify_keys here, because the response object has already been signed by the requested key. Furthermore, it's somewhat unnecessary because existing versions of Synapse (which get upset that the notary key isn't present in verify_keys) will fall back to a direct fetch via `/key/v2/server`. Also: more tests for fetching keys via perspectives: it would be nice if we actually tested when our fetcher can't talk to our notary impl.
* | Merge pull request #6624 from matrix-org/babolivier/retention_docBrendan Abolivier2020-01-082-0/+192
|\ \ | | | | | | Add complete documentation of the message retention policies support
| * | Fix referenceBrendan Abolivier2020-01-071-1/+1
| | |
| * | Incorporate reviewBrendan Abolivier2020-01-071-27/+28
| | |
| * | Merge branch 'develop' into babolivier/retention_docBrendan Abolivier2020-01-0783-491/+788
| |\|
| * | Apply suggestions from code reviewBrendan Abolivier2020-01-071-5/+4
| | | | | | | | | Co-Authored-By: Richard van der Hoff <1389908+richvdh@users.noreply.github.com>
| * | Update changelog.d/6624.docBrendan Abolivier2020-01-071-1/+1
| | | | | | | | | Co-Authored-By: Richard van der Hoff <1389908+richvdh@users.noreply.github.com>
| * | Fix vacuum instructions for sqliteBrendan Abolivier2020-01-031-2/+2
| | |
| * | Rename changelogBrendan Abolivier2020-01-031-0/+0
| | |
| * | Add a complete documentation of the message retention policies supportBrendan Abolivier2020-01-032-0/+192
| | |
* | | contrib/docker-compose: fixing mount that overrides containers' /etc (#6656)Fabian Meyer2020-01-082-1/+2
| | | | | | | | | | | | The mount in the form of ./matrix-config:/etc overwrites the contents of the container /etc folder. Since all valid ca certificates are stored in /etc, the synapse.push.httppusher, for example, cannot validate the certificate from matrix.org.
* | | typoMatthew Hodgson2020-01-071-1/+1
| | |
* | | Correctly proxy remote group HTTP errors. (#6654)Erik Johnston2020-01-072-0/+17
| | | | | | | | | | | | | | | e.g. if remote returns a 404 then that shouldn't be treated as an error but should be proxied through.
* | | Merge pull request #6621 from matrix-org/babolivier/purge_job_config_typoBrendan Abolivier2020-01-073-10/+11
|\ \ \ | |_|/ |/| | Fix a typo in the purge jobs configuration example
| * | RewordBrendan Abolivier2020-01-072-6/+6
| | |
| * | Change the example from 5min to 12hBrendan Abolivier2020-01-072-8/+8
| | | | | | | | | | | | Have a purge job running every 5min is probably not something we want to advise admins to do as a sort-of default.
| * | ChangelogBrendan Abolivier2020-01-031-0/+1
| | |
| * | Update sample configBrendan Abolivier2020-01-031-1/+1
| | |
| * | Fix a typo in the purge jobs configuration exampleBrendan Abolivier2020-01-031-1/+1
| |/
* | Fixup changelog v1.8.0rc1Erik Johnston2020-01-071-3/+3
| |
* | Fixup changelogErik Johnston2020-01-071-1/+1
| |
* | Fixup changelogErik Johnston2020-01-071-21/+11
| |
* | 1.8.0rc1Erik Johnston2020-01-0756-55/+81
| |
* | Merge pull request #6652 from matrix-org/babolivier/depth_missing_eventsBrendan Abolivier2020-01-073-3/+4
|\ \ | | | | | | Fix conditions failing if min_depth = 0
| * | ChangelogBrendan Abolivier2020-01-071-0/+1
| | |
| * | Fix conditions failing if min_depth = 0Brendan Abolivier2020-01-072-3/+3
| |/ | | | | | | This could result in Synapse not fetching prev_events for new events in the room if it has missed some events.
* | Add a background update to clear tombstoned rooms from the directory (#6648)Richard van der Hoff2020-01-076-1/+106
| | | | | | | | | | | | * Add a background update to clear tombstoned rooms from the directory * use the ABC metaclass
* | Async/await for background updates (#6647)Richard van der Hoff2020-01-072-16/+21
| | | | | | | | so that bg update routines can be async
* | port BackgroundUpdateTestCase to HomeserverTestCase (#6653)Richard van der Hoff2020-01-072-35/+38
| |
* | Merge pull request #6645 from matrix-org/rav/fix_synchrotron_errorRichard van der Hoff2020-01-073-15/+48
|\ \ | | | | | | Fix exceptions in the synchrotron worker log when events are rejected.
| * | changelogRichard van der Hoff2020-01-061-0/+1
| | |
| * | Fix exceptions in log when rejected event is replicatedRichard van der Hoff2020-01-061-2/+9
| | |
| * | async/await for SyncReplicationHandler.process_and_notifyRichard van der Hoff2020-01-061-5/+4
| | |
| * | Clarify documentation on get_event* methodsRichard van der Hoff2020-01-061-9/+35
| | | | | | | | | | | | Make it clearer how they behave in the face of rejected and/or missing events.
* | | Merge pull request #6629 from matrix-org/rav/kill_event_reference_hashesRichard van der Hoff2020-01-067-103/+55
|\ \ \ | |/ / |/| | Remove a bunch of unused code from event creation
| * | changelogRichard van der Hoff2020-01-061-0/+1
| | |
| * | Remove unused get_latest_event_ids_and_hashes_in_roomRichard van der Hoff2020-01-061-42/+0
| | |
| * | Remove unused get_prev_events_and_hashes_for_roomRichard van der Hoff2020-01-062-43/+6
| | |
| * | Remove unused hashes and depths from _update_membership paramsRichard van der Hoff2020-01-061-13/+4
| | |
| * | Remove unused hashes and depths from create_event paramsRichard van der Hoff2020-01-063-22/+13
| | |
| * | Remove unused hashes and depths from create_new_client_event paramsRichard van der Hoff2020-01-062-12/+26
| | |
| * | replace get_prev_events_and_hashes_for_room with get_prev_events_for_room in ↵Richard van der Hoff2020-01-062-9/+38
| | | | | | | | | | | | create_new_client_event
| * | rename get_prev_events_for_room to get_prev_events_and_hashes_for_roomRichard van der Hoff2020-01-064-7/+12
| | | | | | | | | | | | ... to make way for a new method which just returns the event ids
* | | Fix some test failures when frozen_dicts are enabled (#6642)Richard van der Hoff2020-01-065-11/+20
| | | | | | | | | | | | Fixes #4026
* | | Add experimental 'databases' config (#6580)Erik Johnston2020-01-063-13/+64
| | |
* | | Fix an error which was thrown by the PresenceHandler _on_shutdown handler. ↵Richard van der Hoff2020-01-062-7/+3
| | | | | | | | | | | | (#6640)
* | | Fix exception when fetching notary server's old keys (#6625)Richard van der Hoff2020-01-063-50/+103
| | | | | | | | | | | | | | | | | | Lift the restriction that *all* the keys used for signing v2 key responses be present in verify_keys. Fixes #6596.
* | | Workaround for error when fetching notary's own key (#6620)Richard van der Hoff2020-01-064-9/+163
|/ / | | | | | | | | | | | | | | | | | | | | | | | | | | * Kill off redundant SynapseRequestFactory We already get the Site via the Channel, so there's no need for a dedicated RequestFactory: we can just use the right constructor. * Workaround for error when fetching notary's own key As a notary server, when we return our own keys, include all of our signing keys in verify_keys. This is a workaround for #6596.
* | Fix power levels being incorrectly set in old and new rooms after a room ↵Andrew Morgan2020-01-062-7/+11
| | | | | | | | | | | | upgrade (#6633) Modify a copy of an upgraded room's PL before sending to the new room
* | Automate generation of the sample and debian log configs (#6627)Richard van der Hoff2020-01-039-40/+73
| |
* | Raise an error if someone tries to use the log_file config option (#6626)Richard van der Hoff2020-01-033-3/+17
| | | | | | | | This has caused some confusion for people who didn't notice it going away.
* | Remove unused, undocumented "content repo" resource (#6628)Richard van der Hoff2020-01-039-128/+3
| | | | | | | | | | | | This looks like it got half-killed back in #888. Fixes #6567.
* | Kill off redundant SynapseRequestFactory (#6619)Richard van der Hoff2020-01-033-17/+8
| | | | | | | | We already get the Site via the Channel, so there's no need for a dedicated RequestFactory: we can just use the right constructor.
* | Reduce the reconnect time when replication fails. (#6617)Richard van der Hoff2020-01-032-1/+3
|/
* Added the section 'Configuration' in /docs/turn-howto.md (#6614)ewaf12020-01-022-0/+3
| | | | put the 2nd part of the "source installation"-section into a new section, because it also applies to Debian packages
* Reword sections of federate.md that explained delegation at time of Synapse ↵Aaron Raimist2020-01-022-21/+4
| | | | | | | | | | | | 1.0 transition (#6601) * Remove sections of federate.md explaining delegation at time of Synapse 1.0 transition Signed-off-by: Aaron Raimist <aaron@raim.ist> * Add changelog Signed-off-by: Aaron Raimist <aaron@raim.ist>
* Merge branch 'master' into developRichard van der Hoff2019-12-315-16/+98
|\
| * 1.7.3 v1.7.3 github/release-v1.7.3 release-v1.7.3Richard van der Hoff2019-12-314-2/+18
| |
| * Hacks to work around #6605 (#6608)Richard van der Hoff2019-12-312-15/+38
| | | | | | | | | | When we have an event which refers to non-existent auth_events, ignore said events rather than exploding in a ball of fire. Fixes #6605.
| * sample log config 1.7.2Richard van der Hoff2019-12-241-0/+43
| | | | | | | | TODO: automate generation of this
| * Update reverse proxy file name (#6590)dopple2019-12-221-1/+1
| | | | | | s/reverse_proxy.rst/reverse_proxy.md/
* | Update reverse proxy file name (#6590)dopple2019-12-221-1/+1
| | | | | | s/reverse_proxy.rst/reverse_proxy.md/
* | Merge branch 'master' into developRichard van der Hoff2019-12-204-2/+23
|\|
| * Merge tag 'v1.7.2'Richard van der Hoff2019-12-205-3/+32
| |\ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Synapse 1.7.2 (2019-12-20) ========================== This release fixes some regressions introduced in Synapse 1.7.0 and 1.7.1. Bugfixes -------- - Fix a regression introduced in Synapse 1.7.1 which caused errors when attempting to backfill rooms over federation. ([\#6576](https://github.com/matrix-org/synapse/issues/6576)) - Fix a bug introduced in Synapse 1.7.0 which caused an error on startup when upgrading from versions before 1.3.0. ([\#6578](https://github.com/matrix-org/synapse/issues/6578))
| | * 1.7.2 v1.7.2 github/release-v1.7.2 release-v1.7.2Richard van der Hoff2019-12-205-3/+19
| | |
| | * Backport fixes to sqlite upgrade from develop (#6578)Richard van der Hoff2019-12-202-1/+10
| | | | | | | | | | | | | | | Only run prepare_database on connection for in-memory databases. Fixes #6569.
| | * Fix exceptions when attempting to backfill (#6576)Richard van der Hoff2019-12-202-1/+5
| | | | | | | | | Fixes #6575
* | | Split state groups into a separate data store (#6296)Erik Johnston2019-12-2028-1168/+1159
| | |
* | | Change EventContext to use the Storage class (#6564)Erik Johnston2019-12-2015-53/+64
| | |
* | | Explode on duplicate delta file names. (#6565)Erik Johnston2019-12-192-0/+19
| | |
* | | Port some admin handlers to async/await (#6559)Erik Johnston2019-12-194-56/+46
| | |
* | | Improve diagnostics on database upgrade failure (#6570)Richard van der Hoff2019-12-193-8/+7
| | | | | | | | | | | | `Failed to upgrade database` is not helpful, and it's unlikely that UPGRADE.rst has anything useful.
* | | Fix sdnotify with acme enabled (#6571)Richard van der Hoff2019-12-192-3/+8
| | | | | | | | | | | | | | | | | | | | | If acme was enabled, the sdnotify startup hook would never be run because we would try to add it to a hook which had already fired. There's no need to delay it: we can sdnotify as soon as we've started the listeners.
* | | Add an export_signing_key script (#6546)Richard van der Hoff2019-12-195-22/+130
| | | | | | | | | | | | | | | I want to do some key rotation, and it is silly that we don't have a way to do this.
* | | Clean up startup for the pusher (#6558)Richard van der Hoff2019-12-187-43/+45
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Remove redundant python2 support code `str.decode()` doesn't exist on python3, so presumably this code was doing nothing * Filter out pushers with corrupt data When we get a row with unparsable json, drop the row, rather than returning a row with null `data`, which will then cause an explosion later on. * Improve logging when we can't start a pusher Log the ID to help us understand the problem * Make email pusher setup more robust We know we'll have a `data` member, since that comes from the database. What we *don't* know is if that is a dict, and if that has a `brand` member, and if that member is a string.
* | | Add delta file to fix missing default table data (#6555)Andrew Morgan2019-12-184-15/+24
| | |
* | | Add database config class (#6513)Erik Johnston2019-12-1819-209/+287
| | | | | | | | | | | | | | | This encapsulates config for a given database and is the way to get new connections.
* | | Merge branch 'master' into developRichard van der Hoff2019-12-1814-15/+25
|\| |
| * | Merge tag 'v1.7.1'Richard van der Hoff2019-12-1815-373/+547
| |\| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Synapse 1.7.1 (2019-12-18) ========================== This release includes several security fixes as well as a fix to a bug exposed by the security fixes. Administrators are encouraged to upgrade as soon as possible. Security updates ---------------- - Fix a bug which could cause room events to be incorrectly authorized using events from a different room. ([\#6501](https://github.com/matrix-org/synapse/issues/6501), [\#6503](https://github.com/matrix-org/synapse/issues/6503), [\#6521](https://github.com/matrix-org/synapse/issues/6521), [\#6524](https://github.com/matrix-org/synapse/issues/6524), [\#6530](https://github.com/matrix-org/synapse/issues/6530), [\#6531](https://github.com/matrix-org/synapse/issues/6531)) - Fix a bug causing responses to the `/context` client endpoint to not use the pruned version of the event. ([\#6553](https://github.com/matrix-org/synapse/issues/6553)) - Fix a cause of state resets in room versions 2 onwards. ([\#6556](https://github.com/matrix-org/synapse/issues/6556), [\#6560](https://github.com/matrix-org/synapse/issues/6560)) Bugfixes -------- - Fix a bug which could cause the federation server to incorrectly return errors when handling certain obscure event graphs. ([\#6526](https://github.com/matrix-org/synapse/issues/6526), [\#6527](https://github.com/matrix-org/synapse/issues/6527))
| | * too many parens v1.7.1 github/release-v1.7.1 release-v1.7.1Richard van der Hoff2019-12-181-1/+1
| | |
| | * 1.7.1Richard van der Hoff2019-12-1814-15/+25
| | |
* | | Merge release-v1.7.1 into developRichard van der Hoff2019-12-187-10/+145
|\ \ \ | | |/ | |/|
| * | Fix bug where we added duplicate event IDs as auth_events (#6560)Erik Johnston2019-12-172-7/+9
| | |
| * | Add auth events as per spec. (#6556)Erik Johnston2019-12-162-67/+35
| | | | | | | | | | | | | | | Previously we tried to be clever and filter out some unnecessary event IDs to keep the auth chain small, but that had some annoying interactions with state res v2 so we stop doing that for now.
| * | Merge pull request #6553 from matrix-org/babolivier/fix-context-filterBrendan Abolivier2019-12-164-3/+135
| |\ \ | | | | | | | | Use the filtered version of an event when responding to /context requests for that event
| | * \ Merge branch 'babolivier/fix-context-filter' of ↵Brendan Abolivier2019-12-161-1/+1
| | |\ \ | | | | | | | | | | | | | | | github.com:matrix-org/synapse into babolivier/fix-context-filter
| | | * | Update changelog.d/6553.bugfixBrendan Abolivier2019-12-161-1/+1
| | | | | | | | | | | | | | | Co-Authored-By: Andrew Morgan <1342360+anoadragon453@users.noreply.github.com>
| | * | | Incorporate reviewBrendan Abolivier2019-12-162-6/+1
| | |/ /
| | * | LintBrendan Abolivier2019-12-161-2/+1
| | | |
| | * | Add test caseBrendan Abolivier2019-12-161-0/+133
| | | |
| | * | ChangelogBrendan Abolivier2019-12-161-0/+1
| | | |
| | * | Update the documentation of the filtering functionBrendan Abolivier2019-12-161-1/+2
| | | |
| | * | Use the filtered version of an event when responding to /context requests ↵Brendan Abolivier2019-12-161-1/+4
| | | | | | | | | | | | | | | | | | | | | | | | for that event Sometimes the filtering function can return a pruned version of an event (on top of either the event itself or an empty list), if it thinks the user should be able to see that there's an event there but not the content of that event. Therefore, the previous logic of 'if filtered is empty then we can use the event we retrieved from the database' is flawed, and we should use the event returned by the filtering function.
| * | | Exclude rejected state events when calculating state at backwards extrems ↵Richard van der Hoff2019-12-162-1/+2
| | | | | | | | | | | | | | | | | | | | (#6527) This fixes a weird bug where, if you were determined enough, you could end up with a rejected event forming part of the state at a backwards-extremity. Authing that backwards extrem would then lead to us trying to pull the rejected event from the db (with allow_rejected=False), which would fail with a 404.
| * | | Persist auth/state events at backwards extremities when we fetch them (#6526)Richard van der Hoff2019-12-163-165/+83
| | | | | | | | | | | | | | | | The main point here is to make sure that the state returned by _get_state_in_room has been authed before we try to use it as state in the room.
| * | | sanity-checking for events used in state res (#6531)Richard van der Hoff2019-12-166-43/+128
| | | | | | | | | | | | | | | | | | | | When we perform state resolution, check that all of the events involved are in the right room.
| * | | Sanity-check room ids in event auth (#6530)Richard van der Hoff2019-12-162-0/+14
| | | | | | | | | | | | | | | | When we do an event auth operation, check that all of the events involved are in the right room.
| * | | Check the room_id of events when fetching room state/auth (#6524)Richard van der Hoff2019-12-162-24/+56
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | When we request the state/auth_events to populate a backwards extremity (on backfill or in the case of missing events in a transaction push), we should check that the returned events are in the right room rather than blindly using them in the room state or auth chain. Given that _get_events_from_store_or_dest takes a room_id, it seems clear that it should be sanity-checking the room_id of the requested events, so let's do it there.
| * | | Add `include_event_in_state` to _get_state_for_room (#6521)Richard van der Hoff2019-12-162-18/+22
| | | | | | | | | | | | | | | | | | | | | | | | Make it return the state *after* the requested event, rather than the one before it. This is a bit easier and requires fewer calls to get_events_from_store_or_dest.
| * | | Move get_state methods into FederationHandler (#6503)Richard van der Hoff2019-12-163-86/+107
| | | | | | | | | | | | | | | | | | | | This is a non-functional refactor as a precursor to some other work.
| * | | Refactor get_events_from_store_or_dest to return a dict (#6501)Richard van der Hoff2019-12-162-29/+16
| |/ / | | | | | | | | | | | | There was a bunch of unnecessary conversion back and forth between dict and list going on here. We can simplify a bunch of the code.
* | | Remove unused `get_pagination_rows` methods. (#6557)Erik Johnston2019-12-174-18/+1
| | | | | | | | | Remove unused get_pagination_rows methods
* | | Add auth events as per spec. (#6556)Erik Johnston2019-12-162-67/+35
| | | | | | | | | | | | | | | Previously we tried to be clever and filter out some unnecessary event IDs to keep the auth chain small, but that had some annoying interactions with state res v2 so we stop doing that for now.
* | | Add option to allow profile queries without sharing a room (#6523)Will Hunt2019-12-165-1/+28
| | |
* | | Exclude rejected state events when calculating state at backwards extrems ↵Richard van der Hoff2019-12-162-1/+2
| | | | | | | | | | | | | | | (#6527) This fixes a weird bug where, if you were determined enough, you could end up with a rejected event forming part of the state at a backwards-extremity. Authing that backwards extrem would then lead to us trying to pull the rejected event from the db (with allow_rejected=False), which would fail with a 404.
* | | Persist auth/state events at backwards extremities when we fetch them (#6526)Richard van der Hoff2019-12-163-169/+83
| | | | | | | | | The main point here is to make sure that the state returned by _get_state_in_room has been authed before we try to use it as state in the room.
* | | Automatically delete empty groups/communities (#6453)Werner Sembach2019-12-164-0/+38
| | | | | | | | | Signed-off-by: Werner Sembach <werner.sembach@fau.de>
* | | Document Shutdown Room admin API (#6541)Andrew Morgan2019-12-132-0/+73
| | |
* | | sanity-checking for events used in state res (#6531)Richard van der Hoff2019-12-136-43/+128
| | | | | | | | | | | | | | | | | | | | | When we perform state resolution, check that all of the events involved are in the right room.
* | | Sanity-check room ids in event auth (#6530)Richard van der Hoff2019-12-132-0/+14
| | | | | | | | | | | | When we do an event auth operation, check that all of the events involved are in the right room.
* | | Merge pull request #6537 from matrix-org/erikj/bump_mypy_versionErik Johnston2019-12-138-7/+13
|\ \ \ | | | | | | | | Bump mypy version
| * | | NewsfileErik Johnston2019-12-121-0/+1
| | | |
| * | | Bump version of mypyErik Johnston2019-12-127-7/+12
| | | |
* | | | Merge branch 'master' into developErik Johnston2019-12-134-2/+32
|\ \ \ \ | | |_|/ | |/| |
| * | | Merge tag 'v1.7.0'Erik Johnston2019-12-13228-4794/+7883
| |\ \ \ | | | |/ | | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Synapse 1.7.0 (2019-12-13) ========================== This release changes the default settings so that only local authenticated users can query the server's room directory. See the [upgrade notes](UPGRADE.rst#upgrading-to-v170) for details. Support for SQLite versions before 3.11 is now deprecated. A future release will refuse to start if used with an SQLite version before 3.11. Administrators are reminded that SQLite should not be used for production instances. Instructions for migrating to Postgres are available [here](docs/postgres.md). A future release of synapse will, by default, disable federation for servers using SQLite. No significant changes since 1.7.0rc2. Synapse 1.7.0rc2 (2019-12-11) ============================= Bugfixes -------- - Fix incorrect error message for invalid requests when setting user's avatar URL. ([\#6497](https://github.com/matrix-org/synapse/issues/6497)) - Fix support for SQLite 3.7. ([\#6499](https://github.com/matrix-org/synapse/issues/6499)) - Fix regression where sending email push would not work when using a pusher worker. ([\#6507](https://github.com/matrix-org/synapse/issues/6507), [\#6509](https://github.com/matrix-org/synapse/issues/6509)) Synapse 1.7.0rc1 (2019-12-09) ============================= Features -------- - Implement per-room message retention policies. ([\#5815](https://github.com/matrix-org/synapse/issues/5815), [\#6436](https://github.com/matrix-org/synapse/issues/6436)) - Add etag and count fields to key backup endpoints to help clients guess if there are new keys. ([\#5858](https://github.com/matrix-org/synapse/issues/5858)) - Add `/admin/v2/users` endpoint with pagination. Contributed by Awesome Technologies Innovationslabor GmbH. ([\#5925](https://github.com/matrix-org/synapse/issues/5925)) - Require User-Interactive Authentication for `/account/3pid/add`, meaning the user's password will be required to add a third-party ID to their account. ([\#6119](https://github.com/matrix-org/synapse/issues/6119)) - Implement the `/_matrix/federation/unstable/net.atleastfornow/state/<context>` API as drafted in MSC2314. ([\#6176](https://github.com/matrix-org/synapse/issues/6176)) - Configure privacy-preserving settings by default for the room directory. ([\#6355](https://github.com/matrix-org/synapse/issues/6355)) - Add ephemeral messages support by partially implementing [MSC2228](https://github.com/matrix-org/matrix-doc/pull/2228). ([\#6409](https://github.com/matrix-org/synapse/issues/6409)) - Add support for [MSC 2367](https://github.com/matrix-org/matrix-doc/pull/2367), which allows specifying a reason on all membership events. ([\#6434](https://github.com/matrix-org/synapse/issues/6434)) Bugfixes -------- - Transfer non-standard power levels on room upgrade. ([\#6237](https://github.com/matrix-org/synapse/issues/6237)) - Fix error from the Pillow library when uploading RGBA images. ([\#6241](https://github.com/matrix-org/synapse/issues/6241)) - Correctly apply the event filter to the `state`, `events_before` and `events_after` fields in the response to `/context` requests. ([\#6329](https://github.com/matrix-org/synapse/issues/6329)) - Fix caching devices for remote users when using workers, so that we don't attempt to refetch (and potentially fail) each time a user requests devices. ([\#6332](https://github.com/matrix-org/synapse/issues/6332)) - Prevent account data syncs getting lost across TCP replication. ([\#6333](https://github.com/matrix-org/synapse/issues/6333)) - Fix bug: TypeError in `register_user()` while using LDAP auth module. ([\#6406](https://github.com/matrix-org/synapse/issues/6406)) - Fix an intermittent exception when handling read-receipts. ([\#6408](https://github.com/matrix-org/synapse/issues/6408)) - Fix broken guest registration when there are existing blocks of numeric user IDs. ([\#6420](https://github.com/matrix-org/synapse/issues/6420)) - Fix startup error when http proxy is defined. ([\#6421](https://github.com/matrix-org/synapse/issues/6421)) - Fix error when using synapse_port_db on a vanilla synapse db. ([\#6449](https://github.com/matrix-org/synapse/issues/6449)) - Fix uploading multiple cross signing signatures for the same user. ([\#6451](https://github.com/matrix-org/synapse/issues/6451)) - Fix bug which lead to exceptions being thrown in a loop when a cross-signed device is deleted. ([\#6462](https://github.com/matrix-org/synapse/issues/6462)) - Fix `synapse_port_db` not exiting with a 0 code if something went wrong during the port process. ([\#6470](https://github.com/matrix-org/synapse/issues/6470)) - Improve sanity-checking when receiving events over federation. ([\#6472](https://github.com/matrix-org/synapse/issues/6472)) - Fix inaccurate per-block Prometheus metrics. ([\#6491](https://github.com/matrix-org/synapse/issues/6491)) - Fix small performance regression for sending invites. ([\#6493](https://github.com/matrix-org/synapse/issues/6493)) - Back out cross-signing code added in Synapse 1.5.0, which caused a performance regression. ([\#6494](https://github.com/matrix-org/synapse/issues/6494)) Improved Documentation ---------------------- - Update documentation and variables in user contributed systemd reference file. ([\#6369](https://github.com/matrix-org/synapse/issues/6369), [\#6490](https://github.com/matrix-org/synapse/issues/6490)) - Fix link in the user directory documentation. ([\#6388](https://github.com/matrix-org/synapse/issues/6388)) - Add build instructions to the docker readme. ([\#6390](https://github.com/matrix-org/synapse/issues/6390)) - Switch Ubuntu package install recommendation to use python3 packages in INSTALL.md. ([\#6443](https://github.com/matrix-org/synapse/issues/6443)) - Write some docs for the quarantine_media api. ([\#6458](https://github.com/matrix-org/synapse/issues/6458)) - Convert CONTRIBUTING.rst to markdown (among other small fixes). ([\#6461](https://github.com/matrix-org/synapse/issues/6461)) Deprecations and Removals ------------------------- - Remove admin/v1/users_paginate endpoint. Contributed by Awesome Technologies Innovationslabor GmbH. ([\#5925](https://github.com/matrix-org/synapse/issues/5925)) - Remove fallback for federation with old servers which lack the /federation/v1/state_ids API. ([\#6488](https://github.com/matrix-org/synapse/issues/6488)) Internal Changes ---------------- - Add benchmarks for structured logging and improve output performance. ([\#6266](https://github.com/matrix-org/synapse/issues/6266)) - Improve the performance of outputting structured logging. ([\#6322](https://github.com/matrix-org/synapse/issues/6322)) - Refactor some code in the event authentication path for clarity. ([\#6343](https://github.com/matrix-org/synapse/issues/6343), [\#6468](https://github.com/matrix-org/synapse/issues/6468), [\#6480](https://github.com/matrix-org/synapse/issues/6480)) - Clean up some unnecessary quotation marks around the codebase. ([\#6362](https://github.com/matrix-org/synapse/issues/6362)) - Complain on startup instead of 500'ing during runtime when `public_baseurl` isn't set when necessary. ([\#6379](https://github.com/matrix-org/synapse/issues/6379)) - Add a test scenario to make sure room history purges don't break `/messages` in the future. ([\#6392](https://github.com/matrix-org/synapse/issues/6392)) - Clarifications for the email configuration settings. ([\#6423](https://github.com/matrix-org/synapse/issues/6423)) - Add more tests to the blacklist when running in worker mode. ([\#6429](https://github.com/matrix-org/synapse/issues/6429)) - Refactor data store layer to support multiple databases in the future. ([\#6454](https://github.com/matrix-org/synapse/issues/6454), [\#6464](https://github.com/matrix-org/synapse/issues/6464), [\#6469](https://github.com/matrix-org/synapse/issues/6469), [\#6487](https://github.com/matrix-org/synapse/issues/6487)) - Port synapse.rest.client.v1 to async/await. ([\#6482](https://github.com/matrix-org/synapse/issues/6482)) - Port synapse.rest.client.v2_alpha to async/await. ([\#6483](https://github.com/matrix-org/synapse/issues/6483)) - Port SyncHandler to async/await. ([\#6484](https://github.com/matrix-org/synapse/issues/6484))
| | * | More rewording of changelog. v1.7.0 github/release-v1.7.0 release-v1.7.0Erik Johnston2019-12-131-1/+1
| | | |
| | * | Reword changelogErik Johnston2019-12-131-2/+2
| | | |
| | * | Add deprecation notesErik Johnston2019-12-131-1/+7
| | | |
| | * | 1.7.0Erik Johnston2019-12-133-1/+13
| | | |
| * | | Update workers.md to make media_repository work (again) (#6519)Mark Nowiasz2019-12-111-1/+13
| | | |
| * | | Remove #6369 changelogAndrew Morgan2019-12-051-1/+0
| | | |
* | | | Adjust the sytest blacklist for worker mode (#6538)Richard van der Hoff2019-12-132-29/+5
| | | | | | | | | | | | | | | | | | | | Remove tests that got blacklisted while torturing was enabled, and add one that fails.
* | | | Merge pull request #6496 from matrix-org/erikj/initial_sync_asnycErik Johnston2019-12-132-52/+45
|\ \ \ \ | | | | | | | | | | Port synapse.handlers.initial_sync to async/await
| * \ \ \ Merge branch 'develop' of github.com:matrix-org/synapse into ↵Erik Johnston2019-12-11156-850/+1627
| |\ \ \ \ | | | | | | | | | | | | | | | | | | erikj/initial_sync_asnyc
| * | | | | NewsfileErik Johnston2019-12-091-0/+1
| | | | | |
| * | | | | Port synapse.handlers.initial_sync to async/awaitErik Johnston2019-12-091-52/+44
| | | | | |
* | | | | | Merge pull request #6534 from matrix-org/erikj/extend_mypyErik Johnston2019-12-122-1/+14
|\ \ \ \ \ \ | | |_|_|_|/ | |/| | | | Include more folders in mypy
| * | | | | NewsfileErik Johnston2019-12-121-0/+1
| | | | | |
| * | | | | Include more folders in mypyErik Johnston2019-12-121-1/+13
| | | | | |
* | | | | | look up cross-signing keys from the DB in bulk (#6486)Hubert Chathi2019-12-125-21/+242
| | | | | |
* | | | | | Fix redacted events being returned in search results ordered by "recent" (#6522)Andrew Morgan2019-12-122-3/+9
|/ / / / /
* | | | | Check the room_id of events when fetching room state/auth (#6524)Richard van der Hoff2019-12-122-23/+53
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | When we request the state/auth_events to populate a backwards extremity (on backfill or in the case of missing events in a transaction push), we should check that the returned events are in the right room rather than blindly using them in the room state or auth chain. Given that _get_events_from_store_or_dest takes a room_id, it seems clear that it should be sanity-checking the room_id of the requested events, so let's do it there.
* | | | | Merge pull request #6511 from matrix-org/erikj/remove_db_config_from_appsErik Johnston2019-12-1217-102/+27
|\ \ \ \ \ | |_|/ / / |/| | | | Move database config from apps into HomeServer object
| * | | | Add new config param to docstring and add typesErik Johnston2019-12-111-1/+3
| | | | |
| * | | | NewsfileErik Johnston2019-12-101-0/+1
| | | | |
| * | | | Fix upgrade db scriptErik Johnston2019-12-101-27/+6
| | | | |
| * | | | Remove database config parsing from apps.Erik Johnston2019-12-1015-75/+18
| | | | |
* | | | | Add `include_event_in_state` to _get_state_for_room (#6521)Richard van der Hoff2019-12-112-22/+29
| | | | | | | | | | | | | | | | | | | | | | | | | Make it return the state *after* the requested event, rather than the one before it. This is a bit easier and requires fewer calls to get_events_from_store_or_dest.
* | | | | Merge pull request #6517 from matrix-org/rav/event_auth/13Richard van der Hoff2019-12-114-103/+98
|\ \ \ \ \ | | | | | | | | | | | | Port some of FederationHandler to async/await
| * | | | | changelogRichard van der Hoff2019-12-111-0/+1
| | | | | |
| * | | | | convert to async: FederationHandler._process_received_pduRichard van der Hoff2019-12-111-11/+10
| | | | | | | | | | | | | | | | | | | | | | | | also fix user_joined_room to consistently return deferreds
| * | | | | convert to async: FederationHandler._get_state_for_roomRichard van der Hoff2019-12-111-21/+21
| | | | | | | | | | | | | | | | | | | | | | | | ... and _get_events_from_store_or_dest
| * | | | | convert to async: FederationHandler.on_receive_pduRichard van der Hoff2019-12-112-32/+31
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | and associated functions: * on_receive_pdu * handle_queued_pdus * get_missing_events_for_pdu
| * | | | | Convert federation backfill to asyncRichard van der Hoff2019-12-112-39/+35
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | PaginationHandler.get_messages is only called by RoomMessageListRestServlet, which is async. Chase the code path down from there: - FederationHandler.maybe_backfill (and nested try_backfill) - FederationHandler.backfill
* | | | | | Merge pull request #6504 from matrix-org/erikj/account_validity_async_awaitErik Johnston2019-12-114-57/+47
|\ \ \ \ \ \ | |/ / / / / |/| | | | | Port handlers.account_validity to async/await.
| * | | | | NewsfileErik Johnston2019-12-101-0/+1
| | | | | |
| * | | | | Port handlers.account_validity to async/await.Erik Johnston2019-12-103-49/+42
| | | | | |
| * | | | | Port handlers.account_data to async/await.Erik Johnston2019-12-101-9/+5
| |/ / / /
* | | | | Clean up some logging (#6515)Richard van der Hoff2019-12-112-18/+20
| | | | | | | | | | | | | | | | | | | | This just makes some of the logging easier to follow when things start going wrong.
* | | | | Merge tag 'v1.7.0rc2' into developErik Johnston2019-12-117-21/+34
|\ \ \ \ \ | | |_|_|/ | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Synapse 1.7.0rc2 (2019-12-11) ============================= Bugfixes -------- - Fix incorrect error message for invalid requests when setting user's avatar URL. ([\#6497](https://github.com/matrix-org/synapse/issues/6497)) - Fix support for SQLite 3.7. ([\#6499](https://github.com/matrix-org/synapse/issues/6499)) - Fix regression where sending email push would not work when using a pusher worker. ([\#6507](https://github.com/matrix-org/synapse/issues/6507), [\#6509](https://github.com/matrix-org/synapse/issues/6509))
| * | | | 1.7.0rc2 v1.7.0rc2Erik Johnston2019-12-116-5/+12
| | | | |
| * | | | Back out change preventing setting null avatar URLsErik Johnston2019-12-112-7/+7
| | | | |
| * | | | Merge branch 'erikj/fix_sqlite_7' of github.com:matrix-org/synapse into ↵Erik Johnston2019-12-118-14/+51
| |\ \ \ \ | | | | | | | | | | | | | | | | | | release-v1.7.0
| * | | | | Fixup changelogsBrendan Abolivier2019-12-102-2/+2
| | | | | |
| * | | | | Merge pull request #6509 from matrix-org/babolivier/fix-room-store-configErik Johnston2019-12-102-0/+6
| |\ \ \ \ \ | | | | | | | | | | | | | | Give the server config to the RoomWorkerStore
| | * | | | | ChangelogBrendan Abolivier2019-12-101-0/+1
| | | | | | |
| | * | | | | Give the server config to the RoomWorkerStoreBrendan Abolivier2019-12-101-0/+5
| |/ / / / /
| * | | | | Merge pull request #6507 from matrix-org/babolivier/pusher-room-storeErik Johnston2019-12-102-1/+7
| |\ \ \ \ \ | | | | | | | | | | | | | | Make the PusherSlaveStore inherit from the slave RoomStore
| | * | | | | ChangelogBrendan Abolivier2019-12-101-0/+1
| | | | | | |
| | * | | | | Make the PusherSlaveStore inherit from the slave RoomStoreBrendan Abolivier2019-12-101-1/+6
| |/ / / / / | | | | | | | | | | | | | | | | | | So that it has access to the get_retention_policy_for_room function which is required by filter_events_for_client.
| * | | | | Fix erroneous reference for new room directory defaults.Neil Johnson2019-12-101-1/+1
| | | | | |
| * | | | | Update CHANGES.mdNeil Johnson2019-12-091-11/+5
| | | | | |
* | | | | | Prevent redacted events from appearing in message search (#6377)Andrew Morgan2019-12-116-43/+78
| | | | | |
* | | | | | Add dev script to generate full SQL schema files (#6394)Andrew Morgan2019-12-114-19/+198
| | | | | |
* | | | | | Prevent message search in upgraded rooms we're not in (#6385)Andrew Morgan2019-12-114-16/+41
| | | | | |
* | | | | | Merge pull request #6349 from matrix-org/babolivier/msc1802Brendan Abolivier2019-12-115-28/+141
|\ \ \ \ \ \ | | | | | | | | | | | | | | Implement v2 APIs for send_join and send_leave
| * \ \ \ \ \ Merge branch 'develop' into babolivier/msc1802Brendan Abolivier2019-12-05300-3004/+6193
| |\ \ \ \ \ \
| * \ \ \ \ \ \ Merge branch 'develop' into babolivier/msc1802Brendan Abolivier2019-11-142-0/+3
| |\ \ \ \ \ \ \
| * | | | | | | | LintBrendan Abolivier2019-11-111-3/+2
| | | | | | | | |
| * | | | | | | | ChangelogBrendan Abolivier2019-11-111-0/+1
| | | | | | | | |
| * | | | | | | | LintBrendan Abolivier2019-11-111-3/+1
| | | | | | | | |
| * | | | | | | | Fix prefix for v2/send_leaveBrendan Abolivier2019-11-111-0/+2
| | | | | | | | |
| * | | | | | | | Add server-side support to the v2 APIBrendan Abolivier2019-11-112-14/+33
| | | | | | | | |
| * | | | | | | | Implement v2 API for send_leaveBrendan Abolivier2019-11-112-5/+56
| | | | | | | | |
| * | | | | | | | Add missing yieldBrendan Abolivier2019-11-111-1/+1
| | | | | | | | |
| * | | | | | | | Implement v2 API for send_joinBrendan Abolivier2019-11-112-8/+51
| | | | | | | | |
* | | | | | | | | Merge pull request #6512 from matrix-org/erikj/silence_mypyErik Johnston2019-12-112-1/+2
|\ \ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | Silence mypy errors for files outside those specified
| * | | | | | | | | NewsfileErik Johnston2019-12-101-0/+1
| | | | | | | | | |
| * | | | | | | | | Silence mypy errors for files outside those specifiedErik Johnston2019-12-101-1/+1
| | |_|_|_|_|/ / / | |/| | | | | | |
* | | | | | | | | Move get_state methods into FederationHandler (#6503)Richard van der Hoff2019-12-103-86/+107
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is a non-functional refactor as a precursor to some other work.
* | | | | | | | | Allow SAML username provider plugins (#6411)Andrew Morgan2019-12-105-106/+417
| | | | | | | | |
* | | | | | | | | Merge pull request #6510 from matrix-org/erikj/phone_home_stats_dbErik Johnston2019-12-102-2/+5
|\ \ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | Phone home stats DB reporting should not assume a single DB.
| * | | | | | | | | NewsfileErik Johnston2019-12-101-0/+1
| | | | | | | | | |
| * | | | | | | | | Phone home stats DB reporting should not assume a single DB.Erik Johnston2019-12-101-2/+4
| |/ / / / / / / /
* | | | | | | | | Fix race which caused deleted devices to reappear (#6514)Richard van der Hoff2019-12-103-23/+35
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Stop the `update_client_ips` background job from recreating deleted devices.
* | | | | | | | | Refactor get_events_from_store_or_dest to return a dict (#6501)Richard van der Hoff2019-12-102-29/+16
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | There was a bunch of unnecessary conversion back and forth between dict and list going on here. We can simplify a bunch of the code.
* | | | | | | | | Remove redundant code from event authorisation implementation. (#6502)Richard van der Hoff2019-12-102-6/+3
| | | | | | | | |
* | | | | | | | | Merge pull request #6505 from matrix-org/erikj/make_deferred_yiedableErik Johnston2019-12-103-1/+35
|\ \ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | Fix `make_deferred_yieldable` to work with coroutines
| * | | | | | | | | Update commentErik Johnston2019-12-101-2/+4
| | | | | | | | | |
| * | | | | | | | | NewsfileErik Johnston2019-12-101-0/+1
| | | | | | | | | |
| * | | | | | | | | Fix make_deferred_yieldable to work with coroutinesErik Johnston2019-12-102-1/+32
| |/ / / / / / / /
* | | | | | | | | Merge pull request #6499 from matrix-org/erikj/fix_sqlite_7Erik Johnston2019-12-106-11/+42
|\ \ \ \ \ \ \ \ \ | | |_|_|_|_|/ / / | |/| | | | | | | Fix support for SQLite 3.7.
| * | | | | | | | Drop unused indexErik Johnston2019-12-104-13/+18
| | | | | | | | |
| * | | | | | | | Convert _censor_redactions to async since it awaits on coroutinesErik Johnston2019-12-101-11/+9
| | | | | | | | |
| * | | | | | | | Only start censor background job after indices are createdErik Johnston2019-12-102-2/+9
| | | | | | | | |
| * | | | | | | | NewsfileErik Johnston2019-12-091-0/+1
| | | | | | | | |
| * | | | | | | | Fix support for SQLite 3.7.Erik Johnston2019-12-093-2/+22
| |/ / / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Partial indices support was added in 3.8.0, so we need to use the background updates that handles this correctly.
* | | | | | | | Merge pull request #6506 from matrix-org/erikj/remove_snapshot_cacheErik Johnston2019-12-104-168/+9
|\ \ \ \ \ \ \ \ | |/ / / / / / / |/| | | | | | | Remove SnapshotCache in favour of ResponseCache
| * | | | | | | NewsfileErik Johnston2019-12-101-0/+1
| | |_|_|_|/ / | |/| | | | |
| * | | | | | Remove SnapshotCache in favour of ResponseCacheErik Johnston2019-12-093-168/+8
| | | | | | |
* | | | | | | Merge tag 'v1.7.0rc1' into developNeil Johnson2019-12-0955-54/+80
|\ \ \ \ \ \ \ | | |_|_|_|/ / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Synapse 1.7.0rc1 (2019-12-09) ============================= Features -------- - Implement per-room message retention policies. ([\#5815](https://github.com/matrix-org/synapse/issues/5815), [\#6436](https://github.com/matrix-org/synapse/issues/6436)) - Add etag and count fields to key backup endpoints to help clients guess if there are new keys. ([\#5858](https://github.com/matrix-org/synapse/issues/5858)) - Add `/admin/v2/users` endpoint with pagination. Contributed by Awesome Technologies Innovationslabor GmbH. ([\#5925](https://github.com/matrix-org/synapse/issues/5925)) - Require User-Interactive Authentication for `/account/3pid/add`, meaning the user's password will be required to add a third-party ID to their account. ([\#6119](https://github.com/matrix-org/synapse/issues/6119)) - Implement the `/_matrix/federation/unstable/net.atleastfornow/state/<context>` API as drafted in MSC2314. ([\#6176](https://github.com/matrix-org/synapse/issues/6176)) - Configure privacy-preserving settings by default for the room directory. ([\#6354](https://github.com/matrix-org/synapse/issues/6354)) - Add ephemeral messages support by partially implementing [MSC2228](https://github.com/matrix-org/matrix-doc/pull/2228). ([\#6409](https://github.com/matrix-org/synapse/issues/6409)) - Add support for [MSC 2367](https://github.com/matrix-org/matrix-doc/pull/2367), which allows specifying a reason on all membership events. ([\#6434](https://github.com/matrix-org/synapse/issues/6434)) Bugfixes -------- - Transfer non-standard power levels on room upgrade. ([\#6237](https://github.com/matrix-org/synapse/issues/6237)) - Fix error from the Pillow library when uploading RGBA images. ([\#6241](https://github.com/matrix-org/synapse/issues/6241)) - Correctly apply the event filter to the `state`, `events_before` and `events_after` fields in the response to `/context` requests. ([\#6329](https://github.com/matrix-org/synapse/issues/6329)) - Fix caching devices for remote users when using workers, so that we don't attempt to refetch (and potentially fail) each time a user requests devices. ([\#6332](https://github.com/matrix-org/synapse/issues/6332)) - Prevent account data syncs getting lost across TCP replication. ([\#6333](https://github.com/matrix-org/synapse/issues/6333)) - Fix bug: TypeError in `register_user()` while using LDAP auth module. ([\#6406](https://github.com/matrix-org/synapse/issues/6406)) - Fix an intermittent exception when handling read-receipts. ([\#6408](https://github.com/matrix-org/synapse/issues/6408)) - Fix broken guest registration when there are existing blocks of numeric user IDs. ([\#6420](https://github.com/matrix-org/synapse/issues/6420)) - Fix startup error when http proxy is defined. ([\#6421](https://github.com/matrix-org/synapse/issues/6421)) - Fix error when using synapse_port_db on a vanilla synapse db. ([\#6449](https://github.com/matrix-org/synapse/issues/6449)) - Fix uploading multiple cross signing signatures for the same user. ([\#6451](https://github.com/matrix-org/synapse/issues/6451)) - Fix bug which lead to exceptions being thrown in a loop when a cross-signed device is deleted. ([\#6462](https://github.com/matrix-org/synapse/issues/6462)) - Fix `synapse_port_db` not exiting with a 0 code if something went wrong during the port process. ([\#6470](https://github.com/matrix-org/synapse/issues/6470)) - Improve sanity-checking when receiving events over federation. ([\#6472](https://github.com/matrix-org/synapse/issues/6472)) - Fix inaccurate per-block Prometheus metrics. ([\#6491](https://github.com/matrix-org/synapse/issues/6491)) - Fix small performance regression for sending invites. ([\#6493](https://github.com/matrix-org/synapse/issues/6493)) - Back out cross-signing code added in Synapse 1.5.0, which caused a performance regression. ([\#6494](https://github.com/matrix-org/synapse/issues/6494)) Improved Documentation ---------------------- - Update documentation and variables in user contributed systemd reference file. ([\#6369](https://github.com/matrix-org/synapse/issues/6369), [\#6490](https://github.com/matrix-org/synapse/issues/6490)) - Fix link in the user directory documentation. ([\#6388](https://github.com/matrix-org/synapse/issues/6388)) - Add build instructions to the docker readme. ([\#6390](https://github.com/matrix-org/synapse/issues/6390)) - Switch Ubuntu package install recommendation to use python3 packages in INSTALL.md. ([\#6443](https://github.com/matrix-org/synapse/issues/6443)) - Write some docs for the quarantine_media api. ([\#6458](https://github.com/matrix-org/synapse/issues/6458)) - Convert CONTRIBUTING.rst to markdown (among other small fixes). ([\#6461](https://github.com/matrix-org/synapse/issues/6461)) Deprecations and Removals ------------------------- - Remove admin/v1/users_paginate endpoint. Contributed by Awesome Technologies Innovationslabor GmbH. ([\#5925](https://github.com/matrix-org/synapse/issues/5925)) - Remove fallback for federation with old servers which lack the /federation/v1/state_ids API. ([\#6488](https://github.com/matrix-org/synapse/issues/6488)) Internal Changes ---------------- - Add benchmarks for structured logging and improve output performance. ([\#6266](https://github.com/matrix-org/synapse/issues/6266)) - Improve the performance of outputting structured logging. ([\#6322](https://github.com/matrix-org/synapse/issues/6322)) - Refactor some code in the event authentication path for clarity. ([\#6343](https://github.com/matrix-org/synapse/issues/6343), [\#6468](https://github.com/matrix-org/synapse/issues/6468), [\#6480](https://github.com/matrix-org/synapse/issues/6480)) - Clean up some unnecessary quotation marks around the codebase. ([\#6362](https://github.com/matrix-org/synapse/issues/6362)) - Complain on startup instead of 500'ing during runtime when `public_baseurl` isn't set when necessary. ([\#6379](https://github.com/matrix-org/synapse/issues/6379)) - Add a test scenario to make sure room history purges don't break `/messages` in the future. ([\#6392](https://github.com/matrix-org/synapse/issues/6392)) - Clarifications for the email configuration settings. ([\#6423](https://github.com/matrix-org/synapse/issues/6423)) - Add more tests to the blacklist when running in worker mode. ([\#6429](https://github.com/matrix-org/synapse/issues/6429)) - Refactor data store layer to support multiple databases in the future. ([\#6454](https://github.com/matrix-org/synapse/issues/6454), [\#6464](https://github.com/matrix-org/synapse/issues/6464), [\#6469](https://github.com/matrix-org/synapse/issues/6469), [\#6487](https://github.com/matrix-org/synapse/issues/6487)) - Port synapse.rest.client.v1 to async/await. ([\#6482](https://github.com/matrix-org/synapse/issues/6482)) - Port synapse.rest.client.v2_alpha to async/await. ([\#6483](https://github.com/matrix-org/synapse/issues/6483)) - Port SyncHandler to async/await. ([\#6484](https://github.com/matrix-org/synapse/issues/6484))
| * | | | | | 1.7.0rc1 v1.7.0rc1Neil Johnson2019-12-0955-54/+79
| | | | | | |
| * | | | | | Systemd documentation (#6490)Clifford Garwood II2019-12-092-1/+2
| | | | | | |
* | | | | | | Better errors regarding changing avatar_url (#6497)Andrew Morgan2019-12-092-3/+9
|/ / / / / /
* | | | | | Back out perf regression from get_cross_signing_keys_from_cache. (#6494)Neil Johnson2019-12-094-30/+20
| | | | | | | | | | | | | | | | | | Back out cross-signing code added in Synapse 1.5.0, which caused a performance regression.
* | | | | | Merge pull request #6487 from matrix-org/erikj/pass_in_dbErik Johnston2019-12-0956-244/+242
|\ \ \ \ \ \ | |/ / / / / |/| | | | | Pass in Database object to data stores.
| * | | | | Fix commentErik Johnston2019-12-091-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | Co-Authored-By: Richard van der Hoff <1389908+richvdh@users.noreply.github.com>
| * | | | | Fix port db scriptErik Johnston2019-12-064-37/+5
| | | | | |
| * | | | | NewsfileErik Johnston2019-12-061-0/+1
| | | | | |
| * | | | | Fixup testsErik Johnston2019-12-066-23/+20
| | | | | |
| * | | | | Move start up DB checks to main data store.Erik Johnston2019-12-062-18/+12
| | | | | |
| * | | | | Pass Database into the data storeErik Johnston2019-12-065-28/+24
| | | | | |
| * | | | | Move are_all_users_on_domain checks to main data store.Erik Johnston2019-12-063-24/+24
| | | | | |
| * | | | | Change DataStores to accept 'database' param.Erik Johnston2019-12-0641-114/+156
| | | | | |
* | | | | | Merge pull request #6493 from matrix-org/erikj/invite_state_configErik Johnston2019-12-092-1/+4
|\ \ \ \ \ \ | | | | | | | | | | | | | | Pull out room_invite_state_types config option once.
| * | | | | | NewsfileErik Johnston2019-12-091-0/+1
| | | | | | |
| * | | | | | Pull out room_invite_state_types config option once.Erik Johnston2019-12-091-1/+3
| |/ / / / / | | | | | | | | | | | | | | | | | | Pulling things out of config is currently surprisingly expensive.
* | | | | | Fix inaccurate per-block metrics (#6491)Richard van der Hoff2019-12-092-42/+19
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | `Measure` incorrectly assumed that it was the only thing being done by the parent `LoggingContext`. For instance, during a "renew group attestations" operation, hundreds of `outbound_request` calls could take place in parallel, all using the same `LoggingContext`. This would mean that any resources used during *any* of those calls would be reported against *all* of them, producing wildly inaccurate results. Instead, we now give each `Measure` block its own `LoggingContext` (using the parent `LoggingContext` mechanism to ensure that the log lines look correct and that the metrics are ultimately propogated to the top level for reporting against requests/backgrond tasks).
* | | | | | Remove fallback for missing /federation/v1/state_ids API (#6488)Richard van der Hoff2019-12-093-96/+18
| | | | | | | | | | | | | | | | | | | | | | | | This API was added way back in 0.17.0; the code here is annoying to maintain and entirely redundant.
* | | | | | Merge pull request #6484 from matrix-org/erikj/port_sync_handlerErik Johnston2019-12-0912-202/+208
|\ \ \ \ \ \ | |/ / / / / |/| | | | | Port SyncHandler to async/await
| * | | | | Fixup functions to consistently return deferredsErik Johnston2019-12-066-14/+28
| | | | | |
| * | | | | NewsfileErik Johnston2019-12-051-0/+1
| | | | | |
| * | | | | Port SyncHandler to async/awaitErik Johnston2019-12-056-191/+182
| | | | | |
* | | | | | Merge pull request #6469 from matrix-org/erikj/make_database_classErik Johnston2019-12-0668-2514/+2685
|\ \ \ \ \ \ | |_|_|_|/ / |/| | | | | Create a Database class and move methods out of SQLBaseStore
| * | | | | Merge branch 'develop' of github.com:matrix-org/synapse into ↵Erik Johnston2019-12-0656-823/+766
| |\ \ \ \ \ | |/ / / / / |/| | | | | | | | | | | erikj/make_database_class
* | | | | | Replace /admin/v1/users_paginate endpoint with /admin/v2/users (#5925)Manuel Stahl2019-12-059-109/+161
| |/ / / / |/| | | |
* | | | | Merge pull request #6483 from matrix-org/erikj/port_rest_v2Erik Johnston2019-12-0524-505/+362
|\ \ \ \ \ | | | | | | | | | | | | Port rest client v2_alpha to async/await
| * | | | | NewsfileErik Johnston2019-12-051-0/+1
| | | | | |
| * | | | | Port rest.client.v2Erik Johnston2019-12-0523-505/+361
|/ / / / /
* | | | | Merge pull request #6482 from matrix-org/erikj/port_rest_v1Erik Johnston2019-12-0515-169/+134
|\ \ \ \ \ | | | | | | | | | | | | Port rest/v1 to async/await
| * | | | | NewsfileErik Johnston2019-12-051-0/+1
| | | | | |
| * | | | | Fixup testsErik Johnston2019-12-053-2/+15
| | | | | |
| * | | | | Port rest/v1 to async/awaitErik Johnston2019-12-0511-167/+118
| | | | | |