diff options
author | Tim Bray <tbray@textuality.com> | 2014-11-19 14:35:05 -0800 |
---|---|---|
committer | Tim Bray <tbray@textuality.com> | 2014-11-19 14:35:05 -0800 |
commit | b5cdeb7f5a54be7443894ca2cb4bd27359fae9ce (patch) | |
tree | 52b61ea702ed09bc9e722669dc5f8732a7e3aa2e /OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service | |
parent | 0f59e6bd950087d99a0909e55276e649639bb51b (diff) | |
download | open-keychain-b5cdeb7f5a54be7443894ca2cb4bd27359fae9ce.tar.gz open-keychain-b5cdeb7f5a54be7443894ca2cb4bd27359fae9ce.tar.bz2 open-keychain-b5cdeb7f5a54be7443894ca2cb4bd27359fae9ce.zip |
Prevent multiple cloud-trust-search launches. Handle DNS query failure gracefully. Fixes #1007 & #1008.
Diffstat (limited to 'OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service')
-rw-r--r-- | OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java index 8a670df25..954963fb6 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java @@ -85,6 +85,7 @@ import java.util.List; import java.util.concurrent.atomic.AtomicBoolean; import de.measite.minidns.Client; +import de.measite.minidns.DNSMessage; import de.measite.minidns.Question; import de.measite.minidns.Record; import de.measite.minidns.record.Data; @@ -330,7 +331,12 @@ public class KeychainIntentService extends IntentService implements Progressable String domain = prover.dnsTxtCheckRequired(); if (domain != null) { - Record[] records = new Client().query(new Question(domain, Record.TYPE.TXT)).getAnswers(); + DNSMessage dnsQuery = new Client().query(new Question(domain, Record.TYPE.TXT)); + if (dnsQuery == null) { + sendProofError(prover.getLog(), getString(R.string.keybase_dns_query_failure)); + return; + } + Record[] records = dnsQuery.getAnswers(); List<List<byte[]>> extents = new ArrayList<List<byte[]>>(); for (Record r : records) { Data d = r.getPayload(); |