This commit is contained in:
@@ -1,6 +1,5 @@
|
||||
#!/usr/bin/env python3
|
||||
import logging
|
||||
from mqtt_flask_instance import mqtt
|
||||
from app import app
|
||||
import config
|
||||
from db import db
|
||||
from schemas import DeviceSchema, SensorSchema
|
||||
@@ -17,31 +16,29 @@ __version__text__ = "1"
|
||||
deviceschema = DeviceSchema(many=False)
|
||||
sensorschema = SensorSchema(many=False)
|
||||
|
||||
LOGGER = logging.getLogger(__name__)
|
||||
|
||||
|
||||
def handle_status_message(client, userdata, message):
|
||||
data = dict(
|
||||
topic=message.topic,
|
||||
payload=message.payload.decode()
|
||||
)
|
||||
LOGGER.info(data)
|
||||
app.logger.info(data)
|
||||
try:
|
||||
ids = data['topic'].replace(f"{config.MQTT_STATUS_TOPIC}/", "").split("/")
|
||||
if len(ids) == 1:
|
||||
data['payload']['deviceID'] = ids[0]
|
||||
status_message = deviceschema.load(data['payload'], session=db.session, transient=True).data
|
||||
LOGGER.info(f"Recieved status message from {data['payload']['deviceID']}, persisting to db.")
|
||||
app.logger.info(f"Recieved status message from {data['payload']['deviceID']}, persisting to db.")
|
||||
db.session.merge(status_message)
|
||||
else:
|
||||
if len(ids) == 2:
|
||||
data['payload']['deviceID'] = ids[0]
|
||||
data['payload']['sensorID'] = ids[1]
|
||||
status_message = sensorschema.load(data['payload'], session=db.session, transient=True).data
|
||||
LOGGER.info(f"Recieved status message from sensor {data['payload']['sensorID']}, persisting to db.")
|
||||
app.logger.info(f"Recieved status message from sensor {data['payload']['sensorID']}, persisting to db.")
|
||||
db.session.merge(status_message)
|
||||
except Exception as e:
|
||||
db.session.rollback()
|
||||
LOGGER.exception(e)
|
||||
app.logger.exception(e)
|
||||
else:
|
||||
db.session.commit()
|
||||
|
||||
Reference in New Issue
Block a user