com.proofpoint.http.client.jetty.JettyAsyncSocketAddressResolver Maven / Gradle / Ivy
The newest version!
package com.proofpoint.http.client.jetty;
import com.google.common.net.InetAddresses;
import org.eclipse.jetty.util.Promise;
import org.eclipse.jetty.util.SocketAddressResolver;
import org.eclipse.jetty.util.thread.Scheduler;
import java.net.InetAddress;
import java.net.InetSocketAddress;
import java.util.List;
import java.util.Optional;
import java.util.concurrent.Executor;
/**
* For IP address literals this SocketAddressResolver implementation does not dispatch the address resolution
* to the executor. Under high load this helps offloading the executor, which may be shared by multiple different
* HTTP clients.
*/
class JettyAsyncSocketAddressResolver
extends SocketAddressResolver.Async
{
public JettyAsyncSocketAddressResolver(Executor executor, Scheduler scheduler, long timeout)
{
super(executor, scheduler, timeout);
}
@Override
public void resolve(String host, int port, Promise> promise)
{
Optional address = resolve(host);
if (address.isPresent()) {
promise.succeeded(List.of(new InetSocketAddress(address.get(), port)));
return;
}
super.resolve(host, port, promise);
}
private static Optional resolve(String host)
{
try {
return Optional.of(InetAddresses.forString(host));
}
catch (IllegalArgumentException ignored) {
// not an IP address literal
return Optional.empty();
}
}
}