MonScoDocEssai/app/scodoc/notes_log.py

88 lines
2.4 KiB
Python
Raw Normal View History

2020-09-26 16:19:37 +02:00
# -*- mode: python -*-
# -*- coding: utf-8 -*-
2021-02-02 14:49:49 +01:00
import os
import time
2020-09-26 16:19:37 +02:00
import traceback
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
from email.header import Header
2021-07-31 19:01:10 +03:00
from flask import g, current_app
2020-09-26 16:19:37 +02:00
2021-07-12 15:13:10 +02:00
"""Simple & stupid file logguer, used only to debug
(logging to SQL is done in scolog)
"""
2020-09-26 16:19:37 +02:00
LOG_FILENAME = "notes.log" # empty to disable logging
2021-08-25 18:15:03 +02:00
DEFAULT_LOG_DIR = (
"/opt/scodoc-data/log" # clients should call set_log_directory to change this
)
2020-09-26 16:19:37 +02:00
2021-07-31 19:01:10 +03:00
ALARM_DESTINATION = "emmanuel.viennet@gmail.com" # XXX a mettre en preference
2020-09-26 16:19:37 +02:00
2021-07-09 23:31:16 +02:00
class _logguer(object):
2020-09-26 16:19:37 +02:00
def __init__(self):
self.file = None
self.directory = None
self.set_log_directory(DEFAULT_LOG_DIR)
def set_log_directory(self, directory):
if self.directory != directory and self.file:
# changing directory when a log is already open: close it
self.file.close()
self.file = None
self.directory = directory
def _open(self):
if LOG_FILENAME:
path = os.path.join(self.directory, LOG_FILENAME)
self.file = open(path, "a")
2020-12-26 00:11:55 +01:00
self("new _logguer (%s)" % path)
2020-09-26 16:19:37 +02:00
else:
self.file = None # logging disabled
def __call__(self, msg):
if not self.file:
self._open()
if self.file:
2021-07-31 19:01:10 +03:00
try:
dept = getattr(g, "scodoc_dept", "")
except RuntimeError:
# Flask Working outside of application context.
dept = ""
2020-09-26 16:19:37 +02:00
if dept:
dept = " (%s)" % dept
2021-07-12 15:13:10 +02:00
msg = dept + " " + msg
self.file.write("[%s]%s\n" % (time.strftime("%a %b %d %H:%M:%S %Y"), msg))
if current_app:
current_app.logger.info(msg)
2020-09-26 16:19:37 +02:00
self.file.flush()
log = _logguer()
# Alarms by email:
def sendAlarm(subj, txt):
2021-07-09 16:29:45 +02:00
from . import sco_utils
from . import sco_emails
from . import sco_preferences
2020-09-26 16:19:37 +02:00
msg = MIMEMultipart()
subj = Header(subj, sco_utils.SCO_ENCODING)
msg["Subject"] = subj
msg["From"] = sco_preferences.get_preference("email_from_addr")
2020-09-26 16:19:37 +02:00
msg["To"] = ALARM_DESTINATION
msg.epilogue = ""
txt = MIMEText(txt, "plain", sco_utils.SCO_ENCODING)
msg.attach(txt)
sco_emails.sendEmail(msg)
2020-09-26 16:19:37 +02:00
# Debug: log call stack
def logCallStack():
log("Call stack:\n" + "\n".join(x.strip() for x in traceback.format_stack()[:-1]))