Commit 5610ab92 authored by Aurel's avatar Aurel

anwser with the no error packet when asking to change node/cluster state


git-svn-id: https://svn.erp5.org/repos/neo/branches/prototype3@699 71dcc9de-d417-0410-9af5-da40c76e7ee4
parent b524a503
...@@ -298,6 +298,10 @@ class MasterRequestEventHandler(MasterBaseEventHandler): ...@@ -298,6 +298,10 @@ class MasterRequestEventHandler(MasterBaseEventHandler):
p = protocol.answerNodeState(uuid, state) p = protocol.answerNodeState(uuid, state)
client_conn.notify(p, kw['msg_id']) client_conn.notify(p, kw['msg_id'])
def handleNoError(self, conn, packet, msg):
client_conn, kw = self.app.dispatcher.retrieve(packet.getId())
p = protocol.noError(msg)
client_conn.notify(p, kw['msg_id'])
class MasterBootstrapEventHandler(MasterBaseEventHandler): class MasterBootstrapEventHandler(MasterBaseEventHandler):
"""This class manage the bootstrap part to the primary master node""" """This class manage the bootstrap part to the primary master node"""
......
...@@ -56,7 +56,8 @@ class AdministrationEventHandler(MasterEventHandler): ...@@ -56,7 +56,8 @@ class AdministrationEventHandler(MasterEventHandler):
self.checkClusterName(name) self.checkClusterName(name)
if state == protocol.RUNNING: if state == protocol.RUNNING:
self.app.cluster_state = state self.app.cluster_state = state
conn.answer(protocol.answerClusterState(self.app.cluster_state), packet) p = protocol.noError('cluster state changed')
conn.answer(p, packet)
def handleSetNodeState(self, conn, packet, uuid, state, modify_partition_table): def handleSetNodeState(self, conn, packet, uuid, state, modify_partition_table):
logging.info("set node state for %s-%s : %s" % (dump(uuid), state, modify_partition_table)) logging.info("set node state for %s-%s : %s" % (dump(uuid), state, modify_partition_table))
...@@ -65,13 +66,13 @@ class AdministrationEventHandler(MasterEventHandler): ...@@ -65,13 +66,13 @@ class AdministrationEventHandler(MasterEventHandler):
# get message for self # get message for self
if state == RUNNING_STATE: if state == RUNNING_STATE:
# yes I know # yes I know
p = protocol.answerNodeState(app.uuid, state) p = protocol.noError('node state changed')
conn.answer(p, packet) conn.answer(p, packet)
return return
else: else:
# I was asked to shutdown # I was asked to shutdown
node.setState(state) node.setState(state)
p = protocol.answerNodeState(app.uuid, state) p = protocol.noError('node state changed')
conn.answer(p, packet) conn.answer(p, packet)
app.shutdown() app.shutdown()
...@@ -82,13 +83,13 @@ class AdministrationEventHandler(MasterEventHandler): ...@@ -82,13 +83,13 @@ class AdministrationEventHandler(MasterEventHandler):
return return
if node.getState() == state: if node.getState() == state:
# no change, just notify admin node # no change, just notify admin node
p = protocol.answerNodeState(app.uuid, state) p = protocol.noError('node state changed')
conn.answer(p, packet) conn.answer(p, packet)
# forward information to all nodes # forward information to all nodes
if node.getState() != state: if node.getState() != state:
node.setState(state) node.setState(state)
p = protocol.answerNodeState(app.uuid, state) p = protocol.noError('state changed')
conn.answer(p, packet) conn.answer(p, packet)
app.broadcastNodeInformation(node) app.broadcastNodeInformation(node)
# If this is a storage node, ask it to start. # If this is a storage node, ask it to start.
...@@ -132,7 +133,8 @@ class AdministrationEventHandler(MasterEventHandler): ...@@ -132,7 +133,8 @@ class AdministrationEventHandler(MasterEventHandler):
# nothing to do # nothing to do
if not uuid_set: if not uuid_set:
logging.warning('No nodes added') logging.warning('No nodes added')
conn.answer(protocol.answerNewNodes(()), packet) p = protocol.noError('no nodes added')
conn.answer(p, packet)
return return
uuids = ', '.join([dump(uuid) for uuid in uuid_set]) uuids = ', '.join([dump(uuid) for uuid in uuid_set])
logging.info('Adding nodes %s' % uuids) logging.info('Adding nodes %s' % uuids)
...@@ -149,4 +151,5 @@ class AdministrationEventHandler(MasterEventHandler): ...@@ -149,4 +151,5 @@ class AdministrationEventHandler(MasterEventHandler):
s_conn.notify(protocol.startOperation()) s_conn.notify(protocol.startOperation())
# broadcast the new partition table # broadcast the new partition table
app.broadcastPartitionChanges(app.pt.setNextID(), cell_list) app.broadcastPartitionChanges(app.pt.setNextID(), cell_list)
conn.answer(protocol.answerNewNodes(list(uuid_set)), packet) p = protocol.noError('node added')
conn.answer(p, packet)
...@@ -93,3 +93,5 @@ class CommandEventHandler(EventHandler): ...@@ -93,3 +93,5 @@ class CommandEventHandler(EventHandler):
uuids = ', '.join([dump(uuid) for uuid in uuid_list]) uuids = ', '.join([dump(uuid) for uuid in uuid_list])
self.app.result = 'New storage nodes : %s' % uuids self.app.result = 'New storage nodes : %s' % uuids
def handleNoError(self, conn, packet, msg):
self.app.result = msg
...@@ -985,7 +985,7 @@ def _error(error_code, error_message): ...@@ -985,7 +985,7 @@ def _error(error_code, error_message):
return Packet(ERROR, body) return Packet(ERROR, body)
def noError(message): def noError(message):
return _error(NO_ERROR_CODE, 'no error: ' + message) return _error(NO_ERROR_CODE, message)
def protocolError(error_message): def protocolError(error_message):
return _error(PROTOCOL_ERROR_CODE, 'protocol error: ' + error_message) return _error(PROTOCOL_ERROR_CODE, 'protocol error: ' + error_message)
......
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