mirror of
https://git.anonymousland.org/anonymousland/synapse.git
synced 2025-01-24 17:20:59 -05:00
Fix logcontext leaks in rate limiter
This commit is contained in:
parent
d72faf2fad
commit
a7fe62f0cb
@ -18,7 +18,10 @@ from twisted.internet import defer
|
||||
from synapse.api.errors import LimitExceededError
|
||||
|
||||
from synapse.util.async import sleep
|
||||
from synapse.util.logcontext import run_in_background
|
||||
from synapse.util.logcontext import (
|
||||
run_in_background, make_deferred_yieldable,
|
||||
PreserveLoggingContext,
|
||||
)
|
||||
|
||||
import collections
|
||||
import contextlib
|
||||
@ -176,6 +179,9 @@ class _PerHostRatelimiter(object):
|
||||
return r
|
||||
|
||||
def on_err(r):
|
||||
# XXX: why is this necessary? this is called before we start
|
||||
# processing the request so why would the request be in
|
||||
# current_processing?
|
||||
self.current_processing.discard(request_id)
|
||||
return r
|
||||
|
||||
@ -187,7 +193,7 @@ class _PerHostRatelimiter(object):
|
||||
|
||||
ret_defer.addCallbacks(on_start, on_err)
|
||||
ret_defer.addBoth(on_both)
|
||||
return ret_defer
|
||||
return make_deferred_yieldable(ret_defer)
|
||||
|
||||
def _on_exit(self, request_id):
|
||||
logger.debug(
|
||||
@ -197,7 +203,12 @@ class _PerHostRatelimiter(object):
|
||||
self.current_processing.discard(request_id)
|
||||
try:
|
||||
request_id, deferred = self.ready_request_queue.popitem()
|
||||
|
||||
# XXX: why do we do the following? the on_start callback above will
|
||||
# do it for us.
|
||||
self.current_processing.add(request_id)
|
||||
deferred.callback(None)
|
||||
|
||||
with PreserveLoggingContext():
|
||||
deferred.callback(None)
|
||||
except KeyError:
|
||||
pass
|
||||
|
Loading…
Reference in New Issue
Block a user