remove "announcement_distinct_hosts" from introweb JSON

The machine-parseable JSON output for the introducer status web page
used to include a key named "announcement_distinct_hosts", which counted
the number of distinct IP addresses advertised by all connected storage
servers. This hasn't worked since Aug-2014 when foolscap-0.6.5 change
the internal hints format.

This removes that field.
This commit is contained in:
Brian Warner 2015-09-22 16:34:50 -07:00 committed by Daira Hopwood
parent 781192d0ee
commit 7d30bcf499
2 changed files with 0 additions and 18 deletions

View File

@ -887,8 +887,6 @@ class SystemTest(SystemTestMixin, RunBinTahoeMixin):
{"storage": 5}) {"storage": 5})
self.failUnlessEqual(data["announcement_summary"], self.failUnlessEqual(data["announcement_summary"],
{"storage": 5}) {"storage": 5})
self.failUnlessEqual(data["announcement_distinct_hosts"],
{"storage": 1})
except unittest.FailTest: except unittest.FailTest:
print print
print "GET %s?t=json output was:" % self.introweb_url print "GET %s?t=json output was:" % self.introweb_url

View File

@ -42,28 +42,12 @@ class IntroducerRoot(rend.Page):
res["subscription_summary"] = counts res["subscription_summary"] = counts
announcement_summary = {} announcement_summary = {}
service_hosts = {}
for ad in self.introducer_service.get_announcements(): for ad in self.introducer_service.get_announcements():
service_name = ad.service_name service_name = ad.service_name
if service_name not in announcement_summary: if service_name not in announcement_summary:
announcement_summary[service_name] = 0 announcement_summary[service_name] = 0
announcement_summary[service_name] += 1 announcement_summary[service_name] += 1
if service_name not in service_hosts:
service_hosts[service_name] = set()
# it's nice to know how many distinct hosts are available for
# each service. We define a "host" by a set of addresses
# (hostnames or ipv4 addresses), which we extract from the
# connection hints. In practice, this is usually close
# enough: when multiple services are run on a single host,
# they're usually either configured with the same addresses,
# or setLocationAutomatically picks up the same interfaces.
host = frozenset(ad.advertised_addresses)
service_hosts[service_name].add(host)
res["announcement_summary"] = announcement_summary res["announcement_summary"] = announcement_summary
distinct_hosts = dict([(name, len(hosts))
for (name, hosts)
in service_hosts.iteritems()])
res["announcement_distinct_hosts"] = distinct_hosts
return simplejson.dumps(res, indent=1) + "\n" return simplejson.dumps(res, indent=1) + "\n"