1
0
Fork 0
ynh-apps_tools/appslib/logging_sender.py

71 lines
1.9 KiB
Python
Raw Normal View History

#!/usr/bin/env python3
import subprocess
import logging
import logging.handlers
def notify(message: str, channel: str, markdown: bool = False) -> None:
print(f"{channel} -> {message}")
chan_list = ["dev", "apps", "doc"]
if not any(channel in x for x in chan_list):
logging.error(
f"Provided chan '{channel}' is not part of the available options ('dev', 'apps', 'doc')."
)
for char in ["'", "`", "!", ";", "$"]:
message = message.replace(char, "")
command = [
"/var/www/webhooks/matrix-commander",
"--message",
message,
"--credentials",
"/var/www/webhooks/credentials.json",
"--store",
"/var/www/webhooks/store",
"--room",
f"yunohost-{channel}",
]
if markdown:
command.append("--markdown")
try:
subprocess.call(command, stdout=subprocess.DEVNULL)
except FileNotFoundError:
logging.warning("The logging sender tool /var/www/webhooks/matrix-commander does not exist.")
except subprocess.CalledProcessError as e:
logging.warning(
f"""Could not send a notification on {channel}.
Message: {message}
Error: {e}"""
)
2024-02-24 18:41:11 +01:00
2024-02-08 22:18:59 +01:00
class LogSenderHandler(logging.Handler):
2024-03-24 17:18:42 +01:00
def __init__(self) -> None:
logging.Handler.__init__(self)
self.is_logging = False
2024-03-24 17:18:42 +01:00
def emit(self, record: logging.LogRecord) -> None:
2024-02-24 18:41:11 +01:00
msg = f"[Apps tools error] {record.msg}"
notify(msg, "dev")
@classmethod
2024-03-24 17:18:42 +01:00
def add(cls, level: int = logging.ERROR) -> None:
if not logging.getLogger().handlers:
logging.basicConfig()
# create handler
handler = cls()
handler.setLevel(level)
# add the handler
logging.getLogger().handlers.append(handler)
2024-03-24 17:18:42 +01:00
def enable() -> None:
2024-02-08 22:18:59 +01:00
"""Enables the LogSenderHandler"""
LogSenderHandler.add(logging.ERROR)