send-twisted: set transit key before sending phase1

This ensures that we'll be ready for them. Previously there was a race
between us revealing the direct hints to the peer, and us setting the
transit key (thus allowing us to check inbound handshake requests). The
Transit instance didn't handle the race, causing errors to be thrown
when the other side connected quickly.
This commit is contained in:
Brian Warner 2016-02-17 19:01:20 -08:00
parent aa27bfd32c
commit 7f056ca075

View File

@ -55,9 +55,13 @@ def send_twisted(args):
print(u"Wormhole code is: %s" % code, file=args.stdout) print(u"Wormhole code is: %s" % code, file=args.stdout)
print(u"", file=args.stdout) print(u"", file=args.stdout)
if args.verify: # get the verifier, because that also lets us derive the transit key,
# which we want to set before revealing the connection hints to the far
# side, so we'll be ready for them when they connect
verifier_bytes = yield w.get_verifier() verifier_bytes = yield w.get_verifier()
verifier = binascii.hexlify(verifier_bytes).decode("ascii") verifier = binascii.hexlify(verifier_bytes).decode("ascii")
if args.verify:
while True: while True:
ok = six.moves.input("Verifier %s. ok? (yes/no): " % verifier) ok = six.moves.input("Verifier %s. ok? (yes/no): " % verifier)
if ok.lower() == "yes": if ok.lower() == "yes":
@ -67,6 +71,9 @@ def send_twisted(args):
}).encode("utf-8") }).encode("utf-8")
yield w.send_data(reject_data) yield w.send_data(reject_data)
raise TransferError("verification rejected, abandoning transfer") raise TransferError("verification rejected, abandoning transfer")
if fd_to_send is not None:
transit_key = w.derive_key(APPID+"/transit-key")
transit_sender.set_transit_key(transit_key)
my_phase1_bytes = json.dumps(phase1).encode("utf-8") my_phase1_bytes = json.dumps(phase1).encode("utf-8")
yield w.send_data(my_phase1_bytes) yield w.send_data(my_phase1_bytes)
@ -92,10 +99,6 @@ def send_twisted(args):
raise TransferError("ambiguous response from remote, " raise TransferError("ambiguous response from remote, "
"transfer abandoned: %s" % (them_phase1,)) "transfer abandoned: %s" % (them_phase1,))
tdata = them_phase1["transit"] tdata = them_phase1["transit"]
# this is happening too late: the other side already connects to our
# server
transit_key = w.derive_key(APPID+"/transit-key")
transit_sender.set_transit_key(transit_key)
yield w.close() yield w.close()
yield _send_file_twisted(tdata, transit_sender, fd_to_send, yield _send_file_twisted(tdata, transit_sender, fd_to_send,
args.stdout, args.hide_progress) args.stdout, args.hide_progress)