demo.py: update to match merged file/text commands

This commit is contained in:
Brian Warner 2015-10-06 19:12:09 -07:00
parent 2da94d5069
commit fc641622ba

View File

@ -5,11 +5,11 @@ from twisted.internet import reactor
from .transcribe import Wormhole
from .. import public_relay
APPID = "lothar.com/wormhole/text-xfer"
APPID = b"lothar.com/wormhole/text-or-file-xfer"
w = Wormhole(APPID, public_relay.RENDEZVOUS_RELAY)
if sys.argv[1] == "send-text":
if sys.argv[1] == "send":
message = sys.argv[2]
data = json.dumps({"message": message}).encode("utf-8")
d = w.get_code()
@ -22,12 +22,12 @@ if sys.argv[1] == "send-text":
d.addCallback(_sent)
def _got_data(them_bytes):
them_d = json.loads(them_bytes.decode("utf-8"))
if them_d["message"] == "ok":
if them_d["message_ack"] == "ok":
print("text sent")
else:
print("error sending text: %r" % (them_d,))
d.addCallback(_got_data)
elif sys.argv[1] == "receive-text":
elif sys.argv[1] == "receive":
code = sys.argv[2]
w.set_code(code)
d = w.get_data()
@ -35,14 +35,37 @@ elif sys.argv[1] == "receive-text":
them_d = json.loads(them_bytes.decode("utf-8"))
if "error" in them_d:
print("ERROR: " + them_d["error"], file=sys.stderr)
return 1
raise RuntimeError
if "file" in them_d:
print("they're trying to send us a file, which I don't handle")
data = json.dumps({"error": "not capable of receiving files"})
d1 = w.send_data(data.encode("utf-8"))
d1.addCallback(lambda _: RuntimeError())
return d1
if not "message" in them_d:
print("I don't know what they're offering\n")
print(them_d)
data = json.dumps({"error": "huh?"})
d1 = w.send_data(data.encode("utf-8"))
d1.addCallback(lambda _: RuntimeError())
return d1
print(them_d["message"])
data = json.dumps({"message": "ok"}).encode("utf-8")
return w.send_data(data)
data = json.dumps({"message_ack": "ok"})
d1 = w.send_data(data.encode("utf-8"))
d1.addCallback(lambda _: 0)
return d1
d.addCallback(_got_data)
else:
raise ValueError("bad command")
d.addCallback(w.close)
d.addBoth(w.close)
rc = []
def _success(res):
rc.append(res)
def _fail(f):
log.err(f)
rc.append(1)
d.addCallbacks(_success, _fail)
d.addCallback(lambda _: reactor.stop())
d.addErrback(log.err)
reactor.run()
sys.exit(rc[0])