annotate racc.py @ 3:3d7fc94a404a

a few more inputs; daemonize
author drewp@bigasterisk.com
date Wed, 08 Mar 2023 10:57:11 -0800
parents 0ecb388a0b90
children
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 import logging
3
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
2 import os
0
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
3 import socket
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
4 import sys
3
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
5
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
6 import background_loop
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
7 import daemonocle
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
8 import psutil
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
9 import uvicorn
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
10 from prometheus_client import Gauge
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
11 from starlette.applications import Starlette
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
12 from starlette.requests import Request
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
13 from starlette.responses import HTMLResponse
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
14 from starlette.routing import Route
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
15 from starlette.staticfiles import StaticFiles
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
16 from starlette_exporter import PrometheusMiddleware, handle_metrics
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
17 ''
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
18 import progs_all as progs
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
19
2
0ecb388a0b90 start power code
drewp@bigasterisk.com
parents: 1
diff changeset
20 if psutil.OSX:
3
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
21 import current_window_title_osx as current_window_title
0
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
22 import idle_osx as idle
2
0ecb388a0b90 start power code
drewp@bigasterisk.com
parents: 1
diff changeset
23 import power_osx as power
3
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
24 import volume_osx as volume
2
0ecb388a0b90 start power code
drewp@bigasterisk.com
parents: 1
diff changeset
25 elif psutil.LINUX:
3
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
26 import current_window_title_linux as current_window_title
0
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
27 import idle_linux as idle
3
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
28 import power_linux as power
1
04c8a1b3976b volume r/w on linux+osx
drewp@bigasterisk.com
parents: 0
diff changeset
29 import volume_linux as volume
0
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
30 else:
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
31 raise NotImplementedError(repr(sys.implementation))
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
32
3
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
33 DEBUG = os.environ.get('RACC_DEBUG', False)
0
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
34 logging.basicConfig(level=logging.INFO)
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
35 log = logging.getLogger()
3
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
36 hostname = socket.gethostname().split('.')[0]
0
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
37 RACC_RUNNING = Gauge("racc_running", "program is running", ['host', 'prog'])
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
38 RACC_IDLE = Gauge("racc_idle", "desktop mouse/kb idle seconds", ['host'])
3
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
39 RACC_SCREEN = Gauge("racc_screen_on", "screen in unlocked/on mode", ['host'])
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
40 RACC_CURRENT_WINDOW = Gauge("racc_current_window",
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
41 "label carries title; site is last part",
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
42 ['host', 'title', 'site'])
0
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
3
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
45 def update(first_run):
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
46 try:
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
47 for p, val in progs.get_running_progs().items():
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
48 RACC_RUNNING.labels(host=hostname, prog=p).set(val)
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
49 except Exception:
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
50 if DEBUG: raise
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
51
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
52 try:
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
53 RACC_IDLE.labels(host=hostname).set(idle.get_idle_seconds())
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
54 except Exception:
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
55 if DEBUG: raise
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
56
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
57 try:
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
58 RACC_SCREEN.labels(host=hostname).set(power.is_screen_on())
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
59 except Exception:
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
60 if DEBUG: raise
0
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
61
3
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
62 try:
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
63 title = current_window_title.get_current_window_title()
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
64 # chrome, at least on osx, adds icon to window title when it's playing audio
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
65 title = title.rstrip('🔊').strip()
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
66 # some websites choose to title like '<something> - <site name>'
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
67 last_section = title.split(' - ')[-1].strip()
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
68 if last_section in {'YouTube', 'Google Search', 'Google Chrome', 'Visual Studio Code', 'Roblox'}:
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
69 site = last_section.lower().replace(' ', '_')
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
70 else:
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
71 site = ''
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
72 RACC_CURRENT_WINDOW.clear()
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
73 RACC_CURRENT_WINDOW.labels(host=hostname, title=title,
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
74 site=site).set(1)
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
75 except Exception:
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
76 if DEBUG: raise
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
77
0
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
78
1
04c8a1b3976b volume r/w on linux+osx
drewp@bigasterisk.com
parents: 0
diff changeset
79 async def root(req: Request) -> HTMLResponse:
04c8a1b3976b volume r/w on linux+osx
drewp@bigasterisk.com
parents: 0
diff changeset
80 vol = await volume.get_volume()
04c8a1b3976b volume r/w on linux+osx
drewp@bigasterisk.com
parents: 0
diff changeset
81 return HTMLResponse(f'''controls for {hostname} whose volume is {vol}''')
0
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
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
84 def main():
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
85 app = Starlette(debug=True,
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
86 routes=[
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
87 Route('/', root),
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
88 ],
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
89 on_startup=[
3
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
90 lambda: background_loop.loop_forever(update, 5),
0
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
91 ])
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
92
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
93 app.add_middleware(PrometheusMiddleware, app_name='racc')
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
94 app.add_route("/metrics", handle_metrics)
3
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
95 uvicorn.run(app, host='0.0.0.0', port=5150)
0
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
96
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
97
05bdded21d38 start: progs and idle time
drewp@bigasterisk.com
parents:
diff changeset
98 if __name__ == "__main__":
3
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
99 d = daemonocle.Daemon(
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
100 worker=main,
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
101 work_dir='.',
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
102 pid_file='/tmp/racc.pid',
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
103 detach=True,
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
104 )
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
105 d.stop(timeout=1, force=True)
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
106 if DEBUG:
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
107 main()
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
108 else:
3d7fc94a404a a few more inputs; daemonize
drewp@bigasterisk.com
parents: 2
diff changeset
109 d.cli()