Connect, emit, ping

This commit is contained in:
Roy Hyunjin Han 2015-02-18 09:47:52 -05:00
commit 5917925ccc
2 changed files with 165 additions and 3 deletions

View file

@ -1,12 +1,114 @@
# !!! Get pong
# !!! Change print statements into logging statements
import json
import requests
import time
__version__ = '0.5.4'
TRANSPORTS = []
class EngineIO(object):
pass
_engine_io_protocol = 3
_request_index = 0
def __init__(
self, host, port=None,
resource='engine.io'):
self._url = 'http://%s:%s/%s/' % (host, port, resource)
self._session = requests.Session()
response = self._session.get(self._url, params={
'EIO': self._engine_io_protocol,
'transport': 'polling',
't': self._get_timestamp(),
})
packs = _decode_content(response.content)
packet_type, packet = packs[0]
assert packet_type == 0
packet_json = json.loads(packet)
print packet_json
# packet_json['pingInterval']
# packet_json['pingTimeout']
# packet_json['upgrades']
self._session_id = packet_json['sid']
response = self._session.get(self._url, params={
'EIO': self._engine_io_protocol,
'transport': 'polling',
't': self._get_timestamp(),
'sid': self._session_id,
})
packs = _decode_content(response.content)
for packet_type, packet in packs:
print 'engineIO_packet_type = %s' % packet_type
print 'socketIO_packet_type = %s' % packet[0]
print 'packet = %s' % packet[1:]
def _get_timestamp(self):
timestamp = '%s-%s' % (int(time.time() * 1000), self._request_index)
self._request_index += 1
return timestamp
def _message(self, packet):
packet_type = 4
response = self._session.post(self._url, params={
'EIO': self._engine_io_protocol,
'transport': 'polling',
't': self._get_timestamp(),
'sid': self._session_id,
}, data=_encode_content([(packet_type, packet)]), headers={
'content-type': 'application/octet-stream',
})
packs = _decode_content(response.content)
for packet_type, packet in packs:
print 'engineIO_packet_type = %s' % packet_type
print 'socketIO_packet_type = %s' % packet[0]
print 'packet = %s' % packet[1:]
def _ping(self):
packet_type = 2
packet = ''
response = self._session.post(self._url, params={
'EIO': self._engine_io_protocol,
'transport': 'polling',
't': self._get_timestamp(),
'sid': self._session_id,
}, data=_encode_content([(packet_type, packet)]), headers={
'content-type': 'application/octet-stream',
})
packs = _decode_content(response.content)
for packet_type, packet in packs:
print 'engineIO_packet_type = %s' % packet_type
print 'socketIO_packet_type = %s' % packet[0]
print 'packet = %s' % packet[1:]
class SocketIO(EngineIO):
pass
def __init__(
self, host, port=None, Namespace=None,
wait_for_connection=True, transports=TRANSPORTS,
resource='socket.io', **kw):
super(SocketIO, self).__init__(host, port, resource)
def define(self):
pass
def wait(self):
pass
def emit(self, event, *args, **kw):
packet_type = 2
packet = json.dumps([event])
self._message(str(packet_type) + packet)
def on(self, event, callback):
pass
class BaseNamespace(object):
@ -17,5 +119,57 @@ class LoggingNamespace(BaseNamespace):
pass
def _decode_content(content):
print content
packs = []
index = 0
content_length = len(content)
while index < content_length:
try:
index, packet_length = _read_packet_length(content, index)
except IndexError:
break
index, packet = _read_packet(content, index, packet_length)
packet_type = int(packet[0])
packet_payload = packet[1:]
packs.append((packet_type, packet_payload))
return packs
def _encode_content(packs):
parts = []
for packet_type, packet_payload in packs:
packet = str(packet_type) + str(packet_payload)
parts.append(_make_packet_header(packet) + packet)
return ''.join(parts)
def _read_packet_length(content, index):
while ord(content[index]) != 0:
index += 1
index += 1
packet_length_string = ''
while ord(content[index]) != 255:
packet_length_string += str(ord(content[index]))
index += 1
return index, int(packet_length_string)
def _read_packet(content, index, packet_length):
while ord(content[index]) == 255:
index += 1
packet = content[index:index + packet_length]
return index + packet_length, packet
def _make_packet_header(packet):
length_string = str(len(packet))
header_digits = [0]
for index in xrange(len(length_string)):
header_digits.append(ord(length_string[index]) - 48)
header_digits.append(255)
return ''.join(chr(x) for x in header_digits)
def find_callback(args, kw=None):
pass