annotate light_bridge.py @ 15:61d4ccecfed8

rough refactor
author drewp@bigasterisk.com
date Sun, 28 Jan 2024 21:18:01 -0800
parents e3dbd04dab96
children cee43f550577
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
drewp@bigasterisk.com
parents:
diff changeset
1 """
drewp@bigasterisk.com
parents:
diff changeset
2 replaces a lot of mqtt_to_rdf and rdf_to_mqtt
drewp@bigasterisk.com
parents:
diff changeset
3 """
11
028ed39aa78f more ts types; attempted multiplayer but the change events are managed wrong
drewp@bigasterisk.com
parents: 10
diff changeset
4 import asyncio
0
drewp@bigasterisk.com
parents:
diff changeset
5 import json
drewp@bigasterisk.com
parents:
diff changeset
6 import logging
7
05fb0319eb64 cleanup
drewp@bigasterisk.com
parents: 6
diff changeset
7 import time
2
c6fd04e07db0 refactor light.py
drewp@bigasterisk.com
parents: 1
diff changeset
8 from functools import partial
10
140633abfa2a route colors from PUT to Light.setColor
drewp@bigasterisk.com
parents: 7
diff changeset
9 from color import Color
0
drewp@bigasterisk.com
parents:
diff changeset
10
drewp@bigasterisk.com
parents:
diff changeset
11 from patchablegraph import PatchableGraph
drewp@bigasterisk.com
parents:
diff changeset
12 from patchablegraph.handler import GraphEvents, StaticGraph
2
c6fd04e07db0 refactor light.py
drewp@bigasterisk.com
parents: 1
diff changeset
13 from sse_starlette.sse import EventSourceResponse
0
drewp@bigasterisk.com
parents:
diff changeset
14 from starlette.applications import Starlette
drewp@bigasterisk.com
parents:
diff changeset
15 from starlette.requests import Request
drewp@bigasterisk.com
parents:
diff changeset
16 from starlette.responses import JSONResponse
drewp@bigasterisk.com
parents:
diff changeset
17 from starlette.routing import Route
drewp@bigasterisk.com
parents:
diff changeset
18 from starlette_exporter import PrometheusMiddleware, handle_metrics
2
c6fd04e07db0 refactor light.py
drewp@bigasterisk.com
parents: 1
diff changeset
19
7
05fb0319eb64 cleanup
drewp@bigasterisk.com
parents: 6
diff changeset
20 from light import Lights
14
e3dbd04dab96 add mqtt; talk to first light (no throttling)
drewp@bigasterisk.com
parents: 11
diff changeset
21 from mqtt_io import MqttIo
0
drewp@bigasterisk.com
parents:
diff changeset
22 logging.basicConfig(level=logging.INFO)
drewp@bigasterisk.com
parents:
diff changeset
23 log = logging.getLogger()
drewp@bigasterisk.com
parents:
diff changeset
24
drewp@bigasterisk.com
parents:
diff changeset
25
drewp@bigasterisk.com
parents:
diff changeset
26 async def output(lights: Lights, request: Request) -> JSONResponse:
drewp@bigasterisk.com
parents:
diff changeset
27 light = lights.byName(request.query_params['light'])
10
140633abfa2a route colors from PUT to Light.setColor
drewp@bigasterisk.com
parents: 7
diff changeset
28 body = (await request.body()).decode('utf8')
140633abfa2a route colors from PUT to Light.setColor
drewp@bigasterisk.com
parents: 7
diff changeset
29 await light.setColor(Color.fromHex(body))
5
7eeda7f4f9cd spell it to_dict, for compat with DataClassJsonMixin
drewp@bigasterisk.com
parents: 2
diff changeset
30 return JSONResponse(light.to_dict())
0
drewp@bigasterisk.com
parents:
diff changeset
31
drewp@bigasterisk.com
parents:
diff changeset
32
drewp@bigasterisk.com
parents:
diff changeset
33 async def table(lights: Lights, req: Request) -> EventSourceResponse:
drewp@bigasterisk.com
parents:
diff changeset
34
11
028ed39aa78f more ts types; attempted multiplayer but the change events are managed wrong
drewp@bigasterisk.com
parents: 10
diff changeset
35 def updateMessage():
028ed39aa78f more ts types; attempted multiplayer but the change events are managed wrong
drewp@bigasterisk.com
parents: 10
diff changeset
36 return json.dumps({'now': time.time()} | lights.to_dict())
028ed39aa78f more ts types; attempted multiplayer but the change events are managed wrong
drewp@bigasterisk.com
parents: 10
diff changeset
37
0
drewp@bigasterisk.com
parents:
diff changeset
38 async def g():
11
028ed39aa78f more ts types; attempted multiplayer but the change events are managed wrong
drewp@bigasterisk.com
parents: 10
diff changeset
39 yield updateMessage()
028ed39aa78f more ts types; attempted multiplayer but the change events are managed wrong
drewp@bigasterisk.com
parents: 10
diff changeset
40 async for ping in lights.changes(): # broken if there's more than one caller!
028ed39aa78f more ts types; attempted multiplayer but the change events are managed wrong
drewp@bigasterisk.com
parents: 10
diff changeset
41 log.info('send table event')
028ed39aa78f more ts types; attempted multiplayer but the change events are managed wrong
drewp@bigasterisk.com
parents: 10
diff changeset
42 yield updateMessage()
028ed39aa78f more ts types; attempted multiplayer but the change events are managed wrong
drewp@bigasterisk.com
parents: 10
diff changeset
43 await asyncio.sleep(.5) # slow down the inf loop
0
drewp@bigasterisk.com
parents:
diff changeset
44
drewp@bigasterisk.com
parents:
diff changeset
45 return EventSourceResponse(g())
drewp@bigasterisk.com
parents:
diff changeset
46
drewp@bigasterisk.com
parents:
diff changeset
47
drewp@bigasterisk.com
parents:
diff changeset
48 def main():
14
e3dbd04dab96 add mqtt; talk to first light (no throttling)
drewp@bigasterisk.com
parents: 11
diff changeset
49 mqtt = MqttIo()
e3dbd04dab96 add mqtt; talk to first light (no throttling)
drewp@bigasterisk.com
parents: 11
diff changeset
50 lights = Lights(mqtt)
0
drewp@bigasterisk.com
parents:
diff changeset
51 graph = PatchableGraph()
drewp@bigasterisk.com
parents:
diff changeset
52 app = Starlette(debug=True,
drewp@bigasterisk.com
parents:
diff changeset
53 routes=[
drewp@bigasterisk.com
parents:
diff changeset
54 Route('/api/output', partial(output, lights), methods=['PUT']),
drewp@bigasterisk.com
parents:
diff changeset
55 Route('/api/table', partial(table, lights)),
drewp@bigasterisk.com
parents:
diff changeset
56 Route('/api/graph', StaticGraph(graph)),
drewp@bigasterisk.com
parents:
diff changeset
57 Route('/api/graph/events', GraphEvents(graph)),
drewp@bigasterisk.com
parents:
diff changeset
58 ])
drewp@bigasterisk.com
parents:
diff changeset
59
drewp@bigasterisk.com
parents:
diff changeset
60 app.add_middleware(PrometheusMiddleware, app_name='light-bridge')
drewp@bigasterisk.com
parents:
diff changeset
61 app.add_route("/metrics", handle_metrics)
drewp@bigasterisk.com
parents:
diff changeset
62
drewp@bigasterisk.com
parents:
diff changeset
63 return app
drewp@bigasterisk.com
parents:
diff changeset
64
drewp@bigasterisk.com
parents:
diff changeset
65
drewp@bigasterisk.com
parents:
diff changeset
66 app = main()