All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.littleshoot.proxy.ActivityTracker Maven / Gradle / Ivy

package org.littleshoot.proxy;

import io.netty.handler.codec.http.HttpRequest;
import io.netty.handler.codec.http.HttpResponse;

import javax.net.ssl.SSLSession;
import java.net.InetSocketAddress;

/**
 * 

* Interface for receiving information about activity in the proxy. *

* *

* Sub-classes may wish to extend {@link ActivityTrackerAdapter} for sensible * defaults. *

*/ public interface ActivityTracker { /** * Record that a client connected. * * @param clientAddress */ void clientConnected(InetSocketAddress clientAddress); /** * Record that a client's SSL handshake completed. * * @param clientAddress * @param sslSession */ void clientSSLHandshakeSucceeded(InetSocketAddress clientAddress, SSLSession sslSession); /** * Record that a client disconnected. * * @param clientAddress * @param sslSession */ void clientDisconnected(InetSocketAddress clientAddress, SSLSession sslSession); /** * Record that the proxy received bytes from the client. * * @param flowContext * if full information is available, this will be a * {@link FullFlowContext}. * @param numberOfBytes */ void bytesReceivedFromClient(FlowContext flowContext, int numberOfBytes); /** *

* Record that proxy received an {@link HttpRequest} from the client. *

* *

* Note - on chunked transfers, this is only called once (for the initial * HttpRequest object). *

* * @param flowContext * if full information is available, this will be a * {@link FullFlowContext}. * @param httpRequest */ void requestReceivedFromClient(FlowContext flowContext, HttpRequest httpRequest); /** * Record that the proxy attempted to send bytes to the server. * * @param flowContext * provides contextual information about the flow * @param numberOfBytes */ void bytesSentToServer(FullFlowContext flowContext, int numberOfBytes); /** *

* Record that proxy attempted to send a request to the server. *

* *

* Note - on chunked transfers, this is only called once (for the initial * HttpRequest object). *

* * @param flowContext * provides contextual information about the flow * @param httpRequest */ void requestSentToServer(FullFlowContext flowContext, HttpRequest httpRequest); /** * Record that the proxy received bytes from the server. * * @param flowContext * provides contextual information about the flow * @param numberOfBytes */ void bytesReceivedFromServer(FullFlowContext flowContext, int numberOfBytes); /** *

* Record that the proxy received an {@link HttpResponse} from the server. *

* *

* Note - on chunked transfers, this is only called once (for the initial * HttpRequest object). *

* * @param flowContext * provides contextual information about the flow * @param httpResponse */ void responseReceivedFromServer(FullFlowContext flowContext, HttpResponse httpResponse); /** * Record that the proxy sent bytes to the client. * * @param flowContext * if full information is available, this will be a * {@link FullFlowContext}. * @param numberOfBytes */ void bytesSentToClient(FlowContext flowContext, int numberOfBytes); /** *

* Record that the proxy sent a response to the client. *

* *

* Note - on chunked transfers, this is only called once (for the initial * HttpRequest object). *

* * @param flowContext * if full information is available, this will be a * {@link FullFlowContext}. * @param httpResponse */ void responseSentToClient(FlowContext flowContext, HttpResponse httpResponse); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy