/*
* Copyright (c) 2014 The APN-PROXY Project
*
* The APN-PROXY Project licenses this file to you 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 com.xx_dev.apn.proxy.test;
import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.SimpleChannelInboundHandler;
import io.netty.handler.codec.http.HttpObject;
import io.netty.handler.codec.http.HttpResponse;
import io.netty.handler.codec.http.LastHttpContent;
import org.apache.log4j.Logger;
/**
* @author xmx
* @version $Id: com.xx_dev.apn.proxy.test.TestHttpClientHandler 14-1-8 16:13 (xmx) Exp $
*/
public class TestHttpClientHandler extends SimpleChannelInboundHandler<HttpObject> {
private static final Logger logger = Logger.getLogger(TestHttpClientHandler.class);
@Override
public void channelRead0(ChannelHandlerContext ctx, HttpObject msg) throws Exception {
// if (msg instanceof HttpResponse) {
// HttpResponse response = (HttpResponse) msg;
//
// logger.info("STATUS: " + response.getStatus());
// logger.info("VERSION: " + response.getProtocolVersion());
//
// if (!response.headers().isEmpty()) {
// for (String name : response.headers().names()) {
// for (String value : response.headers().getAll(name)) {
// logger.info("HEADER: " + name + " = " + value);
// }
// }
// }
//
// if (HttpHeaders.isTransferEncodingChunked(response)) {
// logger.info("CHUNKED CONTENT {");
// } else {
// logger.info("CONTENT {");
// }
// }
// if (msg instanceof HttpContent) {
// HttpContent content = (HttpContent) msg;
//
// logger.info(content.content().toString(CharsetUtil.UTF_8));
//
// if (content instanceof LastHttpContent) {
// logger.info("} END OF CONTENT");
// }
// }
if (msg instanceof HttpResponse) {
HttpResponse response = (HttpResponse) msg;
TestResultHolder.httpStatusCode(response.getStatus().code());
}
if (msg instanceof LastHttpContent) {
ctx.close();
}
}
@Override
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
logger.error(cause.getMessage(), cause);
ctx.close();
throw new Exception(cause);
}
}