[metrics-bugs] #24837 [Metrics/Onionoo]: Allow Relay Searches for Additional Flags
Tor Bug Tracker & Wiki
blackhole at torproject.org
Tue Jan 9 18:06:03 UTC 2018
#24837: Allow Relay Searches for Additional Flags
-----------------------------+------------------------------
Reporter: teor | Owner: metrics-team
Type: enhancement | Status: new
Priority: Medium | Milestone:
Component: Metrics/Onionoo | Version:
Severity: Normal | Resolution:
Keywords: | Actual Points:
Parent ID: | Points:
Reviewer: | Sponsor:
-----------------------------+------------------------------
Comment (by irl):
The following flags are synthesised by Relay Search:
||=Flag=||=Description=||
|| NotRecommended || This relay is running a version of tor that is not
recommended by the directory authorities ||
|| Unmeasured || This relay has not been measured by at least 3 bwauths ||
|| Hibernating || This relay indicated that it is hibernating in its last
known descriptor ||
|| FallbackDir || This relay is listed as a fallback directory in the tor
source code ||
|| ReachableIPv6 || This relay has been confirmed as reachable via IPv6 in
the consensus ||
|| UnreachableIPv4 || This relay was not reachable on at least one IPv4
address published in the server descriptor ||
|| UnreachableIPv6 || This relay was not reachable on at least one IPv6
address published in the server descriptor ||
|| IPv6 Exit || This relay allows exit connections to IPv6 hosts ||
The relevant code in Relay Search is:
{{{
/* Synthetic Additional Flags */
var additional_flags = []
if (!((typeof relay.recommended_version !== 'undefined') ?
relay.recommended_version : true)) additional_flags.push("Not
Recommended");
if (!((typeof relay.measured !== 'undefined') ? relay.measured : true))
additional_flags.push("Unmeasured");
if (((typeof relay.hibernating !== 'undefined') ? relay.hibernating :
false)) additional_flags.push("Hibernating");
if (IsFallbackDir(relay.fingerprint))
additional_flags.push("FallbackDir");
if (relay.or_v6_addresses.length > 0)
additional_flags.push("ReachableIPv6");
if (relay.unreachable_or_v4_addresses.length > 0)
additional_flags.push("UnreachableIPv4");
if (relay.unreachable_or_v6_addresses.length > 0)
additional_flags.push("UnreachableIPv6");
if (relay.exit_policy_v6_summary !== null) additional_flags.push("IPv6
Exit");
}}}
For the Onionoo protocol, I would prefer it if these flags are kept
separate from the dir-spec flags in a new "additional_flags" field, but
for searching it would be good to still have "flag:X" work. I don't know
if this introduces a lot more complexity in Onionoo though.
Things that would need to be done as I understand it:
* Add a new "additional_flags" field to Onionoo's relay details documents
* Extend the "flag" parameter to also search in this new field, as well as
the existing "flags" field
* Synthesise each of the flags:
* NotRecommended, Hibernating and Unmeasured are all based on boolean
values already in the document
* ReachableIPv6, UnreachableIPv4 and UnreachableIPv6 will require
checking the "or_addresses" and "unreachable_or_addresses" fields
* IPv6 Exit will require checking the exit policies
* FallbackDir will depend on #24436
--
Ticket URL: <https://trac.torproject.org/projects/tor/ticket/24837#comment:5>
Tor Bug Tracker & Wiki <https://trac.torproject.org/>
The Tor Project: anonymity online
More information about the metrics-bugs
mailing list