summary refs log tree commit diff
Commit message (Collapse)AuthorAgeFilesLines
* 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
* 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
|
* 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.
* 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
|
* 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
| * 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 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))
| * | Better errors regarding changing avatar_url (#6497)Andrew Morgan2019-12-092-3/+9
| | |
* | | 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
| |/ |/|
* | 1.7.0rc1 v1.7.0rc1Neil Johnson2019-12-0955-54/+79
| |
* | Systemd documentation (#6490)Clifford Garwood II2019-12-092-1/+2
|/
* 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
| | |
* | | Merge branch 'master' of github.com:matrix-org/synapse into developAndrew Morgan2019-12-053-2/+23
|\ \ \
| * | | Modify systemd unit file reference to align with installation instruction ↵Clifford Garwood II2019-12-053-2/+23
| | | | | | | | | | | | | | | | | | | | (#6369) Signed-off-by: Clifford Garwood II cliff@cigii.com
* | | | Revert "Modify systemd unit file reference to align with installation ↵Andrew Morgan2019-12-053-23/+2
| | | | | | | | | | | | | | | | | | | | | | | | instruction (#6369)" This reverts commit dc8747895ec026c365e687853b5ca12225fb881e.
* | | | Modify systemd unit file reference to align with installation instruction ↵Clifford Garwood II2019-12-053-2/+23
| |/ / |/| | | | | | | | | | | (#6369) Signed-off-by: Clifford Garwood II cliff@cigii.com
* | | Stronger typing in the federation handler (#6480)Richard van der Hoff2019-12-052-24/+58
| | | | | | | | | | | | | | | replace the event_info dict with an attrs thing
* | | Sanity-check the rooms of auth events before pulling them in. (#6472)Richard van der Hoff2019-12-052-9/+26
| | |
| | * Remove unused varErik Johnston2019-12-063-4/+2
| | |
| | * Fix DB scriptsErik Johnston2019-12-052-15/+16
| | |
| | * NewsfileErik Johnston2019-12-051-0/+1
| | |
| | * Move background update handling out of storeErik Johnston2019-12-0527-200/+281
| | |
| | * CommentsErik Johnston2019-12-053-5/+16
| | |
| | * Move DB pool and helper functions into dedicated Database classErik Johnston2019-12-0562-2295/+2377
| |/ |/|
* | Merge pull request #6464 from matrix-org/erikj/make_public_sql_baseErik Johnston2019-12-0559-576/+570
|\ \ | | | | | | Clean up SQLBaseStore private function usage
| * | NewsfileErik Johnston2019-12-041-0/+1
| | |
| * | Remove underscore from SQLBaseStore functionsErik Johnston2019-12-0456-558/+550
| | |
| * | Don't call SQLBaseStore methods from outside storesErik Johnston2019-12-044-19/+20
| | |
* | | Merge pull request #6470 from matrix-org/babolivier/port_db_ci_failureBrendan Abolivier2019-12-043-2/+14
|\ \ \ | | | | | | | | Make synapse_port_db exit with a non-0 code if something failed
| * | | Fix background updates for synapse_port_dbBrendan Abolivier2019-12-042-2/+12
| | | |
| * | | ChangelogBrendan Abolivier2019-12-041-0/+1
| | | |
| * | | Make synapse_port_db exit with a non-0 code if something failedBrendan Abolivier2019-12-041-0/+1
| |/ /
* / / get rid of (most of) have_events from ↵Richard van der Hoff2019-12-043-72/+25
|/ / | | | | | | | | | | | | | | | | | | | | | | | | _update_auth_events_and_context_for_auth (#6468) have_events was a map from event_id to rejection reason (or None) for events which are in our local database. It was used as filter on the list of event_ids being passed into get_events_as_list. However, since get_events_as_list will ignore any event_ids that are unknown or rejected, we can equivalently just leave it to get_events_as_list to do the filtering. That means that we don't have to keep `have_events` up-to-date, and can use `have_seen_events` instead of `get_seen_events_with_rejection` in the one place we do need it.
* | Merge pull request #6454 from matrix-org/erikj/clean_base_StoreErik Johnston2019-12-049-192/+222
|\ \ | | | | | | Move things out of SQLBaseStore
| * | Revert "Move get_user_count_txn out of base store"Erik Johnston2019-12-042-12/+12
| | | | | | | | | | | | | | | | | | This reverts commit 00f0d67566cdfe8eae44aeae1c982c42a255cfcd. Its going to get removed soon, so lets not make merge conflicts.
| * | _CURRENT_STATE_CACHE_NAME is publicErik Johnston2019-12-042-5/+5
| | |
| * | Move get_user_count_txn out of base storeErik Johnston2019-12-042-12/+12
| | |
| * | NewsfileErik Johnston2019-12-041-0/+1
| | |
| * | Move cache invalidation to main data storeErik Johnston2019-12-046-113/+143
| | |
| * | Move event fetch vars to EventWorkStoreErik Johnston2019-12-044-14/+15
| | |
| * | Move account validity bg updates to registration storeErik Johnston2019-12-042-66/+64
| | |
* | | Merge pull request #6441 from syamgk/fix-parameter-mismatchErik Johnston2019-12-042-1/+2
|\ \ \ | | | | | | | | Fix issue #6406 parameter mismatch
| * | | Add changelog fileSyam G Krishnan2019-12-041-0/+1
| | | | | | | | | | | | | | | | Signed-off-by: Syam G Krishnan <syamgk@gmail.com>
| * | | Issue #6406 Fix parameter mismatchSyam G Krishnan2019-12-041-1/+1
| | | | | | | | | | | | | | | | Signed-off-by: Syam G Krishnan <syamgk01@gmail.com>
* | | | Merge pull request #6329 from matrix-org/babolivier/context_filtersBrendan Abolivier2019-12-0410-103/+408
|\ \ \ \ | | | | | | | | | | Filter state, events_before and events_after in /context requests
| * | | | Un-remove room purge testBrendan Abolivier2019-12-041-0/+72
| | | | |
| * | | | Merge branch 'babolivier/context_filters' of github.com:matrix-org/synapse ↵Brendan Abolivier2019-12-041-1/+1
| |\ \ \ \ | | | | | | | | | | | | | | | | | | into babolivier/context_filters
| | * \ \ \ Merge branch 'develop' into babolivier/context_filtersBrendan Abolivier2019-11-26125-1166/+2323
| | |\ \ \ \
| * | \ \ \ \ Merge branch 'develop' into babolivier/context_filtersBrendan Abolivier2019-12-04189-1451/+4493
| |\ \ \ \ \ \
| * | | | | | | Incorporate reviewBrendan Abolivier2019-12-043-3/+2
| | |/ / / / / | |/| | | | |
| * | | | | | Format changelogBrendan Abolivier2019-11-201-1/+1
| | | | | | |
| * | | | | | Update changelog since this isn't going to be featured in 1.6.0Brendan Abolivier2019-11-201-1/+1
| | | | | | |
| * | | | | | Also filter state eventsBrendan Abolivier2019-11-061-1/+7
| | | | | | |
| * | | | | | Only filter if a filter was providedBrendan Abolivier2019-11-051-4/+6
| | | | | | |
| * | | | | | Update copyrightBrendan Abolivier2019-11-051-1/+2
| | | | | | |
| * | | | | | LintBrendan Abolivier2019-11-051-30/+41
| | | | | | |
| * | | | | | Update copyrightsBrendan Abolivier2019-11-058-2/+21
| | | | | | |
| * | | | | | ChangelogBrendan Abolivier2019-11-051-0/+1
| | | | | | |
| * | | | | | Add tests for /searchBrendan Abolivier2019-11-051-44/+143
| | | | | | |
| * | | | | | Merge labels tests for /context and /messagesBrendan Abolivier2019-11-051-146/+130
| | | | | | |
| * | | | | | Add test caseBrendan Abolivier2019-11-051-0/+182
| | | | | | |
| * | | | | | Filter events_before and events_after in /context requestsBrendan Abolivier2019-11-051-2/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | While the current version of the spec doesn't say much about how this endpoint uses filters (see https://github.com/matrix-org/matrix-doc/issues/2338), the current implementation is that some fields of an EventFilter apply (the ones that are used when running the SQL query) and others don't (the ones that are used by the filter itself) because we don't call event_filter.filter(...). This seems counter-intuitive and probably not what we want so this commit fixes it.
* | | | | | | Markdownification and other fixes to CONTRIBUTING (#6461)Andrew Morgan2019-12-044-210/+215
| | | | | | |
* | | | | | | Fix error when using synapse_port_db on a vanilla synapse db (#6449)Andrew Morgan2019-12-042-1/+5
|\ \ \ \ \ \ \ | |_|_|_|_|/ / |/| | | | | |
| * | | | | | Update changelog.d/6449.bugfixAndrew Morgan2019-12-041-1/+1
| | | | | | | | | | | | | | | | | | | | | Co-Authored-By: Erik Johnston <erik@matrix.org>
| * | | | | | Add changelogAndrew Morgan2019-12-021-0/+1
| | | | | | |
| * | | | | | Fix error when using synapse_port_db on a vanilla synapse dbAndrew Morgan2019-12-021-1/+4
| | | | | | |
* | | | | | | Merge pull request #6451 from matrix-org/uhoreg/cross_signing_signatures_indexErik Johnston2019-12-043-1/+25
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | make cross signing signature index non-unique
| * | | | | | | apply changes from reviewHubert Chathi2019-12-032-2/+3
| | | | | | | |
| * | | | | | | add changelogHubert Chathi2019-12-021-0/+1
| | | | | | | |
| * | | | | | | make cross signing signature index non-uniqueHubert Chathi2019-12-022-1/+23
| |/ / / / / /
* | | | | | | privacy by default for room dir (#6355)Neil Johnson2019-12-045-18/+91
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Ensure that the the default settings for the room directory are that the it is hidden from public view by default.
* | | | | | | Fix exception when a cross-signed device is deleted (#6462)Richard van der Hoff2019-12-042-4/+20
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | (hopefully) ... and deobfuscate the relevant bit of code.
* | | | | | | Add ephemeral messages support (MSC2228) (#6409)Brendan Abolivier2019-12-038-7/+379
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Implement part [MSC2228](https://github.com/matrix-org/matrix-doc/pull/2228). The parts that differ are: * the feature is hidden behind a configuration flag (`enable_ephemeral_messages`) * self-destruction doesn't happen for state events * only implement support for the `m.self_destruct_after` field (not the `m.self_destruct` one) * doesn't send synthetic redactions to clients because for this specific case we consider the clients to be able to destroy an event themselves, instead we just censor it (by pruning its JSON) in the database
* | | | | | | write some docs for the quarantine_media api (#6458)Richard van der Hoff2019-12-032-0/+18
| |_|/ / / / |/| | | | |
* | | | | | Add benchmarks for structured logging performance (#6266)Amber Brown2019-12-037-0/+294
|/ / / / /
* | | | | Transfer power level state events on room upgrade (#6237)Andrew Morgan2019-12-022-5/+32
| | | | |
* | | | | Use python3 packages for Ubuntu (#6443)Andrew Morgan2019-12-022-2/+3
| | | | |
* | | | | Fix: Pillow error when uploading RGBA image (#3325) (#6241)Filip Štědronský2019-12-022-1/+5
| |_|/ / |/| | | | | | | Signed-Off-By: Filip Štědronský <g@regnarg.cz>
* | | | Add User-Interactive Auth to /account/3pid/add (#6119)Andrew Morgan2019-11-292-0/+6
| | | |
* | | | Merge pull request #6434 from matrix-org/erikj/msc2367_membership_reasonsErik Johnston2019-11-297-10/+162
|\ \ \ \ | | | | | | | | | | Implement MSC 2367 - Membership Reasons
| * | | | NewsfileErik Johnston2019-11-281-0/+1
| | | | |
| * | | | Add testsErik Johnston2019-11-281-0/+140
| | | | |
| * | | | Propagate reason in remotely rejected invitesErik Johnston2019-11-284-9/+20
| | | | |
| * | | | MSC2367 Allow reason field on all member eventsErik Johnston2019-11-281-1/+1
| | | | |
* | | | | Merge pull request #6436 from matrix-org/babolivier/fix-state-retrievalBrendan Abolivier2019-11-293-9/+20
|\ \ \ \ \ | | | | | | | | | | | | Discard retention policies when retrieving state
| * | | | | LintBrendan Abolivier2019-11-281-4/+8
| | | | | |
| * | | | | ChangelogBrendan Abolivier2019-11-281-0/+1
| | | | | |
| * | | | | Discard retention policies when retrieving stateBrendan Abolivier2019-11-282-9/+15
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Purge jobs don't delete the latest event in a room in order to keep the forward extremity and not break the room. On the other hand, get_state_events, when given an at_token argument calls filter_events_for_client to know if the user can see the event that matches that (sync) token. That function uses the retention policies of the events it's given to filter out those that are too old from a client's view. Some clients, such as Riot, when loading a room, request the list of members for the latest sync token it knows about, and get confused to the point of refusing to send any message if the server tells it that it can't get that information. This can happen very easily with the message retention feature turned on and a room with low activity so that the last event sent becomes too old according to the room's retention policy. An easy and clean fix for that issue is to discard the room's retention policies when retrieving state.
* | | | | blacklist more testsRichard van der Hoff2019-11-281-0/+7
| | | | |
* | | | | Merge branch 'master' into developAndrew Morgan2019-11-283-1/+22
|\ \ \ \ \ | |/ / / / |/| | | / | | |_|/ | |/| |
| * | | 1.6.1 v1.6.1 github/release-v1.6.1 release-v1.6.1Andrew Morgan2019-11-285-3/+22
| | | |
| * | | Remove local threepids on account deactivation (#6426)Andrew Morgan2019-11-283-0/+17
| | | |
| * | | Fix startup error when http proxy is defined. (#6421)Richard van der Hoff2019-11-273-4/+5
| | | | | | | | | | | | | | | | | | | | Guess I only tested this on python 2 :/ Fixes #6419.
* | | | Remove local threepids on account deactivation (#6426)Andrew Morgan2019-11-283-0/+17
| | | |
* | | | Clarifications for the email configuration settings. (#6423)Richard van der Hoff2019-11-283-2/+33
| | | | | | | | | | | | Cf #6422
* | | | Implementation of MSC2314 (#6176)Amber Brown2019-11-2813-65/+174
| | | |
* | | | add etag and count to key backup endpoints (#5858)Hubert Chathi2019-11-277-124/+297
| | | |
* | | | Add more tests to the worker blacklist (#6429)Richard van der Hoff2019-11-272-0/+30
| | | |
* | | | Merge pull request #6358 from matrix-org/babolivier/message_retentionBrendan Abolivier2019-11-2713-8/+1055
|\ \ \ \ | | | | | | | | | | Implement message retention policies (MSC1763)
| * \ \ \ Merge branch 'develop' into babolivier/message_retentionBrendan Abolivier2019-11-26138-1274/+2600
| |\ \ \ \
| * | | | | Don't restrict the tests to v1 roomsBrendan Abolivier2019-11-261-2/+0
| | | | | |
| * | | | | Fix worker modeBrendan Abolivier2019-11-191-56/+56
| | | | | |
| * | | | | Fix 3PID invite exchangeBrendan Abolivier2019-11-191-1/+1
| | | | | |
| * | | | | Lint againBrendan Abolivier2019-11-191-1/+1
| | | | | |
| * | | | | Lint againBrendan Abolivier2019-11-192-11/+3
| | | | | |
| * | | | | LintBrendan Abolivier2019-11-194-101/+77
| | | | | |
| * | | | | Don't apply retention policy based filtering on state eventsBrendan Abolivier2019-11-062-6/+19
| | | | | | | | | | | | | | | | | | | | | | | | As per MSC1763, 'Retention is only considered for non-state events.', so don't filter out state events based on the room's retention policy.
| * | | | | Implement per-room message retention policiesBrendan Abolivier2019-11-0413-6/+1074
| | | | | |
* | | | | | clean up buildkite outputRichard van der Hoff2019-11-261-1/+3
| | | | | |
* | | | | | Remove assertion and provide a clear warning on startup for missing ↵Andrew Morgan2019-11-264-0/+11
| | | | | | | | | | | | | | | | | | | | | | | | public_baseurl (#6379)
* | | | | | Merge pull request #6343 from matrix-org/rav/event_auth/4Richard van der Hoff2019-11-262-37/+45
|\ \ \ \ \ \ | | | | | | | | | | | | | | Refactor _update_auth_events_and_context_for_auth
| * | | | | | remove confusing fixmeRichard van der Hoff2019-11-261-6/+0
| | | | | | |
| * | | | | | Merge remote-tracking branch 'origin/develop' into rav/event_auth/4Richard van der Hoff2019-11-1830-47/+85
| |\ \ \ \ \ \
| * | | | | | | newsfileRichard van der Hoff2019-11-081-0/+1
| | | | | | | |
| * | | | | | | Use get_events_as_list rather than lots of calls to get_eventRichard van der Hoff2019-11-081-16/+8
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | It's more efficient and clearer.
| * | | | | | | Update some docstrings and commentsRichard van der Hoff2019-11-081-8/+31
| | | | | | | |
| * | | | | | | Simplify _update_auth_events_and_context_for_authRichard van der Hoff2019-11-081-11/+9
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | move event_key calculation into _update_context_for_auth_events, since it's only used there.
* | | | | | | | Fix startup error when http proxy is defined. (#6421)Richard van der Hoff2019-11-263-4/+5
| |_|_|/ / / / |/| | | | | | | | | | | | | | | | | | | | | | | | | | | Guess I only tested this on python 2 :/ Fixes #6419.
* | | | | | | Merge pull request #6420 from ↵Erik Johnston2019-11-262-12/+7
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | matrix-org/erikj/fix_find_next_generated_user_id_localpart Fix guest registration
| * | | | | | | Don't construct a setErik Johnston2019-11-261-6/+3
| | | | | | | |
| * | | | | | | NewsfileErik Johnston2019-11-261-0/+1
| | | | | | | |
| * | | | | | | Fix find_next_generated_user_id_localpartErik Johnston2019-11-261-10/+7
|/ / / / / / /
* | | | | | | Merge branch 'master' into developAndrew Morgan2019-11-264-2/+17
|\ \ \ \ \ \ \ | | |_|_|/ / / | |/| | | | |
| * | | | | | 1.6.0 v1.6.0 github/release-v1.6.0 release-v1.6.0Andrew Morgan2019-11-264-2/+16
| | | | | | |
| * | | | | | Fix phone home stats (#6418)Erik Johnston2019-11-262-1/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Fix phone home stats
* | | | | | | Prevent account_data content from being sent over TCP replication (#6333)Andrew Morgan2019-11-263-7/+7
|\ \ \ \ \ \ \
| * \ \ \ \ \ \ Merge branch 'develop' of github.com:matrix-org/synapse into ↵Andrew Morgan2019-11-145-2/+6
| |\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | anoa/fix_account_data_sync * 'develop' of github.com:matrix-org/synapse: Blacklist PurgeRoomTestCase (#6361) Set room version default to 5
| * | | | | | | | lintAndrew Morgan2019-11-081-2/+1
| | | | | | | | |
| * | | | | | | | Add changelogAndrew Morgan2019-11-081-0/+1
| | | | | | | | |
| * | | | | | | | Remove content from being sent for account data rdata streamAndrew Morgan2019-11-082-6/+6
| | |_|/ / / / / | |/| | | | | |
* | | | | | | | Merge pull request #6332 from matrix-org/erikj/query_devices_fixErik Johnston2019-11-264-4/+99
|\ \ \ \ \ \ \ \ | |_|_|_|_|_|_|/ |/| | | | | | | Fix caching devices for remote servers in worker.
| * | | | | | | Fixup docsErik Johnston2019-11-262-2/+6
| | | | | | | |
| * | | | | | | NewsfileErik Johnston2019-11-051-0/+1
| | | | | | | |
| * | | | | | | Fix caching devices for remote servers in worker.Erik Johnston2019-11-053-4/+94
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | When the `/keys/query` API is hit on client_reader worker Synapse may decide that it needs to resync some remote deivces. Usually this happens on master, and then gets cached. However, that fails on workers and so it falls back to fetching devices from remotes directly, which may in turn fail if the remote is down.
* | | | | | | | Make sure that we close cursors before returning from a query (#6408)Richard van der Hoff2019-11-253-10/+44
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | There are lots of words in the comment as to why this is a good idea. Fixes #6403.
* | | | | | | | Merge tag 'v1.6.0rc2' into developRichard van der Hoff2019-11-253-19/+35
|\ \ \ \ \ \ \ \ | | |_|_|/ / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Synapse 1.6.0rc2 (2019-11-25) ============================= Bugfixes -------- - Fix a bug which could cause the background database update hander for event labels to get stuck in a loop raising exceptions. ([\#6407](https://github.com/matrix-org/synapse/issues/6407))
| * | | | | | | 1.6.0rc2 v1.6.0rc2Richard van der Hoff2019-11-253-2/+10
| | | | | | | |
| * | | | | | | Fix exceptions from background database update for event labels. (#6407)Richard van der Hoff2019-11-252-18/+26
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Add some exception handling here so that events whose json cannot be parsed are ignored rather than getting us stuck in a loop. Fixes #6404.
* | | | | | | | Improve the performance of structured logging (#6322)Amber Brown2019-11-264-30/+93
| | | | | | | |
* | | | | | | | Merge pull request #6392 from matrix-org/babolivier/fix-1623Brendan Abolivier2019-11-252-0/+75
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | Test if a purge can make /messages return 500 responses
| * | | | | | | | LintBrendan Abolivier2019-11-201-6/+8
| | | | | | | | |
| * | | | | | | | ChangelogBrendan Abolivier2019-11-201-0/+1
| | | | | | | | |
| * | | | | | | | Test if a purge can make /messages return 500 responsesBrendan Abolivier2019-11-201-0/+72
| | | | | | | | |
* | | | | | | | | Add working build command for docker image (#6390)Andrew Morgan2019-11-232-0/+13
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Add working build command for docker image * Add changelog
* | | | | | | | | Fix link to user_dir_populate.sql in the user directory docs (#6388)Aaron Raimist2019-11-212-2/+2
| | | | | | | | |
* | | | | | | | | Clean up newline quote marks around the codebase (#6362)Andrew Morgan2019-11-2126-46/+43
| | | | | | | | |
* | | | | | | | | update macOS installation instructionsMatthew Hodgson2019-11-201-2/+10
| |/ / / / / / / |/| | | | | | |
* | | | | | | | 1.6.0rc1 v1.6.0rc1Andrew Morgan2019-11-2062-61/+75
| | | | | | | |
* | | | | | | | Docker: Change permissions for data dir before attempting to write to it (#6389)Andrew Morgan2019-11-202-3/+4
| | | | | | | |
* | | | | | | | Move admin endpoints into separate files (#6308)Manuel Stahl2019-11-205-555/+622
| | | | | | | |
* | | | | | | | Merge pull request #6335 from matrix-org/erikj/rc_login_cleanupsBrendan Abolivier2019-11-203-70/+126
|\ \ \ \ \ \ \ \ | |_|_|_|_|/ / / |/| | | | | | | Only do `rc_login` ratelimiting on succesful login.
| * | | | | | | LintBrendan Abolivier2019-11-201-1/+3
| | | | | | | |
| * | | | | | | Apply suggestions from code reviewErik Johnston2019-11-182-3/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Co-Authored-By: Andrew Morgan <1342360+anoadragon453@users.noreply.github.com> Co-Authored-By: Brendan Abolivier <babolivier@matrix.org>
| * | | | | | | NewsfileErik Johnston2019-11-061-0/+1
| | | | | | | |
| * | | | | | | Add failed auth ratelimiting to UIAErik Johnston2019-11-061-1/+32
| | | | | | | |
| * | | | | | | Only do `rc_login` ratelimiting on succesful login.Erik Johnston2019-11-062-72/+94
| | |/ / / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We were doing this in a number of places which meant that some login code paths incremented the counter multiple times. It was also applying ratelimiting to UIA endpoints, which was probably not intentional. In particular, some custom auth modules were calling `check_user_exists`, which incremented the counters, meaning that people would fail to login sometimes.
* | | | | | | Replace UPDATE with UPSERT on device_max_stream_id table (#6363)Andrew Morgan2019-11-152-2/+16
| | | | | | |
* | | | | | | Add optional python dependencies to snap packaging (#6317)James2019-11-142-0/+21
| | | | | | | | | | | | | | | | | | | | | Signed-off-by: James Hebden <james@ec0.io>
* | | | | | | Fix guest -> real account upgrade with account validity enabled (#6359)Andrew Morgan2019-11-142-6/+4
| | | | | | |
* | | | | | | Replace instance variations of homeserver with correct case/spacing (#6357)Andrew Morgan2019-11-1421-37/+38
|\ \ \ \ \ \ \ | |_|_|_|/ / / |/| | | | | |
| * | | | | | Merge branch 'develop' of github.com:matrix-org/synapse into ↵Andrew Morgan2019-11-145-2/+6
| |\ \ \ \ \ \ | |/ / / / / / |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | anoa/homeserver_copy * 'develop' of github.com:matrix-org/synapse: Blacklist PurgeRoomTestCase (#6361) Set room version default to 5
* | | | | | | Merge pull request #6220 from matrix-org/neilj/set_room_version_default_to_5Brendan Abolivier2019-11-143-2/+3
|\ \ \ \ \ \ \ | |_|_|/ / / / |/| | | | | | Set room version default to 5
| * | | | | | Set room version default to 5Neil Johnson2019-10-193-2/+3
| | | | | | |
* | | | | | | Blacklist PurgeRoomTestCase (#6361)Andrew Morgan2019-11-132-0/+3
| |_|_|/ / / |/| | | | |
| | * | | | sample configAndrew Morgan2019-11-121-4/+4
| | | | | |
| | * | | | Add changelogAndrew Morgan2019-11-121-0/+1
| | | | | |
| | * | | | A couple more instancesAndrew Morgan2019-11-122-2/+2
| | | | | |
| | * | | | Replace instance variations of homeserver with correct case/spacingAndrew Morgan2019-11-1218-31/+31
| |/ / / / |/| | | |
* | | | | Merge pull request #6340 from matrix-org/babolivier/pagination_queryBrendan Abolivier2019-11-082-8/+33
|\ \ \ \ \ | | | | | | | | | | | | Fix the SQL SELECT query in _paginate_room_events_txn
| * | | | | Incorporate reviewBrendan Abolivier2019-11-081-12/+12
| | | | | |
| * | | | | LintBrendan Abolivier2019-11-071-2/+2
| | | | | |
| * | | | | Only join on event_labels if we're filtering on labelsBrendan Abolivier2019-11-071-9/+24
| | | | | |
| * | | | | Handle lack of filterBrendan Abolivier2019-11-071-5/+3
| | | | | |
| * | | | | ChangelogBrendan Abolivier2019-11-071-0/+1
| | | | | |
| * | | | | Fix the SQL SELECT query in _paginate_room_events_txnBrendan Abolivier2019-11-071-2/+13
| | | | | | | | | | | | | | | | | | | | | | | | Doing a SELECT DISTINCT when paginating is quite expensive, because it requires the engine to do sorting on the entire events table. However, we only need to run it if we're filtering on 2+ labels, so this PR is changing the request so that DISTINCT is only used then.
* | | | | | Merge pull request #6295 from matrix-org/erikj/split_purge_historyErik Johnston2019-11-088-182/+335
|\ \ \ \ \ \ | | | | | | | | | | | | | | Split purge API into events vs state and add PurgeEventsStorage
| * | | | | | Move type annotation into docstringErik Johnston2019-11-081-3/+3
| | | | | | |
| * | | | | | Fix deleting state groups during room purge.Erik Johnston2019-11-062-14/+17
| | | | | | | | | | | | | | | | | | | | | | | | | | | | And fix the tests to actually test that things got deleted.
| * | | | | | Use correct type annotationErik Johnston2019-11-061-2/+2
| | | | | | |
| * | | | | | Merge branch 'develop' of github.com:matrix-org/synapse into ↵Erik Johnston2019-11-055-83/+146
| |\ \ \ \ \ \ | | | |_|_|_|/ | | |/| | | | | | | | | | | erikj/split_purge_history
| * | | | | | Change to not require a state_groups.room_id index.Erik Johnston2019-11-044-53/+45
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This does mean that we won't clean up orphaned state groups (i.e. state groups that were persisted but the associated event wasn't).
| * | | | | | Merge branch 'develop' of github.com:matrix-org/synapse into ↵Erik Johnston2019-11-0496-369/+2050
| |\ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | | | | erikj/split_purge_history
| * | | | | | | Fix up commentErik Johnston2019-11-011-2/+1
| | | | | | | |