diff options
author | Richard van der Hoff <1389908+richvdh@users.noreply.github.com> | 2021-10-05 13:01:41 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-10-05 13:01:41 +0100 |
commit | 787af4a1062fecc350fa14fe2abfc0e9d2f1555e (patch) | |
tree | 64c4a84652677b710bb7c1e87de78dcfe6681316 | |
parent | `_update_auth_events_and_context_for_auth`: add some comments (#10987) (diff) | |
download | synapse-787af4a1062fecc350fa14fe2abfc0e9d2f1555e.tar.xz |
Host `cache_joined_hosts_for_event` to caller (#10986)
`_check_event_auth` is only called in two places, and only one of those sets `send_on_behalf_of`. Warming the cache isn't really part of auth anyway, so moving it out makes a lot more sense.
-rw-r--r-- | changelog.d/10986.misc | 1 | ||||
-rw-r--r-- | synapse/handlers/federation_event.py | 18 |
2 files changed, 9 insertions, 10 deletions
diff --git a/changelog.d/10986.misc b/changelog.d/10986.misc new file mode 100644 index 0000000000..9a765435db --- /dev/null +++ b/changelog.d/10986.misc @@ -0,0 +1 @@ +Clean up some of the federation event authentication code for clarity. diff --git a/synapse/handlers/federation_event.py b/synapse/handlers/federation_event.py index aa20d75550..9269cb444d 100644 --- a/synapse/handlers/federation_event.py +++ b/synapse/handlers/federation_event.py @@ -356,6 +356,11 @@ class FederationEventHandler: ) # all looks good, we can persist the event. + + # First, precalculate the joined hosts so that the federation sender doesn't + # need to. + await self._event_creation_handler.cache_joined_hosts_for_event(event, context) + await self._run_push_actions_and_persist_event(event, context) return event, context @@ -1299,17 +1304,10 @@ class FederationEventHandler: except AuthError as e: logger.warning("Failed auth resolution for %r because %s", event, e) context.rejected = RejectedReason.AUTH_ERROR + return context - if not context.rejected: - await self._check_for_soft_fail(event, state, backfilled, origin=origin) - await self._maybe_kick_guest_users(event) - - # If we are going to send this event over federation we precaclculate - # the joined hosts. - if event.internal_metadata.get_send_on_behalf_of(): - await self._event_creation_handler.cache_joined_hosts_for_event( - event, context - ) + await self._check_for_soft_fail(event, state, backfilled, origin=origin) + await self._maybe_kick_guest_users(event) return context |