From c100e1c0445704f30572009290d9813588ef20a0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Th=C3=A9ophile=20Diot?= Date: Mon, 17 Jun 2024 12:09:24 +0200 Subject: [PATCH] chore: Refactor Database.py to improve setting existence check --- src/common/db/Database.py | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/src/common/db/Database.py b/src/common/db/Database.py index d3ad8af54..77d162574 100644 --- a/src/common/db/Database.py +++ b/src/common/db/Database.py @@ -394,9 +394,20 @@ def is_setting(self, setting: str, *, multisite: bool = False) -> bool: """Check if the setting exists in the database and optionally if it's multisite""" with self.__db_session() as session: try: - if multisite: - return session.query(Settings).filter_by(id=setting, context="multisite").first() is not None - return session.query(Settings).filter_by(id=setting).first() is not None + multiple = False + if self.suffix_rx.search(setting): + setting = setting.rsplit("_", 1)[0] + multiple = True + + db_setting = session.query(Settings).filter_by(id=setting).first() + + if not db_setting: + return False + elif multisite and db_setting.context != "multisite": + return False + elif multiple and db_setting.multiple is None: + return False + return True except (ProgrammingError, OperationalError): return False