new client connection logic
- esp32 requests for image when ready to receive - server serves initial image on request
This commit is contained in:
@@ -17,6 +17,7 @@ Protocol:
|
|||||||
|
|
||||||
import argparse
|
import argparse
|
||||||
import asyncio
|
import asyncio
|
||||||
|
import json
|
||||||
import logging
|
import logging
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
@@ -68,17 +69,17 @@ async def handler(ws):
|
|||||||
|
|
||||||
configs = load_config(_config_path)
|
configs = load_config(_config_path)
|
||||||
img_idle = load_status_image(IMG_DIR / "idle.png")
|
img_idle = load_status_image(IMG_DIR / "idle.png")
|
||||||
|
current_img = img_idle
|
||||||
|
|
||||||
try:
|
alarms = [_prepare_alarm(entry) for entry in configs] if configs else []
|
||||||
await send_status_image(ws, img_idle)
|
|
||||||
|
|
||||||
if not configs:
|
async def alarm_ticker():
|
||||||
|
nonlocal current_img
|
||||||
|
if not alarms:
|
||||||
log.info("No alarms configured — idling forever")
|
log.info("No alarms configured — idling forever")
|
||||||
await asyncio.Future()
|
await asyncio.Future()
|
||||||
return
|
return
|
||||||
|
|
||||||
alarms = [_prepare_alarm(entry) for entry in configs]
|
|
||||||
|
|
||||||
while True:
|
while True:
|
||||||
for alarm in alarms:
|
for alarm in alarms:
|
||||||
if should_fire(alarm["config"]):
|
if should_fire(alarm["config"]):
|
||||||
@@ -88,13 +89,28 @@ async def handler(ws):
|
|||||||
alarm["last_fired"] = current_minute
|
alarm["last_fired"] = current_minute
|
||||||
log.info("Alarm firing: %s at %s",
|
log.info("Alarm firing: %s at %s",
|
||||||
alarm["config"]["alarm_time"], current_minute)
|
alarm["config"]["alarm_time"], current_minute)
|
||||||
await send_status_image(ws, alarm["img"])
|
current_img = alarm["img"]
|
||||||
|
await send_status_image(ws, current_img)
|
||||||
await stream_alarm(ws, alarm["pcm"], alarm["sr"],
|
await stream_alarm(ws, alarm["pcm"], alarm["sr"],
|
||||||
alarm["ch"], alarm["bits"])
|
alarm["ch"], alarm["bits"])
|
||||||
await send_status_image(ws, img_idle)
|
current_img = img_idle
|
||||||
|
await send_status_image(ws, current_img)
|
||||||
|
|
||||||
await asyncio.sleep(TICK_INTERVAL)
|
await asyncio.sleep(TICK_INTERVAL)
|
||||||
|
|
||||||
|
async def receiver():
|
||||||
|
async for msg in ws:
|
||||||
|
try:
|
||||||
|
data = json.loads(msg)
|
||||||
|
except (json.JSONDecodeError, TypeError):
|
||||||
|
continue
|
||||||
|
if data.get("type") == "request_image":
|
||||||
|
log.info("Client requested image — sending current (%d bytes)",
|
||||||
|
len(current_img))
|
||||||
|
await send_status_image(ws, current_img)
|
||||||
|
|
||||||
|
try:
|
||||||
|
await asyncio.gather(alarm_ticker(), receiver())
|
||||||
except websockets.exceptions.ConnectionClosed:
|
except websockets.exceptions.ConnectionClosed:
|
||||||
log.info("Client disconnected: %s:%d", remote[0], remote[1])
|
log.info("Client disconnected: %s:%d", remote[0], remote[1])
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user