listboxes: make nicer
This commit is contained in:
105
listboxes
105
listboxes
@ -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)
|
||||||
|
Reference in New Issue
Block a user