Package org.apache.synapse.transport.nhttp.debug

Source Code of org.apache.synapse.transport.nhttp.debug.ServerConnectionDebug

/**
*  Licensed to the Apache Software Foundation (ASF) under one
*  or more contributor license agreements.  See the NOTICE file
*  distributed with this work for additional information
*  regarding copyright ownership.  The ASF 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 org.apache.synapse.transport.nhttp.debug;

import org.apache.http.HttpInetConnection;
import org.apache.http.HttpRequest;
import org.apache.http.RequestLine;
import org.apache.http.nio.NHttpServerConnection;
import org.apache.synapse.transport.nhttp.ServerHandler;

import java.net.InetAddress;

/**
* A connection debug object would be accumulated during request processing, but only made use
* of if the connection encounters issues during processing.
*/
public class ServerConnectionDebug extends AbstractConnectionDebug {

    private long connectionCreationTime;
    private long requestStartTime;
    private long requestCompletionTime;
    private long responseStartTime;
    private long responseCompletionTime;

    private String remoteClientIP;
    private String requestURLPAth;
    private String requestHTTPMethod;
    private String requestHTTPProtocol;

    private ClientConnectionDebug clientConnectionDebug = null;

    public ServerConnectionDebug(NHttpServerConnection conn) {

        super();
        this.connectionCreationTime = (Long) conn.getContext().getAttribute(
                ServerHandler.CONNECTION_CREATION_TIME);
        this.requestStartTime = System.currentTimeMillis();

        // assume an entity body is not present. If present this would be overwritten
        this.requestCompletionTime = System.currentTimeMillis();

        RequestLine reqLine = conn.getHttpRequest().getRequestLine();
        this.requestURLPAth = reqLine.getUri();
        this.requestHTTPMethod = reqLine.getMethod();
        this.requestHTTPProtocol = reqLine.getProtocolVersion().toString();

        if (conn instanceof HttpInetConnection) {
            HttpInetConnection inetConn = (HttpInetConnection) conn;
            InetAddress remoteAddr = inetConn.getRemoteAddress();
            if (remoteAddr != null) {
                this.remoteClientIP = remoteAddr.getHostAddress();
            }
        }

        HttpRequest req = conn.getHttpRequest();
        this.headers = req.getAllHeaders();
    }

    public void recordResponseStartTime() {
        this.responseStartTime = System.currentTimeMillis();
    }

    public void recordRequestCompletionTime() {
        this.requestCompletionTime = System.currentTimeMillis();
    }

    public void recordResponseCompletionTime() {
        this.responseCompletionTime = System.currentTimeMillis();
    }

    public void setClientConnectionDebug(ClientConnectionDebug clientConnectionDebug) {
        this.clientConnectionDebug = clientConnectionDebug;
    }

    public ClientConnectionDebug getClientConnectionDebug() {
        return clientConnectionDebug;
    }

    public String dump() {
        StringBuffer sb = new StringBuffer(50);
        responseCompletionTime = responseCompletionTime == 0 ?
                System.currentTimeMillis() : responseCompletionTime;
        long totalTime = responseCompletionTime - requestStartTime;

        sb.append("C2E-Req-StartTime").append(keyValueSeparator).append(format(requestStartTime));
        sb.append(fieldSeparator);
        sb.append("C2E-Req-EndTime").append(keyValueSeparator).append(format(requestCompletionTime));
        sb.append(fieldSeparator);
        sb.append("C2E-Req-ConnCreateTime").append(keyValueSeparator).append(format(connectionCreationTime));
        sb.append(statementSeparator);

        sb.append("C2E-Req-URL").append(keyValueSeparator).append(requestURLPAth);
        sb.append(fieldSeparator);
        sb.append("C2E-Req-Protocol").append(keyValueSeparator).append(requestHTTPProtocol);
        sb.append(fieldSeparator);
        sb.append("C2E-Req-Method").append(keyValueSeparator).append(requestHTTPMethod);
        sb.append(statementSeparator);

        sb.append("C2E-Req-IP").append(keyValueSeparator).append(remoteClientIP);
        if (!printNoHeaders) {
            sb.append(fieldSeparator);
            sb.append("C2E-Req-Info").append("{").append(headersToString()).append("}");
        }
        sb.append(statementSeparator);

        if (clientConnectionDebug != null) {
            sb.append(clientConnectionDebug.dump());
        }

        sb.append("E2C-Resp-Start").append(keyValueSeparator).append(format(responseStartTime));
        sb.append(fieldSeparator);
        sb.append("E2C-Resp-End").append(keyValueSeparator).append(format(responseCompletionTime));
        sb.append(statementSeparator);

        sb.append("Total-Time").append(keyValueSeparator).append(totalTime).append("ms");
        if (clientConnectionDebug != null) {
            long svcTime = clientConnectionDebug.getResponseCompletionTime()
                    - clientConnectionDebug.getLastRequestStartTime();
            svcTime = svcTime < 0 ? clientConnectionDebug.getResponseStartTime()
                    - clientConnectionDebug.getLastRequestStartTime() : svcTime;
            sb.append(fieldSeparator);
            sb.append("Svc-Time").append(keyValueSeparator).append(svcTime > 0 ?
                    Long.toString(svcTime) + "ms" : "UNDETERMINED");
            sb.append(fieldSeparator);
            sb.append("ESB-Time").append(keyValueSeparator).append(svcTime > 0 ?
                    Long.toString(totalTime - svcTime) + "ms" : "UNDETERMINED");
        }

        return sb.toString();
    }

}
TOP

Related Classes of org.apache.synapse.transport.nhttp.debug.ServerConnectionDebug

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.