summary refs log tree commit diff
path: root/synapse/rest/client/transactions.py
diff options
context:
space:
mode:
authorErik Johnston <erik@matrix.org>2017-02-15 10:17:01 +0000
committerErik Johnston <erik@matrix.org>2017-02-15 10:17:01 +0000
commit3b42bb96e4bba78ea881f35673964a97d57a9d26 (patch)
tree3ab584bb3bbed269d4f95d0cab484e1d5836ec74 /synapse/rest/client/transactions.py
parentMerge branch 'develop' into matrix-org-hotfixes (diff)
parentMerge pull request #1914 from matrix-org/erikj/cache_presence (diff)
downloadsynapse-3b42bb96e4bba78ea881f35673964a97d57a9d26.tar.xz
Merge commit 'd7457c7661fa3b28427b21f44252c3abbee45ef8' of github.com:matrix-org/synapse into matrix-org-hotfixes
Diffstat (limited to 'synapse/rest/client/transactions.py')
-rw-r--r--synapse/rest/client/transactions.py14
1 files changed, 11 insertions, 3 deletions
diff --git a/synapse/rest/client/transactions.py b/synapse/rest/client/transactions.py

index efa77b8c51..fceca2edeb 100644 --- a/synapse/rest/client/transactions.py +++ b/synapse/rest/client/transactions.py
@@ -87,9 +87,17 @@ class HttpTransactionCache(object): deferred = fn(*args, **kwargs) - # We don't add an errback to the raw deferred, so we ask ObservableDeferred - # to swallow the error. This is fine as the error will still be reported - # to the observers. + # if the request fails with a Twisted failure, remove it + # from the transaction map. This is done to ensure that we don't + # cache transient errors like rate-limiting errors, etc. + def remove_from_map(err): + self.transactions.pop(txn_key, None) + return err + deferred.addErrback(remove_from_map) + + # We don't add any other errbacks to the raw deferred, so we ask + # ObservableDeferred to swallow the error. This is fine as the error will + # still be reported to the observers. observable = ObservableDeferred(deferred, consumeErrors=True) self.transactions[txn_key] = (observable, self.clock.time_msec()) return observable.observe()