From bd59e8b5bd2a6a5b8cf1c5d9ac2aa639a6c55ba6 Mon Sep 17 00:00:00 2001 From: shahargl Date: Mon, 6 Jan 2025 15:33:25 +0200 Subject: [PATCH] feat: wip --- keep/api/logging.py | 31 ++++++++++--------------------- pyproject.toml | 2 +- 2 files changed, 11 insertions(+), 22 deletions(-) diff --git a/keep/api/logging.py b/keep/api/logging.py index 88be1bf08..36c13d85f 100644 --- a/keep/api/logging.py +++ b/keep/api/logging.py @@ -11,7 +11,6 @@ import urllib3 from sqlmodel import Session -from keep.api.consts import RUNNING_IN_CLOUD_RUN from keep.api.core.db import get_session, push_logs_to_db from keep.api.models.db.provider import ProviderExecutionLog @@ -140,26 +139,16 @@ def process(self, msg, kwargs): def dump(self): self.logger.info("Dumping workflow logs") - # TODO - this is a POC level code. - # TODO - we should: - # TODO - 1. find the right handler to push the logs to the DB - # TODO - 2. find a better way to push the logs async (maybe another service) - workflow_db_handler = next( - iter( - [ - handler - for handler in ( - # tb: for some reason, when running in cloud run, the handler is nested in another handler - # this needs to be handled in a better way - self.logger.parent.parent.handlers - if RUNNING_IN_CLOUD_RUN - else self.logger.parent.handlers - ) - if isinstance(handler, WorkflowDBHandler) - ] - ), - None, - ) + root_logger = logging.getLogger() + handlers = root_logger.handlers + workflow_db_handler = None + + for handler in handlers: + # should be always the second + if isinstance(handler, WorkflowDBHandler): + workflow_db_handler = handler + break + if workflow_db_handler: self.logger.info("Pushing logs to DB") workflow_db_handler.push_logs_to_db() diff --git a/pyproject.toml b/pyproject.toml index f8d595770..47fc30ea5 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "keep" -version = "0.33.9" +version = "0.34.0" description = "Alerting. for developers, by developers." authors = ["Keep Alerting LTD"] packages = [{include = "keep"}]