/* * Galaxy * Copyright (c) 2012-2014, Parallel Universe Software Co. All rights reserved. * * This program and the accompanying materials are dual-licensed under * either the terms of the Eclipse Public License v1.0 as published by * the Eclipse Foundation * * or (per the licensee's choosing) * * under the terms of the GNU Lesser General Public License version 3.0 * as published by the Free Software Foundation. */ package co.paralleluniverse.galaxy.netty; import co.paralleluniverse.galaxy.cluster.NodeInfo; import java.net.SocketAddress; import org.jboss.netty.channel.Channel; import org.jboss.netty.channel.ChannelHandler; import org.jboss.netty.channel.ChannelHandlerContext; /** * * @author pron */ @ChannelHandler.Sharable public class ChannelAttachedNodeResolver extends ChannelMessageNodeResolver { @Override protected short getNodeId(ChannelHandlerContext ctx, SocketAddress address) { final Channel channel = ctx.getChannel(); //final SocketAddress address = channel.getRemoteAddress(); NodeInfo node = ChannelNodeInfo.nodeInfo.get(channel); assert node != null; return node.getNodeId(); } }