better telnet wrapper
All checks were successful
Deploy powerbar.ti Frontend Portal / Deploy-Tinance2-Frontend-Portal-Production (push) Successful in 7s

This commit is contained in:
Matthew Frost 2023-11-24 12:48:00 +01:00
parent ea551687f8
commit 34bcb35e6b
2 changed files with 33 additions and 13 deletions

File diff suppressed because one or more lines are too long

View file

@ -1,4 +1,3 @@
from flask import render_template, Blueprint from flask import render_template, Blueprint
from app.settings import powerbars, groups from app.settings import powerbars, groups
from flask import jsonify from flask import jsonify
@ -8,6 +7,30 @@ import time
routes = Blueprint('routes', __name__) routes = Blueprint('routes', __name__)
# Create a dictionary to store the active telnet connections
active_telnet_connections = {}
def get_telnet_connection(powerbar):
"""
Get the active telnet connection for the given powerbar.
If the connection does not exist, create a new one.
Args:
powerbar (str): The name of the powerbar.
Returns:
telnetlib.Telnet: The telnet connection object.
"""
if powerbar in active_telnet_connections:
return active_telnet_connections[powerbar]
else:
tn = telnetlib.Telnet(powerbars[powerbar]['host'], powerbars[powerbar]['port'])
active_telnet_connections[powerbar] = tn
return tn
def find_group_by_name(name): def find_group_by_name(name):
for group in groups: for group in groups:
if group["name"] == name: if group["name"] == name:
@ -74,9 +97,8 @@ def powerbar_control(powerbar, outlet, action):
if action in ['on', 'off']: if action in ['on', 'off']:
try: try:
print(f"Turning {action} powerbar {powerbar} outlet {outlet}") print(f"Turning {action} powerbar {powerbar} outlet {outlet}")
tn = telnetlib.Telnet(powerbars[powerbar]['host'], powerbars[powerbar]['port']) tn = get_telnet_connection(powerbar)
tn.write(f"{action} {outlet}\r\n".encode('ascii')) tn.write(f"{action} {outlet}\r\n".encode('ascii'))
tn.close()
powerbars[powerbar]['outlets'][outlet]['state'] = action powerbars[powerbar]['outlets'][outlet]['state'] = action
print(f"Turned {action} powerbar {powerbar} outlet {outlet}") print(f"Turned {action} powerbar {powerbar} outlet {outlet}")
except Exception as E: except Exception as E:
@ -84,30 +106,27 @@ def powerbar_control(powerbar, outlet, action):
return jsonify({'error': 'Telnet error'}), 500 return jsonify({'error': 'Telnet error'}), 500
if action == 'cycle': if action == 'cycle':
tn = telnetlib.Telnet(powerbars[powerbar]['host'], powerbars[powerbar]['port']) tn = get_telnet_connection(powerbar)
print(f"Turning Off powerbar {powerbar} outlet {outlet}") print(f"Turning Off powerbar {powerbar} outlet {outlet}")
powerbars[powerbar]['outlets'][outlet]['state'] = "off" powerbars[powerbar]['outlets'][outlet]['state'] = "off"
tn.write(f"off {outlet}\r\n".encode('ascii')) tn.write(f"off {outlet}\r\n".encode('ascii'))
time.sleep(5) time.sleep(5)
print(f"Turning On powerbar {powerbar} outlet {outlet}") print(f"Turning On powerbar {powerbar} outlet {outlet}")
tn.write(f"on {outlet}\r\n".encode('ascii')) tn.write(f"on {outlet}\r\n".encode('ascii'))
tn.close()
powerbars[powerbar]['outlets'][outlet]['state'] = "on" powerbars[powerbar]['outlets'][outlet]['state'] = "on"
if action == 'toggle': if action == 'toggle':
print(powerbars[powerbar]['outlets'][outlet]['state']) print(powerbars[powerbar]['outlets'][outlet]['state'])
if powerbars[powerbar]['outlets'][outlet]['state'] == "on": if powerbars[powerbar]['outlets'][outlet]['state'] == "on":
tn = telnetlib.Telnet(powerbars[powerbar]['host'], powerbars[powerbar]['port']) tn = get_telnet_connection(powerbar)
print(f"Turning Off powerbar {powerbar} outlet {outlet}") print(f"Turning Off powerbar {powerbar} outlet {outlet}")
tn.write(f"off {outlet}\r\n".encode('ascii')) tn.write(f"off {outlet}\r\n".encode('ascii'))
tn.close()
powerbars[powerbar]['outlets'][outlet]['state'] = "off" powerbars[powerbar]['outlets'][outlet]['state'] = "off"
elif powerbars[powerbar]['outlets'][outlet]['state'] == "off": elif powerbars[powerbar]['outlets'][outlet]['state'] == "off":
tn = telnetlib.Telnet(powerbars[powerbar]['host'], powerbars[powerbar]['port']) tn = get_telnet_connection(powerbar)
print(f"Turning On powerbar {powerbar} outlet {outlet}") print(f"Turning On powerbar {powerbar} outlet {outlet}")
tn.write(f"on {outlet}\r\n".encode('ascii')) tn.write(f"on {outlet}\r\n".encode('ascii'))
tn.close()
powerbars[powerbar]['outlets'][outlet]['state'] = "on" powerbars[powerbar]['outlets'][outlet]['state'] = "on"
return jsonify({'state': powerbars[powerbar]['outlets'][outlet].get('state', 'unknown')}) return jsonify({'state': powerbars[powerbar]['outlets'][outlet].get('state', 'unknown')})
@ -168,12 +187,11 @@ def powebar_group_action(group, action):
try: try:
for device in group["devices"]: for device in group["devices"]:
powerbar = device["powerbar"] powerbar = device["powerbar"]
tn = telnetlib.Telnet(powerbars[powerbar]['host'], powerbars[powerbar]['port']) tn = get_telnet_connection(powerbar)
print(f"Powerbar: {powerbar}") print(f"Powerbar: {powerbar}")
outlets = ",".join([str(x) for x in device['outlets']]) outlets = ",".join([str(x) for x in device['outlets']])
print(f"Turning {action} powerbar {powerbar} outlet {outlets}") print(f"Turning {action} powerbar {powerbar} outlet {outlets}")
tn.write(f"{action} {outlets}\r\n".encode('ascii')) tn.write(f"{action} {outlets}\r\n".encode('ascii'))
tn.close()
for outlet in device['outlets']: for outlet in device['outlets']:
if outlet in powerbars[powerbar]['outlets']: if outlet in powerbars[powerbar]['outlets']:
powerbars[powerbar]['outlets'][outlet]['state'] = action powerbars[powerbar]['outlets'][outlet]['state'] = action
@ -195,3 +213,5 @@ def powebar_groups():
except Exception as E: except Exception as E:
print(f"Telnet error: {E}") print(f"Telnet error: {E}")
return jsonify({'error': 'no groups defined for powerbar'}), 404 return jsonify({'error': 'no groups defined for powerbar'}), 404