[tor-commits] [onionoo/master] Fixes for reverse DNS resolver

karsten at torproject.org karsten at torproject.org
Thu Aug 16 07:28:52 UTC 2018


commit 4b05f840fc19d81d5e05f8b0b89c80473024f07a
Author: Iain R. Learmonth <irl at fsfe.org>
Date:   Tue Aug 14 12:51:40 2018 +0100

    Fixes for reverse DNS resolver
    
     * SortedSets are used in place of Lists to ensure deterministic
       ordering of looked up names
     * The NodeStatus serialization is extended to include verified
       and unverified host names
     * The existing host name field in NodeStatus serializations is
       removed and a placeholder inserted
     * The last reverse DNS lookup time is now only updated on successful
       lookups
     * The host name field is removed from summary and details documents
     * Tests are updated to use SortedSets in place of Lists
    
    Fixes: #27050
---
 .../torproject/onionoo/docs/DetailsDocument.java   | 21 +++++-----
 .../org/torproject/onionoo/docs/DetailsStatus.java | 16 ++++----
 .../org/torproject/onionoo/docs/DocumentStore.java |  7 ++--
 .../org/torproject/onionoo/docs/NodeStatus.java    | 47 ++++++++++++----------
 .../torproject/onionoo/docs/SummaryDocument.java   | 17 ++++----
 .../org/torproject/onionoo/server/NodeIndexer.java |  9 ++---
 .../torproject/onionoo/server/ResponseBuilder.java |  2 -
 .../onionoo/updater/NodeDetailsStatusUpdater.java  | 33 ++++-----------
 .../onionoo/updater/RdnsLookupRequest.java         | 24 ++++-------
 .../onionoo/updater/RdnsLookupWorker.java          | 13 ++----
 .../onionoo/updater/ReverseDomainNameResolver.java | 19 +++------
 .../onionoo/writer/DetailsDocumentWriter.java      |  1 -
 .../onionoo/writer/SummaryDocumentWriter.java      |  8 ++--
 .../onionoo/docs/SummaryDocumentTest.java          |  2 +-
 .../onionoo/server/ResourceServletTest.java        | 19 +++++----
 .../server/SummaryDocumentComparatorTest.java      |  2 +-
 16 files changed, 98 insertions(+), 142 deletions(-)

diff --git a/src/main/java/org/torproject/onionoo/docs/DetailsDocument.java b/src/main/java/org/torproject/onionoo/docs/DetailsDocument.java
index 650ba5b..5e53d4c 100644
--- a/src/main/java/org/torproject/onionoo/docs/DetailsDocument.java
+++ b/src/main/java/org/torproject/onionoo/docs/DetailsDocument.java
@@ -9,6 +9,7 @@ import java.util.ArrayList;
 import java.util.List;
 import java.util.Map;
 import java.util.SortedSet;
