mirror of
https://github.com/jetty/jetty.project.git
synced 2025-03-03 20:39:18 +00:00
Fixes #212 - HttpClient to support pluggable AuthenticationStore.
This commit is contained in:
parent
7ad415b9b8
commit
ce9be291d3
@ -118,33 +118,33 @@ public class HttpClient extends ContainerLifeCycle
|
||||
private final ConcurrentMap<Origin, HttpDestination> destinations = new ConcurrentHashMap<>();
|
||||
private final ProtocolHandlers handlers = new ProtocolHandlers();
|
||||
private final List<Request.Listener> requestListeners = new ArrayList<>();
|
||||
private final AuthenticationStore authenticationStore = new HttpAuthenticationStore();
|
||||
private final Set<ContentDecoder.Factory> decoderFactories = new ContentDecoderFactorySet();
|
||||
private final ProxyConfiguration proxyConfig = new ProxyConfiguration();
|
||||
private final HttpClientTransport transport;
|
||||
private final SslContextFactory sslContextFactory;
|
||||
private volatile CookieManager cookieManager;
|
||||
private volatile CookieStore cookieStore;
|
||||
private volatile Executor executor;
|
||||
private volatile ByteBufferPool byteBufferPool;
|
||||
private volatile Scheduler scheduler;
|
||||
private volatile SocketAddressResolver resolver;
|
||||
private volatile HttpField agentField = new HttpField(HttpHeader.USER_AGENT, "Jetty/" + Jetty.VERSION);
|
||||
private volatile boolean followRedirects = true;
|
||||
private volatile int maxConnectionsPerDestination = 64;
|
||||
private volatile int maxRequestsQueuedPerDestination = 1024;
|
||||
private volatile int requestBufferSize = 4096;
|
||||
private volatile int responseBufferSize = 16384;
|
||||
private volatile int maxRedirects = 8;
|
||||
private volatile SocketAddress bindAddress;
|
||||
private volatile long connectTimeout = 15000;
|
||||
private volatile long addressResolutionTimeout = 15000;
|
||||
private volatile long idleTimeout;
|
||||
private volatile boolean tcpNoDelay = true;
|
||||
private volatile boolean strictEventOrdering = false;
|
||||
private volatile HttpField encodingField;
|
||||
private volatile boolean removeIdleDestinations = false;
|
||||
private volatile boolean connectBlocking = false;
|
||||
private AuthenticationStore authenticationStore;
|
||||
private CookieManager cookieManager;
|
||||
private CookieStore cookieStore;
|
||||
private Executor executor;
|
||||
private ByteBufferPool byteBufferPool;
|
||||
private Scheduler scheduler;
|
||||
private SocketAddressResolver resolver;
|
||||
private HttpField agentField = new HttpField(HttpHeader.USER_AGENT, "Jetty/" + Jetty.VERSION);
|
||||
private boolean followRedirects = true;
|
||||
private int maxConnectionsPerDestination = 64;
|
||||
private int maxRequestsQueuedPerDestination = 1024;
|
||||
private int requestBufferSize = 4096;
|
||||
private int responseBufferSize = 16384;
|
||||
private int maxRedirects = 8;
|
||||
private SocketAddress bindAddress;
|
||||
private long connectTimeout = 15000;
|
||||
private long addressResolutionTimeout = 15000;
|
||||
private long idleTimeout;
|
||||
private boolean tcpNoDelay = true;
|
||||
private boolean strictEventOrdering = false;
|
||||
private HttpField encodingField;
|
||||
private boolean removeIdleDestinations = false;
|
||||
private boolean connectBlocking = false;
|
||||
|
||||
/**
|
||||
* Creates a {@link HttpClient} instance that can perform requests to non-TLS destinations only
|
||||
@ -227,6 +227,9 @@ public class HttpClient extends ContainerLifeCycle
|
||||
|
||||
decoderFactories.add(new GZIPContentDecoder.Factory(byteBufferPool));
|
||||
|
||||
if (authenticationStore == null)
|
||||
authenticationStore = new HttpAuthenticationStore();
|
||||
|
||||
cookieManager = newCookieManager();
|
||||
cookieStore = cookieManager.getCookieStore();
|
||||
|
||||
@ -302,6 +305,14 @@ public class HttpClient extends ContainerLifeCycle
|
||||
return authenticationStore;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param authenticationStore the authentication store associated with this instance
|
||||
*/
|
||||
public void setAuthenticationStore(AuthenticationStore authenticationStore)
|
||||
{
|
||||
this.authenticationStore = authenticationStore;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns a <em>non</em> thread-safe set of {@link ContentDecoder.Factory}s that can be modified before
|
||||
* performing requests.
|
||||
|
Loading…
x
Reference in New Issue
Block a user