bc9e7e8b93
* build(deps): bump structlog from 20.1.0 to 20.2.0 Bumps [structlog](https://github.com/hynek/structlog) from 20.1.0 to 20.2.0. - [Release notes](https://github.com/hynek/structlog/releases) - [Changelog](https://github.com/hynek/structlog/blob/master/CHANGELOG.rst) - [Commits](https://github.com/hynek/structlog/compare/20.1.0...20.2.0) Signed-off-by: dependabot[bot] <support@github.com> * *: use structlog.stdlib instead of structlog for type-hints Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Jens Langhammer <jens.langhammer@beryju.org>
23 lines
764 B
Python
23 lines
764 B
Python
"""authentik saml source signal listener"""
|
|
from django.contrib.auth.signals import user_logged_out
|
|
from django.dispatch import receiver
|
|
from django.http import HttpRequest
|
|
from structlog.stdlib import get_logger
|
|
|
|
from authentik.core.models import User
|
|
|
|
LOGGER = get_logger()
|
|
|
|
|
|
@receiver(user_logged_out)
|
|
# pylint: disable=unused-argument
|
|
def on_user_logged_out(sender, request: HttpRequest, user: User, **_):
|
|
"""Delete temporary user if the `delete_on_logout` flag is enabled"""
|
|
if not user:
|
|
return
|
|
if "saml" in user.attributes:
|
|
if "delete_on_logout" in user.attributes["saml"]:
|
|
if user.attributes["saml"]["delete_on_logout"]:
|
|
LOGGER.debug("Deleted temporary user", user=user)
|
|
user.delete()
|