This commit is contained in:
parent
009e3e4933
commit
422a7efa6f
@ -28,7 +28,8 @@ class SensorStatusEnum(StatusEnum):
|
||||
|
||||
class Device(db.Model):
|
||||
__tablename__ = 'device'
|
||||
id = db.Column(db.UUID, primary_key=True)
|
||||
id = db.Column(db.Integer, primary_key=True)
|
||||
sensorid = db.Column(db.UUID, nullable=False)
|
||||
status = db.Column(db.Enum(DeviceStatusEnum), nullable=False)
|
||||
url = db.Column(db.String, nullable=False)
|
||||
lastupdate = db.Column(db.TIMESTAMP, nullable=False, server_default=func.now(), onupdate=func.current_timestamp())
|
||||
|
@ -16,6 +16,9 @@ __version__text__ = "1"
|
||||
deviceschema = DeviceSchema(many=False)
|
||||
|
||||
|
||||
LOGGER = logging.getLogger(__name__)
|
||||
|
||||
|
||||
@mqtt.on_message()
|
||||
def handle_status_message(client, userdata, message):
|
||||
data = dict(
|
||||
@ -24,10 +27,10 @@ def handle_status_message(client, userdata, message):
|
||||
)
|
||||
try:
|
||||
status_message = deviceschema.load(data['payload'], session=db.session, transient=True).data
|
||||
logging.info(f"Recieved status message from {data['payload']['id']}, persisting to db.")
|
||||
LOGGER.info(f"Recieved status message from {data['payload']['id']}, persisting to db.")
|
||||
db.session.merge(status_message)
|
||||
except Exception as e:
|
||||
db.session.rollback()
|
||||
logging.exception(e)
|
||||
LOGGER.exception(e)
|
||||
else:
|
||||
db.session.commit()
|
||||
|
115
src/resources.py
115
src/resources.py
@ -1,6 +1,11 @@
|
||||
#!/usr/bin/env python3
|
||||
import logging
|
||||
|
||||
from flask_restful import Resource
|
||||
from db import db
|
||||
from mqtt_flask_instance import mqtt
|
||||
import config
|
||||
import models
|
||||
import schemas
|
||||
|
||||
"""
|
||||
Flask Restful endpoints
|
||||
@ -10,3 +15,111 @@ __author__ = '@tormakris'
|
||||
__copyright__ = "Copyright 2020, Birbnetes Team"
|
||||
__module_name__ = "resources"
|
||||
__version__text__ = "1"
|
||||
|
||||
LOGGER = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class AllDevicesResource(Resource):
|
||||
"""
|
||||
Query and control all known devices
|
||||
"""
|
||||
alldeviceschema = schemas.DeviceSchema(many=True)
|
||||
|
||||
def get(self):
|
||||
"""
|
||||
Get all stored items
|
||||
:return:
|
||||
"""
|
||||
alldevices = models.Device.query.all()
|
||||
return self.alldeviceschema.dump(list(alldevices)), 200
|
||||
|
||||
def delete(self):
|
||||
"""
|
||||
Shut down every device
|
||||
:return:
|
||||
"""
|
||||
ids = db.session.query(models.Device.id).filter(models.Device.status != models.DeviceStatusEnum.offline)
|
||||
for d_id in ids:
|
||||
mqtt.publish(config.MQTT_COMMAND_TOPIC, {"deviceID": d_id, "command": "offline"})
|
||||
|
||||
def post(self):
|
||||
"""
|
||||
Bring every device online
|
||||
:return:
|
||||
"""
|
||||
ids = db.session.query(models.Device.id).filter(models.Device.status != models.DeviceStatusEnum.online)
|
||||
for d_id in ids:
|
||||
mqtt.publish(config.MQTT_COMMAND_TOPIC, {"deviceID": d_id, "command": "online"})
|
||||
|
||||
|
||||
class DeviceResource(Resource):
|
||||
"""
|
||||
Query and control a particular device
|
||||
"""
|
||||
deviceschema = schemas.DeviceSchema(many=False)
|
||||
|
||||
def get(self, deviceid: str):
|
||||
"""
|
||||
Query a device
|
||||
:param deviceid: UUID of device
|
||||
:return:
|
||||
"""
|
||||
device = models.Device.query.filter_by(id=deviceid).first_or_404()
|
||||
return self.deviceschema.dump(device), 200
|
||||
|
||||
def delete(self, deviceid: str):
|
||||
"""
|
||||
Shut down a device
|
||||
:param deviceid: UUID of device
|
||||
:return:
|
||||
"""
|
||||
device = db.session.query(models.Device.id).filter(str(models.Device.id) == deviceid).first()
|
||||
mqtt.publish(config.MQTT_COMMAND_TOPIC, {"deviceID": device, "command": "offline"})
|
||||
|
||||
def post(self, deviceid: str):
|
||||
"""
|
||||
Bring a device online
|
||||
:param deviceid: UUID of device
|
||||
:return:
|
||||
"""
|
||||
device = db.session.query(models.Device.id).filter(str(models.Device.id) == deviceid).first()
|
||||
mqtt.publish(config.MQTT_COMMAND_TOPIC, {"deviceID": device, "command": "offline"})
|
||||
|
||||
|
||||
class SensorResource(Resource):
|
||||
"""
|
||||
Query and control a particular sensor of a device
|
||||
"""
|
||||
sensorschema = schemas.SensorSchema(many=False)
|
||||
|
||||
def get(self, deviceid: str, sensorid: str):
|
||||
"""
|
||||
Query a sensor
|
||||
:param deviceid: UUID of device
|
||||
:param sensorid: UUID of sensor
|
||||
:return:
|
||||
"""
|
||||
sensor = models.Sensor.query.filter_by(device_id=deviceid, sensorid=sensorid).first_or_404()
|
||||
return self.sensorschema.dump(sensor)
|
||||
|
||||
def delete(self, deviceid: str, sensorid: str):
|
||||
"""
|
||||
Shut down a sensor of a device
|
||||
:param deviceid: UUID of device
|
||||
:param sensorid: UUID of sensor
|
||||
:return:
|
||||
"""
|
||||
sensor = db.session.query(models.Sensor.device_id, models.Sensor.id).filter(
|
||||
str(models.Sensor.device_id) == deviceid & & str(models.Sensor.id) == sensorid)
|
||||
mqtt.publish(config.MQTT_COMMAND_TOPIC, {"deviceID": sensor, "sensorID": sensor, "command": "offline"})
|
||||
|
||||
def post(self, deviceid: str, sensorid: str):
|
||||
"""
|
||||
Bring a sensor online
|
||||
:param deviceid: UUID of device
|
||||
:param sensorid: UUID of sensor
|
||||
:return:
|
||||
"""
|
||||
sensor = db.session.query(models.Sensor.device_id, models.Sensor.id).filter(
|
||||
str(models.Sensor.device_id) == deviceid & & str(models.Sensor.id) == sensorid)
|
||||
mqtt.publish(config.MQTT_COMMAND_TOPIC, {"deviceID": sensor, "sensorID": sensor, "command": "online"})
|
||||
|
@ -21,6 +21,7 @@ class SensorSchema(ma.SQLAlchemyAutoSchema):
|
||||
class Meta:
|
||||
model = models.Sensor
|
||||
include_fk = True
|
||||
exclude = ('id',)
|
||||
|
||||
|
||||
class DeviceSchema(ma.SQLAlchemyAutoSchema):
|
||||
|
Loading…
Reference in New Issue
Block a user