summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTeddy <[email protected]>2013-08-28 23:23:07 +0800
committerTeddy <[email protected]>2013-08-28 23:23:07 +0800
commitcef62991bfc27f763e9d4f83170bdff828fb96a9 (patch)
treed3f2fdb61617698ee50944b958559cf14c11c6fa
parent8e3c5382c8e96b6ef8f394fb49a89a68cc151d1c (diff)
fixed early push
-rw-r--r--server/piztor/ptp_send.py2
-rw-r--r--server/piztor/server.py11
2 files changed, 8 insertions, 5 deletions
diff --git a/server/piztor/ptp_send.py b/server/piztor/ptp_send.py
index b820041..7c55f07 100644
--- a/server/piztor/ptp_send.py
+++ b/server/piztor/ptp_send.py
@@ -232,7 +232,7 @@ def open_push_tunnel(token, username):
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.connect((host, port))
sock.sendall(data)
- sock.recv(4096)
+ print get_hex(sock.recv(6))
length = -1
while True:
diff --git a/server/piztor/server.py b/server/piztor/server.py
index bb88b53..a58a301 100644
--- a/server/piztor/server.py
+++ b/server/piztor/server.py
@@ -71,6 +71,7 @@ class PushData(object):
class PushTextMesgData(PushData):
def __init__(self, mesg):
self.finger_print = sha256(mesg).digest()
+ logger.info("Mesg: %s", mesg)
buff = struct.pack("!B32s", 0x00, self.finger_print)
buff += mesg
buff += chr(0)
@@ -89,7 +90,6 @@ class PushTunnel(object):
def add(self, pdata):
logger.info("-- Push data enqued --")
- logger.info("Data: %s", get_hex(pdata.data))
self.pending.append(pdata)
def on_receive(self, data):
@@ -101,14 +101,18 @@ class PushTunnel(object):
self.push()
def push(self):
+ print "Pushing via " + str(self)
+ print "Pending size: " + str(len(self.pending))
+ print self.conn
if (self.conn is None) or len(self.pending) == 0:
return
- print "Pushing"
front = self.pending.popleft()
self.pending.appendleft(front)
+ print get_hex(front.data)
self.conn.transport.write(front.data)
def connect(self, conn):
+ print conn
conn.tunnel = self
self.conn = conn
@@ -478,7 +482,6 @@ class OpenPushTunnelHandler(RequestHandler):
if pt.has_key(uid):
tunnel = pt[uid]
tunnel.connect(conn)
- tunnel.push()
logger.info("Push tunnel opened successfully!")
return struct.pack("!LBB", self._response_size,
@@ -531,7 +534,6 @@ class SendTextMessageHandler(RequestHandler):
if pt.has_key(uid):
tunnel = pt[uid]
tunnel.add(PushTextMesgData(mesg))
- tunnel.push()
logger.info("Sent text mesg successfully!")
return struct.pack("!LBB", self._response_size,
_OptCode.send_text_mesg,
@@ -600,6 +602,7 @@ class PTP(Protocol, TimeoutMixin):
self.transport.write(reply)
if self.tunnel:
logger.info("Blocking the client...")
+ self.tunnel.push()
self.buff = bytes()
self.length = -1
self.setTimeout(None)