|
|
@ -25,7 +25,6 @@ import android.net.Uri;
|
|
|
|
import android.util.Pair;
|
|
|
|
import android.util.Pair;
|
|
|
|
|
|
|
|
|
|
|
|
import androidx.annotation.NonNull;
|
|
|
|
import androidx.annotation.NonNull;
|
|
|
|
import androidx.core.net.MailTo;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import java.io.FileNotFoundException;
|
|
|
|
import java.io.FileNotFoundException;
|
|
|
|
import java.io.IOException;
|
|
|
|
import java.io.IOException;
|
|
|
@ -44,29 +43,19 @@ public class IPInfo {
|
|
|
|
private final static int FETCH_TIMEOUT = 15 * 1000; // milliseconds
|
|
|
|
private final static int FETCH_TIMEOUT = 15 * 1000; // milliseconds
|
|
|
|
|
|
|
|
|
|
|
|
static Pair<InetAddress, Organization> getOrganization(@NonNull Uri uri, Context context) throws IOException, ParseException {
|
|
|
|
static Pair<InetAddress, Organization> getOrganization(@NonNull Uri uri, Context context) throws IOException, ParseException {
|
|
|
|
if ("mailto".equalsIgnoreCase(uri.getScheme())) {
|
|
|
|
String host = UriHelper.getHost(uri);
|
|
|
|
MailTo email = MailTo.parse(uri.toString());
|
|
|
|
|
|
|
|
String domain = UriHelper.getEmailDomain(email.getTo());
|
|
|
|
|
|
|
|
if (domain == null)
|
|
|
|
|
|
|
|
throw new UnknownHostException();
|
|
|
|
|
|
|
|
//InetAddress address = DnsHelper.lookupMx(context, domain);
|
|
|
|
|
|
|
|
//if (address == null)
|
|
|
|
|
|
|
|
// throw new UnknownHostException();
|
|
|
|
|
|
|
|
InetAddress address = InetAddress.getByName(domain);
|
|
|
|
|
|
|
|
return new Pair<>(address, getOrganization(address, context));
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
String host = uri.getHost();
|
|
|
|
|
|
|
|
if (host == null)
|
|
|
|
if (host == null)
|
|
|
|
throw new UnknownHostException();
|
|
|
|
throw new UnknownHostException();
|
|
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
host = IDN.toASCII(host, IDN.ALLOW_UNASSIGNED);
|
|
|
|
host = IDN.toASCII(host, IDN.ALLOW_UNASSIGNED);
|
|
|
|
} catch (Throwable ex) {
|
|
|
|
} catch (Throwable ex) {
|
|
|
|
Log.i(ex);
|
|
|
|
Log.i(ex);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
InetAddress address = InetAddress.getByName(host);
|
|
|
|
InetAddress address = InetAddress.getByName(host);
|
|
|
|
return new Pair<>(address, getOrganization(address, context));
|
|
|
|
return new Pair<>(address, getOrganization(address, context));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static Organization getOrganization(InetAddress address, Context context) throws IOException {
|
|
|
|
static Organization getOrganization(InetAddress address, Context context) throws IOException {
|
|
|
|
synchronized (addressOrganization) {
|
|
|
|
synchronized (addressOrganization) {
|
|
|
|