commit 557c2ccfd7e09d9deef836cc993a6db92a5c2ae7
Author: Karsten Loesing <karsten.loesing(a)gmx.net>
Date: Tue Jun 17 13:57:15 2014 +0200
Always accept [SP|TAB]+ as delimiter instead of just SP.
Better fix for #12403.
---
.../descriptor/impl/BandwidthHistoryImpl.java | 5 -----
.../descriptor/impl/BridgeNetworkStatusImpl.java | 2 +-
.../descriptor/impl/BridgePoolAssignmentImpl.java | 4 ++--
.../torproject/descriptor/impl/DirSourceEntryImpl.java | 4 ++--
.../descriptor/impl/DirectoryKeyCertificateImpl.java | 2 +-
.../descriptor/impl/ExtraInfoDescriptorImpl.java | 15 +++------------
.../torproject/descriptor/impl/MicrodescriptorImpl.java | 2 +-
.../descriptor/impl/NetworkStatusEntryImpl.java | 6 +++---
.../torproject/descriptor/impl/RelayDirectoryImpl.java | 11 ++++++-----
.../impl/RelayNetworkStatusConsensusImpl.java | 4 ++--
.../descriptor/impl/RelayNetworkStatusImpl.java | 4 ++--
.../descriptor/impl/RelayNetworkStatusVoteImpl.java | 2 +-
.../descriptor/impl/ServerDescriptorImpl.java | 15 +++------------
.../descriptor/impl/ExtraInfoDescriptorImplTest.java | 4 ++--
14 files changed, 29 insertions(+), 51 deletions(-)
diff --git a/src/org/torproject/descriptor/impl/BandwidthHistoryImpl.java b/src/org/torproject/descriptor/impl/BandwidthHistoryImpl.java
index 00953c0..1ceae54 100644
--- a/src/org/torproject/descriptor/impl/BandwidthHistoryImpl.java
+++ b/src/org/torproject/descriptor/impl/BandwidthHistoryImpl.java
@@ -13,11 +13,6 @@ public class BandwidthHistoryImpl implements BandwidthHistory {
String[] partsNoOpt) throws DescriptorParseException {
boolean isValid = false;
this.line = line;
- if (lineNoOpt.startsWith("read-history ")) {
- lineNoOpt = "read-history "
- + lineNoOpt.substring("read-history ".length());
- partsNoOpt = lineNoOpt.split(" ");
- }
if (partsNoOpt.length == 5 || partsNoOpt.length == 6) {
try {
this.historyEndMillis = ParseHelper.parseTimestampAtIndex(line,
diff --git a/src/org/torproject/descriptor/impl/BridgeNetworkStatusImpl.java b/src/org/torproject/descriptor/impl/BridgeNetworkStatusImpl.java
index 581c6e5..a63d52a 100644
--- a/src/org/torproject/descriptor/impl/BridgeNetworkStatusImpl.java
+++ b/src/org/torproject/descriptor/impl/BridgeNetworkStatusImpl.java
@@ -54,7 +54,7 @@ public class BridgeNetworkStatusImpl extends NetworkStatusImpl
Scanner s = new Scanner(new String(headerBytes)).useDelimiter("\n");
while (s.hasNext()) {
String line = s.next();
- String[] parts = line.split(" ");
+ String[] parts = line.split("[ \t]+");
String keyword = parts[0];
if (keyword.equals("published")) {
this.parsePublishedLine(line, parts);
diff --git a/src/org/torproject/descriptor/impl/BridgePoolAssignmentImpl.java b/src/org/torproject/descriptor/impl/BridgePoolAssignmentImpl.java
index 8ca4ea6..c959602 100644
--- a/src/org/torproject/descriptor/impl/BridgePoolAssignmentImpl.java
+++ b/src/org/torproject/descriptor/impl/BridgePoolAssignmentImpl.java
@@ -62,7 +62,7 @@ public class BridgePoolAssignmentImpl extends DescriptorImpl
private void parseBridgePoolAssignmentLine(String line)
throws DescriptorParseException {
- String[] parts = line.split(" ");
+ String[] parts = line.split("[ \t]+");
if (parts.length != 3) {
throw new DescriptorParseException("Illegal line '" + line
+ "' in bridge pool assignment.");
@@ -73,7 +73,7 @@ public class BridgePoolAssignmentImpl extends DescriptorImpl
private void parseBridgeLine(String line)
throws DescriptorParseException {
- String[] parts = line.split(" ");
+ String[] parts = line.split("[ \t]+");
if (parts.length < 2) {
throw new DescriptorParseException("Illegal line '" + line
+ "' in bridge pool assignment.");
diff --git a/src/org/torproject/descriptor/impl/DirSourceEntryImpl.java b/src/org/torproject/descriptor/impl/DirSourceEntryImpl.java
index be915f9..bd97948 100644
--- a/src/org/torproject/descriptor/impl/DirSourceEntryImpl.java
+++ b/src/org/torproject/descriptor/impl/DirSourceEntryImpl.java
@@ -104,7 +104,7 @@ public class DirSourceEntryImpl implements DirSourceEntry {
private void parseDirSourceLine(String line)
throws DescriptorParseException {
this.parsedExactlyOnceKeyword("dir-source");
- String[] parts = line.split(" ");
+ String[] parts = line.split("[ \t]+");
if (parts.length != 7) {
throw new DescriptorParseException("Invalid line '" + line + "'.");
}
@@ -135,7 +135,7 @@ public class DirSourceEntryImpl implements DirSourceEntry {
private void parseVoteDigestLine(String line)
throws DescriptorParseException {
this.parsedExactlyOnceKeyword("vote-digest");
- String[] parts = line.split(" ");
+ String[] parts = line.split("[ \t]+");
if (parts.length != 2) {
throw new DescriptorParseException("Invalid line '" + line + "'.");
}
diff --git a/src/org/torproject/descriptor/impl/DirectoryKeyCertificateImpl.java b/src/org/torproject/descriptor/impl/DirectoryKeyCertificateImpl.java
index 59846df..8ef1bd7 100644
--- a/src/org/torproject/descriptor/impl/DirectoryKeyCertificateImpl.java
+++ b/src/org/torproject/descriptor/impl/DirectoryKeyCertificateImpl.java
@@ -61,7 +61,7 @@ public class DirectoryKeyCertificateImpl extends DescriptorImpl
StringBuilder crypto = null;
while (s.hasNext()) {
String line = s.next();
- String[] parts = line.split(" ");
+ String[] parts = line.split("[ \t]+");
String keyword = parts[0];
if (keyword.equals("dir-key-certificate-version")) {
this.parseDirKeyCertificateVersionLine(line, parts);
diff --git a/src/org/torproject/descriptor/impl/ExtraInfoDescriptorImpl.java b/src/org/torproject/descriptor/impl/ExtraInfoDescriptorImpl.java
index 5951da0..68cb850 100644
--- a/src/org/torproject/descriptor/impl/ExtraInfoDescriptorImpl.java
+++ b/src/org/torproject/descriptor/impl/ExtraInfoDescriptorImpl.java
@@ -93,7 +93,7 @@ public class ExtraInfoDescriptorImpl extends DescriptorImpl
String line = s.next();
String lineNoOpt = line.startsWith("opt ") ?
line.substring("opt ".length()) : line;
- String[] partsNoOpt = lineNoOpt.split(" ");
+ String[] partsNoOpt = lineNoOpt.split("[ \t]+");
String keyword = partsNoOpt[0];
if (keyword.equals("extra-info")) {
this.parseExtraInfoLine(line, lineNoOpt, partsNoOpt);
@@ -201,17 +201,8 @@ public class ExtraInfoDescriptorImpl extends DescriptorImpl
private void parseExtraInfoLine(String line, String lineNoOpt,
String[] partsNoOpt) throws DescriptorParseException {
if (partsNoOpt.length != 3) {
- /* Also accept [SP|TAB]+ where we'd previously only accept SP as
- * delimiter. This is a hotfix for #12403, because we're currently
- * not storing valid descriptors. A better place to implement this
- * would probably be in DescriptorImpl. */
- partsNoOpt = line.startsWith("opt ") ?
- line.substring("opt ".length()).split("[ \t]+") :
- line.split("[ \t]+");
- if (partsNoOpt.length != 3) {
- throw new DescriptorParseException("Illegal line '" + line
- + "' in extra-info descriptor.");
- }
+ throw new DescriptorParseException("Illegal line '" + line
+ + "' in extra-info descriptor.");
}
this.nickname = ParseHelper.parseNickname(line, partsNoOpt[1]);
this.fingerprint = ParseHelper.parseTwentyByteHexString(line,
diff --git a/src/org/torproject/descriptor/impl/MicrodescriptorImpl.java b/src/org/torproject/descriptor/impl/MicrodescriptorImpl.java
index 30db583..c27e946 100644
--- a/src/org/torproject/descriptor/impl/MicrodescriptorImpl.java
+++ b/src/org/torproject/descriptor/impl/MicrodescriptorImpl.java
@@ -61,7 +61,7 @@ public class MicrodescriptorImpl extends DescriptorImpl
if (line.startsWith("@")) {
continue;
}
- String[] parts = line.split(" ");
+ String[] parts = line.split("[ \t]+");
String keyword = parts[0];
if (keyword.equals("onion-key")) {
this.parseOnionKeyLine(line, parts);
diff --git a/src/org/torproject/descriptor/impl/NetworkStatusEntryImpl.java b/src/org/torproject/descriptor/impl/NetworkStatusEntryImpl.java
index 7bfcb29..3962009 100644
--- a/src/org/torproject/descriptor/impl/NetworkStatusEntryImpl.java
+++ b/src/org/torproject/descriptor/impl/NetworkStatusEntryImpl.java
@@ -67,12 +67,12 @@ public class NetworkStatusEntryImpl implements NetworkStatusEntry {
throw new DescriptorParseException("Status entry must start with "
+ "an r line.");
}
- String[] rLineParts = line.split(" ");
+ String[] rLineParts = line.split("[ \t]+");
this.parseRLine(line, rLineParts);
while (s.hasNext()) {
line = s.next();
- String[] parts = !line.startsWith("opt ") ? line.split(" ") :
- line.substring("opt ".length()).split(" ");
+ String[] parts = !line.startsWith("opt ") ? line.split("[ \t]+") :
+ line.substring("opt ".length()).split("[ \t]+");
String keyword = parts[0];
if (keyword.equals("a")) {
this.parseALine(line, parts);
diff --git a/src/org/torproject/descriptor/impl/RelayDirectoryImpl.java b/src/org/torproject/descriptor/impl/RelayDirectoryImpl.java
index 2426023..3a149a8 100644
--- a/src/org/torproject/descriptor/impl/RelayDirectoryImpl.java
+++ b/src/org/torproject/descriptor/impl/RelayDirectoryImpl.java
@@ -192,7 +192,7 @@ public class RelayDirectoryImpl extends DescriptorImpl
}
String lineNoOpt = line.startsWith("opt ") ?
line.substring("opt ".length()) : line;
- String[] partsNoOpt = lineNoOpt.split(" ");
+ String[] partsNoOpt = lineNoOpt.split("[ \t]+");
String keyword = partsNoOpt[0];
if (keyword.equals("signed-directory")) {
this.parseSignedDirectoryLine(line, lineNoOpt, partsNoOpt);
@@ -248,14 +248,15 @@ public class RelayDirectoryImpl extends DescriptorImpl
} else {
String publishedLineNoOpt = publishedLine.startsWith("opt ") ?
publishedLine.substring("opt ".length()) : publishedLine;
- String[] publishedPartsNoOpt = publishedLineNoOpt.split(" ");
+ String[] publishedPartsNoOpt = publishedLineNoOpt.split("[ \t]+");
this.parsePublishedLine(publishedLine, publishedLineNoOpt,
publishedPartsNoOpt);
}
if (routerStatusLine != null) {
String routerStatusLineNoOpt = routerStatusLine.startsWith("opt ") ?
routerStatusLine.substring("opt ".length()) : routerStatusLine;
- String[] routerStatusPartsNoOpt = routerStatusLineNoOpt.split(" ");
+ String[] routerStatusPartsNoOpt =
+ routerStatusLineNoOpt.split("[ \t]+");
this.parseRouterStatusLine(routerStatusLine, routerStatusLineNoOpt,
routerStatusPartsNoOpt);
} else if (runningRoutersLine != null) {
@@ -264,7 +265,7 @@ public class RelayDirectoryImpl extends DescriptorImpl
runningRoutersLine.substring("opt ".length()) :
runningRoutersLine;
String[] runningRoutersPartsNoOpt =
- runningRoutersLineNoOpt.split(" ");
+ runningRoutersLineNoOpt.split("[ \t]+");
this.parseRunningRoutersLine(runningRoutersLine,
runningRoutersLineNoOpt, runningRoutersPartsNoOpt);
} else {
@@ -293,7 +294,7 @@ public class RelayDirectoryImpl extends DescriptorImpl
String line = s.next();
String lineNoOpt = line.startsWith("opt ") ?
line.substring("opt ".length()) : line;
- String[] partsNoOpt = lineNoOpt.split(" ");
+ String[] partsNoOpt = lineNoOpt.split("[ \t]+");
String keyword = partsNoOpt[0];
if (keyword.equals("directory-signature")) {
this.parseDirectorySignatureLine(line, lineNoOpt, partsNoOpt);
diff --git a/src/org/torproject/descriptor/impl/RelayNetworkStatusConsensusImpl.java b/src/org/torproject/descriptor/impl/RelayNetworkStatusConsensusImpl.java
index ff963e6..faad733 100644
--- a/src/org/torproject/descriptor/impl/RelayNetworkStatusConsensusImpl.java
+++ b/src/org/torproject/descriptor/impl/RelayNetworkStatusConsensusImpl.java
@@ -85,7 +85,7 @@ public class RelayNetworkStatusConsensusImpl extends NetworkStatusImpl
Scanner s = new Scanner(new String(headerBytes)).useDelimiter("\n");
while (s.hasNext()) {
String line = s.next();
- String[] parts = line.split(" ");
+ String[] parts = line.split("[ \t]+");
String keyword = parts[0];
if (keyword.equals("network-status-version")) {
this.parseNetworkStatusVersionLine(line, parts);
@@ -143,7 +143,7 @@ public class RelayNetworkStatusConsensusImpl extends NetworkStatusImpl
Scanner s = new Scanner(new String(footerBytes)).useDelimiter("\n");
while (s.hasNext()) {
String line = s.next();
- String[] parts = line.split(" ");
+ String[] parts = line.split("[ \t]+");
String keyword = parts[0];
if (keyword.equals("directory-footer")) {
} else if (keyword.equals("bandwidth-weights")) {
diff --git a/src/org/torproject/descriptor/impl/RelayNetworkStatusImpl.java b/src/org/torproject/descriptor/impl/RelayNetworkStatusImpl.java
index 6089fc7..8f0d984 100644
--- a/src/org/torproject/descriptor/impl/RelayNetworkStatusImpl.java
+++ b/src/org/torproject/descriptor/impl/RelayNetworkStatusImpl.java
@@ -88,7 +88,7 @@ public class RelayNetworkStatusImpl extends NetworkStatusImpl
if (line.isEmpty()) {
continue;
}
- String[] parts = line.split(" ");
+ String[] parts = line.split("[ \t]+");
String keyword = parts[0];
if (keyword.equals("network-status-version")) {
this.parseNetworkStatusVersionLine(line, parts);
@@ -151,7 +151,7 @@ public class RelayNetworkStatusImpl extends NetworkStatusImpl
StringBuilder crypto = null;
while (s.hasNext()) {
String line = s.next();
- String[] parts = line.split(" ");
+ String[] parts = line.split("[ \t]+");
String keyword = parts[0];
if (keyword.equals("directory-signature")) {
this.parseDirectorySignatureLine(line, parts);
diff --git a/src/org/torproject/descriptor/impl/RelayNetworkStatusVoteImpl.java b/src/org/torproject/descriptor/impl/RelayNetworkStatusVoteImpl.java
index d0d09f7..9dbc1f0 100644
--- a/src/org/torproject/descriptor/impl/RelayNetworkStatusVoteImpl.java
+++ b/src/org/torproject/descriptor/impl/RelayNetworkStatusVoteImpl.java
@@ -76,7 +76,7 @@ public class RelayNetworkStatusVoteImpl extends NetworkStatusImpl
boolean skipCrypto = false; /* TODO Parse crypto parts. */
while (s.hasNext()) {
String line = s.next();
- String[] parts = line.split(" ");
+ String[] parts = line.split("[ \t]+");
String keyword = parts[0];
if (keyword.equals("network-status-version")) {
this.parseNetworkStatusVersionLine(line, parts);
diff --git a/src/org/torproject/descriptor/impl/ServerDescriptorImpl.java b/src/org/torproject/descriptor/impl/ServerDescriptorImpl.java
index 69ffcd8..6adc689 100644
--- a/src/org/torproject/descriptor/impl/ServerDescriptorImpl.java
+++ b/src/org/torproject/descriptor/impl/ServerDescriptorImpl.java
@@ -73,7 +73,7 @@ public class ServerDescriptorImpl extends DescriptorImpl
}
String lineNoOpt = line.startsWith("opt ") ?
line.substring("opt ".length()) : line;
- String[] partsNoOpt = lineNoOpt.split(" ");
+ String[] partsNoOpt = lineNoOpt.split("[ \t]+");
String keyword = partsNoOpt[0];
if (keyword.equals("router")) {
this.parseRouterLine(line, lineNoOpt, partsNoOpt);
@@ -170,17 +170,8 @@ public class ServerDescriptorImpl extends DescriptorImpl
private void parseRouterLine(String line, String lineNoOpt,
String[] partsNoOpt) throws DescriptorParseException {
if (partsNoOpt.length != 6) {
- /* Also accept [SP|TAB]+ where we'd previously only accept SP as
- * delimiter. This is a hotfix for #12403, because we're currently
- * not storing valid descriptors. A better place to implement this
- * would probably be in DescriptorImpl. */
- partsNoOpt = line.startsWith("opt ") ?
- line.substring("opt ".length()).split("[ \t]+") :
- line.split("[ \t]+");
- if (partsNoOpt.length != 6) {
- throw new DescriptorParseException("Illegal line '" + line
- + "' in server descriptor.");
- }
+ throw new DescriptorParseException("Illegal line '" + line
+ + "' in server descriptor.");
}
this.nickname = ParseHelper.parseNickname(line, partsNoOpt[1]);
this.address = ParseHelper.parseIpv4Address(line, partsNoOpt[2]);
diff --git a/test/org/torproject/descriptor/impl/ExtraInfoDescriptorImplTest.java b/test/org/torproject/descriptor/impl/ExtraInfoDescriptorImplTest.java
index f73b4a1..12484e5 100644
--- a/test/org/torproject/descriptor/impl/ExtraInfoDescriptorImplTest.java
+++ b/test/org/torproject/descriptor/impl/ExtraInfoDescriptorImplTest.java
@@ -830,7 +830,7 @@ public class ExtraInfoDescriptorImplTest {
+ "-4713350144,-4723824640,-4710717440,-4572675072");
}
- @Test(expected = DescriptorParseException.class)
+ @Test()
public void testReadHistoryTabInterval()
throws DescriptorParseException {
DescriptorBuilder.createWithReadHistoryLine("read-history "
@@ -838,7 +838,7 @@ public class ExtraInfoDescriptorImplTest {
+ "4707695616,4699666432,4650004480,4489718784");
}
- @Test(expected = DescriptorParseException.class)
+ @Test()
public void testReadHistoryTabIntervalBytes()
throws DescriptorParseException {
DescriptorBuilder.createWithReadHistoryLine("read-history "