annotate racc.py @ 2:0ecb388a0b90

start power code
author drewp@bigasterisk.com
date Sat, 04 Mar 2023 12:10:36 -0800
parents 04c8a1b3976b
children 3d7fc94a404a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
1 from starlette.applications import Starlette
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
2 from starlette.exceptions import HTTPException
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
3 from starlette.requests import Request
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
4 from starlette.responses import JSONResponse, HTMLResponse
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
5 from starlette.staticfiles import StaticFiles
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
6 from starlette.routing import Route, Mount
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
7 from starlette.templating import Jinja2Templates
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
8 import uvicorn
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
9 import psutil
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
10 from starlette_exporter import PrometheusMiddleware, handle_metrics
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
11 from prometheus_client import Summary, Gauge
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
12 import background_loop
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
13 from typing import List, Optional
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
14 import logging
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
15 import socket
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
16 import sys
2
0ecb388a0b90 start power code
drewp@bigasterisk.com
parents: 1
diff changeset
17 if psutil.OSX:
0
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
18 import idle_osx as idle
1
04c8a1b3976b volume r/w on linux+osx
drewp@bigasterisk.com
parents: 0
diff changeset
19 import volume_osx as volume
2
0ecb388a0b90 start power code
drewp@bigasterisk.com
parents: 1
diff changeset
20 import power_osx as power
0ecb388a0b90 start power code
drewp@bigasterisk.com
parents: 1
diff changeset
21 elif psutil.LINUX:
0
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
22 import idle_linux as idle
1
04c8a1b3976b volume r/w on linux+osx
drewp@bigasterisk.com
parents: 0
diff changeset
23 import volume_linux as volume
2
0ecb388a0b90 start power code
drewp@bigasterisk.com
parents: 1
diff changeset
24 import power_linux as power
0
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
25 else:
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
26 raise NotImplementedError(repr(sys.implementation))
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
27
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
28 hostname = socket.gethostname().split('.')[0]
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
29 logging.basicConfig(level=logging.INFO)
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
30 log = logging.getLogger()
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
31
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
32
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
33 def progname(cmdline: List[str]) -> Optional[str]:
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
34 if len(cmdline) < 1:
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
35 return None
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
36 if cmdline[-1].endswith('/steam'):
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
37 return 'steam'
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
38 if cmdline[0].endswith('/minecraft-launcher'):
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
39 return 'minecraft-launcher'
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
40 if cmdline[0].endswith('/java') and '--versionType' in cmdline:
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
41 return 'minecraft'
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
42
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
43
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
44 RACC_RUNNING = Gauge("racc_running", "program is running", ['host', 'prog'])
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
45 RACC_IDLE = Gauge("racc_idle", "desktop mouse/kb idle seconds", ['host'])
2
0ecb388a0b90 start power code
drewp@bigasterisk.com
parents: 1
diff changeset
46 RACC_SCREEN = Gauge("racc_screen", "screen in unlocked/on mode", ['host'])
0
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
47
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
48
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
49 def update_progs(first_run):
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
50 out = []
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
51 progs = set()
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
52 for proc in psutil.process_iter(['pid', 'name']):
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
53 try:
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
54 prog = progname(proc.cmdline())
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
55 if prog:
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
56 progs.add(prog)
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
57 except (psutil.AccessDenied, psutil.NoSuchProcess):
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
58 pass
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
59
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
60 for p in [
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
61 'minecraft',
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
62 'minecraft-launcher',
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
63 'steam',
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
64 ]:
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
65 RACC_RUNNING.labels(host=hostname, prog=p).set(p in progs)
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
66 RACC_IDLE.labels(host=hostname).set(idle.get_idle_seconds())
2
0ecb388a0b90 start power code
drewp@bigasterisk.com
parents: 1
diff changeset
67 RACC_SCREEN.labels(host=hostname).set(power.is_screen_on())
0
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
68
1
04c8a1b3976b volume r/w on linux+osx
drewp@bigasterisk.com
parents: 0
diff changeset
69 async def root(req: Request) -> HTMLResponse:
04c8a1b3976b volume r/w on linux+osx
drewp@bigasterisk.com
parents: 0
diff changeset
70 vol = await volume.get_volume()
04c8a1b3976b volume r/w on linux+osx
drewp@bigasterisk.com
parents: 0
diff changeset
71 return HTMLResponse(f'''controls for {hostname} whose volume is {vol}''')
0
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
72
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
73
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
74 def main():
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
75 app = Starlette(debug=True,
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
76 routes=[
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
77 Route('/', root),
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
78 ],
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
79 on_startup=[
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
80 lambda: background_loop.loop_forever(update_progs, 3),
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
81 ])
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
82
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
83 app.add_middleware(PrometheusMiddleware, app_name='racc')
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
84 app.add_route("/metrics", handle_metrics)
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
85 return app
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
86
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
87
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
88 if __name__ == "__main__":
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
89 uvicorn.run(main(), host='0.0.0.0', port=5150)