Commit f5b79552 authored by Yoshinori Okuji's avatar Yoshinori Okuji

More fixes on the protocol.

git-svn-id: https://svn.erp5.org/repos/neo/branches/prototype3@66 71dcc9de-d417-0410-9af5-da40c76e7ee4
parent 2b87c2c2
...@@ -232,7 +232,7 @@ class EventHandler(object): ...@@ -232,7 +232,7 @@ class EventHandler(object):
serial_end, compression, checksum, data): serial_end, compression, checksum, data):
self.handleUnexpectedPacket(conn, packet) self.handleUnexpectedPacket(conn, packet)
def handleAskTIDs(self, conn, packet, first, last, spec): def handleAskTIDs(self, conn, packet, first, last):
self.handleUnexpectedPacket(conn, packet) self.handleUnexpectedPacket(conn, packet)
def handleAnswerTIDs(self, conn, packet, tid_list): def handleAnswerTIDs(self, conn, packet, tid_list):
......
...@@ -151,7 +151,8 @@ ASK_OBJECT = 0x001b ...@@ -151,7 +151,8 @@ ASK_OBJECT = 0x001b
# Answer the requested object. S -> C. # Answer the requested object. S -> C.
ANSWER_OBJECT = 0x801b ANSWER_OBJECT = 0x801b
# Ask for TIDs between a range of offset. C -> S. # Ask for TIDs between a range of offsets. The order of TIDs is descending,
# and the range is [first, last). C -> S.
ASK_TIDS = 0x001d ASK_TIDS = 0x001d
# Answer the requested TIDs. S -> C. # Answer the requested TIDs. S -> C.
...@@ -572,20 +573,16 @@ class Packet(object): ...@@ -572,20 +573,16 @@ class Packet(object):
compression, checksum, len(data)) + data compression, checksum, len(data)) + data
return self return self
def askTIDs(self, msg_id, first, last, spec): def askTIDs(self, msg_id, first, last):
self._id = msg_id self._id = msg_id
self._type = ASK_TIDS self._type = ASK_TIDS
body = [pack('!LLL', first, last, len(spec))] self._body = pack('!LL', first, last)
# spec is a dict if given
for key, value in spec.items():
body.append(pack('!LL', len(key), len(value))+key+value)
self._body = ''.join(body)
return self return self
def answerTIDs(self, msg_id, tid_list): def answerTIDs(self, msg_id, tid_list):
self._id = msg_id self._id = msg_id
self._type = ANSWER_TIDS self._type = ANSWER_TIDS
body = [pack('!H', len(tid_list))] body = [pack('!L', len(tid_list))]
body.extend(tid_list) body.extend(tid_list)
self._body = ''.join(body) self._body = ''.join(body)
return self return self
...@@ -599,7 +596,7 @@ class Packet(object): ...@@ -599,7 +596,7 @@ class Packet(object):
def answerTransactionInformation(self, msg_id, tid, user, desc, oid_list): def answerTransactionInformation(self, msg_id, tid, user, desc, oid_list):
self._id = msg_id self._id = msg_id
self._type = ANSWER_TRANSACTION_INFORMATION self._type = ANSWER_TRANSACTION_INFORMATION
body = [pack('!8sHHH', tid, len(user), len(desc), len(oid_list))] body = [pack('!8sHHL', tid, len(user), len(desc), len(oid_list))]
body.append(user) body.append(user)
body.append(desc) body.append(desc)
body.extend(oid_list) body.extend(oid_list)
...@@ -1025,29 +1022,18 @@ class Packet(object): ...@@ -1025,29 +1022,18 @@ class Packet(object):
def _decodeAskTIDs(self): def _decodeAskTIDs(self):
try: try:
first, last, spec_len = unpack('!LLL', self._body[:12]) first, last = unpack('!LL', self._body[:8])
spec = {}
dict_item_len = 0
# recreate spec dict
for i in xrange(spec_len):
key_len, value_len = unpack('!LL', self._body[12+dict_item_len:20+
dict_item_len])
key = self.body[20+dict_item_len:20+dict_item_len+key_len]
value = self.body[20+dict_item_len+key_len:20+dict_item_len+key_len+
value_len]
dict_item_list = dict_item_list + 8 + key_len + value_len
spec[key] = value
except: except:
raise ProtocolError(self, 'invalid ask tids') raise ProtocolError(self, 'invalid ask tids')
return first, last, spec return first, last
decode_table[ASK_TIDS] = _decodeAskTIDs decode_table[ASK_TIDS] = _decodeAskTIDs
def _decodeAnswerTIDs(self): def _decodeAnswerTIDs(self):
try: try:
n = unpack('!H', self._body[:2]) n = unpack('!L', self._body[:4])
tid_list = [] tid_list = []
for i in xrange(n): for i in xrange(n):
tid = unpack('8s', self._body[2+i*8:10+i*8]) tid = unpack('8s', self._body[4+i*8:12+i*8])
tid_list.append(tid) tid_list.append(tid)
except: except:
raise ProtocolError(self, 'invalid answer tids') raise ProtocolError(self, 'invalid answer tids')
...@@ -1064,8 +1050,8 @@ class Packet(object): ...@@ -1064,8 +1050,8 @@ class Packet(object):
def _decodeAnswerTransactionInformation(self): def _decodeAnswerTransactionInformation(self):
try: try:
tid, user_len, desc_len, oid_len = unpack('!8sHHH', self._body[:12]) tid, user_len, desc_len, oid_len = unpack('!8sHHL', self._body[:16])
offset = 14 offset = 16
user = self._body[offset:offset+user_len] user = self._body[offset:offset+user_len]
offset += user_len offset += user_len
desc = self._body[offset:offset+desc_len] desc = self._body[offset:offset+desc_len]
......
...@@ -183,4 +183,7 @@ class StorageEventHandler(EventHandler): ...@@ -183,4 +183,7 @@ class StorageEventHandler(EventHandler):
def handleAskStoreObject(self, conn, packet, msg_id, oid, serial, def handleAskStoreObject(self, conn, packet, msg_id, oid, serial,
compression, data, checksum, tid): compression, data, checksum, tid):
pass self.handleUnexpectedPacket(conn, packet)
def handleAskObject(self, conn, packet, oid, serial, tid):
self.handleUnexpectedPacket(conn, packet)
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment