diff options
author | Erik Johnston <erik@matrix.org> | 2015-03-02 11:39:40 +0000 |
---|---|---|
committer | Erik Johnston <erik@matrix.org> | 2015-03-02 11:39:57 +0000 |
commit | 23d9bd1d745a037202bb9a134cdb848eb65a01e9 (patch) | |
tree | e15b8f526068e6f1a8ae457e9702b83f40f0616b /synapse/federation/federation_server.py | |
parent | SYWEB-278 Don't allow rules with no rule_id. (diff) | |
download | synapse-23d9bd1d745a037202bb9a134cdb848eb65a01e9.tar.xz |
Process transactions serially.
Since the events received in a transaction are ordered, later events might depend on earlier events and so we shouldn't blindly process them in parellel.
Diffstat (limited to '')
-rw-r--r-- | synapse/federation/federation_server.py | 24 |
1 files changed, 10 insertions, 14 deletions
diff --git a/synapse/federation/federation_server.py b/synapse/federation/federation_server.py index 22b9663831..7ee37fb34d 100644 --- a/synapse/federation/federation_server.py +++ b/synapse/federation/federation_server.py @@ -112,17 +112,23 @@ 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) + return failure d.addErrback(handle_failure) - dl.append(d) + try: + yield d + results.append({}) + 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 +141,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 )), } |