mirror of
https://github.com/craigerl/aprsd.git
synced 2024-09-28 16:16:51 -04:00
Hemna
35d41582ee
Added wsgi.py to be used with gunicorn to start aprsd's web admin interface. gunicorn -b :8080 "aprsd.wsgi:app"
90 lines
2.6 KiB
Python
90 lines
2.6 KiB
Python
import logging
|
|
from logging import NullHandler
|
|
from logging.handlers import RotatingFileHandler
|
|
import queue
|
|
import sys
|
|
|
|
from oslo_config import cfg
|
|
|
|
from aprsd import conf
|
|
from aprsd.log import rich as aprsd_logging
|
|
|
|
|
|
CONF = cfg.CONF
|
|
LOG = logging.getLogger("APRSD")
|
|
logging_queue = queue.Queue()
|
|
|
|
|
|
# Setup the log faciility
|
|
# to disable log to stdout, but still log to file
|
|
# use the --quiet option on the cmdln
|
|
def setup_logging(loglevel, quiet):
|
|
log_level = conf.log.LOG_LEVELS[loglevel]
|
|
LOG.setLevel(log_level)
|
|
date_format = CONF.logging.date_format
|
|
rh = None
|
|
fh = None
|
|
|
|
rich_logging = False
|
|
if CONF.logging.get("rich_logging", False) and not quiet:
|
|
log_format = "%(message)s"
|
|
log_formatter = logging.Formatter(fmt=log_format, datefmt=date_format)
|
|
rh = aprsd_logging.APRSDRichHandler(
|
|
show_thread=True, thread_width=20,
|
|
rich_tracebacks=True, omit_repeated_times=False,
|
|
)
|
|
rh.setFormatter(log_formatter)
|
|
LOG.addHandler(rh)
|
|
rich_logging = True
|
|
|
|
log_file = CONF.logging.logfile
|
|
log_format = CONF.logging.logformat
|
|
log_formatter = logging.Formatter(fmt=log_format, datefmt=date_format)
|
|
|
|
if log_file:
|
|
fh = RotatingFileHandler(log_file, maxBytes=(10248576 * 5), backupCount=4)
|
|
fh.setFormatter(log_formatter)
|
|
LOG.addHandler(fh)
|
|
|
|
imap_logger = None
|
|
if CONF.email_plugin.enabled and CONF.email_plugin.debug:
|
|
imap_logger = logging.getLogger("imapclient.imaplib")
|
|
imap_logger.setLevel(log_level)
|
|
if rh:
|
|
imap_logger.addHandler(rh)
|
|
if fh:
|
|
imap_logger.addHandler(fh)
|
|
|
|
if CONF.admin.web_enabled:
|
|
qh = logging.handlers.QueueHandler(logging_queue)
|
|
q_log_formatter = logging.Formatter(
|
|
fmt=CONF.logging.logformat,
|
|
datefmt=CONF.logging.date_format,
|
|
)
|
|
qh.setFormatter(q_log_formatter)
|
|
LOG.addHandler(qh)
|
|
|
|
if not quiet and not rich_logging:
|
|
sh = logging.StreamHandler(sys.stdout)
|
|
sh.setFormatter(log_formatter)
|
|
LOG.addHandler(sh)
|
|
if imap_logger:
|
|
imap_logger.addHandler(sh)
|
|
|
|
|
|
def setup_logging_no_config(loglevel, quiet):
|
|
log_level = conf.log.LOG_LEVELS[loglevel]
|
|
LOG.setLevel(log_level)
|
|
log_format = CONF.logging.logformat
|
|
date_format = CONF.logging.date_format
|
|
log_formatter = logging.Formatter(fmt=log_format, datefmt=date_format)
|
|
fh = NullHandler()
|
|
|
|
fh.setFormatter(log_formatter)
|
|
LOG.addHandler(fh)
|
|
|
|
if not quiet:
|
|
sh = logging.StreamHandler(sys.stdout)
|
|
sh.setFormatter(log_formatter)
|
|
LOG.addHandler(sh)
|