diff --git a/application/config/config.yaml b/application/config/config.yaml index 7f867b412fd2da08dca1df6f5be4d63ee0cb5e64..550074454640dc2a730b938203ef83cf49535b31 100644 --- a/application/config/config.yaml +++ b/application/config/config.yaml @@ -20,3 +20,6 @@ Elasticsearch: CaCerts: Index: filebeat-ctocst_router-2021.11 Type: _doc + +Logger: + Level: DEBUG diff --git a/application/libs/flask_loguru/logger.py b/application/libs/flask_loguru/logger.py index fd7ff8b272fccf4831c889fce6b5ca6c2df7300f..0c32c6c11e2a321c6c2be4c5d25b3450bc47b17e 100644 --- a/application/libs/flask_loguru/logger.py +++ b/application/libs/flask_loguru/logger.py @@ -10,35 +10,60 @@ # @Description : """ -import os import sys from flask import Flask, request, g from loguru import logger from .format import patching +from application.common import ConfigHelper class FlaskLoguru: def __init__(self, app=None): + """ + Initialize the FlaskLoguru instance. + If an app is provided, also initialize that app for logging. + """ if app is not None: self.init_app(app) def init_app(self, app: Flask) -> None: - """Initialize the app""" + """ + Initialize the given app for logging with Loguru. + This involves setting up a new logger and registering it with the app. + """ + # Remove any existing handlers from the logger logger.remove() - # 获取日志级别 - level = app.config.Logger.Level if app.config.get('Logger') is not None else 'DEBUG' + + config_helper = ConfigHelper(app) + + # Fetch the logging configuration from the app's config + cfg = config_helper.Logger + + # Get the log level from the config, or default to 'DEBUG' if not provided + level = cfg.Level or 'DEBUG' + + # Add a new handler to the logger with the configured log level logger.add(sys.stderr, level=level, format=patching) - # 注册扩展 + + # Register this logger with the app + # If the app does not already have an 'extensions' attribute, add one if not hasattr(app, 'extensions'): app.extensions = {} + # Initialize the app's 'loguru' extension if it does not already exist app.extensions.setdefault('loguru', {}) + + # Register this logger with the app's 'loguru' extension app.extensions['loguru'][self] = logger @app.before_request def before_request(): + """ + A function to run before each request. + Logs the start of the request. + """ data = dict( url=request.url, method=request.method, @@ -50,11 +75,19 @@ class FlaskLoguru: @app.after_request def after_request(response): + """ + A function to run after each request. + Logs the completion of the request. + """ g.logger.info('Request completed') return response @app.teardown_request def teardown_request(exception=None): + """ + A function to run when ending each request, + either because the request was completed or because an error occurred. + """ if exception: data = dict( exception=str(exception)