events: exclude base models from model audit log

Signed-off-by: Jens Langhammer <jens@goauthentik.io>
This commit is contained in:
Jens Langhammer 2023-01-18 13:52:11 +01:00
parent b75d659707
commit 6e0c9acb34
No known key found for this signature in database
2 changed files with 21 additions and 4 deletions

View file

@ -94,7 +94,7 @@ class BlueprintEntry:
depth: int = 0, depth: int = 0,
context_tag_type: Optional[type["YAMLTagContext"] | tuple["YAMLTagContext", ...]] = None, context_tag_type: Optional[type["YAMLTagContext"] | tuple["YAMLTagContext", ...]] = None,
) -> "YAMLTagContext": ) -> "YAMLTagContext":
"""Get a YAMLTagContex object located at a certain depth in the tag tree""" """Get a YAMLTagContext object located at a certain depth in the tag tree"""
if depth < 0: if depth < 0:
raise ValueError("depth must be a positive number or zero") raise ValueError("depth must be a positive number or zero")

View file

@ -12,12 +12,21 @@ from django.http import HttpRequest, HttpResponse
from django_otp.plugins.otp_static.models import StaticToken from django_otp.plugins.otp_static.models import StaticToken
from guardian.models import UserObjectPermission from guardian.models import UserObjectPermission
from authentik.core.models import AuthenticatedSession, User from authentik.core.models import (
AuthenticatedSession,
PropertyMapping,
Provider,
Source,
User,
UserSourceConnection,
)
from authentik.events.models import Event, EventAction, Notification from authentik.events.models import Event, EventAction, Notification
from authentik.events.utils import model_to_dict from authentik.events.utils import model_to_dict
from authentik.flows.models import FlowToken from authentik.flows.models import FlowToken, Stage
from authentik.lib.sentry import before_send from authentik.lib.sentry import before_send
from authentik.lib.utils.errors import exception_to_string from authentik.lib.utils.errors import exception_to_string
from authentik.outposts.models import OutpostServiceConnection
from authentik.policies.models import Policy, PolicyBindingModel
IGNORED_MODELS = ( IGNORED_MODELS = (
Event, Event,
@ -27,6 +36,14 @@ IGNORED_MODELS = (
StaticToken, StaticToken,
Session, Session,
FlowToken, FlowToken,
Provider,
Source,
PropertyMapping,
UserSourceConnection,
Stage,
OutpostServiceConnection,
Policy,
PolicyBindingModel,
) )
@ -34,7 +51,7 @@ def should_log_model(model: Model) -> bool:
"""Return true if operation on `model` should be logged""" """Return true if operation on `model` should be logged"""
if model.__module__.startswith("silk"): if model.__module__.startswith("silk"):
return False return False
return not isinstance(model, IGNORED_MODELS) return model.__class__ not in IGNORED_MODELS
class EventNewThread(Thread): class EventNewThread(Thread):