Commit 3213148a authored by Grégory Wisniewski's avatar Grégory Wisniewski

Fix bugs around protocol exceptions handling : exception's arguments were not

handled propely.


git-svn-id: https://svn.erp5.org/repos/neo/branches/prototype3@528 71dcc9de-d417-0410-9af5-da40c76e7ee4
parent 729e3046
...@@ -131,19 +131,20 @@ class EventHandler(object): ...@@ -131,19 +131,20 @@ class EventHandler(object):
"""Called when a packet is received.""" """Called when a packet is received."""
self.dispatch(conn, packet) self.dispatch(conn, packet)
# XXX: what's the purpose of this method ?
def peerBroken(self, conn): def peerBroken(self, conn):
"""Called when a peer is broken.""" """Called when a peer is broken."""
logging.error('%s:%d is broken', *(conn.getAddress())) logging.error('%s:%d is broken', *(conn.getAddress()))
def packetMalformed(self, conn, packet, error_message): def packetMalformed(self, conn, packet, message='', *args):
"""Called when a packet is malformed.""" """Called when a packet is malformed."""
args = (conn.getAddress()[0], conn.getAddress()[1], error_message) args = (conn.getAddress()[0], conn.getAddress()[1], message)
if packet is None: if packet is None:
# if decoding fail, there's no packet instance # if decoding fail, there's no packet instance
logging.info('malformed packet from %s:%d: %s', *args) logging.info('malformed packet from %s:%d: %s', *args)
else: else:
logging.info('malformed packet %s from %s:%d: %s', packet.getType(), *args) logging.info('malformed packet %s from %s:%d: %s', packet.getType(), *args)
response = protocol.protocolError(error_message) response = protocol.protocolError(message)
if packet is not None: if packet is not None:
conn.answer(response, packet) conn.answer(response, packet)
else: else:
...@@ -151,7 +152,7 @@ class EventHandler(object): ...@@ -151,7 +152,7 @@ class EventHandler(object):
conn.abort() conn.abort()
self.peerBroken(conn) self.peerBroken(conn)
def unexpectedPacket(self, conn, packet, message = None): def unexpectedPacket(self, conn, packet, message=None, *args):
"""Handle an unexpected packet.""" """Handle an unexpected packet."""
if message is None: if message is None:
message = 'unexpected packet type %s' % packet.getType() message = 'unexpected packet type %s' % packet.getType()
...@@ -162,17 +163,17 @@ class EventHandler(object): ...@@ -162,17 +163,17 @@ class EventHandler(object):
conn.abort() conn.abort()
self.peerBroken(conn) self.peerBroken(conn)
def brokenNodeDisallowedError(conn, packet, message=None): def brokenNodeDisallowedError(self, conn, packet, *args):
""" Called when a broken node send packets """ """ Called when a broken node send packets """
conn.answer(protocol.brokenNodeDisallowedError('go away'), packet) conn.answer(protocol.brokenNodeDisallowedError('go away'), packet)
conn.abort() conn.abort()
def notReadyError(self, conn, packet, message=None): def notReadyError(self, conn, packet, *args):
""" Called when the node is not ready """ """ Called when the node is not ready """
conn.answer(protocol.notReady('retry later'), packet) conn.answer(protocol.notReady('retry later'), packet)
conn.abort() conn.abort()
def protocolError(self, conn, packet, message): def protocolError(self, conn, packet, message='', *args):
""" Called for any other protocol error """ """ Called for any other protocol error """
conn.answer(protocol.protocolError(message), packet) conn.answer(protocol.protocolError(message), packet)
conn.abort() conn.abort()
...@@ -186,16 +187,16 @@ class EventHandler(object): ...@@ -186,16 +187,16 @@ class EventHandler(object):
method(conn, packet, *args) method(conn, packet, *args)
except (KeyError, ValueError): except (KeyError, ValueError):
self.unexpectedPacket(conn, packet) self.unexpectedPacket(conn, packet)
except UnexpectedPacketError, msg: except UnexpectedPacketError, e:
self.unexpectedPacket(conn, packet, msg) self.unexpectedPacket(conn, packet, *e.args)
except PacketMalformedError, msg: except PacketMalformedError, e:
self.packetMalformed(conn, packet, msg) self.packetMalformed(conn, packet, *e.args)
except BrokenNodeDisallowedError, msg: except BrokenNodeDisallowedError, e:
self.brokenNodeDisallowedError(conn, packet, msg) self.brokenNodeDisallowedError(conn, packet, *e.args)
except NotReadyError, msg: except NotReadyError, e:
self.notReadyError(conn, packet, msg) self.notReadyError(conn, packet, *e.args)
except ProtocolError, msg: except ProtocolError, e:
self.protocolError(self, conn, packet, msg) self.protocolError(conn, packet, *e.args)
# Packet handlers. # Packet handlers.
......
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