Use Android DNS resolver (experimental)

pull/184/head
M66B 4 years ago
parent e3520957ed
commit c8a89faa8d

@ -21,6 +21,7 @@ package eu.faircode.email;
import android.content.Context;
import android.net.ConnectivityManager;
import android.net.DnsResolver;
import android.net.LinkProperties;
import android.net.Network;
import android.net.NetworkInfo;
@ -30,16 +31,20 @@ import androidx.annotation.NonNull;
import org.xbill.DNS.Lookup;
import org.xbill.DNS.MXRecord;
import org.xbill.DNS.Message;
import org.xbill.DNS.Record;
import org.xbill.DNS.SRVRecord;
import org.xbill.DNS.SimpleResolver;
import org.xbill.DNS.TextParseException;
import org.xbill.DNS.Type;
import java.io.IOException;
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.Semaphore;
import java.util.concurrent.TimeUnit;
import javax.mail.Address;
import javax.mail.internet.InternetAddress;
@ -115,7 +120,60 @@ public class DnsHelper {
}
try {
SimpleResolver resolver = new SimpleResolver(getDnsServer(context));
SimpleResolver resolver = new SimpleResolver(getDnsServer(context)) {
private IOException ex;
private Message result;
@Override
public Message send(Message query) throws IOException {
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.Q || !BuildConfig.DEBUG)
return super.send(query);
else {
Log.i("Using Android DNS resolver");
Semaphore sem = new Semaphore(0);
DnsResolver resolver = DnsResolver.getInstance();
resolver.rawQuery(
null,
query.toWire(),
DnsResolver.FLAG_EMPTY,
Helper.getBackgroundExecutor(1, "dns"),
null,
new DnsResolver.Callback<byte[]>() {
@Override
public void onAnswer(@NonNull byte[] answer, int rcode) {
Log.i("DNS rcode=" + rcode);
try {
if (rcode == 0)
result = new Message(answer);
else
throw new IOException("rcode=" + rcode);
} catch (Throwable e) {
ex = new IOException(e.getMessage());
}
sem.release();
}
@Override
public void onError(@NonNull DnsResolver.DnsException e) {
Log.w(e);
ex = new IOException(e.getMessage());
sem.release();
}
});
try {
if (!sem.tryAcquire(LOOKUP_TIMEOUT, TimeUnit.SECONDS))
throw new IOException("timeout");
} catch (InterruptedException e) {
ex = new IOException("interrupted");
}
if (ex == null)
return result;
else
throw ex;
}
}
};
resolver.setTimeout(LOOKUP_TIMEOUT);
Lookup lookup = new Lookup(name, rtype);
lookup.setResolver(resolver);

Loading…
Cancel
Save