From 29f467e9d844eaf8b64f3fc8f17154a0eaff9baf Mon Sep 17 00:00:00 2001 From: Brian Warner Date: Wed, 8 Mar 2017 08:46:15 +0100 Subject: [PATCH] CLI: don't hide errors, fuss with verifier API --- src/wormhole/cli/cmd_receive.py | 24 +++++++++++++++--- src/wormhole/cli/cmd_send.py | 43 +++++++++++++++++++++------------ 2 files changed, 47 insertions(+), 20 deletions(-) diff --git a/src/wormhole/cli/cmd_receive.py b/src/wormhole/cli/cmd_receive.py index c15b458..c6ec093 100644 --- a/src/wormhole/cli/cmd_receive.py +++ b/src/wormhole/cli/cmd_receive.py @@ -76,17 +76,33 @@ class TwistedReceiver: # as coming from the "yield self._go" line, which wasn't very useful # for tracking it down. d = self._go(w) + + # if we succeed, we should close and return the w.close results + # (which might be an error) @inlineCallbacks - def _close(res): - yield w.close() + def _good(res): + yield w.close() # wait for ack returnValue(res) - d.addBoth(_close) + + # if we raise an error, we should close and then return the original + # error (the close might give us an error, but it isn't as important + # as the original one) + @inlineCallbacks + def _bad(f): + log.err(f) + try: + yield w.close() # might be an error too + except: + pass + returnValue(f) + + d.addCallbacks(_good, _bad) yield d @inlineCallbacks def _go(self, w): yield self._handle_code(w) - verifier = yield w.when_verifier() + verifier = yield w.when_verified() def on_slow_connection(): print(u"Key established, waiting for confirmation...", file=self.args.stderr) diff --git a/src/wormhole/cli/cmd_send.py b/src/wormhole/cli/cmd_send.py index 337f314..99052a9 100644 --- a/src/wormhole/cli/cmd_send.py +++ b/src/wormhole/cli/cmd_send.py @@ -57,11 +57,27 @@ class Sender: tor_manager=self._tor_manager, timing=self._timing) d = self._go(w) + + # if we succeed, we should close and return the w.close results + # (which might be an error) @inlineCallbacks - def _close(res): - yield w.close() # must wait for ack from close() + def _good(res): + yield w.close() # wait for ack returnValue(res) - d.addBoth(_close) + + # if we raise an error, we should close and then return the original + # error (the close might give us an error, but it isn't as important + # as the original one) + @inlineCallbacks + def _bad(f): + log.err(f) + try: + yield w.close() # might be an error too + except: + pass + returnValue(f) + + d.addCallbacks(_good, _bad) yield d def _send_data(self, data, w): @@ -98,23 +114,18 @@ class Sender: args.stderr.flush() print(u"", file=args.stderr) - verifier_bytes = yield w.when_verifier() - # we've seen PAKE, but not yet VERSION, so we don't know if they got - # the right password or not - def on_slow_connection(): print(u"Key established, waiting for confirmation...", file=args.stderr) - notify = self._reactor.callLater(VERIFY_TIMER, on_slow_connection) + #notify = self._reactor.callLater(VERIFY_TIMER, on_slow_connection) - # TODO: maybe don't stall for VERSION, if they don't want - # verification, to save a roundtrip? - try: - yield w.when_version() - # this may raise WrongPasswordError - finally: - if not notify.called: - notify.cancel() + # TODO: don't stall on w.verify() unless they want it + #try: + # verifier_bytes = yield w.when_verified() # might WrongPasswordError + #finally: + # if not notify.called: + # notify.cancel() + yield w.when_verified() if args.verify: verifier = bytes_to_hexstr(verifier_bytes)