pikvm/pikvm#1342: Verbose platform info in /api/info

This commit is contained in:
Maxim Devaev 2024-07-27 14:07:26 +03:00
parent 6a665cd62f
commit 7e42d32007
5 changed files with 40 additions and 9 deletions

View File

@ -123,6 +123,7 @@ run: testenv $(TESTENV_GPIO)
&& cp -r /usr/share/kvmd/configs.default/nginx/* /etc/kvmd/nginx \ && cp -r /usr/share/kvmd/configs.default/nginx/* /etc/kvmd/nginx \
&& cp -a /testenv/.ssl/nginx /etc/kvmd/nginx/ssl \ && cp -a /testenv/.ssl/nginx /etc/kvmd/nginx/ssl \
&& cp -a /testenv/.ssl/vnc /etc/kvmd/vnc/ssl \ && cp -a /testenv/.ssl/vnc /etc/kvmd/vnc/ssl \
&& cp /testenv/platform /usr/share/kvmd \
&& cp /usr/share/kvmd/configs.default/kvmd/*.yaml /etc/kvmd \ && cp /usr/share/kvmd/configs.default/kvmd/*.yaml /etc/kvmd \
&& cp /usr/share/kvmd/configs.default/kvmd/*passwd /etc/kvmd \ && cp /usr/share/kvmd/configs.default/kvmd/*passwd /etc/kvmd \
&& cp /usr/share/kvmd/configs.default/kvmd/*.secret /etc/kvmd \ && cp /usr/share/kvmd/configs.default/kvmd/*.secret /etc/kvmd \
@ -149,6 +150,7 @@ run-cfg: testenv
-it $(TESTENV_IMAGE) /bin/bash -c " \ -it $(TESTENV_IMAGE) /bin/bash -c " \
cp -a /testenv/.ssl/nginx /etc/kvmd/nginx/ssl \ cp -a /testenv/.ssl/nginx /etc/kvmd/nginx/ssl \
&& cp -a /testenv/.ssl/vnc /etc/kvmd/vnc/ssl \ && cp -a /testenv/.ssl/vnc /etc/kvmd/vnc/ssl \
&& cp /testenv/platform /usr/share/kvmd \
&& cp /usr/share/kvmd/configs.default/kvmd/*.yaml /etc/kvmd \ && cp /usr/share/kvmd/configs.default/kvmd/*.yaml /etc/kvmd \
&& cp /usr/share/kvmd/configs.default/kvmd/*passwd /etc/kvmd \ && cp /usr/share/kvmd/configs.default/kvmd/*passwd /etc/kvmd \
&& cp /usr/share/kvmd/configs.default/kvmd/*.secret /etc/kvmd \ && cp /usr/share/kvmd/configs.default/kvmd/*.secret /etc/kvmd \
@ -171,6 +173,7 @@ run-ipmi: testenv
-it $(TESTENV_IMAGE) /bin/bash -c " \ -it $(TESTENV_IMAGE) /bin/bash -c " \
cp -a /testenv/.ssl/nginx /etc/kvmd/nginx/ssl \ cp -a /testenv/.ssl/nginx /etc/kvmd/nginx/ssl \
&& cp -a /testenv/.ssl/vnc /etc/kvmd/vnc/ssl \ && cp -a /testenv/.ssl/vnc /etc/kvmd/vnc/ssl \
&& cp /testenv/platform /usr/share/kvmd \
&& cp /usr/share/kvmd/configs.default/kvmd/*.yaml /etc/kvmd \ && cp /usr/share/kvmd/configs.default/kvmd/*.yaml /etc/kvmd \
&& cp /usr/share/kvmd/configs.default/kvmd/*passwd /etc/kvmd \ && cp /usr/share/kvmd/configs.default/kvmd/*passwd /etc/kvmd \
&& cp /usr/share/kvmd/configs.default/kvmd/*.secret /etc/kvmd \ && cp /usr/share/kvmd/configs.default/kvmd/*.secret /etc/kvmd \
@ -193,6 +196,7 @@ run-vnc: testenv
-it $(TESTENV_IMAGE) /bin/bash -c " \ -it $(TESTENV_IMAGE) /bin/bash -c " \
cp -a /testenv/.ssl/nginx /etc/kvmd/nginx/ssl \ cp -a /testenv/.ssl/nginx /etc/kvmd/nginx/ssl \
&& cp -a /testenv/.ssl/vnc /etc/kvmd/vnc/ssl \ && cp -a /testenv/.ssl/vnc /etc/kvmd/vnc/ssl \
&& cp /testenv/platform /usr/share/kvmd \
&& cp /usr/share/kvmd/configs.default/kvmd/*.yaml /etc/kvmd \ && cp /usr/share/kvmd/configs.default/kvmd/*.yaml /etc/kvmd \
&& cp /usr/share/kvmd/configs.default/kvmd/*passwd /etc/kvmd \ && cp /usr/share/kvmd/configs.default/kvmd/*passwd /etc/kvmd \
&& cp /usr/share/kvmd/configs.default/kvmd/*.secret /etc/kvmd \ && cp /usr/share/kvmd/configs.default/kvmd/*.secret /etc/kvmd \

View File

@ -252,11 +252,11 @@ for _variant in "${_variants[@]}"; do
fi fi
mkdir -p \"\$pkgdir/usr/share/kvmd\" mkdir -p \"\$pkgdir/usr/share/kvmd\"
local _device=\"\$pkgdir/usr/share/kvmd/device\" local _platform=\"\$pkgdir/usr/share/kvmd/platform\"
rm -f \"\$_device\" rm -f \"\$_platform\"
echo PIKVM_BASE=$_base > \"\$_device\" echo PIKVM_MODEL=$_base > \"\$_platform\"
echo PIKVM_VIDEO=$_video >> \"\$_device\" echo PIKVM_VIDEO=$_video >> \"\$_platform\"
echo PIKVM_BOARD=$_board >> \"\$_device\" echo PIKVM_BOARD=$_board >> \"\$_platform\"
chmod 444 \"\$_device\" chmod 444 \"\$_platform\"
}" }"
done done

View File

@ -382,6 +382,7 @@ def _get_config_scheme() -> dict:
"meta": Option("/etc/kvmd/meta.yaml", type=valid_abs_file), "meta": Option("/etc/kvmd/meta.yaml", type=valid_abs_file),
"extras": Option("/usr/share/kvmd/extras", type=valid_abs_dir), "extras": Option("/usr/share/kvmd/extras", type=valid_abs_dir),
"hw": { "hw": {
"platform": Option("/usr/share/kvmd/platform", type=valid_abs_file, unpack_as="platform_path"),
"vcgencmd_cmd": Option(["/usr/bin/vcgencmd"], type=valid_command), "vcgencmd_cmd": Option(["/usr/bin/vcgencmd"], type=valid_command),
"ignore_past": Option(False, type=valid_bool), "ignore_past": Option(False, type=valid_bool),
"state_poll": Option(5.0, type=valid_float_f01), "state_poll": Option(5.0, type=valid_float_f01),

View File

@ -47,11 +47,13 @@ _RetvalT = TypeVar("_RetvalT")
class HwInfoSubmanager(BaseInfoSubmanager): class HwInfoSubmanager(BaseInfoSubmanager):
def __init__( def __init__(
self, self,
platform_path: str,
vcgencmd_cmd: list[str], vcgencmd_cmd: list[str],
ignore_past: bool, ignore_past: bool,
state_poll: float, state_poll: float,
) -> None: ) -> None:
self.__platform_path = platform_path
self.__vcgencmd_cmd = vcgencmd_cmd self.__vcgencmd_cmd = vcgencmd_cmd
self.__ignore_past = ignore_past self.__ignore_past = ignore_past
self.__state_poll = state_poll self.__state_poll = state_poll
@ -60,12 +62,16 @@ class HwInfoSubmanager(BaseInfoSubmanager):
async def get_state(self) -> dict: async def get_state(self) -> dict:
( (
model, serial, throttling, base, serial,
cpu_percent, cpu_temp, (model, video, board),
throttling,
cpu_percent,
cpu_temp,
(mem_percent, mem_total, mem_available), (mem_percent, mem_total, mem_available),
) = await asyncio.gather( ) = await asyncio.gather(
self.__read_dt_file("model"), self.__read_dt_file("model"),
self.__read_dt_file("serial-number"), self.__read_dt_file("serial-number"),
self.__read_platform_file(),
self.__get_throttling(), self.__get_throttling(),
self.__get_cpu_percent(), self.__get_cpu_percent(),
self.__get_cpu_temp(), self.__get_cpu_temp(),
@ -74,8 +80,11 @@ class HwInfoSubmanager(BaseInfoSubmanager):
return { return {
"platform": { "platform": {
"type": "rpi", "type": "rpi",
"base": model, "base": base,
"serial": serial, "serial": serial,
"model": model,
"video": video,
"board": board,
}, },
"health": { "health": {
"temp": { "temp": {
@ -114,6 +123,20 @@ class HwInfoSubmanager(BaseInfoSubmanager):
return None return None
return self.__dt_cache[name] return self.__dt_cache[name]
async def __read_platform_file(self) -> tuple[(str | None), (str | None), (str | None)]:
try:
text = await aiotools.read_file(self.__platform_path)
parsed: dict[str, str] = {}
for row in text.split("\n"):
row = row.strip()
if row:
(key, value) = row.split("=", 1)
parsed[key.strip()] = value.strip()
return (parsed["PIKVM_MODEL"], parsed["PIKVM_VIDEO"], parsed["PIKVM_BOARD"])
except Exception:
get_logger(0).exception("Can't read device model")
return (None, None, None)
async def __get_cpu_temp(self) -> (float | None): async def __get_cpu_temp(self) -> (float | None):
temp_path = f"{env.SYSFS_PREFIX}/sys/class/thermal/thermal_zone0/temp" temp_path = f"{env.SYSFS_PREFIX}/sys/class/thermal/thermal_zone0/temp"
try: try:

3
testenv/platform Normal file
View File

@ -0,0 +1,3 @@
PIKVM_MODEL=test_model
PIKVM_VIDEO=test_video
PIKVM_BOARD=test_board