9310d4cdc0
Signed-off-by: Jens Langhammer <jens@goauthentik.io>
68 lines
2.1 KiB
Python
68 lines
2.1 KiB
Python
"""authentik Blueprints app"""
|
|
|
|
from importlib import import_module
|
|
from inspect import ismethod
|
|
|
|
from django.apps import AppConfig
|
|
from django.db import DatabaseError, InternalError, ProgrammingError
|
|
from structlog.stdlib import BoundLogger, get_logger
|
|
|
|
|
|
class ManagedAppConfig(AppConfig):
|
|
"""Basic reconciliation logic for apps"""
|
|
|
|
_logger: BoundLogger
|
|
|
|
def __init__(self, app_name: str, *args, **kwargs) -> None:
|
|
super().__init__(app_name, *args, **kwargs)
|
|
self._logger = get_logger().bind(app_name=app_name)
|
|
|
|
def ready(self) -> None:
|
|
self.reconcile()
|
|
return super().ready()
|
|
|
|
def import_module(self, path: str):
|
|
"""Load module"""
|
|
import_module(path)
|
|
|
|
def reconcile(self) -> None:
|
|
"""reconcile ourselves"""
|
|
prefix = "reconcile_"
|
|
for meth_name in dir(self):
|
|
meth = getattr(self, meth_name)
|
|
if not ismethod(meth):
|
|
continue
|
|
if not meth_name.startswith(prefix):
|
|
continue
|
|
name = meth_name.replace(prefix, "")
|
|
try:
|
|
self._logger.debug("Starting reconciler", name=name)
|
|
meth()
|
|
self._logger.debug("Successfully reconciled", name=name)
|
|
except (DatabaseError, ProgrammingError, InternalError) as exc:
|
|
self._logger.debug("Failed to run reconcile", name=name, exc=exc)
|
|
|
|
|
|
class AuthentikBlueprintsConfig(ManagedAppConfig):
|
|
"""authentik Blueprints app"""
|
|
|
|
name = "authentik.blueprints"
|
|
label = "authentik_blueprints"
|
|
verbose_name = "authentik Blueprints"
|
|
default = True
|
|
|
|
def reconcile_load_blueprints_v1_tasks(self):
|
|
"""Load v1 tasks"""
|
|
self.import_module("authentik.blueprints.v1.tasks")
|
|
|
|
def reconcile_blueprints_discovery(self):
|
|
"""Run blueprint discovery"""
|
|
from authentik.blueprints.v1.tasks import blueprints_discovery, clear_failed_blueprints
|
|
|
|
blueprints_discovery.delay()
|
|
clear_failed_blueprints.delay()
|
|
|
|
def import_models(self):
|
|
super().import_models()
|
|
self.import_module("authentik.blueprints.v1.meta.apply_blueprint")
|