-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathpeers_of_peer.py
executable file
·62 lines (44 loc) · 1.87 KB
/
peers_of_peer.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
#!/usr/bin/env python3
# This script is a way to discover the peers of a remote node.
# This script connects to a peer repeadedly to get a keepalive packet.
# It collects the peers in the keepalive packets and then prints them at the end.
import argparse
import peercrawler
from pynanocoin import *
from peer import Peer
def parse_args():
parser = argparse.ArgumentParser()
group = parser.add_mutually_exclusive_group()
group.add_argument('-b', '--beta', action='store_true', default=False,
help='use beta network')
group.add_argument('-t', '--test', action='store_true', default=False,
help='use test network')
parser.add_argument('-c', '--count', type=int, default=150,
help='number of times to connect to get a keepalive packet')
parser.add_argument('-p', '--peer',
help='peer to contact for frontiers (if not set, one is randomly selected using DNS)')
return parser.parse_args()
def main():
args = parse_args()
ctx = livectx
if args.beta: ctx = betactx
if args.test: ctx = testctx
if args.peer is not None:
peeraddr, peerport = parse_endpoint(args.peer, default_port=ctx['peerport'])
print('Connecting to [%s]:%s' % (peeraddr, peerport))
peer = Peer(ip_addr(peeraddr), peerport)
else:
peer = peercrawler.get_random_peer(ctx, lambda p: p.score >= 1000 and p.ip.is_ipv4())
print('Using peer %s' % peer)
peeraddr = str(peer.ip)
peerport = peer.port
peerman = peercrawler.peer_manager(ctx, verbosity=1)
peers = []
for i in range(args.count):
print('.', flush=True, end='')
new_peers = peerman.get_peers_from_peer(peer, no_telemetry=True, no_confirm_req=True)
peers.extend(new_peers)
for p in peers:
print(p)
if __name__ == "__main__":
main()