[tor-commits] [onionoo/master] Avoid passing around formatted timestamps if feasible.
karsten at torproject.org
karsten at torproject.org
Sun Aug 17 07:06:45 UTC 2014
commit 29109e2b8136234ba36b3c5f6b1e4418e5cc794a
Author: Karsten Loesing <karsten.loesing at gmx.net>
Date: Fri Aug 15 10:07:31 2014 +0200
Avoid passing around formatted timestamps if feasible.
Implements part of #12866.
---
.../onionoo/docs/ClientsGraphHistory.java | 18 ++++++-----
.../torproject/onionoo/docs/DetailsDocument.java | 34 +++++++++++---------
.../org/torproject/onionoo/docs/DetailsStatus.java | 17 +++++-----
.../org/torproject/onionoo/docs/GraphHistory.java | 18 ++++++-----
.../org/torproject/onionoo/server/NodeIndex.java | 11 ++++---
.../org/torproject/onionoo/server/NodeIndexer.java | 6 ++--
.../onionoo/updater/NodeDetailsStatusUpdater.java | 32 +++++++-----------
.../onionoo/writer/BandwidthDocumentWriter.java | 4 +--
.../onionoo/writer/ClientsDocumentWriter.java | 4 +--
.../onionoo/writer/DetailsDocumentWriter.java | 14 +++-----
.../onionoo/writer/UptimeDocumentWriter.java | 4 +--
.../onionoo/writer/WeightsDocumentWriter.java | 4 +--
.../onionoo/UptimeDocumentWriterTest.java | 8 ++---
13 files changed, 85 insertions(+), 89 deletions(-)
diff --git a/src/main/java/org/torproject/onionoo/docs/ClientsGraphHistory.java b/src/main/java/org/torproject/onionoo/docs/ClientsGraphHistory.java
index e1db663..00d11a0 100644
--- a/src/main/java/org/torproject/onionoo/docs/ClientsGraphHistory.java
+++ b/src/main/java/org/torproject/onionoo/docs/ClientsGraphHistory.java
@@ -6,22 +6,24 @@ import java.util.ArrayList;
import java.util.List;
import java.util.SortedMap;
+import org.torproject.onionoo.util.DateTimeHelper;
+
public class ClientsGraphHistory {
private String first;
- public void setFirst(String first) {
- this.first = first;
+ public void setFirst(long first) {
+ this.first = DateTimeHelper.format(first);
}
- public String getFirst() {
- return this.first;
+ public long getFirst() {
+ return DateTimeHelper.parse(this.first);
}
private String last;
- public void setLast(String last) {
- this.last = last;
+ public void setLast(long last) {
+ this.last = DateTimeHelper.format(last);
}
- public String getLast() {
- return this.last;
+ public long getLast() {
+ return DateTimeHelper.parse(this.last);
}
private Integer interval;
diff --git a/src/main/java/org/torproject/onionoo/docs/DetailsDocument.java b/src/main/java/org/torproject/onionoo/docs/DetailsDocument.java
index 142b591..9196153 100644
--- a/src/main/java/org/torproject/onionoo/docs/DetailsDocument.java
+++ b/src/main/java/org/torproject/onionoo/docs/DetailsDocument.java
@@ -6,6 +6,7 @@ import java.util.List;
import java.util.Map;
import org.apache.commons.lang.StringEscapeUtils;
+import org.torproject.onionoo.util.DateTimeHelper;
public class DetailsDocument extends Document {
@@ -75,28 +76,29 @@ public class DetailsDocument extends Document {
}
private String last_seen;
- public void setLastSeen(String lastSeen) {
- this.last_seen = lastSeen;
+ public void setLastSeen(long lastSeen) {
+ this.last_seen = DateTimeHelper.format(lastSeen);
}
- public String getLastSeen() {
- return this.last_seen;
+ public long getLastSeen() {
+ return DateTimeHelper.parse(this.last_seen);
}
private String last_changed_address_or_port;
public void setLastChangedAddressOrPort(
- String lastChangedAddressOrPort) {
- this.last_changed_address_or_port = lastChangedAddressOrPort;
+ long lastChangedAddressOrPort) {
+ this.last_changed_address_or_port = DateTimeHelper.format(
+ lastChangedAddressOrPort);
}
- public String getLastChangedAddressOrPort() {
- return this.last_changed_address_or_port;
+ public long getLastChangedAddressOrPort() {
+ return DateTimeHelper.parse(this.last_changed_address_or_port);
}
private String first_seen;
- public void setFirstSeen(String firstSeen) {
- this.first_seen = firstSeen;
+ public void setFirstSeen(long firstSeen) {
+ this.first_seen = DateTimeHelper.format(firstSeen);
}
- public String getFirstSeen() {
- return this.first_seen;
+ public long getFirstSeen() {
+ return DateTimeHelper.parse(this.first_seen);
}
private Boolean running;
@@ -196,11 +198,11 @@ public class DetailsDocument extends Document {
}
private String last_restarted;
- public void setLastRestarted(String lastRestarted) {
- this.last_restarted = lastRestarted;
+ public void setLastRestarted(long lastRestarted) {
+ this.last_restarted = DateTimeHelper.format(lastRestarted);
}
- public String getLastRestarted() {
- return this.last_restarted;
+ public long getLastRestarted() {
+ return DateTimeHelper.parse(this.last_restarted);
}
private Integer bandwidth_rate;
diff --git a/src/main/java/org/torproject/onionoo/docs/DetailsStatus.java b/src/main/java/org/torproject/onionoo/docs/DetailsStatus.java
index a19b4b9..77ab269 100644
--- a/src/main/java/org/torproject/onionoo/docs/DetailsStatus.java
+++ b/src/main/java/org/torproject/onionoo/docs/DetailsStatus.java
@@ -6,6 +6,7 @@ import java.util.List;
import java.util.Map;
import org.apache.commons.lang.StringEscapeUtils;
+import org.torproject.onionoo.util.DateTimeHelper;
public class DetailsStatus extends Document {
@@ -27,19 +28,19 @@ public class DetailsStatus extends Document {
}
private String desc_published;
- public void setDescPublished(String descPublished) {
- this.desc_published = descPublished;
+ public void setDescPublished(long descPublished) {
+ this.desc_published = DateTimeHelper.format(descPublished);
}
- public String getDescPublished() {
- return this.desc_published;
+ public long getDescPublished() {
+ return DateTimeHelper.parse(this.desc_published);
}
private String last_restarted;
- public void setLastRestarted(String lastRestarted) {
- this.last_restarted = lastRestarted;
+ public void setLastRestarted(long lastRestarted) {
+ this.last_restarted = DateTimeHelper.format(lastRestarted);
}
- public String getLastRestarted() {
- return this.last_restarted;
+ public long getLastRestarted() {
+ return DateTimeHelper.parse(this.last_restarted);
}
private Integer bandwidth_rate;
diff --git a/src/main/java/org/torproject/onionoo/docs/GraphHistory.java b/src/main/java/org/torproject/onionoo/docs/GraphHistory.java
index 19ace31..10941db 100644
--- a/src/main/java/org/torproject/onionoo/docs/GraphHistory.java
+++ b/src/main/java/org/torproject/onionoo/docs/GraphHistory.java
@@ -4,22 +4,24 @@ package org.torproject.onionoo.docs;
import java.util.List;
+import org.torproject.onionoo.util.DateTimeHelper;
+
public class GraphHistory {
private String first;
- public void setFirst(String first) {
- this.first = first;
+ public void setFirst(long first) {
+ this.first = DateTimeHelper.format(first);
}
- public String getFirst() {
- return this.first;
+ public long getFirst() {
+ return DateTimeHelper.parse(this.first);
}
private String last;
- public void setLast(String last) {
- this.last = last;
+ public void setLast(long last) {
+ this.last = DateTimeHelper.format(last);
}
- public String getLast() {
- return this.last;
+ public long getLast() {
+ return DateTimeHelper.parse(this.last);
}
private Integer interval;
diff --git a/src/main/java/org/torproject/onionoo/server/NodeIndex.java b/src/main/java/org/torproject/onionoo/server/NodeIndex.java
index 7b95d2e..f2859a5 100644
--- a/src/main/java/org/torproject/onionoo/server/NodeIndex.java
+++ b/src/main/java/org/torproject/onionoo/server/NodeIndex.java
@@ -6,20 +6,23 @@ import java.util.Set;
import java.util.SortedMap;
import org.torproject.onionoo.docs.SummaryDocument;
+import org.torproject.onionoo.util.DateTimeHelper;
class NodeIndex {
private String relaysPublishedString;
- public void setRelaysPublishedString(String relaysPublishedString) {
- this.relaysPublishedString = relaysPublishedString;
+ public void setRelaysPublishedMillis(long relaysPublishedMillis) {
+ this.relaysPublishedString =
+ DateTimeHelper.format(relaysPublishedMillis);
}
public String getRelaysPublishedString() {
return relaysPublishedString;
}
private String bridgesPublishedString;
- public void setBridgesPublishedString(String bridgesPublishedString) {
- this.bridgesPublishedString = bridgesPublishedString;
+ public void setBridgesPublishedMillis(long bridgesPublishedMillis) {
+ this.bridgesPublishedString =
+ DateTimeHelper.format(bridgesPublishedMillis);
}
public String getBridgesPublishedString() {
return bridgesPublishedString;
diff --git a/src/main/java/org/torproject/onionoo/server/NodeIndexer.java b/src/main/java/org/torproject/onionoo/server/NodeIndexer.java
index f72d322..1cbd75e 100644
--- a/src/main/java/org/torproject/onionoo/server/NodeIndexer.java
+++ b/src/main/java/org/torproject/onionoo/server/NodeIndexer.java
@@ -286,10 +286,8 @@ public class NodeIndexer implements ServletContextListener, Runnable {
newNodeIndex.setRelaysByLastSeenDays(newRelaysByLastSeenDays);
newNodeIndex.setBridgesByFirstSeenDays(newBridgesByFirstSeenDays);
newNodeIndex.setBridgesByLastSeenDays(newBridgesByLastSeenDays);
- newNodeIndex.setRelaysPublishedString(DateTimeHelper.format(
- relaysLastValidAfterMillis));
- newNodeIndex.setBridgesPublishedString(DateTimeHelper.format(
- bridgesLastPublishedMillis));
+ newNodeIndex.setRelaysPublishedMillis(relaysLastValidAfterMillis);
+ newNodeIndex.setBridgesPublishedMillis(bridgesLastPublishedMillis);
synchronized (this) {
this.lastIndexed = updateStatusMillis;
this.latestNodeIndex = newNodeIndex;
diff --git a/src/main/java/org/torproject/onionoo/updater/NodeDetailsStatusUpdater.java b/src/main/java/org/torproject/onionoo/updater/NodeDetailsStatusUpdater.java
index 979c49b..827c890 100644
--- a/src/main/java/org/torproject/onionoo/updater/NodeDetailsStatusUpdater.java
+++ b/src/main/java/org/torproject/onionoo/updater/NodeDetailsStatusUpdater.java
@@ -105,25 +105,21 @@ public class NodeDetailsStatusUpdater implements DescriptorListener,
String fingerprint = descriptor.getFingerprint();
DetailsStatus detailsStatus = this.documentStore.retrieve(
DetailsStatus.class, true, fingerprint);
- String publishedDateTime =
- DateTimeHelper.format(descriptor.getPublishedMillis());
if (detailsStatus == null) {
detailsStatus = new DetailsStatus();
- } else if (detailsStatus.getDescPublished() != null &&
- publishedDateTime.compareTo(
- detailsStatus.getDescPublished()) <= 0) {
+ } else if (descriptor.getPublishedMillis() >
+ detailsStatus.getDescPublished()) {
return;
}
- String lastRestartedString = DateTimeHelper.format(
- descriptor.getPublishedMillis() - descriptor.getUptime()
- * DateTimeHelper.ONE_SECOND);
+ long lastRestartedMillis = descriptor.getPublishedMillis()
+ - descriptor.getUptime() * DateTimeHelper.ONE_SECOND;
int bandwidthRate = descriptor.getBandwidthRate();
int bandwidthBurst = descriptor.getBandwidthBurst();
int observedBandwidth = descriptor.getBandwidthObserved();
int advertisedBandwidth = Math.min(bandwidthRate,
Math.min(bandwidthBurst, observedBandwidth));
- detailsStatus.setDescPublished(publishedDateTime);
- detailsStatus.setLastRestarted(lastRestartedString);
+ detailsStatus.setDescPublished(descriptor.getPublishedMillis());
+ detailsStatus.setLastRestarted(lastRestartedMillis);
detailsStatus.setBandwidthRate(bandwidthRate);
detailsStatus.setBandwidthBurst(bandwidthBurst);
detailsStatus.setObservedBandwidth(observedBandwidth);
@@ -227,23 +223,19 @@ public class NodeDetailsStatusUpdater implements DescriptorListener,
String fingerprint = descriptor.getFingerprint();
DetailsStatus detailsStatus = this.documentStore.retrieve(
DetailsStatus.class, true, fingerprint);
- String publishedDateTime =
- DateTimeHelper.format(descriptor.getPublishedMillis());
if (detailsStatus == null) {
detailsStatus = new DetailsStatus();
- } else if (detailsStatus.getDescPublished() != null &&
- publishedDateTime.compareTo(
- detailsStatus.getDescPublished()) <= 0) {
+ } else if (detailsStatus.getDescPublished() >
+ descriptor.getPublishedMillis()) {
return;
}
- String lastRestartedString = DateTimeHelper.format(
- descriptor.getPublishedMillis() - descriptor.getUptime()
- * DateTimeHelper.ONE_SECOND);
+ long lastRestartedMillis = descriptor.getPublishedMillis()
+ - descriptor.getUptime() * DateTimeHelper.ONE_SECOND;
int advertisedBandwidth = Math.min(descriptor.getBandwidthRate(),
Math.min(descriptor.getBandwidthBurst(),
descriptor.getBandwidthObserved()));
- detailsStatus.setDescPublished(publishedDateTime);
- detailsStatus.setLastRestarted(lastRestartedString);
+ detailsStatus.setDescPublished(descriptor.getPublishedMillis());
+ detailsStatus.setLastRestarted(lastRestartedMillis);
detailsStatus.setAdvertisedBandwidth(advertisedBandwidth);
detailsStatus.setPlatform(descriptor.getPlatform());
this.documentStore.store(detailsStatus, fingerprint);
diff --git a/src/main/java/org/torproject/onionoo/writer/BandwidthDocumentWriter.java b/src/main/java/org/torproject/onionoo/writer/BandwidthDocumentWriter.java
index c5ae22e..5ce467c 100644
--- a/src/main/java/org/torproject/onionoo/writer/BandwidthDocumentWriter.java
+++ b/src/main/java/org/torproject/onionoo/writer/BandwidthDocumentWriter.java
@@ -168,8 +168,8 @@ public class BandwidthDocumentWriter implements FingerprintListener,
double factor = ((double) maxValue) / 999.0;
int count = lastNonNullIndex - firstNonNullIndex + 1;
GraphHistory graphHistory = new GraphHistory();
- graphHistory.setFirst(DateTimeHelper.format(firstDataPointMillis));
- graphHistory.setLast(DateTimeHelper.format(lastDataPointMillis));
+ graphHistory.setFirst(firstDataPointMillis);
+ graphHistory.setLast(lastDataPointMillis);
graphHistory.setInterval((int) (dataPointInterval
/ DateTimeHelper.ONE_SECOND));
graphHistory.setFactor(factor);
diff --git a/src/main/java/org/torproject/onionoo/writer/ClientsDocumentWriter.java b/src/main/java/org/torproject/onionoo/writer/ClientsDocumentWriter.java
index ae64f86..6684db7 100644
--- a/src/main/java/org/torproject/onionoo/writer/ClientsDocumentWriter.java
+++ b/src/main/java/org/torproject/onionoo/writer/ClientsDocumentWriter.java
@@ -227,8 +227,8 @@ public class ClientsDocumentWriter implements FingerprintListener,
double factor = ((double) maxValue) / 999.0;
int count = lastNonNullIndex - firstNonNullIndex + 1;
ClientsGraphHistory graphHistory = new ClientsGraphHistory();
- graphHistory.setFirst(DateTimeHelper.format(firstDataPointMillis));
- graphHistory.setLast(DateTimeHelper.format(lastDataPointMillis));
+ graphHistory.setFirst(firstDataPointMillis);
+ graphHistory.setLast(lastDataPointMillis);
graphHistory.setInterval((int) (dataPointInterval
/ DateTimeHelper.ONE_SECOND));
graphHistory.setFactor(factor);
diff --git a/src/main/java/org/torproject/onionoo/writer/DetailsDocumentWriter.java b/src/main/java/org/torproject/onionoo/writer/DetailsDocumentWriter.java
index 8e2cb9f..8d69079 100644
--- a/src/main/java/org/torproject/onionoo/writer/DetailsDocumentWriter.java
+++ b/src/main/java/org/torproject/onionoo/writer/DetailsDocumentWriter.java
@@ -92,12 +92,10 @@ public class DetailsDocumentWriter implements FingerprintListener,
detailsDocument.setDirAddress(entry.getAddress() + ":"
+ entry.getDirPort());
}
- detailsDocument.setLastSeen(DateTimeHelper.format(
- entry.getLastSeenMillis()));
- detailsDocument.setFirstSeen(DateTimeHelper.format(
- entry.getFirstSeenMillis()));
+ detailsDocument.setLastSeen(entry.getLastSeenMillis());
+ detailsDocument.setFirstSeen(entry.getFirstSeenMillis());
detailsDocument.setLastChangedAddressOrPort(
- DateTimeHelper.format(entry.getLastChangedOrAddress()));
+ entry.getLastChangedOrAddress());
detailsDocument.setRunning(entry.getRunning());
if (!entry.getRelayFlags().isEmpty()) {
detailsDocument.setFlags(new ArrayList<String>(
@@ -202,10 +200,8 @@ public class DetailsDocumentWriter implements FingerprintListener,
orAddresses.add(orAddress.toLowerCase());
}
detailsDocument.setOrAddresses(orAddresses);
- detailsDocument.setLastSeen(DateTimeHelper.format(
- entry.getLastSeenMillis()));
- detailsDocument.setFirstSeen(DateTimeHelper.format(
- entry.getFirstSeenMillis()));
+ detailsDocument.setLastSeen(entry.getLastSeenMillis());
+ detailsDocument.setFirstSeen(entry.getFirstSeenMillis());
detailsDocument.setRunning(entry.getRunning());
detailsDocument.setFlags(new ArrayList<String>(
entry.getRelayFlags()));
diff --git a/src/main/java/org/torproject/onionoo/writer/UptimeDocumentWriter.java b/src/main/java/org/torproject/onionoo/writer/UptimeDocumentWriter.java
index f58ec93..71f4d9a 100644
--- a/src/main/java/org/torproject/onionoo/writer/UptimeDocumentWriter.java
+++ b/src/main/java/org/torproject/onionoo/writer/UptimeDocumentWriter.java
@@ -267,8 +267,8 @@ public class UptimeDocumentWriter implements FingerprintListener,
+ (lastNonNullIndex - firstNonNullIndex) * dataPointInterval;
int count = lastNonNullIndex - firstNonNullIndex + 1;
GraphHistory graphHistory = new GraphHistory();
- graphHistory.setFirst(DateTimeHelper.format(firstDataPointMillis));
- graphHistory.setLast(DateTimeHelper.format(lastDataPointMillis));
+ graphHistory.setFirst(firstDataPointMillis);
+ graphHistory.setLast(lastDataPointMillis);
graphHistory.setInterval((int) (dataPointInterval
/ DateTimeHelper.ONE_SECOND));
graphHistory.setFactor(1.0 / 999.0);
diff --git a/src/main/java/org/torproject/onionoo/writer/WeightsDocumentWriter.java b/src/main/java/org/torproject/onionoo/writer/WeightsDocumentWriter.java
index e0601c1..cfb410c 100644
--- a/src/main/java/org/torproject/onionoo/writer/WeightsDocumentWriter.java
+++ b/src/main/java/org/torproject/onionoo/writer/WeightsDocumentWriter.java
@@ -199,8 +199,8 @@ public class WeightsDocumentWriter implements FingerprintListener,
double factor = ((double) maxValue) / 999.0;
int count = lastNonNullIndex - firstNonNullIndex + 1;
GraphHistory graphHistory = new GraphHistory();
- graphHistory.setFirst(DateTimeHelper.format(firstDataPointMillis));
- graphHistory.setLast(DateTimeHelper.format(lastDataPointMillis));
+ graphHistory.setFirst(firstDataPointMillis);
+ graphHistory.setLast(lastDataPointMillis);
graphHistory.setInterval((int) (dataPointInterval
/ DateTimeHelper.ONE_SECOND));
graphHistory.setFactor(factor);
diff --git a/src/test/java/org/torproject/onionoo/UptimeDocumentWriterTest.java b/src/test/java/org/torproject/onionoo/UptimeDocumentWriterTest.java
index f430c0b..afae0e8 100644
--- a/src/test/java/org/torproject/onionoo/UptimeDocumentWriterTest.java
+++ b/src/test/java/org/torproject/onionoo/UptimeDocumentWriterTest.java
@@ -97,10 +97,10 @@ public class UptimeDocumentWriterTest {
assertTrue("Should contain a graph for " + graphName + ".",
document.getUptime().containsKey(graphName));
GraphHistory history = document.getUptime().get(graphName);
- assertEquals("First data point should be " + first + ".", first,
- history.getFirst());
- assertEquals("Last data point should be " + last + ".", last,
- history.getLast());
+ assertEquals("First data point should be " + first + ".",
+ DateTimeHelper.parse(first), history.getFirst());
+ assertEquals("Last data point should be " + last + ".",
+ DateTimeHelper.parse(last), history.getLast());
assertEquals("Interval should be " + interval + " seconds.", interval,
(int) history.getInterval());
assertEquals("Factor should be 1.0 / 999.0.", 1.0 / 999.0,
More information about the tor-commits
mailing list