summary refs log tree commit diff
Commit message (Collapse)AuthorAgeFilesLines
* Merge remote-tracking branch 'origin/release-v1.11.1' into developPatrick Cloke2020-02-272-6/+9
|\
| * Cast a coroutine into a Deferred in the federation base (#6996)Patrick Cloke2020-02-262-6/+9
| | | | | | | | Properly convert a coroutine into a Deferred in federation_base to fix an error when joining a room.
* | Don't refuse to start worker if media listener configured. (#7002)Erik Johnston2020-02-272-14/+21
| | | | | | | | | | | | | | | | Instead lets just warn if the worker has a media listener configured but has the media repository disabled. Previously non media repository workers would just ignore the media listener.
* | set worker_app for frontend proxy test (#7003)Richard van der Hoff2020-02-272-0/+6
| | | | | | to stop the federationhandler trying to do master stuff
* | Expose common commands via snap run interface to allow easier invocation (#6315)James2020-02-272-5/+17
| | | | | | | | | | Signed-off-by: James Hebden <james@ec0.io>
* | Add some type annotations in `synapse.storage` (#6987)Richard van der Hoff2020-02-278-84/+270
| | | | | | | | | | I cracked, and added some type definitions in synapse.storage.
* | Store room version on invite (#6983)Richard van der Hoff2020-02-267-2/+78
| | | | | | | | | | When we get an invite over federation, store the room version in the rooms table. The general idea here is that, when we pull the invite out again, we'll want to know what room_version it belongs to (so that we can later redact it if need be). So we need to store it somewhere...
* | Port PresenceHandler to async/await (#6991)Erik Johnston2020-02-267-115/+113
| |
* | Updated warning for incorrect database collation/ctype (#6985)Uday Bansal2020-02-262-3/+8
| | | | | | Signed-off-by: Uday Bansal <43824981+udaybansal19@users.noreply.github.com>
* | Ensure 'deactivated' parameter is a boolean on user admin API, Fix error ↵Andrew Morgan2020-02-264-4/+68
| | | | | | | | handling of call to deactivate user (#6990)
* | Sanity-check database before running upgrades (#6982)Richard van der Hoff2020-02-250-0/+0
| | | | | | | | | | | | Some of the database deltas rely on `config.server_name` being set correctly, so we should check that it is before running the deltas. Fixes #6870.
* | Sanity-check database before running upgrades (#6982)Richard van der Hoff2020-02-253-17/+33
| | | | | | | | | | | | Some of the database deltas rely on `config.server_name` being set correctly, so we should check that it is before running the deltas. Fixes #6870.
* | Merge worker apps into one. (#6964)Erik Johnston2020-02-2516-2327/+1052
| |
* | contrib/docker: remove quotes for POSTGRES_INITDB_ARGS (#6984)Fridtjof Mund2020-02-252-1/+2
| | | | | | | | | | I made a mistake in https://github.com/matrix-org/synapse/pull/6921 - the quotes break the postgres container's startup script (or docker-compose), which makes initdb fail: https://github.com/matrix-org/synapse/pull/6921#issuecomment-590657154 Signed-off-by: Fridtjof Mund <fridtjof@das-labor.org>
* | Remove redundant store_room call (#6979)Richard van der Hoff2020-02-242-23/+1
| | | | | | | | | | `_process_received_pdu` is only called by `on_receive_pdu`, which ignores any events for unknown rooms, so this is redundant.
* | Upsert room version when we join over federation (#6968)Richard van der Hoff2020-02-243-10/+30
| | | | | | | | | | | | | | | | This is intended as a precursor to storing room versions when we receive an invite over federation, but has the happy side-effect of fixing #3374 at last. In short: change the store_room with try/except to a proper upsert which updates the right columns.
* | Fix minor issues with email config (#6962)Richard van der Hoff2020-02-243-40/+36
| | | | | | | | | | | | * Give `notif_template_html`, `notif_template_text` default values (fixes #6960) * Don't complain if `smtp_host` and `smtp_port` are unset, since they have sensible defaults (fixes #6961) * Set the example for `enable_notifs` to `True`, for consistency and because it's more useful * Raise errors as ConfigError rather than RuntimeError for nicer formatting
* | No longer use room alias events to calculate room names for push ↵Patrick Cloke2020-02-212-22/+15
| | | | | | | | notifications. (#6966)
* | Change displayname of user as admin in rooms (#6876)Dirk Klimpel2020-02-212-1/+12
| |
* | Stop returning aliases as part of the room list. (#6970)Patrick Cloke2020-02-212-9/+1
| |
* | Publishing/removing from the directory requires a power level greater than ↵Patrick Cloke2020-02-212-5/+6
| | | | | | | | canonical aliases.
* | Clarify list/set/dict/tuple comprehensions and enforce via flake8 (#6957)Patrick Cloke2020-02-2173-276/+251
| | | | | | | | Ensure good comprehension hygiene using flake8-comprehensions.
* | Merge pull request #6967 from matrix-org/rav/increase_max_events_behindRichard van der Hoff2020-02-212-1/+2
|\ \ | | | | | | Increase MAX_EVENTS_BEHIND for replication clients
| * | changelogRichard van der Hoff2020-02-211-0/+1
| | |
| * | Increase MAX_EVENTS_BEHIND for replication clientsErik Johnston2020-02-211-1/+1
| | |
* | | Merge branch 'master' into developRichard van der Hoff2020-02-215-11/+25
|\ \ \ | |/ / |/| / | |/
| * 1.11.0 v1.11.0 github/release-v1.11.0 release-v1.11.0Richard van der Hoff2020-02-214-2/+16
| |
| * Small grammar fixes to the ACME v1 deprecation notice (#6944)Andrew Morgan2020-02-213-10/+10
| | | | | | Some small fixes to the copy in #6907.
* | Do not send alias events when creating / upgrading a room (#6941)Patrick Cloke2020-02-203-40/+16
| | | | | | Stop emitting room alias update events during room creation/upgrade.
* | don't insert into the device table for remote cross-signing keys (#6956)Hubert Chathi2020-02-202-15/+19
| |
* | Add some clarifications to README.md in the database schema directory. (#6615)Ruben Barkow-Kuder2020-02-202-8/+17
| | | | | | Signed-off-by: Ruben Barkow-Kuder <github@r.z11.de>
* | Minor perf fixes to `get_auth_chain_ids`.Erik Johnston2020-02-193-7/+6
| |
* | Freeze allocated objects on startup. (#6953)Erik Johnston2020-02-192-0/+10
| | | | | | | | | | This may make gc go a bit faster as the gc will know things like caches/data stores etc. are frozen without having to check.
* | Reduce auth chains fetched during v2 state res. (#6952)Erik Johnston2020-02-195-13/+39
|/ | | | | | The state res v2 algorithm only cares about the difference between auth chains, so we can pass in the known common state to the `get_auth_chain` storage function so that it can ignore those events.
* update changes.md v1.11.0rc1Richard van der Hoff2020-02-191-6/+5
|
* 1.11.0rc1Richard van der Hoff2020-02-1957-56/+74
|
* Revert `get_auth_chain_ids` changes (#6951)Erik Johnston2020-02-192-28/+1
|
* Merge pull request #6949 from matrix-org/rav/list_room_aliases_peekableRichard van der Hoff2020-02-1910-86/+97
|\ | | | | Make room alias lists peekable
| * changelogRichard van der Hoff2020-02-191-0/+1
| |
| * Make room alias lists peekableRichard van der Hoff2020-02-192-1/+20
| | | | | | | | | | | | As per https://github.com/matrix-org/matrix-doc/pull/2432#pullrequestreview-360566830, make room alias lists accessible to users outside world_readable rooms.
| * Add `allow_departed_users` param to `check_in_room_or_world_readable`Richard van der Hoff2020-02-195-15/+33
| | | | | | | | | | | | | | ... and set it everywhere it's called. while we're here, rename it for consistency with `check_user_in_room` (and to help check that I haven't missed any instances)
| * Refactor the membership check methods in AuthRichard van der Hoff2020-02-184-73/+46
| | | | | | | | | | these were getting a bit unwieldy, so let's combine `check_joined_room` and `check_user_was_in_room` into a single `check_user_in_room`.
* | Merge pull request #6940 from matrix-org/babolivier/federate.mdBrendan Abolivier2020-02-194-153/+127
|\ \ | | | | | | Clean up and update federation docs
| * | Incorporate reviewBrendan Abolivier2020-02-192-12/+13
| | |
| * | Incorporate reviewBrendan Abolivier2020-02-182-21/+17
| | |
| * | PhrasingBrendan Abolivier2020-02-181-1/+1
| | |
| * | ChangelogBrendan Abolivier2020-02-181-0/+1
| | |
| * | Add mention of SRV records as an advanced topicBrendan Abolivier2020-02-181-0/+10
| | |
| * | Argh trailing spacesBrendan Abolivier2020-02-181-2/+2
| | |
| * | Fix links in the reverse proxy docBrendan Abolivier2020-02-181-3/+4
| | |
| * | Make federate.md more of a sumary of the steps to follow to set up replicationBrendan Abolivier2020-02-181-17/+28
| | |
| * | Split the delegating documentation out of federate.md and trim it downBrendan Abolivier2020-02-182-133/+87
| | |
* | | Move MSC2432 stuff onto unstable prefix (#6948)Richard van der Hoff2020-02-194-4/+23
| | | | | | | | | it's not in the spec yet, so needs to be unstable. Also add a feature flag for it. Also add a test for admin users.
* | | Tiny optimisation for _get_handler_for_request (#6950)Richard van der Hoff2020-02-192-1/+4
| | | | | | | | | | | | we have hundreds of path_regexes (see #5118), so let's not convert the same bytes to str for each of them.
* | | Increase DB/CPU perf of `_is_server_still_joined` check. (#6936)Erik Johnston2020-02-193-15/+60
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Increase DB/CPU perf of `_is_server_still_joined` check. For rooms with large amount of state a single user leaving could cause us to go and load a lot of membership events and then pull out membership state in a large number of batches. * Newsfile * Update synapse/storage/persist_events.py Co-Authored-By: Richard van der Hoff <1389908+richvdh@users.noreply.github.com> * Fix adding if too soon * Update docstring * Review comments * Woops typo Co-authored-by: Richard van der Hoff <1389908+richvdh@users.noreply.github.com>
* | | Merge pull request #6945 from matrix-org/babolivier/fix-retention-debug-logBrendan Abolivier2020-02-192-1/+2
|\ \ \ | | | | | | | | Fix log in message retention purge jobs
| * | | Update changelog.d/6945.bugfixBrendan Abolivier2020-02-191-1/+1
| | | | | | | | | | | | Co-Authored-By: Richard van der Hoff <1389908+richvdh@users.noreply.github.com>
| * | | ChangelogBrendan Abolivier2020-02-181-0/+1
| | | |
| * | | Fix log in message retention purge jobsBrendan Abolivier2020-02-181-1/+1
| | | |
* | | | Limit size of get_auth_chain_ids query (#6947)Erik Johnston2020-02-192-18/+24
| |_|/ |/| |
* | | Implement GET /_matrix/client/r0/rooms/{roomId}/aliases (#6939)Richard van der Hoff2020-02-185-11/+128
| | | | | | | | | | | | | | | per matrix-org/matrix-doc#2432
* | | Merge pull request #6872 from matrix-org/rav/dictpropertyRichard van der Hoff2020-02-183-82/+120
|\ \ \ | | | | | | | | Rewrite _EventInternalMetadata to back it with a dict
| * | | changelogRichard van der Hoff2020-02-141-0/+1
| | | |
| * | | Rewrite _EventInternalMetadata to back it with a _dictRichard van der Hoff2020-02-141-16/+39
| | | | | | | | | | | | | | | | Mostly, this gives mypy an easier time.
| * | | Replace _event_dict_property with DictPropertyRichard van der Hoff2020-02-142-66/+80
| | | | | | | | | | | | | | | | | | | | this amounts to the same thing, but replaces `_event_dict` with `_dict`, and removes some of the function layers generated by `property`.
* | | | Merge pull request #6907 from matrix-org/babolivier/acme-configBrendan Abolivier2020-02-184-1/+40
|\ \ \ \ | |_|/ / |/| | | Add mention and warning about ACME v1 deprecation to the TLS config
| * | | Make the log more noticeableBrendan Abolivier2020-02-181-1/+2
| | | |
| * | | Print the error as an error log and raise the same exception we gotBrendan Abolivier2020-02-181-9/+10
| | | |
| * | | Linters are hard but in they end they just want what's best for usBrendan Abolivier2020-02-131-1/+1
| | | |
| * | | LintBrendan Abolivier2020-02-131-6/+7
| | | |
| * | | ChangelogBrendan Abolivier2020-02-131-0/+1
| | | |
| * | | LintBrendan Abolivier2020-02-131-7/+6
| | | |
| * | | Add a separator for the config warningBrendan Abolivier2020-02-131-1/+1
| | | |
| * | | Add a comprehensive error when failing to register for an ACME accountBrendan Abolivier2020-02-131-1/+13
| | | |
| * | | Add mention and warning about ACME v1 deprecation to the Synapse configBrendan Abolivier2020-02-132-0/+24
| | | |
* | | | Increase perf of `get_auth_chain_ids` used in state res v2. (#6937)Erik Johnston2020-02-182-0/+24
| | | | | | | | | | | | We do this by moving the recursive query to be fully in the DB.
* | | | Fix worker docs to point `/publicised_groups` API correctly. (#6938)Erik Johnston2020-02-182-3/+5
| | | |
* | | | Merge pull request #6909 from matrix-org/babolivier/acme-installBrendan Abolivier2020-02-182-11/+18
|\ \ \ \ | | | | | | | | | | Update INSTALL.md to recommend reverse proxying and warn about ACMEv1 deprecation
| * | | | Update INSTALL.mdBrendan Abolivier2020-02-131-1/+3
| | | | | | | | | | | | | | | Co-Authored-By: Richard van der Hoff <1389908+richvdh@users.noreply.github.com>
| * | | | ChangelogBrendan Abolivier2020-02-131-0/+1
| | | | |
| * | | | Update INSTALL.md to recommend reverse proxying and warn about ACMEv1 ↵Brendan Abolivier2020-02-131-11/+15
| | |_|/ | |/| | | | | | | | | | deprecation
* | | | Stop sending events when creating or deleting aliases (#6904)Patrick Cloke2020-02-184-42/+194
| | | | | | | | | | | | Stop sending events when creating or deleting associations (room aliases). Send an updated canonical alias event if one of the alt_aliases is deleted.
* | | | Kill off deprecated "config-on-the-fly" docker mode (#6918)Richard van der Hoff2020-02-183-40/+33
| | | | | | | | | | | | | | | | | | | | Lots of people seem to get confused by this mode, and it's been deprecated since Synapse 1.1.0. It's time for it to go.
* | | | #6924 has been released in 1.10.1Richard van der Hoff2020-02-171-1/+0
| | | |
* | | | Merge branch 'master' into developRichard van der Hoff2020-02-173-1/+16
|\ \ \ \
| * \ \ \ Merge branch 'release-v1.10.1'Richard van der Hoff2020-02-174-3/+21
| |\ \ \ \
| | * | | | 1.10.1 v1.10.1 github/release-v1.10.1 release-v1.10.1Richard van der Hoff2020-02-174-2/+16
| | | | | |
| | * | | | wait for current_state_events_membership before ↵Richard van der Hoff2020-02-172-2/+6
| | | | | | | | | | | | | | | | | | | | | | | | delete_old_current_state_events (#6924)
* | | | | | Raise the default power levels for invites, tombstones and server acls (#6834)Andrew Morgan2020-02-173-2/+13
| | | | | |
* | | | | | wait for current_state_events_membership before ↵Richard van der Hoff2020-02-172-2/+6
| | | | | | | | | | | | | | | | | | | | | | | | delete_old_current_state_events (#6924)
* | | | | | Add type hints to the spam check module (#6915)Patrick Cloke2020-02-144-22/+36
| | | | | | | | | | | | | | | | | | | | | | | | Add typing information to the spam checker modules.
* | | | | | contrib/docker: Ensure correct encoding and locale settings on DB creation ↵Fridtjof Mund2020-02-142-0/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | (#6921) Signed-off-by: Fridtjof Mund <fridtjof@das-labor.org>
* | | | | | Add a warning about indentation to generated config (#6920)Richard van der Hoff2020-02-144-4/+29
| | | | | | | | | | | | | | | | | | Fixes #6916.
* | | | | | Convert the directory handler tests to use HomeserverTestCase (#6919)Patrick Cloke2020-02-142-24/+18
| |_|_|_|/ |/| | | | | | | | | Convert directory handler tests to use HomeserverTestCase.
* | | | | Filter the results of user directory searching via the spam checker (#6888)Patrick Cloke2020-02-145-2/+135
| |_|/ / |/| | | | | | | Add a method to the spam checker to filter the user directory results.
* | | | Update changelog for #6905 to group it with upcoming PRsBrendan Abolivier2020-02-131-1/+1
| | | |
* | | | Add documentation for the spam checker module (#6906)Patrick Cloke2020-02-132-0/+86
| | | | | | | | | | | | Add documentation for the spam checker.
* | | | Merge pull request #6905 from matrix-org/babolivier/acme.mdBrendan Abolivier2020-02-132-12/+44
|\ \ \ \ | | | | | | | | | | Update ACME.md to mention ACME v1 deprecation
| * | | | Update docs/ACME.mdBrendan Abolivier2020-02-131-1/+1
| | | | |
| * | | | Mention that using Synapse to serve certificates requires restartsBrendan Abolivier2020-02-121-1/+3
| | | | |
| * | | | ChangelogBrendan Abolivier2020-02-121-0/+1
| | | | |
| * | | | Remove duplicated info about certbot et alBrendan Abolivier2020-02-121-5/+0
| | | | |
| * | | | Update ACME.md to mention ACME v1 deprecationBrendan Abolivier2020-02-121-7/+41
| | |_|/ | |/| |
* / | | Remove m.lazy_load_members from unstable features since it is in CS r0.5.0 ↵Aaron Raimist2020-02-132-1/+1
|/ / / | | | | | | | | | | | | | | | | | | (#6877) Fixes #5528
* | | Merge pull request #6891 from matrix-org/babolivier/retention-doc-amendBrendan Abolivier2020-02-123-0/+8
|\ \ \ | | | | | | | | Spell out that the last event sent to a room won't be deleted by a purge
| * | | RephraseBrendan Abolivier2020-02-122-5/+5
| | | |
| * | | Update the changelog fileBrendan Abolivier2020-02-111-1/+1
| | | |
| * | | Also spell it out in the purge history API docBrendan Abolivier2020-02-111-0/+3
| | | |
| * | | ChangelogBrendan Abolivier2020-02-111-0/+1
| | | |
| * | | Spell out that Synapse never purges the last event sent in a roomBrendan Abolivier2020-02-111-0/+4
| | | |
* | | | Return a 404 for admin api user lookup if user not found (#6901)Andrew Morgan2020-02-123-1/+21
| | | |
* | | | Merge branch 'master' into developBrendan Abolivier2020-02-125-6/+21
|\ \ \ \ | | |/ / | |/| |
| * | | Merge tag 'v1.10.0'Brendan Abolivier2020-02-1287-520/+1795
| |\ \ \ | | | |/ | | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Synapse 1.10.0 (2020-02-12) =========================== **WARNING to client developers**: As of this release Synapse validates `client_secret` parameters in the Client-Server API as per the spec. See [\#6766](https://github.com/matrix-org/synapse/issues/6766) for details. Updates to the Docker image --------------------------- - Update the docker images to Alpine Linux 3.11. ([\#6897](https://github.com/matrix-org/synapse/issues/6897)) Synapse 1.10.0rc5 (2020-02-11) ============================== Bugfixes -------- - Fix the filtering introduced in 1.10.0rc3 to also apply to the state blocks returned by `/sync`. ([\#6884](https://github.com/matrix-org/synapse/issues/6884)) Synapse 1.10.0rc4 (2020-02-11) ============================== This release candidate was built incorrectly and is superceded by 1.10.0rc5. Synapse 1.10.0rc3 (2020-02-10) ============================== Features -------- - Filter out `m.room.aliases` from the CS API to mitigate abuse while a better solution is specced. ([\#6878](https://github.com/matrix-org/synapse/issues/6878)) Internal Changes ---------------- - Fix continuous integration failures with old versions of `pip`, which were introduced by a release of the `zipp` library. ([\#6880](https://github.com/matrix-org/synapse/issues/6880)) Synapse 1.10.0rc2 (2020-02-06) ============================== Bugfixes -------- - Fix an issue with cross-signing where device signatures were not sent to remote servers. ([\#6844](https://github.com/matrix-org/synapse/issues/6844)) - Fix to the unknown remote device detection which was introduced in 1.10.rc1. ([\#6848](https://github.com/matrix-org/synapse/issues/6848)) Internal Changes ---------------- - Detect unexpected sender keys on remote encrypted events and resync device lists. ([\#6850](https://github.com/matrix-org/synapse/issues/6850)) Synapse 1.10.0rc1 (2020-01-31) ============================== Features -------- - Add experimental support for updated authorization rules for aliases events, from [MSC2260](https://github.com/matrix-org/matrix-doc/pull/2260). ([\#6787](https://github.com/matrix-org/synapse/issues/6787), [\#6790](https://github.com/matrix-org/synapse/issues/6790), [\#6794](https://github.com/matrix-org/synapse/issues/6794)) Bugfixes -------- - Warn if postgres database has a non-C locale, as that can cause issues when upgrading locales (e.g. due to upgrading OS). ([\#6734](https://github.com/matrix-org/synapse/issues/6734)) - Minor fixes to `PUT /_synapse/admin/v2/users` admin api. ([\#6761](https://github.com/matrix-org/synapse/issues/6761)) - Validate `client_secret` parameter using the regex provided by the Client-Server API, temporarily allowing `:` characters for older clients. The `:` character will be removed in a future release. ([\#6767](https://github.com/matrix-org/synapse/issues/6767)) - Fix persisting redaction events that have been redacted (or otherwise don't have a redacts key). ([\#6771](https://github.com/matrix-org/synapse/issues/6771)) - Fix outbound federation request metrics. ([\#6795](https://github.com/matrix-org/synapse/issues/6795)) - Fix bug where querying a remote user's device keys that weren't cached resulted in only returning a single device. ([\#6796](https://github.com/matrix-org/synapse/issues/6796)) - Fix race in federation sender worker that delayed sending of device updates. ([\#6799](https://github.com/matrix-org/synapse/issues/6799), [\#6800](https://github.com/matrix-org/synapse/issues/6800)) - Fix bug where Synapse didn't invalidate cache of remote users' devices when Synapse left a room. ([\#6801](https://github.com/matrix-org/synapse/issues/6801)) - Fix waking up other workers when remote server is detected to have come back online. ([\#6811](https://github.com/matrix-org/synapse/issues/6811)) Improved Documentation ---------------------- - Clarify documentation related to `user_dir` and `federation_reader` workers. ([\#6775](https://github.com/matrix-org/synapse/issues/6775)) Internal Changes ---------------- - Record room versions in the `rooms` table. ([\#6729](https://github.com/matrix-org/synapse/issues/6729), [\#6788](https://github.com/matrix-org/synapse/issues/6788), [\#6810](https://github.com/matrix-org/synapse/issues/6810)) - Propagate cache invalidates from workers to other workers. ([\#6748](https://github.com/matrix-org/synapse/issues/6748)) - Remove some unnecessary admin handler abstraction methods. ([\#6751](https://github.com/matrix-org/synapse/issues/6751)) - Add some debugging for media storage providers. ([\#6757](https://github.com/matrix-org/synapse/issues/6757)) - Detect unknown remote devices and mark cache as stale. ([\#6776](https://github.com/matrix-org/synapse/issues/6776), [\#6819](https://github.com/matrix-org/synapse/issues/6819)) - Attempt to resync remote users' devices when detected as stale. ([\#6786](https://github.com/matrix-org/synapse/issues/6786)) - Delete current state from the database when server leaves a room. ([\#6792](https://github.com/matrix-org/synapse/issues/6792)) - When a client asks for a remote user's device keys check if the local cache for that user has been marked as potentially stale. ([\#6797](https://github.com/matrix-org/synapse/issues/6797)) - Add background update to clean out left rooms from current state. ([\#6802](https://github.com/matrix-org/synapse/issues/6802), [\#6816](https://github.com/matrix-org/synapse/issues/6816)) - Refactoring work in preparation for changing the event redaction algorithm. ([\#6803](https://github.com/matrix-org/synapse/issues/6803), [\#6805](https://github.com/matrix-org/synapse/issues/6805), [\#6806](https://github.com/matrix-org/synapse/issues/6806), [\#6807](https://github.com/matrix-org/synapse/issues/6807), [\#6820](https://github.com/matrix-org/synapse/issues/6820))
| | * | Move the warning at the top of the release changes v1.10.0 github/release-v1.10.0 release-v1.10.0Brendan Abolivier2020-02-121-3/+2
| | | |
| | * | 1.10.0Brendan Abolivier2020-02-124-2/+16
| | | |
| | * | bump the version of Alpine Linux used in the docker images (#6897)Richard van der Hoff2020-02-122-1/+2
| | | |
| * | | Update documentation (#6859)Robin Vleij2020-02-051-1/+2
| | | | | | | | | | | | | | | | Update documentation to reflect the correct format of user_id (fully qualified).
* | | | Use BSD-compatible in-place editing for sed. (#6887)Patrick Cloke2020-02-122-1/+3
| |_|/ |/| |
* | | Merge branch 'release-v1.10.0' into developRichard van der Hoff2020-02-112-5/+9
|\ \ \ | | |/ | |/|
| * | 1.10.0rc5 v1.10.0rc5Richard van der Hoff2020-02-112-2/+6
| | |
| * | changelog wordingRichard van der Hoff2020-02-111-2/+2
| | |
| * | Update CHANGES.mdRichard van der Hoff2020-02-111-1/+1
| | |
| * | changelog formattingRichard van der Hoff2020-02-111-2/+2
| | |
* | | Merge branch 'release-v1.10.0' into developRichard van der Hoff2020-02-113-1/+11
|\| |
| * | 1.10.0rc4Richard van der Hoff2020-02-113-2/+10
| | |
| * | filter out m.room.aliases from /sync state blocks (#6884)Matthew Hodgson2020-02-102-0/+2
| | | | | | | | | We forgot to filter out aliases from /sync state blocks as well as the timeline.
* | | Reject device display names that are too long (#6882)Patrick Cloke2020-02-103-1/+32
| | | | | | | | | | | | | | | | | | | | | | | | * Reject device display names that are too long. Too long is currently defined as 100 characters in length. * Add a regression test for rejecting a too long device display name.
* | | Add an additional test to the SyTest blacklist for worker mode. (#6883)Patrick Cloke2020-02-102-0/+3
| | |
* | | Merge tag 'v1.10.0rc3' into developRichard van der Hoff2020-02-104-2/+23
|\| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Synapse 1.10.0rc3 (2020-02-10) ============================== Features -------- - Filter out m.room.aliases from the CS API to mitigate abuse while a better solution is specced. ([\#6878](https://github.com/matrix-org/synapse/issues/6878)) Internal Changes ---------------- - Fix continuous integration failures with old versions of `pip`, which were introduced by a release of the `zipp` library. ([\#6880](https://github.com/matrix-org/synapse/issues/6880))
| * | 1.10.0rc3 v1.10.0rc3Richard van der Hoff2020-02-104-3/+16
| | |
| * | filter out m.room.aliases from the CS API until a better solution is specced ↵Matthew Hodgson2020-02-102-0/+8
| | | | | | | | | | | | | | | (#6878) We're in the middle of properly mitigating spam caused by malicious aliases being added to a room. However, until this work fully lands, we temporarily filter out all m.room.aliases events from /sync and /messages on the CS API, to remove abusive aliases. This is considered acceptable as m.room.aliases events were never a reliable record of the given alias->id mapping and were purely informational, and in their current state do more harm than good.
* | | Merge remote-tracking branch 'origin/release-v1.10.0' into developRichard van der Hoff2020-02-102-0/+19
|\| |
| * | Update setuptools for python 3.5 tests (#6880)Richard van der Hoff2020-02-102-0/+19
| | | | | | | | | Workaround for jaraco/zipp#40
* | | Add support for putting fed user query API on workers (#6873)Erik Johnston2020-02-075-21/+25
| | |
* | | Remove unused `get_room_stats_state` method. (#6869)Richard van der Hoff2020-02-072-25/+1
| | |
* | | Add a `make_event_from_dict` method (#6858)Richard van der Hoff2020-02-0713-39/+52
| | | | | | | | | | | | | | | | | | | | | ... and use it in places where it's trivial to do so. This will make it easier to pass room versions into the FrozenEvent constructors.
* | | Add typing to synapse.federation.sender (#6871)Erik Johnston2020-02-079-107/+138
| | |
* | | Allow moving group read APIs to workers (#6866)Erik Johnston2020-02-079-687/+722
| | |
* | | Admin api to add an email address (#6789)Dirk Klimpel2020-02-076-2/+78
| | |
* | | remove unused room_version_to_event_format (#6857)Richard van der Hoff2020-02-072-23/+2
| | |
* | | Merge pull request #6856 from matrix-org/rav/redact_changes/6Richard van der Hoff2020-02-075-60/+51
|\ \ \ | | | | | | | | Pass room_version into `event_from_pdu_json`
| * | | Pass room_version into `event_from_pdu_json`Richard van der Hoff2020-02-065-60/+51
| | | | | | | | | | | | | | | | It's called from all over the shop, so this one's a bit messy.
* | | | Limit the number of events that can be requested when backfilling events (#6864)Patrick Cloke2020-02-062-0/+5
|/ / / | | | | | | Limit the maximum number of events requested when backfilling events.
* | | pass room version into FederationClient.send_join (#6854)Richard van der Hoff2020-02-063-30/+34
| | | | | | | | | | | | ... which allows us to sanity-check the create event.
* | | Allow empty federation_certificate_verification_whitelist (#6849)timfi2020-02-062-0/+3
| | |
* | | Third party event rules Update (#6781)PeerD2020-02-063-4/+10
| | |
* | | Reduce amount of logging at INFO level. (#6862)Erik Johnston2020-02-0612-21/+22
| | | | | | | | | | | | | | | | | | | | | | | | A lot of the things we log at INFO are now a bit superfluous, so lets make them DEBUG logs to reduce the amount we log by default. Co-Authored-By: Brendan Abolivier <babolivier@matrix.org> Co-authored-by: Brendan Abolivier <github@brendanabolivier.com>
* | | Merge pull request #6823 from matrix-org/rav/redact_changes/5Richard van der Hoff2020-02-063-19/+14
|\ \ \ | | | | | | | | pass room versions around
| * | | NewsfileRichard van der Hoff2020-02-051-0/+1
| | | |
| * | | Simplify `room_version` handling in `FederationClient.send_invite`Richard van der Hoff2020-02-051-10/+6
| | | |
| * | | Pass room version object into `FederationClient.get_pdu`Richard van der Hoff2020-02-052-9/+7
| | | |
* | | | Merge tag 'v1.10.0rc2' into developErik Johnston2020-02-068-23/+90
|\ \ \ \ | | |/ / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Synapse 1.10.0rc2 (2020-02-06) ============================== Bugfixes -------- - Fix an issue with cross-signing where device signatures were not sent to remote servers. ([\#6844](https://github.com/matrix-org/synapse/issues/6844)) - Fix to the unknown remote device detection which was introduced in 1.10.rc1. ([\#6848](https://github.com/matrix-org/synapse/issues/6848)) Internal Changes ---------------- - Detect unexpected sender keys on remote encrypted events and resync device lists. ([\#6850](https://github.com/matrix-org/synapse/issues/6850))
| * | | Update changelog v1.10.0rc2Erik Johnston2020-02-061-1/+1
| | | |
| * | | Update changelogErik Johnston2020-02-061-2/+2
| | | |
| * | | Update changelogErik Johnston2020-02-061-1/+1
| | | |
| * | | 1.10.0rc2Erik Johnston2020-02-065-4/+17
| | | |
| * | | Check sender_key matches on inbound encrypted events. (#6850)Erik Johnston2020-02-053-14/+67
| | | | | | | | | | | | If they don't then the device lists are probably out of sync.
| * | | Merge pull request #6844 from matrix-org/uhoreg/cross_signing_fix_device_fedHubert Chathi2020-02-052-0/+11
| | | | | | | | | | | | add device signatures to device key query results
| * | | Fix detecting unknown devices from remote encrypted events. (#6848)Erik Johnston2020-02-046-7/+7
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We were looking at the wrong event type (`m.room.encryption` vs `m.room.encrypted`). Also fixup the duplicate `EvenTypes` entries. Introduced in #6776.
* | | | Merge pull request #6855 from matrix-org/clokep/readme-pip-installPatrick Cloke2020-02-052-1/+2
|\ \ \ \ | |_|/ / |/| | | Add quotes around the pip install target to avoid my shell complaining
| * | | Add quotes around pip install target (my shell complained without them).Patrick Cloke2020-02-052-1/+2
| | | |
* | | | Merge pull request #6840 from matrix-org/rav/federation_client_asyncRichard van der Hoff2020-02-052-136/+143
|\ \ \ \ | |/ / / |/| | | Port much of `synapse.federation.federation_client` to async/await
| * | | make FederationClient._do_send_invite asyncRichard van der Hoff2020-02-051-10/+7
| | | |
| * | | Apply suggestions from code reviewRichard van der Hoff2020-02-051-2/+4
| | | | | | | | | | | | Co-Authored-By: Erik Johnston <erik@matrix.org>
| * | | Merge remote-tracking branch 'origin/develop' into rav/federation_client_asyncRichard van der Hoff2020-02-047-349/+386
| |\ \ \
| * | | | make FederationClient.send_invite asyncRichard van der Hoff2020-02-031-6/+5
| | | | |
| * | | | newsfileRichard van der Hoff2020-02-031-0/+1
| | | | |
| * | | | make FederationClient.get_missing_events asyncRichard van der Hoff2020-02-031-20/+20
| | | | |
| * | | | make FederationClient._do_send_leave asyncRichard van der Hoff2020-02-031-4/+3
| | | | |
| * | | | make FederationClient.send_leave.send_request asyncRichard van der Hoff2020-02-031-5/+2
| | | | |
| * | | | make FederationClient._do_send_join asyncRichard van der Hoff2020-02-031-4/+3
| | | | |
| * | | | make FederationClient.send_join.send_request asyncRichard van der Hoff2020-02-031-4/+3
| | | | |
| * | | | make FederationClient.make_membership_event.send_request asyncRichard van der Hoff2020-02-031-4/+3
| | | | |
| * | | | make FederationClient._try_destination_list asyncRichard van der Hoff2020-02-031-10/+26
| | | | |
| * | | | make FederationClient.send_leave asyncRichard van der Hoff2020-02-031-10/+9
| | | | |
| * | | | make FederationClient.send_join asyncRichard van der Hoff2020-02-031-11/+13
| | | | |
| * | | | make FederationClient.make_membership_event asyncRichard van der Hoff2020-02-031-10/+11
| | | | |
| * | | | make FederationClient.get_event_auth asyncRichard van der Hoff2020-02-031-6/+4
| | | | |
| * | | | make FederationClient.get_room_state_ids asyncRichard van der Hoff2020-02-031-4/+5
| | | | |
| * | | | make FederationClient.get_pdu asyncRichard van der Hoff2020-02-031-15/+17
| | | | |
| * | | | make FederationClient.backfill asyncRichard van der Hoff2020-02-031-15/+11
| | | | |
* | | | | Reduce performance logging to DEBUG (#6833)Michael Kaye2020-02-052-1/+2
| | | | | | | | | | | | | | | | | | | | | | | | | * Reduce tnx performance logging to DEBUG * Changelog.d
* | | | | Database updates to populate rooms.room_version (#6847)Richard van der Hoff2020-02-043-0/+58
| | | | | | | | | | | | | | | We're going to need this so that we can figure out how to handle redactions when fetching events from the database.
* | | | | Merge pull request #6844 from matrix-org/uhoreg/cross_signing_fix_device_fedHubert Chathi2020-02-042-0/+11
|\ \ \ \ \ | | | | | | | | | | | | add device signatures to device key query results
| * | | | | add changelogHubert Chathi2020-02-041-0/+1
| | | | | |
| * | | | | add device signatures to device key query resultsHubert Chathi2020-02-041-0/+10
| | | | | |
* | | | | | Update CONTRIBUTING.md about merging PRs. (#6846)Michael Kaye2020-02-042-0/+15
| |_|/ / / |/| | | |
* | | | | Merge pull request #6837 from matrix-org/rav/federation_asyncRichard van der Hoff2020-02-044-235/+212
|\ \ \ \ \ | |/ / / / |/| / / / | |/ / / Port much of `synapse.handlers.federation` to async/await.
| * | | make FederationHandler.send_invite asyncRichard van der Hoff2020-02-032-6/+4
| | | |
| * | | make FederationHandler.on_get_missing_events asyncRichard van der Hoff2020-02-031-5/+4
| | | |
| * | | changelogRichard van der Hoff2020-02-031-0/+1
| | | |
| * | | make FederationHandler.user_joined_room asyncRichard van der Hoff2020-02-031-3/+3
| | | |
| * | | make FederationHandler._clean_room_for_join asyncRichard van der Hoff2020-02-031-4/+4
| | | |
| * | | make FederationHandler._notify_persisted_event asyncRichard van der Hoff2020-02-031-4/+6
| | | |
| * | | make FederationHandler.persist_events_and_notify asyncRichard van der Hoff2020-02-031-10/+10
| | | |
| * | | make FederationHandler._make_and_verify_event asyncRichard van der Hoff2020-02-031-5/+10
| | | |
| * | | make FederationHandler.do_remotely_reject_invite asyncRichard van der Hoff2020-02-032-8/+11
| | | |
| * | | make FederationHandler._check_for_soft_fail asyncRichard van der Hoff2020-02-031-13/+9
| | | |
| * | | make FederationHandler._persist_auth_tree asyncRichard van der Hoff2020-02-031-11/+7
| | | |
| * | | make FederationHandler.do_invite_join asyncRichard van der Hoff2020-02-032-18/+18
| | | |
| * | | make FederationHandler.on_event_auth asyncRichard van der Hoff2020-02-031-5/+4
| | | |
| * | | make FederationHandler.on_exchange_third_party_invite_request asyncRichard van der Hoff2020-02-031-14/+12
| | | |
| * | | make FederationHandler.construct_auth_difference asyncRichard van der Hoff2020-02-031-3/+4
| | | |
| * | | make FederationHandler._update_context_for_auth_events asyncRichard van der Hoff2020-02-031-10/+10
| | | |
| * | | make FederationHandler._update_auth_events_and_context_for_auth asyncRichard van der Hoff2020-02-031-20/+21
| | | |
| * | | make FederationHandler.do_auth asyncRichard van der Hoff2020-02-031-10/+14
| | | |
| * | | make FederationHandler._prep_event asyncRichard van der Hoff2020-02-031-23/+10
| | | |
| * | | make FederationHandler._handle_new_event asyncRichard van der Hoff2020-02-031-6/+7
| | | |
| * | | make FederationHandler._handle_new_events asyncRichard van der Hoff2020-02-031-8/+6
| | | |
| * | | make FederationHandler.on_make_leave_request asyncRichard van der Hoff2020-02-031-13/+10
| | | |
| * | | make FederationHandler.on_send_leave_request asyncRichard van der Hoff2020-02-031-5/+3
| | | |
| * | | make FederationHandler.on_make_join_request asyncRichard van der Hoff2020-02-031-13/+10
| | | |
| * | | make FederationHandler.on_invite_request asyncRichard van der Hoff2020-02-031-5/+4
| | | |
| * | | make FederationHandler.on_send_join_request asyncRichard van der Hoff2020-02-031-9/+7
| | | |
| * | | make FederationHandler.on_query_auth asyncRichard van der Hoff2020-02-031-7/+6
| | | |
* | | | Add typing to SyncHandler (#6821)Erik Johnston2020-02-035-349/+381
| | | | | | | | | | | | | | | | Co-authored-by: Richard van der Hoff <1389908+richvdh@users.noreply.github.com>
* | | | Fix stacktraces when using ObservableDeferred and async/await (#6836)Erik Johnston2020-02-032-0/+5
|/ / /
* | | Allow URL-encoded user IDs on user admin api paths (#6825)Andrew Morgan2020-02-032-2/+3
| | |
* | | Fix `room_version` in `on_invite_request` flow (#6827)Richard van der Hoff2020-02-033-7/+11
|/ / | | | | | | I messed this up a bit in #6805, but fortunately we weren't actually doing anything with the room_version so it didn't matter that it was a str not a RoomVersion.
* | Update changelog v1.10.0rc1Erik Johnston2020-01-311-1/+4
| |
* | Fix link in upgrade.rstErik Johnston2020-01-311-1/+1
| |
* | 1.10.0rc1Erik Johnston2020-01-3135-35/+47
| |
* | Fix deleting of stale marker for device lists (#6819)Erik Johnston2020-01-312-7/+8
| | | | | | | | We were in fact only deleting stale marker when we got an incremental update, rather than when we did a full resync.
* | pass room_version into compute_event_signature (#6807)Richard van der Hoff2020-01-313-9/+25
| |
* | Merge pull request #6806 from matrix-org/rav/redact_changes/3Richard van der Hoff2020-01-316-41/+49
|\ \ | | | | | | Pass room_version into add_hashes_and_signatures
| * | changelogRichard van der Hoff2020-01-301-0/+1
| | |
| * | Pass room_version into add_hashes_and_signaturesRichard van der Hoff2020-01-303-10/+21
| | |
| * | Pass room_version into create_local_event_from_event_dictRichard van der Hoff2020-01-302-25/+19
| | |
| * | Store the room version in EventBuilderRichard van der Hoff2020-01-302-7/+9
| | |
* | | Merge pull request #6820 from matrix-org/rav/get_room_version_idRichard van der Hoff2020-01-3114-38/+64
|\ \ \ | | | | | | | | Make `get_room_version` return a RoomVersion object
| * | | newsfileRichard van der Hoff2020-01-311-0/+1
| | | |
| * | | Add `get_room_version` methodRichard van der Hoff2020-01-312-5/+26
| | | | | | | | | | | | | | | | So that we can start factoring out some of this boilerplatey boilerplate.
| * | | s/get_room_version/get_room_version_id/Richard van der Hoff2020-01-3112-33/+37
| | | | | | | | | | | | | | | | | | | | ... to make way for a forthcoming get_room_version which returns a RoomVersion object.
* | | | Fix bug with getting missing auth event during join 500'ed (#6810)Erik Johnston2020-01-312-1/+6
|/ / /
* | | pass room version into FederationHandler.on_invite_request (#6805)Richard van der Hoff2020-01-303-4/+5
| | |
* | | Log when we delete room in bg update (#6816)Erik Johnston2020-01-302-0/+3
|/ /
* | MSC2260: Block direct sends of m.room.aliases events (#6794)Richard van der Hoff2020-01-304-33/+28
| | | | | | | | | | as per MSC2260
* | Backgroud update to clean out rooms from current state (#6802)Erik Johnston2020-01-303-2/+126
| |
* | Resync remote device list when detected as stale. (#6786)Erik Johnston2020-01-304-7/+28
| |
* | Fix sending server up commands from workers (#6811)Erik Johnston2020-01-306-13/+36
| | | | | | | | Co-authored-by: Andrew Morgan <1342360+anoadragon453@users.noreply.github.com>
* | When server leaves room check for stale device lists. (#6801)Erik Johnston2020-01-303-6/+83
| | | | | | | | | | | | | | | | | | When a server leaves a room it may stop sharing a room with remote users, and thus not get any updates to their device lists. So we need to check for this case and delete those device lists from the cache. We don't need to do this if we stop sharing a room because the remote user leaves the room, because we track that case via looking at membership changes.
* | When a client asks for remote keys check if should resync. (#6797)Erik Johnston2020-01-302-3/+30
| | | | | | | | | | | | If we detect that the remote users' keys may have changed then we should attempt to resync against the remote server rather than using the (potentially) stale local cache.
* | Type defintions for use in refactoring for redaction changes (#6803)Richard van der Hoff2020-01-305-8/+24
| | | | | | | | | | | | | | | | | | | | * Bump signedjson to 1.1 ... so that we can use the type definitions * Fix breakage caused by upgrade to signedjson 1.1 Thanks, @illicitonion...
* | Remove unused DeviceRow class (#6800)Erik Johnston2020-01-292-20/+2
| |
* | Merge pull request #6790 from matrix-org/rav/msc2260.1Richard van der Hoff2020-01-295-18/+112
|\ \ | | | | | | MSC2260: change the default power level for m.room.aliases events
| * | changelogRichard van der Hoff2020-01-291-0/+1
| | |
| * | Make /directory/room/<alias> handle restrictive power levelsRichard van der Hoff2020-01-291-1/+6
| | | | | | | | | | | | | | | Fixes a bug where the alias would be added, but `PUT /directory/room/<alias>` would return a 403.
| * | Set the PL for aliases events to 0.Richard van der Hoff2020-01-292-3/+16
| | |
| * | Factor out a `copy_power_levels_contents` methodRichard van der Hoff2020-01-293-15/+90
|/ / | | | | | | I'm going to need another copy (hah!) of this.
* | Fix race in federation sender that delayed device updates. (#6799)Erik Johnston2020-01-293-30/+23
| | | | | | | | | | | | | | | | | | | | | | | | We were sending device updates down both the federation stream and device streams. This mean there was a race if the federation sender worker processed the federation stream first, as when the sender checked if there were new device updates the slaved ID generator hadn't been updated with the new stream IDs and so returned nothing. This situation is correctly handled by events/receipts/etc by not sending updates down the federation stream and instead having the federation sender worker listen on the other streams and poke the transaction queues as appropriate.