[metrics-bugs] #20765 [Metrics/metrics-lib]: adapt to new lines in votes and consensus and make the adaption to protocol changes easier

Tor Bug Tracker & Wiki blackhole at torproject.org
Mon Dec 5 13:58:28 UTC 2016


#20765: adapt to new lines in votes and consensus and make the adaption to protocol
changes easier
---------------------------------+-----------------------------------
 Reporter:  iwakeh               |          Owner:  metrics-team
     Type:  enhancement          |         Status:  new
 Priority:  Medium               |      Milestone:  metrics-lib 1.6.0
Component:  Metrics/metrics-lib  |        Version:
 Severity:  Normal               |     Resolution:
 Keywords:                       |  Actual Points:
Parent ID:                       |         Points:
 Reviewer:                       |        Sponsor:
---------------------------------+-----------------------------------

Comment (by karsten):

 Replying to [comment:2 iwakeh]:
 > Replying to [comment:1 karsten]:
 > > See also #19634 here for the `shared-rand-*` lines.
 > >
 > > Regarding making these changes without compiling, I'm not certain what
 the benefit would be.  We'll have to put out a new release to make sense
 of these new lines anyway.  And we'll want to include tests.
 > >
 >
 > Yes, that's true.  Still it might be useful (especially for testing) to
 have something other than a bunch of if-else-if statements; maybe in form
 of an enum.

 Agreed, having cleaner code there would be good.  Maybe that comes
 together with rewriting that code for better performance (lazy parsing,
 better control over parsed-descriptor buffer).

 > > Speaking of, I think we accumulated enough changes for a new metrics-
 lib release in December.  Let's discuss that either here or at the next
 meeting.
 >
 > Yes, a December metrics-lib release makes sense!

 Cool!

 I started identifying the code that needs changing by throwing CollecTor's
 November tarballs into a descriptor reader and handling any unrecognized
 lines:

 {{{
 diff --git
 a/src/main/java/org/torproject/descriptor/impl/NetworkStatusEntryImpl.java
 b/src/main/java/org/torproject/descriptor/impl/NetworkStatusEntryImpl.java
 index f528033..dd5fac7 100644
 ---
 a/src/main/java/org/torproject/descriptor/impl/NetworkStatusEntryImpl.java
 +++
 b/src/main/java/org/torproject/descriptor/impl/NetworkStatusEntryImpl.java
 @@ -95,6 +95,9 @@ public class NetworkStatusEntryImpl implements
 NetworkStatusEntry {
          case "v":
            this.parseVLine(line, parts);
            break;
 +        case "pr":
 +          // TODO
 +          break;
          case "w":
            this.parseWLine(line, parts);
            break;
 diff --git
 a/src/main/java/org/torproject/descriptor/impl/RelayNetworkStatusVoteImpl.java
 b/src/main/java/org/torproject/descriptor/impl/RelayNetworkStatusVoteImpl.java
 index 2bf8e88..e0cfdb7 100644
 ---
 a/src/main/java/org/torproject/descriptor/impl/RelayNetworkStatusVoteImpl.java
 +++
 b/src/main/java/org/torproject/descriptor/impl/RelayNetworkStatusVoteImpl.java
 @@ -117,6 +117,18 @@ public class RelayNetworkStatusVoteImpl extends
 NetworkStatusImpl
          case "server-versions":
            this.parseServerVersionsLine(line, parts);
            break;
 +        case "recommended-relay-protocols":
 +          // TODO
 +          break;
 +        case "recommended-client-protocols":
 +          // TODO
 +          break;
 +        case "required-relay-protocols":
 +          // TODO
 +          break;
 +        case "required-client-protocols":
 +          // TODO
 +          break;
          case "package":
            this.parsePackageLine(line, parts);
            break;
 @@ -135,6 +147,15 @@ public class RelayNetworkStatusVoteImpl extends
 NetworkStatusImpl
          case "contact":
            this.parseContactLine(line, parts);
            break;
 +        case "shared-rand-participate":
 +          // TODO
 +          break;
 +        case "shared-rand-commit":
 +          // TODO
 +          break;
 +        case "shared-rand-current-value":
 +          // TODO
 +          break;
          case "dir-key-certificate-version":
            this.parseDirKeyCertificateVersionLine(line, parts);
            break;
 diff --git
 a/src/main/java/org/torproject/descriptor/impl/ServerDescriptorImpl.java
 b/src/main/java/org/torproject/descriptor/impl/ServerDescriptorImpl.java
 index 622e9a4..4c5b00b 100644
 ---
 a/src/main/java/org/torproject/descriptor/impl/ServerDescriptorImpl.java
 +++
 b/src/main/java/org/torproject/descriptor/impl/ServerDescriptorImpl.java
 @@ -80,6 +80,9 @@ public abstract class ServerDescriptorImpl extends
 DescriptorImpl
          case "platform":
            this.parsePlatformLine(line, lineNoOpt, partsNoOpt);
            break;
 +        case "proto":
 +          // TODO
 +          break;
          case "published":
            this.parsePublishedLine(line, lineNoOpt, partsNoOpt);
            break;
 }}}

 Note that the code above does not handle any new lines in consensuses (or
 microdesc-consensuses) that will only be added when enough votes support
 the new lines.  We'll have to look at proposals and/or dir-spec.txt.  But
 the code above might help us identify proposals that we should read.

--
Ticket URL: <https://trac.torproject.org/projects/tor/ticket/20765#comment:3>
Tor Bug Tracker & Wiki <https://trac.torproject.org/>
The Tor Project: anonymity online


More information about the metrics-bugs mailing list