Handle starting command

This commit is contained in:
2025-12-31 16:04:06 +01:00
parent aeb4bd74d9
commit 6e781b464a
4 changed files with 102 additions and 56 deletions

View File

@@ -6,6 +6,7 @@ import requests
from dotenv import load_dotenv
from flask import Flask, jsonify, request
from controllers.GameController import GameController
from hardware.light.lora_light_sensor_reader import LoraLightSensorReader
from hardware.rfid.reader import RfidReader
from services.clock_service import ClockService
@@ -29,61 +30,41 @@ api_username = os.environ.get("API_USERNAME")
api_password = os.environ.get("API_PASSWORD")
app = Flask(__name__)
rfid_reader = RfidReader("/dev/serial0", 9600)
light_sensor_reader = LoraLightSensorReader("/dev/ttyUSB1", 9600)
local_broker = MQTTService(
local_broker_address,
local_broker_port,
client_id="system",
username=local_username,
password=local_password,
)
api_broker = MQTTService(
api_broker_address,
api_broker_port,
client_id=client_id,
username=api_username,
password=api_password,
)
forward_service = ForwarderService(local_broker, api_broker)
game_service = GameService()
@app.route("/command/party/start", methods=['POST'])
def start_party():
try:
data = request.get_json()
print(f"Received data : {data}")
print("Party started!")
return jsonify({"status": "ok", "message": "Party started"}), 200
except Exception as ex:
print(ex)
return jsonify({"status": "error", "message": f"An error occurred : {ex}"}), 500
@app.route("/command/party/play", methods=['POST'])
def make_move():
try:
game_service.make_move()
return jsonify({"status": "ok", "message": "Party started"}), 200
except Exception as ex:
print(ex)
return jsonify({"status": "error", "message": f"An error occurred : {ex}"}), 500
forwarder_service = None
if __name__ == "__main__":
try :
forward_service.register_forwarder(client_id, "/system/sensor/rfid", f"/customer/telemetry/rfid")
forward_service.register_forwarder(client_id, "/system/sensor/light", f"/customer/telemetry/light")
forward_service.register_forwarder(client_id, "/system/sensor/gps", f"/customer/telemetry/gps")
rfid_reader = RfidReader("/dev/serial0", 9600)
light_sensor_reader = LoraLightSensorReader("/dev/ttyUSB1", 9600)
local_broker = MQTTService(
local_broker_address,
local_broker_port,
client_id="system",
username=local_username,
password=local_password,
)
api_broker = MQTTService(
api_broker_address,
api_broker_port,
client_id=client_id,
username=api_username,
password=api_password,
)
forwarder_service = ForwarderService(local_broker, api_broker)
game_controller = GameController(app)
forwarder_service.register_forwarder(client_id, "/system/sensor/rfid", f"/customer/telemetry/rfid")
forwarder_service.register_forwarder(client_id, "/system/sensor/light", f"/customer/telemetry/light")
forwarder_service.register_forwarder(client_id, "/system/sensor/gps", f"/customer/telemetry/gps")
rfid_reader.subscribe(lambda uid: local_broker.publish("/system/sensor/rfid", str(uid), 1))
light_sensor_reader.subscribe(lambda light_value: local_broker.publish("/system/sensor/light", str(light_value), 0))
forward_service.start_all()
forwarder_service.start_all()
rfid_reader.start()
light_sensor_reader.start()
@@ -93,12 +74,12 @@ if __name__ == "__main__":
except KeyboardInterrupt:
print("Keyboard interrupt. Stopping app...")
game_service.stop()
forward_service.stop_all()
#game_service.stop()
forwarder_service.stop_all()
exit()
except Exception as e:
print(e)
game_service.stop()
forward_service.stop_all()
#game_service.stop()
forwarder_service.stop_all()
exit()