Package org.littleshoot.proxy.extras
Class SelfSignedMitmManager
java.lang.Object
org.littleshoot.proxy.extras.SelfSignedMitmManager
- All Implemented Interfaces:
MitmManager
MitmManager that uses self-signed certs for everything.-
Field Summary
Fields -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionclientSslEngineFor(HttpRequest httpRequest, SSLSession serverSslSession) Creates anSSLEnginefor encrypting the client connection based on the given serverSslSession.Creates anSSLEnginefor encrypting the server connection.serverSslEngine(String peerHost, int peerPort) Creates anSSLEnginefor encrypting the server connection.
-
Field Details
-
selfSignedSslEngineSource
-
-
Constructor Details
-
SelfSignedMitmManager
public SelfSignedMitmManager() -
SelfSignedMitmManager
-
-
Method Details
-
serverSslEngine
Description copied from interface:MitmManagerCreates anSSLEnginefor encrypting the server connection. The SSLEngine created by this method may use the given peer information to send SNI information when connecting to the upstream host.- Specified by:
serverSslEnginein interfaceMitmManager- Parameters:
peerHost- to start a client connection to the server.peerPort- to start a client connection to the server.- Returns:
- an SSLEngine used to connect to an upstream server
-
serverSslEngine
Description copied from interface:MitmManagerCreates anSSLEnginefor encrypting the server connection.- Specified by:
serverSslEnginein interfaceMitmManager- Returns:
- an SSLEngine used to connect to an upstream server
-
clientSslEngineFor
Description copied from interface:MitmManagerCreates an
SSLEnginefor encrypting the client connection based on the given serverSslSession.The serverSslSession is provided in case this method needs to inspect the server's certificates or something else about the encryption on the way to the server.
This is the place where one would implement impersonation of the server by issuing replacement certificates signed by the proxy's own certificate.
- Specified by:
clientSslEngineForin interfaceMitmManager- Parameters:
httpRequest- the HTTP CONNECT request that is being man-in-the-middledserverSslSession- theSSLSessionthat's been established with the server- Returns:
- the SSLEngine used to connect to the client
-