ti-powerbar/app/__init__.py

51 lines
1.8 KiB
Python
Raw Normal View History

2023-11-20 10:33:19 +00:00
from flask import Flask
2023-11-19 00:07:25 +00:00
from app.views import routes
2023-11-19 00:48:18 +00:00
from flask import jsonify
2023-11-20 10:33:19 +00:00
from app.settings import powerbars
from app.utils import get_baytech_status_outlet
2023-12-02 17:17:42 +00:00
from flask_socketio import SocketIO, emit
socketio = SocketIO(engineio_logger=True, logger=True, cors_allowed_origins="*")
@socketio.on('connect', namespace='/powerupdates')
def connect_handler():
print('connected')
emit('response', {'meta': 'WS connected'})
2023-11-18 23:23:17 +00:00
def create_app():
# create and configure the app
app = Flask(__name__)
app.config.from_pyfile('settings.py')
2023-11-19 00:07:25 +00:00
app.register_blueprint(routes)
2023-11-20 10:33:19 +00:00
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
2023-12-02 17:17:42 +00:00
socketio.init_app(app)
2023-11-19 00:07:25 +00:00
return app
2023-11-19 00:48:18 +00:00
2023-11-19 00:48:57 +00:00
app = create_app()
2023-11-19 00:48:18 +00:00
@app.errorhandler(403)
def not_authorised(e):
return jsonify(error="Not authorized"), 403
@app.errorhandler(500)
def internal_server_error(e):
return jsonify(error="Internal server error"), 500
2023-11-19 00:48:57 +00:00