diff options
author | Erik Johnston <erik@matrix.org> | 2015-03-02 13:33:05 +0000 |
---|---|---|
committer | Erik Johnston <erik@matrix.org> | 2015-03-02 13:33:05 +0000 |
commit | 210d3c5d726cbcf9ae6e5e3df17cd12df8d250e9 (patch) | |
tree | df9e64962d31f8ceeb8a0760509ff084b90a9dfc /synapse | |
parent | Merge pull request #92 from matrix-org/application-services-event-stream (diff) | |
parent | If we're yielding don't add errback (diff) | |
download | synapse-210d3c5d726cbcf9ae6e5e3df17cd12df8d250e9.tar.xz |
Merge pull request #95 from matrix-org/serialize_transaction_processing
Process transactions serially.
Diffstat (limited to 'synapse')
-rw-r--r-- | synapse/federation/federation_server.py | 32 |
1 files changed, 12 insertions, 20 deletions
diff --git a/synapse/federation/federation_server.py b/synapse/federation/federation_server.py index 22b9663831..bc9bac809a 100644 --- a/synapse/federation/federation_server.py +++ b/synapse/federation/federation_server.py @@ -112,17 +112,19 @@ class FederationServer(FederationBase): logger.debug("[%s] Transaction is new", transaction.transaction_id) with PreserveLoggingContext(): - dl = [] + results = [] + for pdu in pdu_list: d = self._handle_new_pdu(transaction.origin, pdu) - def handle_failure(failure): - failure.trap(FederationError) - self.send_failure(failure.value, transaction.origin) - - d.addErrback(handle_failure) - - dl.append(d) + try: + yield d + results.append({}) + except FederationError as e: + self.send_failure(e, transaction.origin) + results.append({"error": str(e)}) + except Exception as e: + results.append({"error": str(e)}) if hasattr(transaction, "edus"): for edu in [Edu(**x) for x in transaction.edus]: @@ -135,21 +137,11 @@ class FederationServer(FederationBase): for failure in getattr(transaction, "pdu_failures", []): logger.info("Got failure %r", failure) - results = yield defer.DeferredList(dl, consumeErrors=True) - - ret = [] - for r in results: - if r[0]: - ret.append({}) - else: - logger.exception(r[1]) - ret.append({"error": str(r[1].value)}) - - logger.debug("Returning: %s", str(ret)) + logger.debug("Returning: %s", str(results)) response = { "pdus": dict(zip( - (p.event_id for p in pdu_list), ret + (p.event_id for p in pdu_list), results )), } |