from dotenv import load_dotenv
load_dotenv ( ) # take environment variables from .env.
import asyncio
import subprocess
import platform
from . logs import setup_logging
from . logs import logger
setup_logging ( )
def get_kernel_messages ( ) :
"""
Is this the way to do this ?
"""
current_platform = platform . system ( )
if current_platform == " Darwin " :
process = subprocess . Popen (
[ " syslog " ] , stdout = subprocess . PIPE , stderr = subprocess . DEVNULL
)
output , _ = process . communicate ( )
return output . decode ( " utf-8 " )
elif current_platform == " Linux " :
with open ( " /var/log/dmesg " , " r " ) as file :
return file . read ( )
else :
logger . info ( " Unsupported platform. " )
def custom_filter ( message ) :
# Check for {TO_INTERPRETER{ message here }TO_INTERPRETER} pattern
if " { TO_INTERPRETER { " in message and " }TO_INTERPRETER} " in message :
start = message . find ( " { TO_INTERPRETER { " ) + len ( " { TO_INTERPRETER { " )
end = message . find ( " }TO_INTERPRETER} " , start )
return message [ start : end ]
# Check for USB mention
# elif 'USB' in message:
# return message
# # Check for network related keywords
# elif any(keyword in message for keyword in ['network', 'IP', 'internet', 'LAN', 'WAN', 'router', 'switch']) and "networkStatusForFlags" not in message:
# return message
else :
return None
last_messages = " "
def check_filtered_kernel ( ) :
messages = get_kernel_messages ( )
if messages is None :
return " " # Handle unsupported platform or error in fetching kernel messages
global last_messages
messages . replace ( last_messages , " " )
messages = messages . split ( " \n " )
filtered_messages = [ ]
for message in messages :
if custom_filter ( message ) :
filtered_messages . append ( message )
return " \n " . join ( filtered_messages )
async def put_kernel_messages_into_queue ( queue ) :
while True :
text = check_filtered_kernel ( )
if text :
if isinstance ( queue , asyncio . Queue ) :
await queue . put ( { " role " : " computer " , " type " : " console " , " start " : True } )
await queue . put (
{
" role " : " computer " ,
" type " : " console " ,
" format " : " output " ,
" content " : text ,
}
)
await queue . put ( { " role " : " computer " , " type " : " console " , " end " : True } )
else :
queue . put ( { " role " : " computer " , " type " : " console " , " start " : True } )
queue . put (
{
" role " : " computer " ,
" type " : " console " ,
" format " : " output " ,
" content " : text ,
}
)
queue . put ( { " role " : " computer " , " type " : " console " , " end " : True } )
await asyncio . sleep ( 5 )