View Javadoc

1   /*
2    * Copyright 2012 The Netty Project
3    *
4    * The Netty Project licenses this file to you under the Apache License,
5    * version 2.0 (the "License"); you may not use this file except in compliance
6    * with the License. You may obtain a copy of the License at:
7    *
8    *   http://www.apache.org/licenses/LICENSE-2.0
9    *
10   * Unless required by applicable law or agreed to in writing, software
11   * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12   * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13   * License for the specific language governing permissions and limitations
14   * under the License.
15   */
16  package org.jboss.netty.handler.codec.socks;
17  
18  import org.jboss.netty.buffer.ChannelBuffer;
19  import org.jboss.netty.channel.Channel;
20  import org.jboss.netty.channel.ChannelHandlerContext;
21  import org.jboss.netty.handler.codec.replay.ReplayingDecoder;
22  
23  /**
24   * Decodes {@link ChannelBuffer}s into {@link SocksAuthResponse}.
25   * Before returning SocksResponse decoder removes itself from pipeline.
26   */
27  public class SocksAuthResponseDecoder extends ReplayingDecoder<SocksAuthResponseDecoder.State> {
28      private static final String name = "SOCKS_AUTH_RESPONSE_DECODER";
29  
30      public static String getName() {
31          return name;
32      }
33  
34      private SocksMessage.SubnegotiationVersion version;
35      private SocksMessage.AuthStatus authStatus;
36      private SocksResponse msg = SocksCommonUtils.UNKNOWN_SOCKS_RESPONSE;
37  
38      public SocksAuthResponseDecoder() {
39          super(State.CHECK_PROTOCOL_VERSION);
40      }
41  
42      @Override
43      protected Object decode(ChannelHandlerContext ctx, Channel channel,
44                              ChannelBuffer buffer, State state) throws Exception {
45          switch (state) {
46              case CHECK_PROTOCOL_VERSION: {
47                  version = SocksMessage.SubnegotiationVersion.fromByte(buffer.readByte());
48                  if (version != SocksMessage.SubnegotiationVersion.AUTH_PASSWORD) {
49                      break;
50                  }
51                  checkpoint(State.READ_AUTH_RESPONSE);
52              }
53              case READ_AUTH_RESPONSE: {
54                  authStatus = SocksMessage.AuthStatus.fromByte(buffer.readByte());
55                  msg = new SocksAuthResponse(authStatus);
56              }
57          }
58          ctx.getPipeline().remove(this);
59          return msg;
60      }
61  
62      public enum State {
63          CHECK_PROTOCOL_VERSION,
64          READ_AUTH_RESPONSE
65      }
66  }