summary refs log tree commit diff
path: root/scripts-dev/check_pydantic_models.py (unfollow)
Commit message (Collapse)AuthorFilesLines
2022-08-18Fix incorrect juggling of logging contexts in `_PerHostRatelimiter` (#13554)Sean Quah2-10/+8
Signed-off-by: Sean Quah <seanq@matrix.org> Co-authored-by: Richard van der Hoff <1389908+richvdh@users.noreply.github.com>
2022-08-18Track number of hosts affected by the rate limiter (#13541)Eric Eastwood2-4/+40
Track number of hosts affected by the rate limiter so we can differentiate one really noisy homeserver from a general ratelimit tuning problem across the federation. Follow-up to https://github.com/matrix-org/synapse/pull/13534 Part of https://github.com/matrix-org/synapse/issues/13356
2022-08-18Add support for compression to federation responses (#13537)Ayush Anand3-2/+6
Closes #13415. Signed-off-by: Ayush Anand <iamayushanand@gmail.com>
2022-08-18Avoid blocking lazy-loading `/sync`s during partial joins (#13477)Sean Quah3-34/+244
Use a state filter or accept partial state in a few places where we request state, to avoid blocking. To make lazy-loading `/sync`s work, we need to provide the memberships of event senders, which are not guaranteed to be in the room state. Instead we dig through auth events for memberships to present to clients. The auth events of an event are guaranteed to contain a passable membership event, otherwise the event would have been rejected. Note that this only covers the common code paths encountered during testing. There has been no exhaustive checking of all sync code paths. Fixes #13146. Signed-off-by: Sean Quah <seanq@matrix.org>
2022-08-17Add metrics to track how the rate limiter is affecting requests ↵Eric Eastwood2-8/+30
(sleep/reject) (#13534) Related to https://github.com/matrix-org/synapse/pull/13499 Part of https://github.com/matrix-org/synapse/issues/13356
2022-08-17Fix a bug in the `/event_reports` Admin API which meant that the total count ↵reivilibre3-0/+34
could be larger than the number of results you can actually query for. (#13525) Co-authored-by: Brendan Abolivier <babolivier@matrix.org>
2022-08-17A first pass at pruning the Synapse README (#13491)David Robertson3-347/+194
2022-08-17Fix breaking event sending due to bad push rule (#13547)Erik Johnston2-1/+13
Broke by #13522 It looks like we have some rules in the DB with a priority class less than 0 that don't override the base rules. Before these were just dropped, but #13522 made that a hard error.
2022-08-17Reject non-strict types in Pydantic models (#13502)David Robertson4-1/+440
2022-08-17Fix a typo in docs and in some warnings (#13538)Antonin Loubiere5-4/+5
2022-08-17Add forgotten status to Room Details API (#13503)Dirk Klimpel6-1/+101
2022-08-17Add metrics to track rate limiter queue timing (#13544)Eric Eastwood2-0/+31
2022-08-17Time how long it takes us to do backfill processing (#13535)Eric Eastwood3-16/+90
2022-08-17Add specific metric to time long-running `/messages` requests (#13533)Eric Eastwood2-0/+33
2022-08-16Instrument the federation/backfill part of `/messages` (#13489)Eric Eastwood11-33/+220
Instrument the federation/backfill part of `/messages` so it's easier to follow what's going on in Jaeger when viewing a trace. Split out from https://github.com/matrix-org/synapse/pull/13440 Follow-up from https://github.com/matrix-org/synapse/pull/13368 Part of https://github.com/matrix-org/synapse/issues/13356
2022-08-16Note explicitly that #11365 was reverted in the 1.65 CHANGELOGAndrew Morgan1-1/+1
2022-08-161.65.0 v1.65.0Andrew Morgan3-1/+13
2022-08-16Refuse to start when `faster_joins` is enabled on a worker deployment (#13531)Sean Quah2-0/+8
Synapse does not currently support faster room joins on deployments with workers. Signed-off-by: Sean Quah <seanq@matrix.org>
2022-08-16Add missing links in `user_consent` section of configuration manual (#13536)Dirk Klimpel2-2/+3
Signed-off-by: Dirk Klimpel <dirk@klimpel.org>
2022-08-16Faster room joins: make `/joined_members` block whilst the room is partial ↵reivilibre4-1/+22
stated. (#13514)
2022-08-16Make push rules use proper structures. (#13522)Erik Johnston8-333/+494
This improves load times for push rules: | Version | Time per user | Time for 1k users | | -------------------- | ------------- | ----------------- | | Before | 138 µs | 138ms | | Now (with custom) | 2.11 µs | 2.11ms | | Now (without custom) | 49.7 ns | 0.05 ms | This therefore has a large impact on send times for rooms with large numbers of local users in the room.
2022-08-15Use Pydantic to systematically validate a first batch of endpoints in ↵David Robertson10-92/+296
`synapse.rest.client.account`. (#13188)
2022-08-15Add a warning to retention documentation regarding the possibility of ↵Shay3-2/+9
database corruption (#13497)
2022-08-15Instrument `FederationStateIdsServlet` - `/state_ids` (#13499)Eric Eastwood5-2/+21
Instrument FederationStateIdsServlet - `/state_ids` so it's easier to follow what's going on in Jaeger when viewing a trace.
2022-08-15Revert "Update locked versions of mypy and mypy-zope (#13521)"David Robertson7-60/+73
This reverts commit f383b9b3eceaa082d5ae690550fe41460b711779. Other PRs were seeing mypy failures that looked to be related to mypy-zope. Confusingly, we didn't see this on #13521. Revert this for now and investigate later.
2022-08-15Clarifications for event push action processing. (#13485)Patrick Cloke3-21/+35
* Clarifies comments. * Fixes an erroneous comment (about return type) added in #13455 (ec24813220f9d54108924dc04aecd24555277b99). * Clarifies the name of a variable. * Simplifies logic of pulling out the latest join for the requesting user.
2022-08-15Update locked versions of mypy and mypy-zope (#13521)David Robertson7-73/+60
2022-08-13Update grafana dashboardRichard van der Hoff1-1805/+2695
2022-08-12Document that the `DOCKER_BUILDKIT=1` flag is needed to build the docker ↵reivilibre2-1/+2
image. (#13515)
2022-08-11Add `openssl` example for registration HMAC (#13472)James Barton2-2/+20
Signed-off-by: James Barton <james@neodon.com>
2022-08-11Add note to `redaction_retention_period` documentation mentioning that event ↵Andrew Morgan2-0/+5
purging runs at most every 5m (#13492)
2022-08-11Add viewport directive to HTML templates to optimise for mobile (#13493)Germain31-47/+140
2022-08-11Update the rejected state of events during resync (#13459)Richard van der Hoff4-9/+66
Events can be un-rejected or newly-rejected during resync, so ensure we update the database and caches when that happens.
2022-08-111.65.0rc2 v1.65.0rc2Olivier Wilkinson (reivilibre)4-2/+16
2022-08-11Revert 'Remove the unspecced field in the response. (#13365)' to give more ↵reivilibre2-0/+2
time for clients to update. (#13501)
2022-08-10Use literals in place of `HTTPStatus` constants in tests (#13488)Dirk Klimpel12-447/+177
* Use literals in place of `HTTPStatus` constants in tests * newsfile * code style * code style
2022-08-10Add some miscellaneous comments around sync (#13474)Sean Quah3-40/+81
Add some miscellaneous comments to document sync, especially around `compute_state_delta`. Signed-off-by: Sean Quah <seanq@matrix.org> Co-authored-by: Richard van der Hoff <1389908+richvdh@users.noreply.github.com>
2022-08-09Allow use of both `@trace` and `@tag_args` stacked on the same function (#13453)Eric Eastwood3-56/+186
```py @trace @tag_args async def get_oldest_event_ids_with_depth_in_room(...) ... ``` Before this PR, you would see a warning in the logs and the span was not exported: ``` 2022-08-03 19:11:59,383 - synapse.logging.opentracing - 835 - ERROR - GET-0 - @trace may not have wrapped EventFederationWorkerStore.get_oldest_event_ids_with_depth_in_room correctly! The function is not async but returned a coroutine. ```
2022-08-09Use literals in place of `HTTPStatus` constants in tests (#13479)Dirk Klimpel12-141/+141
Replace - `HTTPStatus.NOT_FOUND` - `HTTPStatus.FORBIDDEN` - `HTTPStatus.UNAUTHORIZED` - `HTTPStatus.CONFLICT` - `HTTPStatus.CREATED` Signed-off-by: Dirk Klimpel <dirk@klimpel.org>
2022-08-09Fix changelog mistakeOlivier Wilkinson (reivilibre)1-2/+1
2022-08-09Strengthen tests about deleted old push actions. (#13471)Patrick Cloke2-0/+16
2022-08-09Tweak the changelog v1.65.0rc1Olivier Wilkinson (reivilibre)1-6/+6
2022-08-091.65.0rc1Olivier Wilkinson (reivilibre)52-51/+82
2022-08-09Make the configuration for the cache clearer (#13481)Dirk Klimpel2-4/+6
2022-08-08Update matrix-synapse-ldap3 version in lockfile to v0.2.2. (#13470)Shay2-12/+14
2022-08-08Use literals in place of `HTTPStatus` constants in tests (#13469)Dirk Klimpel13-331/+329
2022-08-08Correct a misnamed argument in state res v2 (#13467)David Robertson2-6/+7
In state res v2, we apply two passes of iterative auth checks. The first pass replays power events and events in their auth chains, but only those belonging to the full conflicted set. The source code as written suggests that we want only those belonging to the auth difference (which is a smaller set of events). At runtime we were doing the correct thing anyway, because the only callsite of `_reverse_topological_power_sort` passes in the `full_conflicted_set`. So this really is just a rename.
2022-08-05Support stable identifiers for MSC2285: private read receipts. (#13273)Šimon Brandner14-94/+246
This adds support for the stable identifiers of MSC2285 while continuing to support the unstable identifiers behind the configuration flag. These will be removed in a future version.
2022-08-05Use literals in place of `HTTPStatus` constants in tests (#13463)Dirk Klimpel18-191/+172
2022-08-05Mark token-authenticaticated-registration API as not-experimental (#11897)Julian-Samuel Gebühr2-3/+4
2022-08-05Update module API "update room membership" method to allow for remote joins ↵Matt C3-4/+34
(#13441) Co-authored-by: MattC <buffless-matt@users.noreply.github.com> Co-authored-by: Brendan Abolivier <babolivier@matrix.org>
2022-08-04Add comments about how event push actions are stored. (#13445)Erik Johnston2-0/+62
2022-08-04Fix `@tag_args` being off-by-one (ahead) (#13452)Eric Eastwood2-2/+14
Fix @tag_args being off-by-one (ahead) Example: ``` argspec.args=[ 'self', 'room_id' ] args=( <synapse.storage.databases.main.DataStore object at 0x10d0b8d00>, '!HBehERstyQBxyJDLfR:my.synapse.server' ) ``` --- The previous logic was also flawed and we can end up in a situation like this: ``` argspec.args=['self', 'dest', 'room_id', 'limit', 'extremities'] args=(<synapse.federation.federation_client.FederationClient object at 0x7f1651c18160>, 'hs1', '!jAEHKIubyIfuLOdfpY:hs1') ``` From this source: ```py async def backfill( self, dest: str, room_id: str, limit: int, extremities: Collection[str] ) -> Optional[List[EventBase]]: ``` And this usage: ```py events = await self._federation_client.backfill( dest, room_id, limit=limit, extremities=extremities ) ``` which would previously cause this error: ``` synapse_main | 2022-08-04 06:13:12,051 - synapse.handlers.federation - 424 - ERROR - GET-5 - Failed to backfill from hs1 because tuple index out of range synapse_main | Traceback (most recent call last): synapse_main | File "/usr/local/lib/python3.9/site-packages/synapse/handlers/federation.py", line 392, in try_backfill synapse_main | await self._federation_event_handler.backfill( synapse_main | File "/usr/local/lib/python3.9/site-packages/synapse/logging/tracing.py", line 828, in _wrapper synapse_main | return await func(*args, **kwargs) synapse_main | File "/usr/local/lib/python3.9/site-packages/synapse/handlers/federation_event.py", line 593, in backfill synapse_main | events = await self._federation_client.backfill( synapse_main | File "/usr/local/lib/python3.9/site-packages/synapse/logging/tracing.py", line 828, in _wrapper synapse_main | return await func(*args, **kwargs) synapse_main | File "/usr/local/lib/python3.9/site-packages/synapse/logging/tracing.py", line 827, in _wrapper synapse_main | with wrapping_logic(func, *args, **kwargs): synapse_main | File "/usr/local/lib/python3.9/contextlib.py", line 119, in __enter__ synapse_main | return next(self.gen) synapse_main | File "/usr/local/lib/python3.9/site-packages/synapse/logging/tracing.py", line 922, in _wrapping_logic synapse_main | set_attribute("ARG_" + arg, str(args[i + 1])) # type: ignore[index] synapse_main | IndexError: tuple index out of range ```
2022-08-04Improve comments (& avoid a duplicate query) in push actions processing. ↵Patrick Cloke2-124/+159
(#13455) * Adds docstrings and inline comments. * Formats SQL queries using triple quoted strings. * Minor formatting changes. * Avoid fetching `event_push_summary_stream_ordering` multiple times in the same transactions.
2022-08-04Update type of `EventContext.rejected` (#13460)Richard van der Hoff3-5/+5
2022-08-04Faster Room Joins: prevent Synapse from answering federated join requests ↵reivilibre3-0/+35
for a room which it has not fully joined yet. (#13416)
2022-08-04Optimise async get event lookups (#13435)Nick Mills-Barrett4-8/+87
Still maintains local in memory lookup optimisation, but does any external lookup as part of the deferred that prevents duplicate lookups for the same event at once. This makes the assumption that fetching from an external cache is a non-zero load operation.
2022-08-04Update some outdated information on `sso_mapping_providers.md` (#13449)Dirk Klimpel2-6/+9
2022-08-04Fix return value in example on `password_auth_provider_callbacks.md` (#13450)Dirk Klimpel2-2/+3
Fixes: #12534 Signed-off-by: Dirk Klimpel <dirk@klimpel.org>
2022-08-04synapse-workers docker: copy nginx and redis in from base images (#13447)Richard van der Hoff3-36/+60
Part of my continuing quest to make the docker images build quicker: copy nginx and redis in from base docker images, rather than apt installing each time.
2022-08-04Add module API method to create a room (#13429)Matt C3-0/+103
Co-authored-by: MattC <buffless-matt@users.noreply.github.com> Co-authored-by: Brendan Abolivier <babolivier@matrix.org>
2022-08-04Fix rooms not being properly excluded from incremental sync (#13408)Brendan Abolivier3-10/+37
2022-08-04Try fix Twisted/treq problemsEric Eastwood2-11/+19
See https://github.com/matrix-org/synapse/pull/13400#discussion_r937213304
2022-08-03Update docs/tracing.mdEric Eastwood2-26/+22
2022-08-03Fix tracing imports after merging in developEric Eastwood11-15/+15
2022-08-03Revert "Update treq to match minimum Twisted Python versions"Eric Eastwood2-17/+12
This reverts commit 270db429cd8bd05032ddde0a4b48da811dd26276.
2022-08-03Update treq to match minimum Twisted Python versionsEric Eastwood2-12/+17
Hopefully fix https://github.com/matrix-org/synapse/runs/7645395562?check_suite_focus=true#step:7:6727 ``` builtins.ImportError: cannot import name '_PY3' from 'twisted.python.compat' (unknown location) ```
2022-08-03Add some tracing spans to give insight into local joins (#13439)Shay3-33/+40
2022-08-03Instrument `/messages` for understandable traces in Jaeger (#13368)Eric Eastwood11-1/+32
In Jaeger: - Before: huge list of uncategorized database calls - After: nice and collapsible into units of work
2022-08-03Return 404 or member list when getting joined_members after leaving (#13374)andrew do3-2/+20
Signed-off-by: Andrew Doh <andrewddo@gmail.com> Co-authored-by: Patrick Cloke <clokep@users.noreply.github.com> Co-authored-by: Andrew Morgan <andrewm@element.io> Co-authored-by: Brendan Abolivier <babolivier@matrix.org>
2022-08-03Install cryptography build dependencies in requirements image. (#13372)Jasper Spaans2-1/+3
2022-08-03Improve documentation on becoming server admin (#13230)jejo862-1/+3
* Improved section regarding server admin Added steps describing how to elevate an existing user to administrator by manipulating a `postgres` database. Signed-off-by: jejo86 28619134+jejo86@users.noreply.github.com * Improved section regarding server admin * Reference database settings Add instructions to check database settings to find out the database name, instead of listing all available PostgreSQL databases. * Add suggestions from PR conversation Replace config filename `homeserver.yaml`. with "config file". Remove instructions to switch to `postgres` user. Add instructions how to connect to SQLite database. * Update changelog.d/13230.doc Co-authored-by: reivilibre <olivier@librepush.net>
2022-08-03Update doc for setting `macaroon_secret_key` (#13443)Dirk Klimpel2-3/+8
* Update doc for setting `macaroon_secret_key` * newsfile
2022-08-03Rename `RateLimitConfig` to `RatelimitSettings` (#13442)Dirk Klimpel5-29/+30
2022-08-03Add module API method to resolve a room alias to a room ID (#13428)Matt C3-0/+44
Co-authored-by: MattC <buffless-matt@users.noreply.github.com> Co-authored-by: Brendan Abolivier <babolivier@matrix.org>
2022-08-03Remove 'Contents' section from the Configuration Manual (#13438)Dirk Klimpel2-43/+1
Fixes: #13053
2022-08-03Fix wrong headline for `url_preview_accept_language` in docs (#13437)Dirk Klimpel2-1/+2
Fixes: #13433
2022-08-03