Adding checks for dmesg log access and creation of it if not accessible.

pull/239/head
Robert Brisita 10 months ago
parent 1324789123
commit 471b5f8a84

@ -5,12 +5,17 @@ load_dotenv() # take environment variables from .env.
import asyncio import asyncio
import subprocess import subprocess
import platform import platform
import os
import shutil
from .logs import setup_logging from .logs import setup_logging
from .logs import logger from .logs import logger
setup_logging() setup_logging()
# dmesg process created at boot time
dmesg_proc = None
def get_kernel_messages(): def get_kernel_messages():
""" """
@ -25,12 +30,37 @@ def get_kernel_messages():
output, _ = process.communicate() output, _ = process.communicate()
return output.decode("utf-8") return output.decode("utf-8")
elif current_platform == "Linux": elif current_platform == "Linux":
with open("/var/log/dmesg", "r") as file: log_path = get_dmesg_log_path()
with open(log_path, 'r') as file:
return file.read() return file.read()
else: else:
logger.info("Unsupported platform.") logger.info("Unsupported platform.")
def get_dmesg_log_path():
"""
Check for the existence of a readable dmesg log file and return its path.
Create an accessible path if not found.
"""
if os.access('/var/log/dmesg', os.F_OK | os.R_OK):
return '/var/log/dmesg'
global dmesg_proc
dmesg_log_path = '/tmp/dmesg'
if dmesg_proc:
return dmesg_log_path
logger.info("Created /tmp/dmesg.")
subprocess.run(['touch', dmesg_log_path])
dmesg_path = shutil.which('dmesg')
if dmesg_path:
logger.info(f"Writing to {dmesg_log_path} from dmesg.")
dmesg_proc = subprocess.Popen([dmesg_path, '--follow'], text=True, stdout=subprocess.PIPE)
subprocess.Popen(['tee', dmesg_log_path], text=True, stdin=dmesg_proc.stdout, stdout=subprocess.DEVNULL)
return dmesg_log_path
def custom_filter(message): def custom_filter(message):
# Check for {TO_INTERPRETER{ message here }TO_INTERPRETER} pattern # Check for {TO_INTERPRETER{ message here }TO_INTERPRETER} pattern
if "{TO_INTERPRETER{" in message and "}TO_INTERPRETER}" in message: if "{TO_INTERPRETER{" in message and "}TO_INTERPRETER}" in message:

Loading…
Cancel
Save