moonraker: logging improvements
Move logging setup to the Server class and enable asyncio debugging. Sanitize debug logging for all "/access" endpoints so tokens and passwords are not logged. SIgned-off-by: Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
parent
c69ded21b0
commit
c6cddf4b05
|
@ -149,9 +149,7 @@ class MoonrakerApp:
|
||||||
mimetypes.add_type('text/plain', '.gcode')
|
mimetypes.add_type('text/plain', '.gcode')
|
||||||
mimetypes.add_type('text/plain', '.cfg')
|
mimetypes.add_type('text/plain', '.cfg')
|
||||||
|
|
||||||
self.debug = config.getboolean('enable_debug_logging', False)
|
self.debug = self.server.is_debug_enabled()
|
||||||
log_level = logging.DEBUG if self.debug else logging.INFO
|
|
||||||
logging.getLogger().setLevel(log_level)
|
|
||||||
app_args: Dict[str, Any] = {
|
app_args: Dict[str, Any] = {
|
||||||
'serve_traceback': self.debug,
|
'serve_traceback': self.debug,
|
||||||
'websocket_ping_interval': 10,
|
'websocket_ping_interval': 10,
|
||||||
|
@ -544,6 +542,14 @@ class DynamicRequestHandler(AuthorizedRequestHandler):
|
||||||
args[key] = value
|
args[key] = value
|
||||||
return args
|
return args
|
||||||
|
|
||||||
|
def _log_debug(self, header: str, args: Dict[str, Any]) -> None:
|
||||||
|
if self.server.is_debug_enabled():
|
||||||
|
if self.request.path.startswith('/access'):
|
||||||
|
resp = {key: "<sanitized>" for key in args}
|
||||||
|
else:
|
||||||
|
resp = args
|
||||||
|
logging.debug(f"{header}::{resp}")
|
||||||
|
|
||||||
async def get(self, *args, **kwargs) -> None:
|
async def get(self, *args, **kwargs) -> None:
|
||||||
await self._process_http_request()
|
await self._process_http_request()
|
||||||
|
|
||||||
|
@ -579,7 +585,7 @@ class DynamicRequestHandler(AuthorizedRequestHandler):
|
||||||
conn = self.get_associated_websocket()
|
conn = self.get_associated_websocket()
|
||||||
args = self.parse_args()
|
args = self.parse_args()
|
||||||
req = f"{self.request.method} {self.request.path}"
|
req = f"{self.request.method} {self.request.path}"
|
||||||
logging.debug(f"HTTP Request::{req}::{args}")
|
self._log_debug(f"HTTP Request::{req}", args)
|
||||||
try:
|
try:
|
||||||
result = await self._do_request(args, conn)
|
result = await self._do_request(args, conn)
|
||||||
except ServerError as e:
|
except ServerError as e:
|
||||||
|
@ -587,7 +593,7 @@ class DynamicRequestHandler(AuthorizedRequestHandler):
|
||||||
e.status_code, str(e)) from e
|
e.status_code, str(e)) from e
|
||||||
if self.wrap_result:
|
if self.wrap_result:
|
||||||
result = {'result': result}
|
result = {'result': result}
|
||||||
logging.debug(f"HTTP Response::{req}::{result}")
|
self._log_debug(f"HTTP Response::{req}", result)
|
||||||
self.finish(result)
|
self.finish(result)
|
||||||
|
|
||||||
class FileRequestHandler(AuthorizedFileHandler):
|
class FileRequestHandler(AuthorizedFileHandler):
|
||||||
|
|
|
@ -38,6 +38,7 @@ class EventLoop:
|
||||||
self.create_future = self.aioloop.create_future
|
self.create_future = self.aioloop.create_future
|
||||||
self.create_task = self.aioloop.create_task
|
self.create_task = self.aioloop.create_task
|
||||||
self.call_at = self.aioloop.call_at
|
self.call_at = self.aioloop.call_at
|
||||||
|
self.set_debug = self.aioloop.set_debug
|
||||||
|
|
||||||
def register_callback(self,
|
def register_callback(self,
|
||||||
callback: FlexCallback,
|
callback: FlexCallback,
|
||||||
|
|
|
@ -88,6 +88,13 @@ class Server:
|
||||||
self.ssl_port: int = config.getint('ssl_port', 7130)
|
self.ssl_port: int = config.getint('ssl_port', 7130)
|
||||||
self.exit_reason: str = ""
|
self.exit_reason: str = ""
|
||||||
|
|
||||||
|
# Configure Debug Logging
|
||||||
|
self.debug = config.getboolean('enable_debug_logging', False)
|
||||||
|
asyncio_debug = config.getboolean('enable_asyncio_debug', False)
|
||||||
|
log_level = logging.DEBUG if self.debug else logging.INFO
|
||||||
|
logging.getLogger().setLevel(log_level)
|
||||||
|
self.event_loop.set_debug(asyncio_debug)
|
||||||
|
|
||||||
# Event initialization
|
# Event initialization
|
||||||
self.events: Dict[str, List[FlexCallback]] = {}
|
self.events: Dict[str, List[FlexCallback]] = {}
|
||||||
|
|
||||||
|
@ -160,6 +167,9 @@ class Server:
|
||||||
def is_running(self) -> bool:
|
def is_running(self) -> bool:
|
||||||
return self.server_running
|
return self.server_running
|
||||||
|
|
||||||
|
def is_debug_enabled(self) -> bool:
|
||||||
|
return self.debug
|
||||||
|
|
||||||
async def _start_server(self):
|
async def _start_server(self):
|
||||||
optional_comps: List[Coroutine] = []
|
optional_comps: List[Coroutine] = []
|
||||||
for name, component in self.components.items():
|
for name, component in self.components.items():
|
||||||
|
|
Loading…
Reference in New Issue