Search in sources :

Example 1 with Message

use of co.rsk.net.messages.Message in project rskj by rsksmart.

the class RskWireProtocol method channelRead0.

@Override
public void channelRead0(final ChannelHandlerContext ctx, EthMessage msg) throws InterruptedException {
    super.channelRead0(ctx, msg);
    if (this.messageRecorder != null) {
        this.messageRecorder.recordMessage(messageSender.getPeerNodeID(), msg);
    }
    if (!hasGoodReputation(ctx)) {
        ctx.disconnect();
        return;
    }
    Metrics.messageBytes(messageSender.getPeerNodeID(), msg.getEncoded().length);
    switch(msg.getCommand()) {
        case STATUS:
            processStatus((org.ethereum.net.eth.message.StatusMessage) msg, ctx);
            break;
        case RSK_MESSAGE:
            RskMessage rskmessage = (RskMessage) msg;
            Message message = rskmessage.getMessage();
            switch(message.getMessageType()) {
                case BLOCK_MESSAGE:
                    loggerNet.trace("RSK Block Message: Block {} {} from {}", ((BlockMessage) message).getBlock().getNumber(), ((BlockMessage) message).getBlock().getShortHash(), this.messageSender.getPeerNodeID());
                    syncStats.addBlocks(1);
                    break;
                case GET_BLOCK_MESSAGE:
                    loggerNet.trace("RSK Get Block Message: Block {} from {}", Hex.toHexString(((GetBlockMessage) message).getBlockHash()).substring(0, 10), this.messageSender.getPeerNodeID());
                    syncStats.getBlock();
                    break;
                case STATUS_MESSAGE:
                    loggerNet.trace("RSK Status Message: Block {} {} from {}", ((StatusMessage) message).getStatus().getBestBlockNumber(), Hex.toHexString(((StatusMessage) message).getStatus().getBestBlockHash()).substring(0, 10), this.messageSender.getPeerNodeID());
                    syncStats.addStatus();
                    break;
            }
            if (this.messageHandler != null) {
                this.messageHandler.postMessage(this.messageSender, rskmessage.getMessage());
            }
            break;
        default:
            break;
    }
}
Also used : BlockMessage(co.rsk.net.messages.BlockMessage) GetBlockMessage(co.rsk.net.messages.GetBlockMessage) StatusMessage(co.rsk.net.messages.StatusMessage) Message(co.rsk.net.messages.Message) BlockMessage(co.rsk.net.messages.BlockMessage) EthMessage(org.ethereum.net.eth.message.EthMessage) GetBlockMessage(co.rsk.net.messages.GetBlockMessage) TransactionsMessage(org.ethereum.net.eth.message.TransactionsMessage) co.rsk.net(co.rsk.net) StatusMessage(co.rsk.net.messages.StatusMessage)

Aggregations

co.rsk.net (co.rsk.net)1 BlockMessage (co.rsk.net.messages.BlockMessage)1 GetBlockMessage (co.rsk.net.messages.GetBlockMessage)1 Message (co.rsk.net.messages.Message)1 StatusMessage (co.rsk.net.messages.StatusMessage)1 EthMessage (org.ethereum.net.eth.message.EthMessage)1 TransactionsMessage (org.ethereum.net.eth.message.TransactionsMessage)1