/* * Copyright 2015 MovingBlocks * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.terasology.network.internal.pipelineFactory; import org.jboss.netty.channel.ChannelPipeline; import org.jboss.netty.channel.ChannelPipelineFactory; import org.jboss.netty.channel.Channels; import org.jboss.netty.handler.codec.compression.ZlibDecoder; import org.jboss.netty.handler.codec.frame.LengthFieldBasedFrameDecoder; import org.jboss.netty.handler.codec.protobuf.ProtobufDecoder; import org.jboss.netty.handler.codec.protobuf.ProtobufEncoder; import org.jboss.netty.handler.codec.protobuf.ProtobufVarint32FrameDecoder; import org.jboss.netty.handler.codec.protobuf.ProtobufVarint32LengthFieldPrepender; import org.terasology.network.internal.ClientHandshakeHandler; import org.terasology.network.internal.ServerInfoRequestHandler; import org.terasology.network.internal.JoinStatusImpl; import org.terasology.network.internal.MetricRecordingHandler; import org.terasology.protobuf.NetData; /** * A pipeline that requests {@link org.terasology.network.ServerInfoMessage} before it auto-disconnects. * This is similar to {@link TerasologyClientPipelineFactory}. */ public class InfoRequestPipelineFactory implements ChannelPipelineFactory { @Override public ChannelPipeline getPipeline() throws Exception { JoinStatusImpl joinStatus = new JoinStatusImpl(); ChannelPipeline p = Channels.pipeline(); p.addLast(MetricRecordingHandler.NAME, new MetricRecordingHandler()); p.addLast("lengthFrameDecoder", new LengthFieldBasedFrameDecoder(8388608, 0, 3, 0, 3)); p.addLast("inflateDecoder", new ZlibDecoder()); p.addLast("frameDecoder", new ProtobufVarint32FrameDecoder()); p.addLast("protobufDecoder", new ProtobufDecoder(NetData.NetMessage.getDefaultInstance())); p.addLast("frameEncoder", new ProtobufVarint32LengthFieldPrepender()); p.addLast("protobufEncoder", new ProtobufEncoder()); p.addLast("authenticationHandler", new ClientHandshakeHandler(joinStatus)); p.addLast("connectionHandler", new ServerInfoRequestHandler()); return p; } }