From aaf275b8d1ee89e752213b4e219e8f97e626dd15 Mon Sep 17 00:00:00 2001 From: Trent Palmer Date: Wed, 3 Feb 2021 09:58:49 -0800 Subject: [PATCH] initial commit --- django_sendxmpp_handler.py | 30 +++++++++++++++++++++++++++++- logging_settings.py | 14 ++++++++++++++ settings.py | 23 +++++++++++++++++++++++ 3 files changed, 66 insertions(+), 1 deletion(-) create mode 100644 logging_settings.py create mode 100644 settings.py diff --git a/django_sendxmpp_handler.py b/django_sendxmpp_handler.py index d0cf0f3..b27a5d9 100644 --- a/django_sendxmpp_handler.py +++ b/django_sendxmpp_handler.py @@ -1,2 +1,30 @@ +# mysite/mysite/django_sendxmpp_handler.py + from logging import Handler -from os import popen \ No newline at end of file +from os import popen +from mysite.settings import LOGGING_XMPP_CONFIG + + +class SENDXMPPHandler(Handler): + def emit(self, record): + try: + message = self.format(record) + + shell_command = "echo '{}' | {} -u {} -j {} -p {} {} --tls-ca-path='/etc/ssl/certs'".format( + message, + LOGGING_XMPP_CONFIG['LOGGING_XMPP_COMMAND'], + LOGGING_XMPP_CONFIG['LOGGING_XMPP_SENDER'], + LOGGING_XMPP_CONFIG['LOGGING_XMPP_SERVER'], + LOGGING_XMPP_CONFIG['LOGGING_XMPP_PASSWORD'], + LOGGING_XMPP_CONFIG['LOGGING_XMPP_RECIPIENT'] + ) + if LOGGING_XMPP_CONFIG['LOGGING_XMPP_USE_TLS'] == '1': + shell_command += ' -t' + + p = popen(shell_command, "w") + status = p.close() + if status: + print("sendxmpp_handler exit status", status) + + except Exception: + self.handleError(record) diff --git a/logging_settings.py b/logging_settings.py new file mode 100644 index 0000000..6a3e281 --- /dev/null +++ b/logging_settings.py @@ -0,0 +1,14 @@ +# mysite/mysite/logging_settings.py + +from copy import deepcopy +from django.utils.log import DEFAULT_LOGGING + + +def init_logging_settings(): + logging_dict = deepcopy(DEFAULT_LOGGING) + logging_dict['handlers']['send_xmpp'] = { + "level": "ERROR", + "class": "mysite.sendxmpp_handler.SENDXMPPHandler" + } + logging_dict['loggers']['django']['handlers'].append("send_xmpp") + return logging_dict diff --git a/settings.py b/settings.py new file mode 100644 index 0000000..fcf00f5 --- /dev/null +++ b/settings.py @@ -0,0 +1,23 @@ +# mysite/mysite/settings.py + +from .logging_settings import init_logging_settings +import os +from dotenv import load_dotenv +load_dotenv() + +LOGGING_XMPP_CONFIG = { + 'LOGGING_XMPP_SERVER': str(os.getenv('LOGGING_XMPP_SERVER')), + + 'LOGGING_XMPP_SENDER': str(os.getenv('LOGGING_XMPP_SENDER')), + + 'LOGGING_XMPP_PASSWORD': str(os.getenv('LOGGING_XMPP_PASSWORD')), + + 'LOGGING_XMPP_RECIPIENT': str(os.getenv('LOGGING_XMPP_RECIPIENT')), + + # '/usr/bin/site_perl/sendxmpp' or maybe '/usr/bin/sendxmpp' + 'LOGGING_XMPP_COMMAND': str(os.getenv('LOGGING_XMPP_COMMAND')), + + 'LOGGING_XMPP_USE_TLS': str(os.getenv('LOGGING_XMPP_USE_TLS')) +} + +LOGGING = init_logging_settings()