matrix-org / synapse

Synapse: Matrix homeserver written in Python/Twisted.
https://matrix-org.github.io/synapse
Apache License 2.0
11.83k stars 2.13k forks source link

Apply join rate limiter outside the lineariser #16441

Closed DMRobertson closed 1 year ago

DMRobertson commented 1 year ago

I came across this logic; got confused, then tried to tidy it up. I found this much easier to reason about---doing the rate limit check up front.

At some point, someone should draw out a flowchart of the various membership-updating functions here. It's very confusing.

Commitwise reviewable.