Browse Source

Be more strict on form of features dictionary

master
Neil Booth 8 years ago
parent
commit
8236aaf234
  1. 5
      lib/peer.py
  2. 4
      server/controller.py
  3. 7
      server/peers.py

5
lib/peer.py

@ -49,6 +49,7 @@ class Peer(object):
a dictionary of features, and a record of the source.''' a dictionary of features, and a record of the source.'''
assert isinstance(host, str) assert isinstance(host, str)
assert isinstance(features, dict) assert isinstance(features, dict)
assert host in features.get('hosts', {})
self.host = host self.host = host
self.features = features.copy() self.features = features.copy()
# Canonicalize / clean-up # Canonicalize / clean-up
@ -105,7 +106,11 @@ class Peer(object):
def update_features(self, features): def update_features(self, features):
'''Update features in-place.''' '''Update features in-place.'''
try:
tmp = Peer(self.host, features) tmp = Peer(self.host, features)
except Exception:
pass
else:
self.features = tmp.features self.features = tmp.features
for feature in self.FEATURES: for feature in self.FEATURES:
setattr(self, feature, getattr(tmp, feature)) setattr(self, feature, getattr(tmp, feature))

4
server/controller.py

@ -508,8 +508,8 @@ class Controller(util.LoggedClass):
host = features['hosts'][hostname] host = features['hosts'][hostname]
yield fmt.format(hostname[:30], yield fmt.format(hostname[:30],
item['status'], item['status'],
host['tcp_port'] or '', host.get('tcp_port') or '',
host['ssl_port'] or '', host.get('ssl_port') or '',
features['server_version'] or 'unknown', features['server_version'] or 'unknown',
features['protocol_min'], features['protocol_min'],
features['protocol_max'], features['protocol_max'],

7
server/peers.py

@ -400,7 +400,12 @@ class PeerManager(util.LoggedClass):
if data: if data:
version, items = ast.literal_eval(data) version, items = ast.literal_eval(data)
if version == 1: if version == 1:
peers = [Peer.deserialize(item) for item in items] peers = []
for item in items:
try:
peers.append(Peer.deserialize(item))
except Exception:
pass
self.add_peers(peers, source='peers file', limit=None) self.add_peers(peers, source='peers file', limit=None)
def import_peers(self): def import_peers(self):

Loading…
Cancel
Save