2018-11-03 18:50:34 -04:00
|
|
|
import time
|
|
|
|
|
2019-12-31 14:52:57 -05:00
|
|
|
from lbry.wallet.server import util
|
2018-11-03 18:50:34 -04:00
|
|
|
|
|
|
|
|
|
|
|
def sessions_lines(data):
|
2019-04-16 02:50:35 -05:00
|
|
|
"""A generator returning lines for a list of sessions.
|
2018-11-03 18:50:34 -04:00
|
|
|
|
2019-04-16 02:50:35 -05:00
|
|
|
data is the return value of rpc_sessions()."""
|
2018-11-03 18:50:34 -04:00
|
|
|
fmt = ('{:<6} {:<5} {:>17} {:>5} {:>5} {:>5} '
|
|
|
|
'{:>7} {:>7} {:>7} {:>7} {:>7} {:>9} {:>21}')
|
|
|
|
yield fmt.format('ID', 'Flags', 'Client', 'Proto',
|
|
|
|
'Reqs', 'Txs', 'Subs',
|
|
|
|
'Recv', 'Recv KB', 'Sent', 'Sent KB', 'Time', 'Peer')
|
|
|
|
for (id_, flags, peer, client, proto, reqs, txs_sent, subs,
|
|
|
|
recv_count, recv_size, send_count, send_size, time) in data:
|
|
|
|
yield fmt.format(id_, flags, client, proto,
|
2019-10-02 19:38:56 +03:00
|
|
|
f'{reqs:,d}',
|
|
|
|
f'{txs_sent:,d}',
|
|
|
|
f'{subs:,d}',
|
|
|
|
f'{recv_count:,d}',
|
2018-11-03 18:50:34 -04:00
|
|
|
'{:,d}'.format(recv_size // 1024),
|
2019-10-02 19:38:56 +03:00
|
|
|
f'{send_count:,d}',
|
2018-11-03 18:50:34 -04:00
|
|
|
'{:,d}'.format(send_size // 1024),
|
|
|
|
util.formatted_time(time, sep=''), peer)
|
|
|
|
|
|
|
|
|
|
|
|
def groups_lines(data):
|
2019-04-16 02:50:35 -05:00
|
|
|
"""A generator returning lines for a list of groups.
|
2018-11-03 18:50:34 -04:00
|
|
|
|
2019-04-16 02:50:35 -05:00
|
|
|
data is the return value of rpc_groups()."""
|
2018-11-03 18:50:34 -04:00
|
|
|
|
|
|
|
fmt = ('{:<6} {:>9} {:>9} {:>6} {:>6} {:>8}'
|
|
|
|
'{:>7} {:>9} {:>7} {:>9}')
|
|
|
|
yield fmt.format('ID', 'Sessions', 'Bwidth KB', 'Reqs', 'Txs', 'Subs',
|
|
|
|
'Recv', 'Recv KB', 'Sent', 'Sent KB')
|
|
|
|
for (id_, session_count, bandwidth, reqs, txs_sent, subs,
|
|
|
|
recv_count, recv_size, send_count, send_size) in data:
|
|
|
|
yield fmt.format(id_,
|
2019-10-02 19:38:56 +03:00
|
|
|
f'{session_count:,d}',
|
2018-11-03 18:50:34 -04:00
|
|
|
'{:,d}'.format(bandwidth // 1024),
|
2019-10-02 19:38:56 +03:00
|
|
|
f'{reqs:,d}',
|
|
|
|
f'{txs_sent:,d}',
|
|
|
|
f'{subs:,d}',
|
|
|
|
f'{recv_count:,d}',
|
2018-11-03 18:50:34 -04:00
|
|
|
'{:,d}'.format(recv_size // 1024),
|
2019-10-02 19:38:56 +03:00
|
|
|
f'{send_count:,d}',
|
2018-11-03 18:50:34 -04:00
|
|
|
'{:,d}'.format(send_size // 1024))
|
|
|
|
|
|
|
|
|
|
|
|
def peers_lines(data):
|
2019-04-16 02:50:35 -05:00
|
|
|
"""A generator returning lines for a list of peers.
|
2018-11-03 18:50:34 -04:00
|
|
|
|
2019-04-16 02:50:35 -05:00
|
|
|
data is the return value of rpc_peers()."""
|
2018-11-03 18:50:34 -04:00
|
|
|
def time_fmt(t):
|
|
|
|
if not t:
|
|
|
|
return 'Never'
|
|
|
|
return util.formatted_time(now - t)
|
|
|
|
|
|
|
|
now = time.time()
|
|
|
|
fmt = ('{:<30} {:<6} {:>5} {:>5} {:<17} {:>4} '
|
|
|
|
'{:>4} {:>8} {:>11} {:>11} {:>5} {:>20} {:<15}')
|
|
|
|
yield fmt.format('Host', 'Status', 'TCP', 'SSL', 'Server', 'Min',
|
|
|
|
'Max', 'Pruning', 'Last Good', 'Last Try',
|
|
|
|
'Tries', 'Source', 'IP Address')
|
|
|
|
for item in data:
|
|
|
|
features = item['features']
|
|
|
|
hostname = item['host']
|
|
|
|
host = features['hosts'][hostname]
|
|
|
|
yield fmt.format(hostname[:30],
|
|
|
|
item['status'],
|
|
|
|
host.get('tcp_port') or '',
|
|
|
|
host.get('ssl_port') or '',
|
|
|
|
features['server_version'] or 'unknown',
|
|
|
|
features['protocol_min'],
|
|
|
|
features['protocol_max'],
|
|
|
|
features['pruning'] or '',
|
|
|
|
time_fmt(item['last_good']),
|
|
|
|
time_fmt(item['last_try']),
|
|
|
|
item['try_count'],
|
|
|
|
item['source'][:20],
|
|
|
|
item['ip_addr'] or '')
|