From 4062918ebb4cb1eae15a53d1e963b001fbcd7104 Mon Sep 17 00:00:00 2001 From: Matthew Frost <matthew.frost@uptic.io> Date: Mon, 20 Nov 2023 11:33:19 +0100 Subject: [PATCH] gets default state on reboot --- app/__init__.py | 21 ++++++++++++++++++++- app/settings.py | 6 +++++- app/templates/index.html | 2 +- app/utils.py | 28 ++++++++++++++++++++++++++++ 4 files changed, 54 insertions(+), 3 deletions(-) create mode 100644 app/utils.py diff --git a/app/__init__.py b/app/__init__.py index 5d9f918..4859fb8 100644 --- a/app/__init__.py +++ b/app/__init__.py @@ -1,12 +1,30 @@ -from flask import Flask, request, redirect, url_for, render_template +from flask import Flask from app.views import routes from flask import jsonify +from app.settings import powerbars +from app.utils import get_baytech_status_outlet def create_app(): # create and configure the app app = Flask(__name__) app.config.from_pyfile('settings.py') app.register_blueprint(routes) + for powerbar_name, powerbar_info in powerbars.items(): + print(f"Checking powerbar state {powerbar_name}") + if powerbar_info['type'] == 'baytech': + try: + print("Is a baytech powerbar, getting outlet status") + outlets = get_baytech_status_outlet(powerbar_info['host'], powerbar_info['port']) + try: + for outlet_id, outlet_info in powerbar_info['outlets'].items(): + powerbar_info['outlets'][outlet_id]['state'] = outlets[outlet_id].lower() + print(f" Powerbar: {powerbar_name} Outlet: {outlet_id}, State: {outlets[outlet_id].lower()}") + except: + print(f"Failed to get outlet status from powerbar {powerbar_name} outlet: {outlet_id}") + continue + except: + print(f"Failed to get outlet status from powerbar {powerbar_name}") + continue return app app = create_app() @@ -19,3 +37,4 @@ def not_authorised(e): def internal_server_error(e): return jsonify(error="Internal server error"), 500 + diff --git a/app/settings.py b/app/settings.py index 1d650a9..885e367 100644 --- a/app/settings.py +++ b/app/settings.py @@ -1,10 +1,11 @@ - +from app.utils import get_baytech_status_outlet powerbars = { "powerbar-aux-space" : { "name" : "Powerbar Aux Space", "host" : "10.209.10.111", "port" : 3696, + "type" : "baytech", "description" : "Powerbar Controlling Aux Space", "outlets" : { 1 : { "name" : "Aux Main Table Light" }, @@ -33,6 +34,7 @@ powerbars = { "name" : "Powerbar Main Space", "host" : "10.209.10.111", "port" : 3697, + "type" : "baytech", "description" : "Powerbar Controlling Main Space", "outlets" : { 4 : { "name" : "LIGHT_MAKERTABLE" }, @@ -62,3 +64,5 @@ powerbars = { ] } } + + diff --git a/app/templates/index.html b/app/templates/index.html index d90a6da..37fea5d 100644 --- a/app/templates/index.html +++ b/app/templates/index.html @@ -104,7 +104,7 @@ input:checked + .slider:before { <body> <div class="container"> - <h1 class="mt-3"> <img style="height: 50px; width: 50px;" src="" alt="Techinc Logo"> powerbar.ti (0.0.11)</h1> + <h1 class="mt-3"> <img style="height: 50px; width: 50px;" src="" alt="Techinc Logo"> powerbar.ti (2.0.11)</h1> <hr> <div class="alert alert-primary" role="alert"> For the API vist '/powerbars' diff --git a/app/utils.py b/app/utils.py new file mode 100644 index 0000000..b2c5aeb --- /dev/null +++ b/app/utils.py @@ -0,0 +1,28 @@ +import telnetlib +import re + +def get_baytech_status_outlet(hostname,port): + try: + # Create a Telnet object and connect to the host + tn = telnetlib.Telnet(hostname, port) + + # Send the command you want to execute + command = "status" + tn.write(command.encode('ascii') + b"\r\n") + + # Read the output until you receive the prompt or a timeout occurs + output = tn.read_until(b"<prompt>", timeout=5).decode('ascii') + # Close the Telnet connection + tn.close() + + pattern = r"(\d+)\)\.\.\.Outlet\s+(\d+)\s+:\s+(\w+)" + outlets = {} + matches = re.findall(pattern, output) + for match in matches: + number = int(match[1]) + status = match[2] + outlets[number] = status + + return outlets + except: + return None