From 4b3d53ba4ea849e32c6a119206383290393d3cd8 Mon Sep 17 00:00:00 2001 From: Brian Warner Date: Tue, 24 May 2016 16:15:43 -0700 Subject: [PATCH] log+ignore unrecognized phase messages This should enable forwards-compatibility with clients which send extra data, like a pre-PAKE "auxdata" message that hints we should spin up a tor client (because they can connect to it) while we're waiting for the user to type in the wormhole code. --- src/wormhole/wormhole.py | 25 ++++++++++++------------- 1 file changed, 12 insertions(+), 13 deletions(-) diff --git a/src/wormhole/wormhole.py b/src/wormhole/wormhole.py index d84af3d..b402e32 100644 --- a/src/wormhole/wormhole.py +++ b/src/wormhole/wormhole.py @@ -673,20 +673,19 @@ class _Wormhole: def _event_received_peer_message(self, side, phase, body): # any message in the mailbox means we no longer need the nameplate self._event_mailbox_used() - #if phase in self._received_messages: - # # a nameplate collision would cause this - # err = ServerError("got duplicate phase %s" % phase, self._ws_url) - # return self._signal_error(err) - #self._received_messages[phase] = body - if phase == u"pake": - self._event_received_pake(body) - return - if phase == u"confirm": - self._event_received_confirm(body) - return - # It's a phase message, aimed at the application above us. Decrypt - # and deliver upstairs, notifying anyone waiting on it + if phase == u"pake": + return self._event_received_pake(body) + if phase == u"confirm": + return self._event_received_confirm(body) + if re.search(r'^\d+$', phase): + return self._event_received_phase_message(side, phase, body) + # ignore unrecognized phases, for forwards-compatibility + log.msg("received unknown phase '%s'" % phase) + + def _event_received_phase_message(self, side, phase, body): + # It's a numbered phase message, aimed at the application above us. + # Decrypt and deliver upstairs, notifying anyone waiting on it try: data_key = self._derive_phase_key(side, phase) plaintext = self._decrypt_data(data_key, body)