+import java.util.TreeSet;
 
 public class DetailsDocument extends Document {
 
@@ -260,19 +261,19 @@ public class DetailsDocument extends Document {
     return unescapeJson(this.hostName);
   }
 
-  private List<String> verifiedHostNames;
+  private SortedSet<String> verifiedHostNames;
 
   /**
    * Creates a copy of the list with each string escaped for JSON compatibility
    * and sets this as the verified host names, unless the argument was null in
    * which case the verified host names are just set to null.
    */
-  public void setVerifiedHostNames(List<String> verifiedHostNames) {
+  public void setVerifiedHostNames(SortedSet<String> verifiedHostNames) {
     if (null == verifiedHostNames) {
       this.verifiedHostNames = null;
       return;
     }
-    this.verifiedHostNames = new ArrayList<>();
+    this.verifiedHostNames = new TreeSet<>();
     for (String hostName : verifiedHostNames) {
       this.verifiedHostNames.add(escapeJson(hostName));
     }
@@ -283,30 +284,30 @@ public class DetailsDocument extends Document {
    * compatibility reversed and returns the copy, unless the held reference was
    * null in which case null is returned.
    */
-  public List<String> getVerifiedHostNames() {
+  public SortedSet<String> getVerifiedHostNames() {
     if (null == this.verifiedHostNames) {
       return null;
     }
-    List<String> verifiedHostNames = new ArrayList<>();
+    SortedSet<String> verifiedHostNames = new TreeSet<>();
     for (String escapedHostName : this.verifiedHostNames) {
       verifiedHostNames.add(unescapeJson(escapedHostName));
     }
     return verifiedHostNames;
   }
 
-  private List<String> unverifiedHostNames;
+  private SortedSet<String> unverifiedHostNames;
 
   /**
    * Creates a copy of the list with each string escaped for JSON compatibility
    * and sets this as the unverified host names, unless the argument was null in
    * which case the unverified host names are just set to null.
    */
-  public void setUnverifiedHostNames(List<String> unverifiedHostNames) {
+  public void setUnverifiedHostNames(SortedSet<String> unverifiedHostNames) {
     if (null == unverifiedHostNames) {
       this.unverifiedHostNames = null;
       return;
     }
-    this.unverifiedHostNames = new ArrayList<>();
+    this.unverifiedHostNames = new TreeSet<>();
     for (String hostName : unverifiedHostNames) {
       this.unverifiedHostNames.add(escapeJson(hostName));
     }
@@ -317,11 +318,11 @@ public class DetailsDocument extends Document {
    * compatibility reversed and returns the copy, unless the held reference was
    * null in which case null is returned.
    */
-  public List<String> getUnverifiedHostNames() {
+  public SortedSet<String> getUnverifiedHostNames() {
     if (null == this.unverifiedHostNames) {
       return null;
     }
-    List<String> unverifiedHostNames = new ArrayList<>();
+    SortedSet<String> unverifiedHostNames = new TreeSet<>();
     for (String escapedHostName : this.unverifiedHostNames) {
       unverifiedHostNames.add(unescapeJson(escapedHostName));
     }
diff --git a/src/main/java/org/torproject/onionoo/docs/DetailsStatus.java b/src/main/java/org/torproject/onionoo/docs/DetailsStatus.java
index 207b0d2..7cd87ee 100644
--- a/src/main/java/org/torproject/onionoo/docs/DetailsStatus.java
+++ b/src/main/java/org/torproject/onionoo/docs/DetailsStatus.java
@@ -538,7 +538,7 @@ public class DetailsStatus extends Document {
    * and sets this as the verified host names, unless the argument was null in
    * which case the verified host names are just set to null.
    */
-  public void setVerifiedHostNames(List<String> verifiedHostNames) {
+  public void setVerifiedHostNames(SortedSet<String> verifiedHostNames) {
     if (null == verifiedHostNames) {
       this.verifiedHostNames = null;
       return;
@@ -554,30 +554,30 @@ public class DetailsStatus extends Document {
    * compatibility reversed and returns the copy, unless the held reference was
    * null in which case null is returned.
    */
-  public List<String> getVerifiedHostNames() {
+  public SortedSet<String> getVerifiedHostNames() {
     if (null == this.verifiedHostNames) {
       return null;
     }
-    List<String> verifiedHostNames = new ArrayList<>();
+    SortedSet<String> verifiedHostNames = new TreeSet<>();
     for (String escapedHostName : this.verifiedHostNames) {
       verifiedHostNames.add(unescapeJson(escapedHostName));
     }
     return verifiedHostNames;
   }
 
-  private List<String> unverifiedHostNames;
+  private SortedSet<String> unverifiedHostNames;
 
   /**
    * Creates a copy of the list with each string escaped for JSON compatibility
    * and sets this as the unverified host names, unless the argument was null in
    * which case the unverified host names are just set to null.
    */
-  public void setUnverifiedHostNames(List<String> unverifiedHostNames) {
+  public void setUnverifiedHostNames(SortedSet<String> unverifiedHostNames) {
     if (null == unverifiedHostNames) {
       this.unverifiedHostNames = null;
       return;
     }
-    this.unverifiedHostNames = new ArrayList<>();
+    this.unverifiedHostNames = new TreeSet<>();
     for (String hostName : unverifiedHostNames) {
       this.unverifiedHostNames.add(escapeJson(hostName));
     }
@@ -588,11 +588,11 @@ public class DetailsStatus extends Document {
    * compatibility reversed and returns the copy, unless the held reference was
    * null in which case null is returned.
    */
-  public List<String> getUnverifiedHostNames() {
+  public SortedSet<String> getUnverifiedHostNames() {
     if (null == this.unverifiedHostNames) {
       return null;
     }
-    List<String> unverifiedHostNames = new ArrayList<>();
+    SortedSet<String> unverifiedHostNames = new TreeSet<>();
     for (String escapedHostName : this.unverifiedHostNames) {
       unverifiedHostNames.add(unescapeJson(escapedHostName));
     }
diff --git a/src/main/java/org/torproject/onionoo/docs/DocumentStore.java b/src/main/java/org/torproject/onionoo/docs/DocumentStore.java
index 8cf76c8..c9dc13b 100644
--- a/src/main/java/org/torproject/onionoo/docs/DocumentStore.java
+++ b/src/main/java/org/torproject/onionoo/docs/DocumentStore.java
@@ -445,15 +445,14 @@ public class DocumentStore {
     long lastSeenMillis = -1L;
     long consensusWeight = -1L;
     long firstSeenMillis = -1L;
-    String hostName = null;
-    List<String> verifiedHostNames = null;
-    List<String> unverifiedHostNames = null;
+    SortedSet<String> verifiedHostNames = null;
+    SortedSet<String> unverifiedHostNames = null;
     Boolean recommendedVersion = null;
     SummaryDocument summaryDocument = new SummaryDocument(isRelay,
         nickname, fingerprint, addresses, lastSeenMillis, running,
         relayFlags, consensusWeight, countryCode, firstSeenMillis,
         asNumber, asName, contact, family, family, version, operatingSystem,
-        hostName, verifiedHostNames, unverifiedHostNames,
+        verifiedHostNames, unverifiedHostNames,
         recommendedVersion);
     return summaryDocument;
   }
diff --git a/src/main/java/org/torproject/onionoo/docs/NodeStatus.java b/src/main/java/org/torproject/onionoo/docs/NodeStatus.java
index 50c66f9..b2b6c8e 100644
--- a/src/main/java/org/torproject/onionoo/docs/NodeStatus.java
+++ b/src/main/java/org/torproject/onionoo/docs/NodeStatus.java
@@ -15,7 +15,6 @@ import java.util.Collection;
 import java.util.Collections;
 import java.util.HashMap;
 import java.util.HashSet;
-import java.util.List;
 import java.util.Map;
 import java.util.Set;
 import java.util.SortedMap;
@@ -409,23 +408,23 @@ public class NodeStatus extends Document {
     return this.hostName;
   }
 
-  private List<String> verifiedHostNames;
+  private SortedSet<String> verifiedHostNames;
 
-  public void setVerifiedHostNames(List<String> verifiedHostNames) {
+  public void setVerifiedHostNames(SortedSet<String> verifiedHostNames) {
     this.verifiedHostNames = verifiedHostNames;
   }
 
-  public List<String> getVerifiedHostNames() {
+  public SortedSet<String> getVerifiedHostNames() {
     return this.verifiedHostNames;
   }
 
-  private List<String> unverifiedHostNames;
+  private SortedSet<String> unverifiedHostNames;
 
-  public void setUnverifiedHostNames(List<String> unverifiedHostNames) {
+  public void setUnverifiedHostNames(SortedSet<String> unverifiedHostNames) {
     this.unverifiedHostNames = unverifiedHostNames;
   }
 
-  public List<String> getUnverifiedHostNames() {
+  public SortedSet<String> getUnverifiedHostNames() {
     return this.unverifiedHostNames;
   }
 
@@ -549,15 +548,7 @@ public class NodeStatus extends Document {
           Arrays.asList(parts[8].split(","))));
       nodeStatus.setConsensusWeight(Long.parseLong(parts[9]));
       nodeStatus.setCountryCode(parts[10]);
-      if (!parts[11].equals("")) {
-        /* This is a (possibly surprising) hack that is part of moving the
-         * host name field from node status to details status.  As part of
-         * that move we ignore all previously looked up host names trigger
-         * a new lookup by setting the last lookup time to 1969-12-31
-         * 23:59:59.999.  This hack may be removed after it has been run
-         * at least once. */
-        parts[12] = "-1";
-      }
+      /* parts[11] previously contained a hostname */
       nodeStatus.setLastRdnsLookup(Long.parseLong(parts[12]));
       if (!parts[13].equals("null")) {
         nodeStatus.setDefaultPolicy(parts[13]);
@@ -621,15 +612,26 @@ public class NodeStatus extends Document {
       if (parts.length >= 24 && !parts[23].isEmpty()) {
         nodeStatus.setVersion(parts[23]);
       }
-      if (parts.length >= 25 && !parts[24].isEmpty()) {
-        nodeStatus.setHostName(parts[24]);
-      }
+      /* parts[24] previously contained a hostname */
       if (parts.length >= 26) {
         nodeStatus.setVersionStatus(TorVersionStatus.ofAbbreviation(parts[25]));
       }
       if (parts.length >= 27) {
         nodeStatus.setAsName(parts[26]);
       }
+      if (parts.length >= 28) {
+        SortedSet<String> verifiedHostNames = new TreeSet<>();
+        SortedSet<String> unverifiedHostNames = new TreeSet<>();
+        String[] groups = parts[27].split(":", -1);
+        if (groups[0].length() > 0) {
+          verifiedHostNames.addAll(Arrays.asList(groups[0].split(";")));
+        }
+        if (groups.length > 1 && groups[1].length() > 0) {
+          unverifiedHostNames.addAll(Arrays.asList(groups[1].split(";")));
+        }
+        nodeStatus.setVerifiedHostNames(verifiedHostNames);
+        nodeStatus.setUnverifiedHostNames(unverifiedHostNames);
+      }
       return nodeStatus;
     } catch (NumberFormatException e) {
       log.error("Number format exception while parsing node "
@@ -696,11 +698,14 @@ public class NodeStatus extends Document {
         .append(StringUtils.join(this.getIndirectFamily(), ";"));
     sb.append("\t")
         .append((this.getVersion() != null ? this.getVersion() : ""));
-    sb.append("\t")
-        .append((this.getHostName() != null ? this.getHostName() : ""));
+    sb.append("\t"); /* formerly used for storing host names */
     sb.append("\t").append(null != this.getVersionStatus()
         ? this.getVersionStatus().getAbbreviation() : "");
     sb.append("\t").append((this.asName != null ? this.asName : ""));
+    sb.append("\t").append(this.verifiedHostNames != null
+          ? StringUtils.join(this.getVerifiedHostNames(), ";") : "")
+        .append(":").append(this.unverifiedHostNames != null
+          ? StringUtils.join(this.getUnverifiedHostNames(), ";") : "");
     return sb.toString();
   }
 }
diff --git a/src/main/java/org/torproject/onionoo/docs/SummaryDocument.java b/src/main/java/org/torproject/onionoo/docs/SummaryDocument.java
index fc84ba6..c4308ec 100644
--- a/src/main/java/org/torproject/onionoo/docs/SummaryDocument.java
+++ b/src/main/java/org/torproject/onionoo/docs/SummaryDocument.java
@@ -332,24 +332,24 @@ public class SummaryDocument extends Document {
   }
 
   @JsonProperty("vh")
-  private List<String> verifiedHostNames;
+  private SortedSet<String> verifiedHostNames;
 
-  public void setVerifiedHostNames(List<String> verifiedHostNames) {
+  public void setVerifiedHostNames(SortedSet<String> verifiedHostNames) {
     this.verifiedHostNames = verifiedHostNames;
   }
 
-  public List<String> getVerifiedHostNames() {
+  public SortedSet<String> getVerifiedHostNames() {
     return this.verifiedHostNames;
   }
 
   @JsonProperty("uh")
-  private List<String> unverifiedHostNames;
+  private SortedSet<String> unverifiedHostNames;
 
-  public void setUnverifiedHostNames(List<String> unverifiedHostNames) {
+  public void setUnverifiedHostNames(SortedSet<String> unverifiedHostNames) {
     this.unverifiedHostNames = unverifiedHostNames;
   }
 
-  public List<String> getUnverifiedHostNames() {
+  public SortedSet<String> getUnverifiedHostNames() {
     return this.unverifiedHostNames;
   }
 
@@ -378,8 +378,8 @@ public class SummaryDocument extends Document {
       String countryCode, long firstSeenMillis, String asNumber, String asName,
       String contact, SortedSet<String> familyFingerprints,
       SortedSet<String> effectiveFamily, String version, String operatingSystem,
-      String hostName, List<String> verifiedHostNames,
-      List<String> unverifiedHostNames, Boolean recommendedVersion) {
+      SortedSet<String> verifiedHostNames,
+      SortedSet<String> unverifiedHostNames, Boolean recommendedVersion) {
     this.setRelay(isRelay);
     this.setNickname(nickname);
     this.setFingerprint(fingerprint);
@@ -397,7 +397,6 @@ public class SummaryDocument extends Document {
     this.setEffectiveFamily(effectiveFamily);
     this.setVersion(version);
     this.setOperatingSystem(operatingSystem);
-    this.setHostName(hostName);
     this.setVerifiedHostNames(verifiedHostNames);
     this.setUnverifiedHostNames(unverifiedHostNames);
     this.setRecommendedVersion(recommendedVersion);
diff --git a/src/main/java/org/torproject/onionoo/server/NodeIndexer.java b/src/main/java/org/torproject/onionoo/server/NodeIndexer.java
index 5a2ea8d..3812fea 100644
--- a/src/main/java/org/torproject/onionoo/server/NodeIndexer.java
+++ b/src/main/java/org/torproject/onionoo/server/NodeIndexer.java
@@ -15,15 +15,14 @@ import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 
 import java.io.File;
-import java.util.ArrayList;
 import java.util.HashMap;
 import java.util.HashSet;
-import java.util.List;
 import java.util.Map;
 import java.util.Set;
 import java.util.SortedMap;
 import java.util.SortedSet;
 import java.util.TreeMap;
+import java.util.TreeSet;
 
 import javax.servlet.ServletContextEvent;
 import javax.servlet.ServletContextListener;
@@ -298,12 +297,12 @@ public class NodeIndexer implements ServletContextListener, Runnable {
         newRelaysByOperatingSystem.get(operatingSystem).add(fingerprint);
         newRelaysByOperatingSystem.get(operatingSystem).add(hashedFingerprint);
       }
-      List<String> allHostNames = new ArrayList<>();
-      List<String> verifiedHostNames = entry.getVerifiedHostNames();
+      SortedSet<String> allHostNames = new TreeSet<>();
+      SortedSet<String> verifiedHostNames = entry.getVerifiedHostNames();
       if (null != verifiedHostNames) {
         allHostNames.addAll(verifiedHostNames);
       }
-      List<String> unverifiedHostNames = entry.getUnverifiedHostNames();
+      SortedSet<String> unverifiedHostNames = entry.getUnverifiedHostNames();
       if (null != unverifiedHostNames) {
         allHostNames.addAll(unverifiedHostNames);
       }
diff --git a/src/main/java/org/torproject/onionoo/server/ResponseBuilder.java b/src/main/java/org/torproject/onionoo/server/ResponseBuilder.java
index 9efd6be..a5bce5f 100644
--- a/src/main/java/org/torproject/onionoo/server/ResponseBuilder.java
+++ b/src/main/java/org/torproject/onionoo/server/ResponseBuilder.java
@@ -287,8 +287,6 @@ public class ResponseBuilder {
             dd.setAsName(detailsDocument.getAsName());
           } else if (field.equals(DetailsDocumentFields.CONSENSUS_WEIGHT)) {
             dd.setConsensusWeight(detailsDocument.getConsensusWeight());
-          } else if (field.equals("host_name")) {
-            dd.setHostName(detailsDocument.getHostName());
           } else if (field.equals("verified_host_names")) {
             dd.setVerifiedHostNames(detailsDocument.getVerifiedHostNames());
           } else if (field.equals("unverified_host_names")) {
diff --git a/src/main/java/org/torproject/onionoo/updater/NodeDetailsStatusUpdater.java b/src/main/java/org/torproject/onionoo/updater/NodeDetailsStatusUpdater.java
index baba85f..507d633 100644
--- a/src/main/java/org/torproject/onionoo/updater/NodeDetailsStatusUpdater.java
+++ b/src/main/java/org/torproject/onionoo/updater/NodeDetailsStatusUpdater.java
@@ -757,35 +757,25 @@ public class NodeDetailsStatusUpdater implements DescriptorListener,
 
   private long startedRdnsLookups = -1L;
 
-  private SortedMap<String, String> rdnsLookupResults = new TreeMap<>();
-  private SortedMap<String, List<String>> rdnsVerifiedLookupResults =
+  private SortedMap<String, SortedSet<String>> rdnsVerifiedLookupResults =
       new TreeMap<>();
-  private SortedMap<String, List<String>> rdnsUnverifiedLookupResults =
+  private SortedMap<String, SortedSet<String>> rdnsUnverifiedLookupResults =
       new TreeMap<>();
 
   private void finishReverseDomainNameLookups() {
     this.reverseDomainNameResolver.finishReverseDomainNameLookups();
     this.startedRdnsLookups =
         this.reverseDomainNameResolver.getLookupStartMillis();
-    Map<String, String> lookupResults =
-        this.reverseDomainNameResolver.getLookupResults();
-    Map<String, List<String>> verifiedLookupResults =
+    Map<String, SortedSet<String>> verifiedLookupResults =
         this.reverseDomainNameResolver.getVerifiedLookupResults();
-    Map<String, List<String>> unverifiedLookupResults =
+    Map<String, SortedSet<String>> unverifiedLookupResults =
         this.reverseDomainNameResolver.getUnverifiedLookupResults();
     for (String fingerprint : this.currentRelays) {
       NodeStatus nodeStatus = this.knownNodes.get(fingerprint);
-      String hostName = lookupResults.get(nodeStatus.getAddress());
-      List<String> verifiedHostNames =
+      SortedSet<String> verifiedHostNames =
               verifiedLookupResults.get(nodeStatus.getAddress());
-      List<String> unverifiedHostNames =
+      SortedSet<String> unverifiedHostNames =
               unverifiedLookupResults.get(nodeStatus.getAddress());
-      if (null != hostName) {
-        this.rdnsLookupResults.put(fingerprint, hostName);
-      } else {
-        /* Maintains bug compatibility with previous implementation */
-        this.rdnsLookupResults.put(fingerprint, nodeStatus.getAddress());
-      }
       if (null != verifiedHostNames && !verifiedHostNames.isEmpty()) {
         this.rdnsVerifiedLookupResults.put(fingerprint, verifiedHostNames);
       }
@@ -902,15 +892,8 @@ public class NodeDetailsStatusUpdater implements DescriptorListener,
             this.exitProbabilities.get(fingerprint));
       }
 
-      if (this.rdnsLookupResults.containsKey(fingerprint)) {
-        String hostName = this.rdnsLookupResults.get(fingerprint);
-        detailsStatus.setHostName(hostName);
-        nodeStatus.setHostName(hostName);
-        nodeStatus.setLastRdnsLookup(this.startedRdnsLookups);
-      }
-
       if (this.rdnsVerifiedLookupResults.containsKey(fingerprint)) {
-        List<String> verifiedHostNames =
+        SortedSet<String> verifiedHostNames =
             this.rdnsVerifiedLookupResults.get(fingerprint);
         detailsStatus.setVerifiedHostNames(verifiedHostNames);
         nodeStatus.setVerifiedHostNames(verifiedHostNames);
@@ -918,7 +901,7 @@ public class NodeDetailsStatusUpdater implements DescriptorListener,
       }
 
       if (this.rdnsUnverifiedLookupResults.containsKey(fingerprint)) {
-        List<String> unverifiedHostNames =
+        SortedSet<String> unverifiedHostNames =
             this.rdnsUnverifiedLookupResults.get(fingerprint);
         detailsStatus.setUnverifiedHostNames(unverifiedHostNames);
         nodeStatus.setUnverifiedHostNames(unverifiedHostNames);
diff --git a/src/main/java/org/torproject/onionoo/updater/RdnsLookupRequest.java b/src/main/java/org/torproject/onionoo/updater/RdnsLookupRequest.java
index 3859262..380b62c 100644
--- a/src/main/java/org/torproject/onionoo/updater/RdnsLookupRequest.java
+++ b/src/main/java/org/torproject/onionoo/updater/RdnsLookupRequest.java
@@ -3,10 +3,9 @@
 
 package org.torproject.onionoo.updater;
 
-import java.util.ArrayList;
 import java.util.Hashtable;
-import java.util.List;
 import java.util.Set;
+import java.util.SortedSet;
 import java.util.TreeSet;
 
 import javax.naming.Context;
@@ -23,9 +22,9 @@ class RdnsLookupRequest extends Thread {
 
   private String address;
 
-  private List<String> verifiedHostNames;
+  private SortedSet<String> verifiedHostNames;
 
-  private List<String> unverifiedHostNames;
+  private SortedSet<String> unverifiedHostNames;
 
   private long lookupStartedMillis = -1L;
 
@@ -41,8 +40,8 @@ class RdnsLookupRequest extends Thread {
   public void run() {
     this.lookupStartedMillis = System.currentTimeMillis();
     try {
-      final List<String> verifiedResults = new ArrayList<>();
-      final List<String> unverifiedResults = new ArrayList<>();
+      final SortedSet<String> verifiedResults = new TreeSet<>();
+      final SortedSet<String> unverifiedResults = new TreeSet<>();
       final String[] bytes = this.address.split("\\.");
       if (bytes.length == 4) {
         final String reverseDnsDomain =
@@ -107,20 +106,11 @@ class RdnsLookupRequest extends Thread {
     return results.toArray(new String[results.size()]);
   }
 
-  public synchronized String getHostName() {
-    List<String> verifiedHostNames = this.verifiedHostNames;
-    if (null != verifiedHostNames && !verifiedHostNames.isEmpty() ) {
-      return verifiedHostNames.get(0);
-    } else {
-      return null;
-    }
-  }
-
-  public synchronized List<String> getVerifiedHostNames() {
+  public synchronized SortedSet<String> getVerifiedHostNames() {
     return this.verifiedHostNames;
   }
 
-  public synchronized List<String> getUnverifiedHostNames() {
+  public synchronized SortedSet<String> getUnverifiedHostNames() {
     return this.unverifiedHostNames;
   }
 
diff --git a/src/main/java/org/torproject/onionoo/updater/RdnsLookupWorker.java b/src/main/java/org/torproject/onionoo/updater/RdnsLookupWorker.java
index 953fdd2..b5523a1 100644
--- a/src/main/java/org/torproject/onionoo/updater/RdnsLookupWorker.java
+++ b/src/main/java/org/torproject/onionoo/updater/RdnsLookupWorker.java
@@ -3,7 +3,7 @@
 
 package org.torproject.onionoo.updater;
 
-import java.util.List;
+import java.util.SortedSet;
 
 class RdnsLookupWorker extends Thread {
 
@@ -39,14 +39,7 @@ class RdnsLookupWorker extends Thread {
       } catch (InterruptedException e) {
         /* Getting interrupted should be the default case. */
       }
-      String hostName = request.getHostName();
-      if (null != hostName) {
-        synchronized (this.reverseDomainNameResolver.rdnsLookupResults) {
-          this.reverseDomainNameResolver.rdnsLookupResults.put(
-              rdnsLookupJob, hostName);
-        }
-      }
-      List<String> verifiedHostNames = request.getVerifiedHostNames();
+      SortedSet<String> verifiedHostNames = request.getVerifiedHostNames();
       if (null != verifiedHostNames && !verifiedHostNames.isEmpty()) {
         synchronized (this.reverseDomainNameResolver
             .rdnsVerifiedLookupResults) {
@@ -54,7 +47,7 @@ class RdnsLookupWorker extends Thread {
               rdnsLookupJob, verifiedHostNames);
         }
       }
-      List<String> unverifiedHostNames = request.getUnverifiedHostNames();
+      SortedSet<String> unverifiedHostNames = request.getUnverifiedHostNames();
       if (null != unverifiedHostNames && !unverifiedHostNames.isEmpty()) {
         synchronized (this.reverseDomainNameResolver
             .rdnsUnverifiedLookupResults) {
diff --git a/src/main/java/org/torproject/onionoo/updater/ReverseDomainNameResolver.java b/src/main/java/org/torproject/onionoo/updater/ReverseDomainNameResolver.java
index 4022dab..d46d6b5 100644
--- a/src/main/java/org/torproject/onionoo/updater/ReverseDomainNameResolver.java
+++ b/src/main/java/org/torproject/onionoo/updater/ReverseDomainNameResolver.java
@@ -12,6 +12,7 @@ import java.util.HashSet;
 import java.util.List;
 import java.util.Map;
 import java.util.Set;
+import java.util.SortedSet;
 
 public class ReverseDomainNameResolver {
 
@@ -28,11 +29,9 @@ public class ReverseDomainNameResolver {
 
   Set<String> rdnsLookupJobs;
 
-  Map<String, String> rdnsLookupResults;
+  Map<String, SortedSet<String>> rdnsVerifiedLookupResults;
 
-  Map<String, List<String>> rdnsVerifiedLookupResults;
-
-  Map<String, List<String>> rdnsUnverifiedLookupResults;
+  Map<String, SortedSet<String>> rdnsUnverifiedLookupResults;
 
   List<Long> rdnsLookupMillis;
 
@@ -56,7 +55,6 @@ public class ReverseDomainNameResolver {
         this.rdnsLookupJobs.add(e.getKey());
       }
     }
-    this.rdnsLookupResults = new HashMap<>();
     this.rdnsVerifiedLookupResults = new HashMap<>();
     this.rdnsUnverifiedLookupResults = new HashMap<>();
     this.rdnsLookupMillis = new ArrayList<>();
@@ -82,22 +80,15 @@ public class ReverseDomainNameResolver {
     }
   }
 
-  /** Returns reverse domain name lookup results. */
-  public Map<String, String> getLookupResults() {
-    synchronized (this.rdnsLookupResults) {
-      return new HashMap<>(this.rdnsLookupResults);
-    }
-  }
-
   /** Returns reverse domain name verified lookup results. */
-  public Map<String, List<String>> getVerifiedLookupResults() {
+  public Map<String, SortedSet<String>> getVerifiedLookupResults() {
     synchronized (this.rdnsVerifiedLookupResults) {
       return new HashMap<>(this.rdnsVerifiedLookupResults);
     }
   }
 
   /** Returns reverse domain name unverified lookup results. */
-  public Map<String, List<String>> getUnverifiedLookupResults() {
+  public Map<String, SortedSet<String>> getUnverifiedLookupResults() {
     synchronized (this.rdnsUnverifiedLookupResults) {
       return new HashMap<>(this.rdnsUnverifiedLookupResults);
     }
diff --git a/src/main/java/org/torproject/onionoo/writer/DetailsDocumentWriter.java b/src/main/java/org/torproject/onionoo/writer/DetailsDocumentWriter.java
index 0162d0b..6519de5 100644
--- a/src/main/java/org/torproject/onionoo/writer/DetailsDocumentWriter.java
+++ b/src/main/java/org/torproject/onionoo/writer/DetailsDocumentWriter.java
@@ -75,7 +75,6 @@ public class DetailsDocumentWriter implements DocumentWriter {
     detailsDocument.setFlags(detailsStatus.getRelayFlags());
     detailsDocument.setConsensusWeight(
         detailsStatus.getConsensusWeight());
-    detailsDocument.setHostName(detailsStatus.getHostName());
     detailsDocument.setVerifiedHostNames(
         detailsStatus.getVerifiedHostNames());
     detailsDocument.setUnverifiedHostNames(
diff --git a/src/main/java/org/torproject/onionoo/writer/SummaryDocumentWriter.java b/src/main/java/org/torproject/onionoo/writer/SummaryDocumentWriter.java
index 2bcc102..5063026 100644
--- a/src/main/java/org/torproject/onionoo/writer/SummaryDocumentWriter.java
+++ b/src/main/java/org/torproject/onionoo/writer/SummaryDocumentWriter.java
@@ -94,15 +94,15 @@ public class SummaryDocumentWriter implements DocumentWriter {
       String nickname = nodeStatus.getNickname();
       String version = nodeStatus.getVersion();
       String operatingSystem = nodeStatus.getOperatingSystem();
-      String hostName = nodeStatus.getHostName();
-      List<String> verifiedHostNames = nodeStatus.getVerifiedHostNames();
-      List<String> unverifiedHostNames = nodeStatus.getUnverifiedHostNames();
+      SortedSet<String> verifiedHostNames = nodeStatus.getVerifiedHostNames();
+      SortedSet<String> unverifiedHostNames =
+          nodeStatus.getUnverifiedHostNames();
       Boolean recommendedVersion = nodeStatus.getRecommendedVersion();
       SummaryDocument summaryDocument = new SummaryDocument(isRelay,
           nickname, fingerprint, addresses, lastSeenMillis, running,
           relayFlags, consensusWeight, countryCode, firstSeenMillis,
           asNumber, asName, contact, declaredFamily, effectiveFamily, version,
-          operatingSystem, hostName, verifiedHostNames,
+          operatingSystem, verifiedHostNames,
           unverifiedHostNames, recommendedVersion);
       if (this.documentStore.store(summaryDocument, fingerprint)) {
         this.writtenDocuments++;
diff --git a/src/test/java/org/torproject/onionoo/docs/SummaryDocumentTest.java b/src/test/java/org/torproject/onionoo/docs/SummaryDocumentTest.java
index f81dc73..120a226 100644
--- a/src/test/java/org/torproject/onionoo/docs/SummaryDocumentTest.java
+++ b/src/test/java/org/torproject/onionoo/docs/SummaryDocumentTest.java
@@ -28,7 +28,7 @@ public class SummaryDocumentTest {
             "0025C136C1F3A9EEFE2AE3F918F03BFA21B5070B" })),
         new TreeSet<>(Arrays.asList(
         new String[] { "001C13B3A55A71B977CA65EC85539D79C653A3FC" })), null,
-        null, null, null, null, true);
+        null, null, null, true);
   }
 
   @Test()
diff --git a/src/test/java/org/torproject/onionoo/server/ResourceServletTest.java b/src/test/java/org/torproject/onionoo/server/ResourceServletTest.java
index e176d9b..923fb6e 100644
--- a/src/test/java/org/torproject/onionoo/server/ResourceServletTest.java
+++ b/src/test/java/org/torproject/onionoo/server/ResourceServletTest.java
@@ -147,9 +147,9 @@ public class ResourceServletTest {
             "0025C136C1F3A9EEFE2AE3F918F03BFA21B5070B" })),
         new TreeSet<>(Arrays.asList(
         new String[] { "001C13B3A55A71B977CA65EC85539D79C653A3FC" })),
-        "0.2.3.25", "linux", "ppp-62-216-201-221.dynamic.mnet-online.de",
-        Arrays.asList(
-            new String[] { "ppp-62-216-201-221.dynamic.mnet-online.de" }),
+        "0.2.3.25", "linux",
+        new TreeSet<>(Arrays.asList(
+            new String[] { "ppp-62-216-201-221.dynamic.mnet-online.de" })),
         null, true);
     this.relays.put("000C5F55BD4814B917CC474BD537F1A3B33CCE2A",
         relayTorkaZ);
@@ -166,9 +166,8 @@ public class ResourceServletTest {
             "000C5F55BD4814B917CC474BD537F1A3B33CCE2A" })),
         new TreeSet<>(Arrays.asList(new String[] {
             "000C5F55BD4814B917CC474BD537F1A3B33CCE2A" })), null, null,
-            "c-68-38-171-200.hsd1.in.comcast.net",
-        Arrays.asList(
-            new String[] {"c-68-38-171-200.hsd1.in.comcast.net"}),
+        new TreeSet<>(Arrays.asList(
+            new String[] {"c-68-38-171-200.hsd1.in.comcast.net"})),
         null, null);
     this.relays.put("001C13B3A55A71B977CA65EC85539D79C653A3FC",
         relayFerrari458);
@@ -184,7 +183,7 @@ public class ResourceServletTest {
         "1024d/51e2a1c7 \"steven j. murdoch\" "
         + "<tor+steven.murdoch at cl.cam.ac.uk> <fb-token:5sr_k_zs2wm=>",
         new TreeSet<String>(), new TreeSet<String>(), "0.2.3.24-rc-dev",
-        "windows xp", null, null, null, false);
+        "windows xp", null, null, false);
     this.relays.put("0025C136C1F3A9EEFE2AE3F918F03BFA21B5070B",
         relayTimMayTribute);
     this.bridges = new TreeMap<>();
@@ -195,7 +194,7 @@ public class ResourceServletTest {
         DateTimeHelper.parse("2013-04-21 18:07:03"), false,
         new TreeSet<>(Arrays.asList(new String[] { "Valid" })), -1L,
         null, DateTimeHelper.parse("2013-04-20 15:37:04"), null, null, null,
-        null, null, "0.2.2.39", null, null, null, null, true);
+        null, null, "0.2.2.39", null, null, null, true);
     this.bridges.put("0000831B236DFF73D409AD17B40E2A728A53994F",
         bridgeec2bridgercc7f31fe);
     org.torproject.onionoo.docs.SummaryDocument bridgeUnnamed =
@@ -205,7 +204,7 @@ public class ResourceServletTest {
         DateTimeHelper.parse("2013-04-20 17:37:04"), false,
         new TreeSet<>(Arrays.asList(new String[] { "Valid" })), -1L,
         null, DateTimeHelper.parse("2013-04-14 07:07:05"), null, null, null,
-        null, null, null, null, null, null, null, null);
+        null, null, null, null, null, null, null);
     this.bridges.put("0002D9BDBBC230BD9C78FF502A16E0033EF87E0C",
         bridgeUnnamed);
     org.torproject.onionoo.docs.SummaryDocument bridgegummy =
@@ -216,7 +215,7 @@ public class ResourceServletTest {
         new TreeSet<>(Arrays.asList(new String[] { "Running",
             "Valid" })), -1L, null,
         DateTimeHelper.parse("2013-01-16 21:07:04"), null, null, null, null,
-        null, "0.2.4.4-alpha-dev", "windows 7", null, null, null, false);
+        null, "0.2.4.4-alpha-dev", "windows 7", null, null, false);
     this.bridges.put("1FEDE50ED8DBA1DD9F9165F78C8131E4A44AB756",
         bridgegummy);
   }
diff --git a/src/test/java/org/torproject/onionoo/server/SummaryDocumentComparatorTest.java b/src/test/java/org/torproject/onionoo/server/SummaryDocumentComparatorTest.java
index c79565a..c87fa42 100644
--- a/src/test/java/org/torproject/onionoo/server/SummaryDocumentComparatorTest.java
+++ b/src/test/java/org/torproject/onionoo/server/SummaryDocumentComparatorTest.java
@@ -42,7 +42,7 @@ public class SummaryDocumentComparatorTest {
             "0025C136C1F3A9EEFE2AE3F918F03BFA21B5070B" })),
         new TreeSet<>(Arrays.asList(
         new String[] { "001C13B3A55A71B977CA65EC85539D79C653A3FC" })), null,
-        null, null, null, null, null);
+        null, null, null, null);
   }
 
   /** Some values for running all comparison types. */





More information about the tor-commits mailing list