listboxes: make nicer

This commit is contained in:
2025-04-09 14:12:34 +02:00
parent 71c5ec34eb
commit 7da25d4190

105
listboxes
View File

@ -7,33 +7,48 @@ from socket import gethostbyname, create_connection
cfgdir = Path(__file__).resolve().parent / 'cfg' cfgdir = Path(__file__).resolve().parent / 'cfg'
def check_ssh(host, port=22): def check_connection(host, port=22):
try: try:
addr = gethostbyname(host) addr = gethostbyname(host)
test_socket = create_connection((addr, port), timeout=0.1) test_socket = create_connection((addr, port), timeout=0.1)
except Exception as e: except Exception as e:
if isinstance(e, TimeoutError): if isinstance(e, TimeoutError):
return False, addr return '', addr
return False, '' return '', ''
else: else:
test_socket.close() test_socket.close()
return True, addr return '*', addr
def print_row(row, sizes):
print(' '.join(v.ljust(l) for v, l in zip(row, sizes)))
def print_line(sizes):
print(' '.join('-' * l for l in sizes))
legend = ['', '', '* running', '* online']
opt = sys.argv[-1] opt = sys.argv[-1]
if opt.startswith('-'): if opt.startswith('-'):
opt = opt[1:] opt = opt[1:]
header = ['box name', 'box type', 'frappy'] header = ['box name', 'box type', 'frappy']
if opt == 's': if opt == 's':
header.append('R') header.append('')
legend = []
else: else:
header.append('ip ')
if opt == 'a': if opt == 'a':
header.extend(['router', '*online ip ', 'MAC addr']) header.extend(['router', 'MAC addr'])
else: else:
header.extend(['R', 'ip']) header.append('')
legend = legend[:4]
table = [header] table = [header]
all_ports = {}
for file in sorted(cfgdir.glob('*.cfg')): for file in sorted(cfgdir.glob('*.cfg')):
name = file.stem
all_ports[name] = box_ports = {}
parser = ConfigParser() parser = ConfigParser()
parser.read(file) parser.read(file)
info = {k: dict(parser[k]) for k in parser.sections()} info = {k: dict(parser[k]) for k in parser.sections()}
@ -42,9 +57,12 @@ for file in sorted(cfgdir.glob('*.cfg')):
ports = sorted(router) ports = sorted(router)
router = [] router = []
following = None following = None
firstport = None
for p in ports: for p in ports:
try: try:
pnum = int(p) pnum = int(p)
if 'router' not in box_ports:
box_ports['router'] = pnum
if pnum == following: if pnum == following:
first = router[-1].split('-')[0] first = router[-1].split('-')[0]
router[-1] = f'{first}-{following}' router[-1] = f'{first}-{following}'
@ -56,42 +74,63 @@ for file in sorted(cfgdir.glob('*.cfg')):
router.append(p) router.append(p)
router = ' '.join(router) router = ' '.join(router)
else: else:
router = 'R' if router else '' router = 'router' if router else ''
frappy = info.get('FRAPPY', {}).get('cfg', '') frappy_info = info.get('FRAPPY', {})
frappy = frappy_info.get('cfg', '')
if frappy:
box_ports['frappy'] = int(frappy_info.get('port', 10767))
box = info.get('BOX', {}) box = info.get('BOX', {})
row = [file.stem, box.get('type', 'unknown'), frappy, router] row = [name, box.get('type', 'unknown'), frappy]
if opt != 's': if opt == 's':
row.append('') row.append(router)
else:
row.extend(['', router])
if opt == 'a': if opt == 'a':
row.append(box.get('mac', '')) row.append(box.get('mac', ''))
table.append(row) table.append(row)
sizes = [max([len(row[i]) for row in table]) for i in range(len(header))] sizes = [max([len(row[i]) for row in table]) for i in range(len(header))]
if opt != 's':
# make space for '*'
sizes[2] += 1
sizes[3] += 1
inside = False firstrow = True
print() print_line(sizes)
for row in table: for row in table:
if inside: if firstrow:
firstrow = False
print_row(header, sizes)
print_line(sizes)
continue
if row[0]:
name = row[0]
online = ''
if opt != 's': if opt != 's':
online, addr = check_ssh(row[0]) online, addr = check_connection(row[0], 22)
if opt == 'a': addr += online
addr = ('*' if online else ' ') + addr if opt != 'a' and online != '*':
elif not online:
continue continue
row[4] = addr row[3] = addr
print(' '.join(v.ljust(l) for v, l in zip(row, sizes))) if opt != 's':
if not inside: port = all_ports[name].get('frappy')
print() if port and online == '*':
inside = True flag = check_connection(name, port)[0]
USAGE = """ else:
Usage: flag = ' '
listboxes o # only boxes online (default) row[2] += flag
listboxes a # all boxes, all info print(' '.join(v.ljust(l) for v, l in zip(row, sizes)))
listboxes s # short (without ip and online check) print_line(sizes)
column R: router configured if legend:
print_row(legend, sizes)
USAGE = f"""
Usage:
listboxes o # only boxes online (default)
listboxes a # all boxes, all info
listboxes s # without ip and online check
""" """
if opt in 'sao': if opt not in 'sao':
print()
else:
print(USAGE) print(USAGE)