Commit message (Collapse) | Author | Age | Files | Lines | ||
---|---|---|---|---|---|---|
... | ||||||
* | | | Merge tag 'v1.10.0rc3' into develop | Richard van der Hoff | 2020-02-10 | 4 | -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.0rc3 | Richard van der Hoff | 2020-02-10 | 4 | -3/+16 | |
| | | | ||||||
| * | | filter out m.room.aliases from the CS API until a better solution is specced ↵ | Matthew Hodgson | 2020-02-10 | 2 | -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 develop | Richard van der Hoff | 2020-02-10 | 2 | -0/+19 | |
|\| | | ||||||
| * | | Update setuptools for python 3.5 tests (#6880) | Richard van der Hoff | 2020-02-10 | 2 | -0/+19 | |
| | | | | | | | | | Workaround for jaraco/zipp#40 | |||||
* | | | Add support for putting fed user query API on workers (#6873) | Erik Johnston | 2020-02-07 | 5 | -21/+25 | |
| | | | ||||||
* | | | Remove unused `get_room_stats_state` method. (#6869) | Richard van der Hoff | 2020-02-07 | 2 | -25/+1 | |
| | | | ||||||
* | | | Add a `make_event_from_dict` method (#6858) | Richard van der Hoff | 2020-02-07 | 13 | -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 Johnston | 2020-02-07 | 9 | -107/+138 | |
| | | | ||||||
* | | | Allow moving group read APIs to workers (#6866) | Erik Johnston | 2020-02-07 | 9 | -687/+722 | |
| | | | ||||||
* | | | Admin api to add an email address (#6789) | Dirk Klimpel | 2020-02-07 | 6 | -2/+78 | |
| | | | ||||||
* | | | remove unused room_version_to_event_format (#6857) | Richard van der Hoff | 2020-02-07 | 2 | -23/+2 | |
| | | | ||||||
* | | | Merge pull request #6856 from matrix-org/rav/redact_changes/6 | Richard van der Hoff | 2020-02-07 | 5 | -60/+51 | |
|\ \ \ | | | | | | | | | Pass room_version into `event_from_pdu_json` | |||||
| * | | | Pass room_version into `event_from_pdu_json` | Richard van der Hoff | 2020-02-06 | 5 | -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 Cloke | 2020-02-06 | 2 | -0/+5 | |
|/ / / | | | | | | | Limit the maximum number of events requested when backfilling events. | |||||
* | | | pass room version into FederationClient.send_join (#6854) | Richard van der Hoff | 2020-02-06 | 3 | -30/+34 | |
| | | | | | | | | | | | | ... which allows us to sanity-check the create event. | |||||
* | | | Allow empty federation_certificate_verification_whitelist (#6849) | timfi | 2020-02-06 | 2 | -0/+3 | |
| | | | ||||||
* | | | Third party event rules Update (#6781) | PeerD | 2020-02-06 | 3 | -4/+10 | |
| | | | ||||||
* | | | Reduce amount of logging at INFO level. (#6862) | Erik Johnston | 2020-02-06 | 12 | -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/5 | Richard van der Hoff | 2020-02-06 | 3 | -19/+14 | |
|\ \ \ | | | | | | | | | pass room versions around | |||||
| * | | | Newsfile | Richard van der Hoff | 2020-02-05 | 1 | -0/+1 | |
| | | | | ||||||
| * | | | Simplify `room_version` handling in `FederationClient.send_invite` | Richard van der Hoff | 2020-02-05 | 1 | -10/+6 | |
| | | | | ||||||
| * | | | Pass room version object into `FederationClient.get_pdu` | Richard van der Hoff | 2020-02-05 | 2 | -9/+7 | |
| | | | | ||||||
* | | | | Merge tag 'v1.10.0rc2' into develop | Erik Johnston | 2020-02-06 | 8 | -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.0rc2 | Erik Johnston | 2020-02-06 | 1 | -1/+1 | |
| | | | | ||||||
| * | | | Update changelog | Erik Johnston | 2020-02-06 | 1 | -2/+2 | |
| | | | | ||||||
| * | | | Update changelog | Erik Johnston | 2020-02-06 | 1 | -1/+1 | |
| | | | | ||||||
| * | | | 1.10.0rc2 | Erik Johnston | 2020-02-06 | 5 | -4/+17 | |
| | | | | ||||||
| * | | | Check sender_key matches on inbound encrypted events. (#6850) | Erik Johnston | 2020-02-05 | 3 | -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_fed | Hubert Chathi | 2020-02-05 | 2 | -0/+11 | |
| | | | | | | | | | | | | add device signatures to device key query results | |||||
| * | | | Fix detecting unknown devices from remote encrypted events. (#6848) | Erik Johnston | 2020-02-04 | 6 | -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-install | Patrick Cloke | 2020-02-05 | 2 | -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 Cloke | 2020-02-05 | 2 | -1/+2 | |
| | | | | ||||||
* | | | | Merge pull request #6840 from matrix-org/rav/federation_client_async | Richard van der Hoff | 2020-02-05 | 2 | -136/+143 | |
|\ \ \ \ | |/ / / |/| | | | Port much of `synapse.federation.federation_client` to async/await | |||||
| * | | | make FederationClient._do_send_invite async | Richard van der Hoff | 2020-02-05 | 1 | -10/+7 | |
| | | | | ||||||
| * | | | Apply suggestions from code review | Richard van der Hoff | 2020-02-05 | 1 | -2/+4 | |
| | | | | | | | | | | | | Co-Authored-By: Erik Johnston <erik@matrix.org> | |||||
| * | | | Merge remote-tracking branch 'origin/develop' into rav/federation_client_async | Richard van der Hoff | 2020-02-04 | 7 | -349/+386 | |
| |\ \ \ | ||||||
| * | | | | make FederationClient.send_invite async | Richard van der Hoff | 2020-02-03 | 1 | -6/+5 | |
| | | | | | ||||||
| * | | | | newsfile | Richard van der Hoff | 2020-02-03 | 1 | -0/+1 | |
| | | | | | ||||||
| * | | | | make FederationClient.get_missing_events async | Richard van der Hoff | 2020-02-03 | 1 | -20/+20 | |
| | | | | | ||||||
| * | | | | make FederationClient._do_send_leave async | Richard van der Hoff | 2020-02-03 | 1 | -4/+3 | |
| | | | | | ||||||
| * | | | | make FederationClient.send_leave.send_request async | Richard van der Hoff | 2020-02-03 | 1 | -5/+2 | |
| | | | | | ||||||
| * | | | | make FederationClient._do_send_join async | Richard van der Hoff | 2020-02-03 | 1 | -4/+3 | |
| | | | | | ||||||
| * | | | | make FederationClient.send_join.send_request async | Richard van der Hoff | 2020-02-03 | 1 | -4/+3 | |
| | | | | | ||||||
| * | | | | make FederationClient.make_membership_event.send_request async | Richard van der Hoff | 2020-02-03 | 1 | -4/+3 | |
| | | | | | ||||||
| * | | | | make FederationClient._try_destination_list async | Richard van der Hoff | 2020-02-03 | 1 | -10/+26 | |
| | | | | | ||||||
| * | | | | make FederationClient.send_leave async | Richard van der Hoff | 2020-02-03 | 1 | -10/+9 | |
| | | | | | ||||||
| * | | | | make FederationClient.send_join async | Richard van der Hoff | 2020-02-03 | 1 | -11/+13 | |
| | | | | | ||||||
| * | | | | make FederationClient.make_membership_event async | Richard van der Hoff | 2020-02-03 | 1 | -10/+11 | |
| | | | | | ||||||
| * | | | | make FederationClient.get_event_auth async | Richard van der Hoff | 2020-02-03 | 1 | -6/+4 | |
| | | | | | ||||||
| * | | | | make FederationClient.get_room_state_ids async | Richard van der Hoff | 2020-02-03 | 1 | -4/+5 | |
| | | | | | ||||||
| * | | | | make FederationClient.get_pdu async | Richard van der Hoff | 2020-02-03 | 1 | -15/+17 | |
| | | | | | ||||||
| * | | | | make FederationClient.backfill async | Richard van der Hoff | 2020-02-03 | 1 | -15/+11 | |
| | | | | | ||||||
* | | | | | Reduce performance logging to DEBUG (#6833) | Michael Kaye | 2020-02-05 | 2 | -1/+2 | |
| | | | | | | | | | | | | | | | | | | | | | | | | | * Reduce tnx performance logging to DEBUG * Changelog.d | |||||
* | | | | | Database updates to populate rooms.room_version (#6847) | Richard van der Hoff | 2020-02-04 | 3 | -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_fed | Hubert Chathi | 2020-02-04 | 2 | -0/+11 | |
|\ \ \ \ \ | | | | | | | | | | | | | add device signatures to device key query results | |||||
| * | | | | | add changelog | Hubert Chathi | 2020-02-04 | 1 | -0/+1 | |
| | | | | | | ||||||
| * | | | | | add device signatures to device key query results | Hubert Chathi | 2020-02-04 | 1 | -0/+10 | |
| | | | | | | ||||||
* | | | | | | Update CONTRIBUTING.md about merging PRs. (#6846) | Michael Kaye | 2020-02-04 | 2 | -0/+15 | |
| |_|/ / / |/| | | | | ||||||
* | | | | | Merge pull request #6837 from matrix-org/rav/federation_async | Richard van der Hoff | 2020-02-04 | 4 | -235/+212 | |
|\ \ \ \ \ | |/ / / / |/| / / / | |/ / / | Port much of `synapse.handlers.federation` to async/await. | |||||
| * | | | make FederationHandler.send_invite async | Richard van der Hoff | 2020-02-03 | 2 | -6/+4 | |
| | | | | ||||||
| * | | | make FederationHandler.on_get_missing_events async | Richard van der Hoff | 2020-02-03 | 1 | -5/+4 | |
| | | | | ||||||
| * | | | changelog | Richard van der Hoff | 2020-02-03 | 1 | -0/+1 | |
| | | | | ||||||
| * | | | make FederationHandler.user_joined_room async | Richard van der Hoff | 2020-02-03 | 1 | -3/+3 | |
| | | | | ||||||
| * | | | make FederationHandler._clean_room_for_join async | Richard van der Hoff | 2020-02-03 | 1 | -4/+4 | |
| | | | | ||||||
| * | | | make FederationHandler._notify_persisted_event async | Richard van der Hoff | 2020-02-03 | 1 | -4/+6 | |
| | | | | ||||||
| * | | | make FederationHandler.persist_events_and_notify async | Richard van der Hoff | 2020-02-03 | 1 | -10/+10 | |
| | | | | ||||||
| * | | | make FederationHandler._make_and_verify_event async | Richard van der Hoff | 2020-02-03 | 1 | -5/+10 | |
| | | | | ||||||
| * | | | make FederationHandler.do_remotely_reject_invite async | Richard van der Hoff | 2020-02-03 | 2 | -8/+11 | |
| | | | | ||||||
| * | | | make FederationHandler._check_for_soft_fail async | Richard van der Hoff | 2020-02-03 | 1 | -13/+9 | |
| | | | | ||||||
| * | | | make FederationHandler._persist_auth_tree async | Richard van der Hoff | 2020-02-03 | 1 | -11/+7 | |
| | | | | ||||||
| * | | | make FederationHandler.do_invite_join async | Richard van der Hoff | 2020-02-03 | 2 | -18/+18 | |
| | | | | ||||||
| * | | | make FederationHandler.on_event_auth async | Richard van der Hoff | 2020-02-03 | 1 | -5/+4 | |
| | | | | ||||||
| * | | | make FederationHandler.on_exchange_third_party_invite_request async | Richard van der Hoff | 2020-02-03 | 1 | -14/+12 | |
| | | | | ||||||
| * | | | make FederationHandler.construct_auth_difference async | Richard van der Hoff | 2020-02-03 | 1 | -3/+4 | |
| | | | | ||||||
| * | | | make FederationHandler._update_context_for_auth_events async | Richard van der Hoff | 2020-02-03 | 1 | -10/+10 | |
| | | | | ||||||
| * | | | make FederationHandler._update_auth_events_and_context_for_auth async | Richard van der Hoff | 2020-02-03 | 1 | -20/+21 | |
| | | | | ||||||
| * | | | make FederationHandler.do_auth async | Richard van der Hoff | 2020-02-03 | 1 | -10/+14 | |
| | | | | ||||||
| * | | | make FederationHandler._prep_event async | Richard van der Hoff | 2020-02-03 | 1 | -23/+10 | |
| | | | | ||||||
| * | | | make FederationHandler._handle_new_event async | Richard van der Hoff | 2020-02-03 | 1 | -6/+7 | |
| | | | | ||||||
| * | | | make FederationHandler._handle_new_events async | Richard van der Hoff | 2020-02-03 | 1 | -8/+6 | |
| | | | | ||||||
| * | | | make FederationHandler.on_make_leave_request async | Richard van der Hoff | 2020-02-03 | 1 | -13/+10 | |
| | | | | ||||||
| * | | | make FederationHandler.on_send_leave_request async | Richard van der Hoff | 2020-02-03 | 1 | -5/+3 | |
| | | | | ||||||
| * | | | make FederationHandler.on_make_join_request async | Richard van der Hoff | 2020-02-03 | 1 | -13/+10 | |
| | | | | ||||||
| * | | | make FederationHandler.on_invite_request async | Richard van der Hoff | 2020-02-03 | 1 | -5/+4 | |
| | | | | ||||||
| * | | | make FederationHandler.on_send_join_request async | Richard van der Hoff | 2020-02-03 | 1 | -9/+7 | |
| | | | | ||||||
| * | | | make FederationHandler.on_query_auth async | Richard van der Hoff | 2020-02-03 | 1 | -7/+6 | |
| | | | | ||||||
* | | | | Add typing to SyncHandler (#6821) | Erik Johnston | 2020-02-03 | 5 | -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 Johnston | 2020-02-03 | 2 | -0/+5 | |
|/ / / | ||||||
* | | | Allow URL-encoded user IDs on user admin api paths (#6825) | Andrew Morgan | 2020-02-03 | 2 | -2/+3 | |
| | | | ||||||
* | | | Fix `room_version` in `on_invite_request` flow (#6827) | Richard van der Hoff | 2020-02-03 | 3 | -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.0rc1 | Erik Johnston | 2020-01-31 | 1 | -1/+4 | |
| | | ||||||
* | | Fix link in upgrade.rst | Erik Johnston | 2020-01-31 | 1 | -1/+1 | |
| | | ||||||
* | | 1.10.0rc1 | Erik Johnston | 2020-01-31 | 35 | -35/+47 | |
| | | ||||||
* | | Fix deleting of stale marker for device lists (#6819) | Erik Johnston | 2020-01-31 | 2 | -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 Hoff | 2020-01-31 | 3 | -9/+25 | |
| | | ||||||
* | | Merge pull request #6806 from matrix-org/rav/redact_changes/3 | Richard van der Hoff | 2020-01-31 | 6 | -41/+49 | |
|\ \ | | | | | | | Pass room_version into add_hashes_and_signatures | |||||
| * | | changelog | Richard van der Hoff | 2020-01-30 | 1 | -0/+1 | |
| | | | ||||||
| * | | Pass room_version into add_hashes_and_signatures | Richard van der Hoff | 2020-01-30 | 3 | -10/+21 | |
| | | | ||||||
| * | | Pass room_version into create_local_event_from_event_dict | Richard van der Hoff | 2020-01-30 | 2 | -25/+19 | |
| | | | ||||||
| * | | Store the room version in EventBuilder | Richard van der Hoff | 2020-01-30 | 2 | -7/+9 | |
| | | | ||||||
* | | | Merge pull request #6820 from matrix-org/rav/get_room_version_id | Richard van der Hoff | 2020-01-31 | 14 | -38/+64 | |
|\ \ \ | | | | | | | | | Make `get_room_version` return a RoomVersion object | |||||
| * | | | newsfile | Richard van der Hoff | 2020-01-31 | 1 | -0/+1 | |
| | | | | ||||||
| * | | | Add `get_room_version` method | Richard van der Hoff | 2020-01-31 | 2 | -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 Hoff | 2020-01-31 | 12 | -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 Johnston | 2020-01-31 | 2 | -1/+6 | |
|/ / / | ||||||
* | | | pass room version into FederationHandler.on_invite_request (#6805) | Richard van der Hoff | 2020-01-30 | 3 | -4/+5 | |
| | | | ||||||
* | | | Log when we delete room in bg update (#6816) | Erik Johnston | 2020-01-30 | 2 | -0/+3 | |
|/ / | ||||||
* | | MSC2260: Block direct sends of m.room.aliases events (#6794) | Richard van der Hoff | 2020-01-30 | 4 | -33/+28 | |
| | | | | | | | | | | as per MSC2260 | |||||
* | | Backgroud update to clean out rooms from current state (#6802) | Erik Johnston | 2020-01-30 | 3 | -2/+126 | |
| | | ||||||
* | | Resync remote device list when detected as stale. (#6786) | Erik Johnston | 2020-01-30 | 4 | -7/+28 | |
| | | ||||||
* | | Fix sending server up commands from workers (#6811) | Erik Johnston | 2020-01-30 | 6 | -13/+36 | |
| | | | | | | | | Co-authored-by: Andrew Morgan <1342360+anoadragon453@users.noreply.github.com> | |||||
* | | When server leaves room check for stale device lists. (#6801) | Erik Johnston | 2020-01-30 | 3 | -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 Johnston | 2020-01-30 | 2 | -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 Hoff | 2020-01-30 | 5 | -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 Johnston | 2020-01-29 | 2 | -20/+2 | |
| | | ||||||
* | | Merge pull request #6790 from matrix-org/rav/msc2260.1 | Richard van der Hoff | 2020-01-29 | 5 | -18/+112 | |
|\ \ | | | | | | | MSC2260: change the default power level for m.room.aliases events | |||||
| * | | changelog | Richard van der Hoff | 2020-01-29 | 1 | -0/+1 | |
| | | | ||||||
| * | | Make /directory/room/<alias> handle restrictive power levels | Richard van der Hoff | 2020-01-29 | 1 | -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 Hoff | 2020-01-29 | 2 | -3/+16 | |
| | | | ||||||
| * | | Factor out a `copy_power_levels_contents` method | Richard van der Hoff | 2020-01-29 | 3 | -15/+90 | |
|/ / | | | | | | | I'm going to need another copy (hah!) of this. | |||||
* | | Fix race in federation sender that delayed device updates. (#6799) | Erik Johnston | 2020-01-29 | 3 | -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. | |||||
* | | Delete current state when server leaves a room (#6792) | Erik Johnston | 2020-01-29 | 3 | -75/+198 | |
| | | | | | | | | | | | | Otherwise its just stale data, which may get deleted later anyway so can't be relied on. It's also a bit of a shotgun if we're trying to get the current state of a room we're not in. | |||||
* | | Fix bug when querying remote user keys that require a resync. (#6796) | Erik Johnston | 2020-01-29 | 2 | -1/+3 | |
| | | | | | | | | We ended up only returning a single device, rather than all of them. | |||||
* | | Fix outbound federation request metrics (#6795) | Erik Johnston | 2020-01-28 | 2 | -0/+5 | |
| | | ||||||
* | | Merge pull request #6787 from matrix-org/rav/msc2260 | Richard van der Hoff | 2020-01-28 | 3 | -5/+36 | |
|\ \ | | | | | | | Implement updated auth rules from MSC2260 | |||||
| * | | fix bad variable ref | Richard van der Hoff | 2020-01-28 | 1 | -1/+1 | |
| | | | ||||||
| * | | update changelog | Richard van der Hoff | 2020-01-28 | 2 | -1/+1 | |
| | | | ||||||
| * | | changelog | Richard van der Hoff | 2020-01-28 | 1 | -0/+1 | |
| | | | ||||||
| * | | Implement updated auth rules from MSC2260 | Richard van der Hoff | 2020-01-28 | 2 | -5/+35 | |
| | | | ||||||
* | | | Detect unknown remote devices and mark cache as stale (#6776) | Erik Johnston | 2020-01-28 | 6 | -8/+126 | |
|/ / | | | | | | | We just mark the fact that the cache may be stale in the database for now. | |||||
* | | Pass room version object into event_auth.check and check_redaction (#6788) | Richard van der Hoff | 2020-01-28 | 8 | -34/+53 | |
| | | | | | | | | | | | | | | These are easier to work with than the strings and we normally have one around. This fixes `FederationHander._persist_auth_tree` which was passing a RoomVersion object into event_auth.check instead of a string. | |||||
* | | Warn if postgres database has non-C locale. (#6734) | Erik Johnston | 2020-01-28 | 6 | -1/+81 | |
| | | | | | | As using non-C locale can cause issues on upgrading OS. | |||||
* | | Merge branch 'master' into develop | Erik Johnston | 2020-01-28 | 4 | -2/+23 | |
|\| | ||||||
| * | 1.9.1 v1.9.1 github/release-v1.9.1 release-v1.9.1 | Erik Johnston | 2020-01-28 | 4 | -2/+16 | |
| | | ||||||
| * | Fix setting `mau_limit_reserved_threepids` config (#6793) | Erik Johnston | 2020-01-28 | 2 | -1/+8 | |
| | | | | | | | | | | Calling the invalidation function during initialisation of the data stores introduces a circular dependency, causing Synapse to fail to start. | |||||
* | | Add `rooms.room_version` column (#6729) | Erik Johnston | 2020-01-27 | 11 | -73/+270 | |
| | | | | | | This is so that we don't have to rely on pulling it out from `current_state_events` table. | |||||
* | | Propagate cache invalidates from workers to other workers. (#6748) | Erik Johnston | 2020-01-27 | 4 | -5/+29 | |
| | | | | | | Currently if a worker invalidates a cache it will be streamed to master, which then didn't forward those to other workers. | |||||
* | | Merge pull request #6775 from matrix-org/jaywink/worker-docs-tweaks | Brendan Abolivier | 2020-01-27 | 2 | -0/+18 | |
|\ \ | | | | | | | Clarifications to the workers documentation | |||||
| * | | Formatting of changelog | Jason Robinson | 2020-01-27 | 1 | -1/+1 | |
| | | | | | | | | | Co-Authored-By: Brendan Abolivier <babolivier@matrix.org> | |||||
| * | | Fix federation_reader listeners doc as per PR review | Jason Robinson | 2020-01-27 | 1 | -2/+12 | |
| | | | | | | | | | | | | Signed-off-by: Jason Robinson <jasonr@matrix.org> | |||||
| * | | Clarifications to the workers documentation | Jason Robinson | 2020-01-24 | 2 | -0/+8 | |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | * Add note that user_dir requires disabling user dir updates from the main synapse process. * Add note that federation_reader should have the federation listener resource. Signed-off-by: Jason Robinson <jasonr@matrix.org> | |||||
* | | | Validate client_secret parameter (#6767) | Andrew Morgan | 2020-01-24 | 6 | -6/+93 | |
|/ / | ||||||
* | | Make 'event.redacts' never raise. (#6771) | Erik Johnston | 2020-01-23 | 5 | -6/+62 | |
| | | | | | | | | | | | | There are quite a few places that we assume that a redaction event has a corresponding `redacts` key, which is not always the case. So lets cheekily make it so that event.redacts just returns None instead. | |||||
* | | Merge branch 'master' into develop | Brendan Abolivier | 2020-01-23 | 4 | -5/+20 | |
|\| | ||||||
| * | Fixup changelog v1.9.0 github/release-v1.9.0 release-v1.9.0 | Brendan Abolivier | 2020-01-23 | 1 | -1/+1 | |
| | | ||||||
| * | Fixup changelog | Brendan Abolivier | 2020-01-23 | 1 | -4/+5 | |
| | | ||||||
| * | Fixup changelog | Brendan Abolivier | 2020-01-23 | 2 | -2/+4 | |
| | | ||||||
| * | Merge branch 'release-v1.9.0' of github.com:matrix-org/synapse into ↵ | Brendan Abolivier | 2020-01-23 | 2 | -4/+5 | |
| |\ | | | | | | | | | | release-v1.9.0 | |||||
| * | | 1.9.0 | Brendan Abolivier | 2020-01-23 | 3 | -1/+13 | |
| | | | ||||||
* | | | a bit of debugging for media storage providers (#6757) | Richard van der Hoff | 2020-01-23 | 3 | -0/+8 | |
| | | | | | | | | | | | | | | | | | | * a bit of debugging for media storage providers * changelog | |||||
* | | | Minor fixes to user admin api (#6761) | Richard van der Hoff | 2020-01-23 | 2 | -9/+6 | |
| | | | | | | | | | | | | * don't insist on a password (this is valid if you have an SSO login) * fix reference to undefined `requester` | |||||
* | | | Merge branch 'release-v1.9.0' into develop | Andrew Morgan | 2020-01-23 | 2 | -4/+5 | |
|\ \ \ | | |/ | |/| | ||||||
| * | | Update admin room docs with correct endpoints (#6770) | Andrew Morgan | 2020-01-23 | 2 | -4/+5 | |
| |/ | ||||||
* / | Remove unnecessary abstractions in admin handler (#6751) | Andrew Morgan | 2020-01-22 | 4 | -73/+11 | |
|/ | ||||||
* | Fixup warning about workers changes v1.9.0rc1 | Brendan Abolivier | 2020-01-22 | 1 | -1/+1 | |
| | ||||||
* | Add deprecation headers | Brendan Abolivier | 2020-01-22 | 1 | -0/+4 | |
| | ||||||
* | Fixup changelog | Brendan Abolivier | 2020-01-22 | 1 | -10/+10 | |
| | ||||||
* | 1.9.0rc1 | Brendan Abolivier | 2020-01-22 | 49 | -49/+71 | |
| | ||||||
* | Admin API to list, filter and sort rooms (#6720) | Andrew Morgan | 2020-01-22 | 8 | -7/+787 | |
| | ||||||
* | Merge pull request #6764 from matrix-org/babolivier/fix-thumbnail | Brendan Abolivier | 2020-01-22 | 3 | -5/+46 | |
|\ | | | | | Fix typo in _select_thumbnail | |||||
| * | Lint + changelog | Brendan Abolivier | 2020-01-22 | 2 | -3/+2 | |
| | | ||||||
| * | Remove unused import | Brendan Abolivier | 2020-01-22 | 1 | -1/+1 | |
| | | ||||||
| * | Add tests for thumbnailing | Brendan Abolivier | 2020-01-22 | 1 | -3/+45 | |
| | | ||||||
| * | Fix typo in _select_thumbnail | Brendan Abolivier | 2020-01-22 | 1 | -1/+1 | |
|/ | ||||||
* | Fix and add test to deprecated quarantine media admin api (#6756) | Andrew Morgan | 2020-01-22 | 3 | -5/+13 | |
| | ||||||
* | Allow monthly active user limiting support for worker mode, fixes #4639. (#6742) | Neil Johnson | 2020-01-22 | 6 | -82/+100 | |
| | ||||||
* | Allow streaming cache invalidate all to workers. (#6749) | Erik Johnston | 2020-01-22 | 6 | -15/+69 | |
| | ||||||
* | Remove unused CI docker compose files (#6754) | Erik Johnston | 2020-01-22 | 4 | -66/+1 | |
| | | | These now exist in the pipelines repo. | |||||
* | Avoid attribute error when `password_config` present but empty (#6753) | Ivan Vilata-i-Balaguer | 2020-01-22 | 2 | -1/+2 | |
| | | | | | | | | | | The old statement returned `None` for such a `password_config` (like the one created on first run), thus retrieval of the `pepper` key failed with `AttributeError`. Fixes #5315 Signed-off-by: Ivan Vilata i Balaguer <ivan@selidor.net> | |||||
* | Port synapse_port_db to async/await (#6718) | Brendan Abolivier | 2020-01-21 | 3 | -89/+126 | |
| | | | | | | | | | | | | | | | | | | | | | | | | | | * Raise an exception if there are pending background updates So we return with a non-0 code * Changelog * Port synapse_port_db to async/await * Port update_database to async/await * Add version string to mocked homeservers * Remove unused imports * Convert overseen bits to async/await * Fixup logging contexts * Fix imports * Add a way to print an error without raising an exception * Incorporate review | |||||
* | Add a DeltaState to track changes to be made to current state (#6716) | Erik Johnston | 2020-01-20 | 3 | -99/+112 | |
| | ||||||
* | Fixup synapse.rest to pass mypy (#6732) | Erik Johnston | 2020-01-20 | 12 | -35/+56 | |
| | ||||||
* | Fix `/events/:event_id` deprecated API. (#6731) | Erik Johnston | 2020-01-20 | 4 | -2/+30 | |
| | ||||||
* | Fixup synapse.api to pass mypy (#6733) | Erik Johnston | 2020-01-20 | 6 | -4/+14 | |
| | ||||||
* | Fix changing password via user admin API. (#6730) | Erik Johnston | 2020-01-20 | 3 | -2/+16 | |
| | ||||||
* | Fix empty account_validity config block (#6747) | Andrew Morgan | 2020-01-20 | 2 | -1/+3 | |
|\ | ||||||
| * | Update changelog.d/6747.bugfix | Andrew Morgan | 2020-01-20 | 1 | -1/+1 | |
| | | | | | | Co-Authored-By: Erik Johnston <erik@matrix.org> | |||||
| * | Add changelog | Andrew Morgan | 2020-01-20 | 1 | -0/+1 | |
| | | ||||||
| * | Fix empty account_validity config block | Andrew Morgan | 2020-01-20 | 1 | -1/+2 | |
| | | ||||||
* | | Revert "Newsfile" | Erik Johnston | 2020-01-20 | 1 | -1/+0 | |
| | | | | | | | | This reverts commit 11c23af465633b8dd641db60793a19e5b7524e2b. | |||||
* | | Newsfile | Erik Johnston | 2020-01-20 | 1 | -0/+1 | |
|/ | ||||||
* | Add more logging around message retention policies support (#6717) | Brendan Abolivier | 2020-01-17 | 3 | -0/+22 | |
| | | | So we can debug issues like #6683 more easily | |||||
* | Fix up changelog | Erik Johnston | 2020-01-17 | 2 | -1/+1 | |
| | ||||||
* | bump version to v1.9.0.dev2 v1.9.0.dev2 | Richard van der Hoff | 2020-01-17 | 1 | -1/+1 | |
| | ||||||
* | Fix syntax error in run_upgrade for schema 57 (#6728) | Satsuki Yanagi | 2020-01-17 | 2 | -3/+5 | |
| | | | | | | | Fix #6727 Related #6655 Co-authored-by: Erik Johnston <erikj@jki.re> | |||||
* | Merge pull request #6714 from matrix-org/babolivier/retention_select_event | Brendan Abolivier | 2020-01-17 | 4 | -7/+8 | |
|\ | | | | | Fix instantiation of message retention purge jobs | |||||
| * | Precise changelog | Brendan Abolivier | 2020-01-16 | 1 | -1/+1 | |
| | | ||||||
| * | Fixup diff | Brendan Abolivier | 2020-01-16 | 1 | -6/+7 | |
| | | ||||||
| * | Remove get_room_event_after_stream_ordering entirely | Brendan Abolivier | 2020-01-16 | 2 | -58/+13 | |
| | | ||||||
| * | Lint | Brendan Abolivier | 2020-01-16 | 1 | -6/+12 | |
| | | ||||||
| * | Rename changelog | Brendan Abolivier | 2020-01-15 | 1 | -0/+0 | |
| | | ||||||
| * | Changelog | Brendan Abolivier | 2020-01-15 | 1 | -0/+1 | |
| | | ||||||
| * | Correctly order when selecting before stream ordering | Brendan Abolivier | 2020-01-15 | 1 | -2/+5 | |
| | | ||||||
| * | Fix typo | Brendan Abolivier | 2020-01-15 | 1 | -1/+1 | |
| | | ||||||
| * | Fix instantiation of message retention purge jobs | Brendan Abolivier | 2020-01-15 | 2 | -13/+48 | |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | When figuring out which topological token to start a purge job at, we need to do the following: 1. Figure out a timestamp before which events will be purged 2. Select the first stream ordering after that timestamp 3. Select info about the first event after that stream ordering 4. Build a topological token from that info In some situations (e.g. quiet rooms with a short max_lifetime), there might not be an event after the stream ordering at step 3, therefore we abort the purge with the error `No event found`. To mitigate that, this patch fetches the first event _before_ the stream ordering, instead of after. | |||||
* | | bump version to v1.9.0.dev1 v1.9.0.dev1 | Richard van der Hoff | 2020-01-17 | 1 | -1/+1 | |
| | | ||||||
* | | Merge pull request #6724 from matrix-org/rav/log_saml_attributes | Richard van der Hoff | 2020-01-17 | 11 | -24/+114 | |
|\ \ | | | | | | | Log saml assertions rather than the whole response | |||||
| * | | changelog | Richard van der Hoff | 2020-01-16 | 1 | -0/+1 | |
| | | | ||||||
| * | | Log saml assertions rather than the whole response | Richard van der Hoff | 2020-01-16 | 3 | -1/+72 | |
| | | | | | | | | | | | | | | | | | | ... since the whole response is huge. We even need to break up the assertions, since kibana otherwise truncates them. | |||||
| * | | move batch_iter to a separate module | Richard van der Hoff | 2020-01-16 | 8 | -23/+41 | |
| | | | ||||||
* | | | Delegate remote_user_id mapping to the saml mapping provider (#6723) | Richard van der Hoff | 2020-01-17 | 3 | -6/+23 | |
| | | | | | | | | | Turns out that figuring out a remote user id for the SAML user isn't quite as obvious as it seems. Factor it out to the SamlMappingProvider so that it's easy to control. | |||||
* | | | Wake up transaction queue when remote server comes back online (#6706) | Erik Johnston | 2020-01-17 | 11 | -8/+135 | |
| | | | | | | | | | | | | | | | This will be used to retry outbound transactions to a remote server if we think it might have come back up. | |||||
* | | | Clarify the `account_validity` and `email` sections of the sample ↵ | Richard van der Hoff | 2020-01-17 | 5 | -272/+320 | |
|/ / | | | | | | | | | | | | | | | | | | | | | configuration. (#6685) Generally try to make this more comprehensible, and make it match the conventions. I've removed the documentation for all the settings which allow you to change the names of the template files, because I can't really see why they are useful. | |||||
* | | Add StateMap type alias (#6715) | Erik Johnston | 2020-01-16 | 14 | -93/+115 | |
| | | ||||||
* | | Add tips for the changelog to the pull request template (#6663) | Andrew Morgan | 2020-01-16 | 3 | -3/+8 | |
| | | ||||||
* | | Add org.matrix.e2e_cross_signing to unstable_features in /versions as per ↵ | Neil Johnson | 2020-01-16 | 2 | -0/+3 | |
| | | | | | | | | MSC1756 (#6712) | |||||
* | | Port synapse.replication.tcp to async/await (#6666) | Erik Johnston | 2020-01-16 | 15 | -105/+80 | |
| | | | | | | | | | | | | | | | | | | | | * Port synapse.replication.tcp to async/await * Newsfile * Correctly document type of on_<FOO> functions as async * Don't be overenthusiastic with the asyncing.... | |||||
* | | Fix purge_room admin API (#6711) | Erik Johnston | 2020-01-15 | 3 | -4/+3 | |
| | | ||||||
* | | Remove duplicate session check in web fallback servlet (#6702) | Andrew Morgan | 2020-01-15 | 2 | -4/+1 | |
| | | ||||||
* | | Merge pull request #6688 from matrix-org/rav/module_api_extensions | Richard van der Hoff | 2020-01-15 | 4 | -7/+61 | |
|\ \ | | | | | | | Cleanups and additions to the module API | |||||
| * \ | Merge branch 'develop' into rav/module_api_extensions | Richard van der Hoff | 2020-01-15 | 64 | -290/+1276 | |
| |\ \ | |/ / |/| | | ||||||
* | | | Implement RedirectException (#6687) | Richard van der Hoff | 2020-01-15 | 4 | -7/+113 | |
| | | | | | | | | | | | | | | | Allow REST endpoint implemnentations to raise a RedirectException, which will redirect the user's browser to a given location. | |||||
* | | | Add `local_current_membership` table (#6655) | Erik Johnston | 2020-01-15 | 20 | -107/+263 | |
| |/ |/| | | | | | | | | | | | Currently we rely on `current_state_events` to figure out what rooms a user was in and their last membership event in there. However, if the server leaves the room then the table may be cleaned up and that information is lost. So lets add a table that separately holds that information. | |||||
* | | Process EDUs in parallel with PDUs. (#6697) | Erik Johnston | 2020-01-14 | 2 | -12/+59 | |
| | | | | | | | | This means that things like to device messages don't get blocked behind processing PDUs, which can potentially take *ages*. | |||||
* | | Fixup synapse.replication to pass mypy checks (#6667) | Erik Johnston | 2020-01-14 | 12 | -86/+105 | |
| | | ||||||
* | | Quarantine media by ID or user ID (#6681) | Andrew Morgan | 2020-01-13 | 7 | -11/+632 | |
| | | ||||||
* | | Document more supported endpoints for workers (#6698) | Richard van der Hoff | 2020-01-13 | 2 | -0/+5 | |
| | | ||||||
* | | Kill off RegistrationError (#6691) | Richard van der Hoff | 2020-01-13 | 4 | -17/+4 | |
| | | | | | | This is pretty pointless. Let's just use SynapseError. | |||||
* | | Don't assign numeric IDs for empty usernames (#6690) | Richard van der Hoff | 2020-01-13 | 2 | -1/+2 | |
| | | | | | | | | Fix a bug where we would assign a numeric userid if somebody tried registering with an empty username | |||||
* | | Merge pull request #6689 from matrix-org/rav/saml_mapping_provider_updates | Richard van der Hoff | 2020-01-13 | 2 | -6/+17 | |
|\ \ | | | | | | | Updates to the SAML mapping provider API | |||||
| * | | changelog | Richard van der Hoff | 2020-01-12 | 1 | -0/+1 | |
| | | | ||||||
| * | | Pass client redirect URL into SAML mapping providers | Richard van der Hoff | 2020-01-12 | 1 | -4/+11 | |
| | | | ||||||
| * | | Pass the module_api into the SamlMappingProvider | Richard van der Hoff | 2020-01-12 | 1 | -2/+5 | |
| | | | | | | | | | | | | | | | ... for consistency with other modules, and because we'll need it sooner or later and it will be a pain to introduce later. | |||||
* | | | Allow additional_resources to implement Resource directly (#6686) | Richard van der Hoff | 2020-01-13 | 2 | -2/+12 | |
| | | | | | | | | | | | | | | | | | | AdditionalResource really doesn't add any value, and it gets in the way for resources which want to support child resources or the like. So, if the resource object already implements the IResource interface, don't bother wrapping it. | |||||
* | | | Fix exceptions on requests for non-ascii urls (#6682) | Richard van der Hoff | 2020-01-13 | 2 | -1/+3 | |
| | | | | | | | | | Fixes #6402 | |||||
* | | | comment for run_in_background | Richard van der Hoff | 2020-01-12 | 1 | -0/+3 | |
| | | | ||||||
* | | | Merge pull request #6675 from matrix-org/rav/die_sqlite37_die_die_die | Richard van der Hoff | 2020-01-10 | 6 | -41/+47 | |
|\ \ \ | | | | | | | | | Refuse to start if sqlite is older than 3.11.0 | |||||
| * | | | update install notes for CentOS | Richard van der Hoff | 2020-01-09 | 1 | -0/+5 | |
| | | | | ||||||
| * | | | changelog | Richard van der Hoff | 2020-01-09 | 1 | -0/+1 | |
| | | | | ||||||
| * | | | Refuse to start if sqlite is older than 3.11.0 | Richard van der Hoff | 2020-01-09 | 3 | -8/+19 | |
| | | | | ||||||
| * | | | Check postgres version in check_database | Richard van der Hoff | 2020-01-09 | 1 | -13/+12 | |
| | | | | | | | | | | | | | | | | | | | | this saves doing it on each connection, and will allow us to pass extra options in. | |||||
| * | | | Modify check_database to take a connection rather than a cursor | Richard van der Hoff | 2020-01-09 | 4 | -28/+18 | |
| |/ / | | | | | | | | | | We might not need the cursor at all. | |||||
* | | | Merge branch 'master' of github.com:matrix-org/synapse into develop | Erik Johnston | 2020-01-09 | 2 | -0/+12 | |
|\ \ \ | |/ / |/| | | ||||||
| * | | Add note about log_file no longer be accepted (#6674) github/release-v1.8.0 release-v1.8.0 | Erik Johnston | 2020-01-09 | 2 | -0/+12 | |
| | | | ||||||
| | * | changelog | Richard van der Hoff | 2020-01-12 | 1 | -0/+1 | |
| | | | ||||||
| | * | Handle `config` not being set for synapse plugin modules | Richard van der Hoff | 2020-01-12 | 1 | -1/+1 | |
| | | | | | | | | | | | | | | | Some modules don't need any config, so having to define a `config` property just to keep the loader happy is a bit annoying. | |||||
| | * | Cleanups and additions to the module API | Richard van der Hoff | 2020-01-12 | 2 | -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 Stahl | 2020-01-09 | 9 | -339/+655 | |
| | | | | | | Signed-off-by: Manuel Stahl <manuel.stahl@awesome-technologies.de> | |||||
* | | Merge branch 'master' into develop | Erik Johnston | 2020-01-09 | 5 | -5/+17 | |
|\| | ||||||
| * | Fixup changelog v1.8.0 | Erik Johnston | 2020-01-09 | 1 | -1/+1 | |
| | | ||||||
| * | 1.8.0 | Erik Johnston | 2020-01-09 | 5 | -5/+17 | |
| | | ||||||
* | | Merge pull request #6664 from matrix-org/erikj/media_admin_apis | Erik Johnston | 2020-01-08 | 3 | -120/+131 | |
|\ \ | | | | | | | Fix media repo admin APIs when using a media worker. | |||||
| * | | Shuffle the code | Erik Johnston | 2020-01-08 | 1 | -25/+16 | |
| | | | ||||||
| * | | Comments | Erik Johnston | 2020-01-08 | 1 | -0/+3 | |
| | | | ||||||
| * | | Do not rely on streaming events, as media repo doesn't | Erik Johnston | 2020-01-08 | 1 | -12/+26 | |
| | | | ||||||
| * | | Newsfile | Erik Johnston | 2020-01-08 | 1 | -0/+1 | |
| | | | ||||||
| * | | Import RoomStore in media worker to fix admin APIs | Erik Johnston | 2020-01-08 | 1 | -0/+2 | |
| | | | ||||||
| * | | Move media admin store functions to worker store | Erik Johnston | 2020-01-08 | 1 | -120/+120 | |
| | | | ||||||
* | | | Merge pull request #6665 from matrix-org/babolivier/retention_doc_typo | Brendan Abolivier | 2020-01-08 | 2 | -1/+2 | |
|\ \ \ | | | | | | | | | Fix typo in message retention policies doc |