Fix possible StackOverflowError when try to resolve authorative names… (#10337)
Motivation: There is a possibility to end up with a StackOverflowError when trying to resolve authorative nameservers because of incorrect wrapping the AuthoritativeDnsServerCache. Modifications: Ensure we don't end up with an overflow due wrapping Result: Fixes https://github.com/netty/netty/issues/10246
This commit is contained in:
parent
21eb936dbe
commit
0bd8771697
@ -498,34 +498,53 @@ abstract class DnsResolveContext<T> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
if (!DnsNameResolver.doResolveAllCached(nameServerName, additionals, resolverPromise, resolveCache(),
|
DnsCache resolveCache = resolveCache();
|
||||||
|
if (!DnsNameResolver.doResolveAllCached(nameServerName, additionals, resolverPromise, resolveCache,
|
||||||
parent.resolvedInternetProtocolFamiliesUnsafe())) {
|
parent.resolvedInternetProtocolFamiliesUnsafe())) {
|
||||||
final AuthoritativeDnsServerCache authoritativeDnsServerCache = authoritativeDnsServerCache();
|
|
||||||
new DnsAddressResolveContext(parent, originalPromise, nameServerName, additionals,
|
new DnsAddressResolveContext(parent, originalPromise, nameServerName, additionals,
|
||||||
parent.newNameServerAddressStream(nameServerName),
|
parent.newNameServerAddressStream(nameServerName), resolveCache,
|
||||||
resolveCache(), new AuthoritativeDnsServerCache() {
|
redirectAuthoritativeDnsServerCache(authoritativeDnsServerCache()), false)
|
||||||
@Override
|
.resolve(resolverPromise);
|
||||||
public DnsServerAddressStream get(String hostname) {
|
}
|
||||||
// To not risk falling into any loop, we will not use the cache while following redirects but only
|
}
|
||||||
// on the initial query.
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
private static AuthoritativeDnsServerCache redirectAuthoritativeDnsServerCache(
|
||||||
public void cache(String hostname, InetSocketAddress address, long originalTtl, EventLoop loop) {
|
AuthoritativeDnsServerCache authoritativeDnsServerCache) {
|
||||||
authoritativeDnsServerCache.cache(hostname, address, originalTtl, loop);
|
// Don't wrap again to prevent the possibility of an StackOverflowError when wrapping another
|
||||||
}
|
// RedirectAuthoritativeDnsServerCache.
|
||||||
|
if (authoritativeDnsServerCache instanceof RedirectAuthoritativeDnsServerCache) {
|
||||||
|
return authoritativeDnsServerCache;
|
||||||
|
}
|
||||||
|
return new RedirectAuthoritativeDnsServerCache(authoritativeDnsServerCache);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
private static final class RedirectAuthoritativeDnsServerCache implements AuthoritativeDnsServerCache {
|
||||||
public void clear() {
|
private final AuthoritativeDnsServerCache wrapped;
|
||||||
authoritativeDnsServerCache.clear();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
RedirectAuthoritativeDnsServerCache(AuthoritativeDnsServerCache authoritativeDnsServerCache) {
|
||||||
public boolean clear(String hostname) {
|
this.wrapped = authoritativeDnsServerCache;
|
||||||
return authoritativeDnsServerCache.clear(hostname);
|
}
|
||||||
}
|
|
||||||
}, false).resolve(resolverPromise);
|
@Override
|
||||||
|
public DnsServerAddressStream get(String hostname) {
|
||||||
|
// To not risk falling into any loop, we will not use the cache while following redirects but only
|
||||||
|
// on the initial query.
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void cache(String hostname, InetSocketAddress address, long originalTtl, EventLoop loop) {
|
||||||
|
wrapped.cache(hostname, address, originalTtl, loop);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void clear() {
|
||||||
|
wrapped.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean clear(String hostname) {
|
||||||
|
return wrapped.clear(hostname);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user