commit f737faa109ab527a5bfa2ded72bffd1d3063f2fc Author: Karsten Loesing karsten.loesing@gmx.net Date: Fri Jan 6 15:37:24 2017 +0100
Fix invalid first_seen timestamps on bridges.
Fix a bug where we'd believe that we have first seen a bridge on January 1, 1970 when in fact we have never seen it in a bridge network status and only learned about it from its self-published bridge server descriptor.
Fixes #20994. --- CHANGELOG.md | 6 ++++ .../onionoo/updater/NodeDetailsStatusUpdater.java | 33 ++-------------------- 2 files changed, 9 insertions(+), 30 deletions(-)
diff --git a/CHANGELOG.md b/CHANGELOG.md index 8eba2fa..c8ab3e1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,11 @@ # Changes in version x.x.x - 2017-xx-xx
+ * Major changes + - Fix a bug where we'd believe that we have first seen a bridge on + January 1, 1970 when in fact we have never seen it in a bridge + network status and only learned about it from its self-published + bridge server descriptor. + * Medium changes - Unify the build process by adding git-submodule metrics-base in src/build and removing all centralized parts of the build diff --git a/src/main/java/org/torproject/onionoo/updater/NodeDetailsStatusUpdater.java b/src/main/java/org/torproject/onionoo/updater/NodeDetailsStatusUpdater.java index a66aba8..d0e4529 100644 --- a/src/main/java/org/torproject/onionoo/updater/NodeDetailsStatusUpdater.java +++ b/src/main/java/org/torproject/onionoo/updater/NodeDetailsStatusUpdater.java @@ -126,8 +126,6 @@ public class NodeDetailsStatusUpdater implements DescriptorListener,
/* Step 1: parse descriptors. */
- private SortedSet<String> updatedNodes = new TreeSet<String>(); - @Override public void processDescriptor(Descriptor descriptor, boolean relay) { if (descriptor instanceof ServerDescriptor && relay) { @@ -335,7 +333,6 @@ public class NodeDetailsStatusUpdater implements DescriptorListener, detailsStatus.setAdvertisedBandwidth(advertisedBandwidth); detailsStatus.setPlatform(descriptor.getPlatform()); this.documentStore.store(detailsStatus, fingerprint); - this.updatedNodes.add(fingerprint); }
private void processBridgeExtraInfoDescriptor( @@ -352,7 +349,6 @@ public class NodeDetailsStatusUpdater implements DescriptorListener, descriptor.getPublishedMillis()); detailsStatus.setTransports(descriptor.getTransports()); this.documentStore.store(detailsStatus, fingerprint); - this.updatedNodes.add(fingerprint); } }
@@ -446,7 +442,6 @@ public class NodeDetailsStatusUpdater implements DescriptorListener, for (Map.Entry<String, NodeStatus> e : this.knownNodes.entrySet()) { String fingerprint = e.getKey(); NodeStatus nodeStatus = e.getValue(); - this.updatedNodes.add(fingerprint); if (nodeStatus.isRelay() && nodeStatus.getLastSeenMillis() >= cutoff) { this.currentRelays.add(fingerprint); @@ -510,15 +505,6 @@ public class NodeDetailsStatusUpdater implements DescriptorListener, } else { updatedNodeStatus = nodeStatus; this.knownNodes.put(fingerprint, nodeStatus); - if (nodeStatus.getLastSeenMillis() == (nodeStatus.isRelay() - ? previousRelaysLastValidAfterMillis - : previousBridgesLastValidAfterMillis)) { - /* This relay or bridge was previously running, but we didn't - * parse any descriptors with its fingerprint. Make sure to - * update its details status file later on, so it has the - * correct running bit. */ - this.updatedNodes.add(fingerprint); - } } if (updatedNodeStatus.isRelay() && updatedNodeStatus.getLastSeenMillis() >= cutoff) { @@ -581,7 +567,6 @@ public class NodeDetailsStatusUpdater implements DescriptorListener, nodeStatus.getAddress()); if (lookupResult != null) { this.geoIpLookupResults.put(fingerprint, lookupResult); - this.updatedNodes.add(fingerprint); } } } @@ -683,22 +668,18 @@ public class NodeDetailsStatusUpdater implements DescriptorListener, if (consensusWeights.containsKey(fingerprint)) { this.consensusWeightFractions.put(fingerprint, (float) (consensusWeights.get(fingerprint) / totalConsensusWeight)); - this.updatedNodes.add(fingerprint); } if (guardWeights.containsKey(fingerprint)) { this.guardProbabilities.put(fingerprint, (float) (guardWeights.get(fingerprint) / totalGuardWeight)); - this.updatedNodes.add(fingerprint); } if (middleWeights.containsKey(fingerprint)) { this.middleProbabilities.put(fingerprint, (float) (middleWeights.get(fingerprint) / totalMiddleWeight)); - this.updatedNodes.add(fingerprint); } if (exitWeights.containsKey(fingerprint)) { this.exitProbabilities.put(fingerprint, (float) (exitWeights.get(fingerprint) / totalExitWeight)); - this.updatedNodes.add(fingerprint); } } } @@ -766,21 +747,16 @@ public class NodeDetailsStatusUpdater implements DescriptorListener, } for (String fingerprint : this.currentRelays) { NodeStatus nodeStatus = this.knownNodes.get(fingerprint); - if (nodeStatus == null) { - continue; - } if (effectiveFamilies.containsKey(fingerprint) || extendedFamilies.containsKey(fingerprint)) { nodeStatus.setEffectiveFamily(effectiveFamilies.get(fingerprint)); nodeStatus.setExtendedFamily(extendedFamilies.get(fingerprint)); - this.updatedNodes.add(fingerprint); } else if ((nodeStatus.getEffectiveFamily() != null && !nodeStatus.getEffectiveFamily().isEmpty()) || (nodeStatus.getIndirectFamily() != null && !nodeStatus.getIndirectFamily().isEmpty())) { nodeStatus.setEffectiveFamily(null); nodeStatus.setExtendedFamily(null); - this.updatedNodes.add(fingerprint); } } } @@ -801,7 +777,6 @@ public class NodeDetailsStatusUpdater implements DescriptorListener, String hostName = lookupResults.get(nodeStatus.getAddress()); if (hostName != null) { this.rdnsLookupResults.put(fingerprint, hostName); - this.updatedNodes.add(fingerprint); } } } @@ -809,11 +784,9 @@ public class NodeDetailsStatusUpdater implements DescriptorListener, /* Step 4: update details statuses and then node statuses. */
private void updateNodeDetailsStatuses() { - for (String fingerprint : this.updatedNodes) { - NodeStatus nodeStatus = this.knownNodes.get(fingerprint); - if (nodeStatus == null) { - nodeStatus = new NodeStatus(fingerprint); - } + for (Map.Entry<String, NodeStatus> entry : this.knownNodes.entrySet()) { + String fingerprint = entry.getKey(); + NodeStatus nodeStatus = entry.getValue(); DetailsStatus detailsStatus = this.documentStore.retrieve( DetailsStatus.class, true, fingerprint); if (detailsStatus == null) {