Merge pull request #1554 from henning-schild/henning/staging0

hook: gracefully ignore non functional hooks and fall back to none
This commit is contained in:
Peter Bieringer 2024-08-07 08:09:58 +02:00 committed by GitHub
commit 2d0496b888
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -3,14 +3,23 @@ from enum import Enum
from typing import Sequence
from radicale import pathutils, utils
from radicale.log import logger
INTERNAL_TYPES: Sequence[str] = ("none", "rabbitmq")
def load(configuration):
"""Load the storage module chosen in configuration."""
return utils.load_plugin(
INTERNAL_TYPES, "hook", "Hook", BaseHook, configuration)
try:
return utils.load_plugin(
INTERNAL_TYPES, "hook", "Hook", BaseHook, configuration)
except Exception as e:
logger.warn(e)
logger.warn("Hook \"%s\" failed to load, falling back to \"none\"." % configuration.get("hook", "type"))
configuration = configuration.copy()
configuration.update({"hook": {"type": "none"}}, "hook", privileged=True)
return utils.load_plugin(
INTERNAL_TYPES, "hook", "Hook", BaseHook, configuration)
class BaseHook: