From a39fef11b89c53b28eb27094edfcb218cd8e7601 Mon Sep 17 00:00:00 2001 From: Jens L Date: Fri, 1 Sep 2023 12:59:25 +0200 Subject: [PATCH] =?UTF-8?q?providers/saml:=20fix=20SAML=20metadata=20impor?= =?UTF-8?q?t=20API=20requiring=20flow=20slug=20inst=E2=80=A6=20(#6729)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * providers/saml: fix SAML metadata import API requiring flow slug instead of pk Signed-off-by: Jens Langhammer * replace format_exc_info with dict_tracebacks, and only for json logger Signed-off-by: Jens Langhammer --------- Signed-off-by: Jens Langhammer --- authentik/providers/saml/api/providers.py | 7 ++----- authentik/providers/saml/tests/test_api.py | 4 ++-- authentik/root/settings.py | 3 +-- schema.yml | 3 +-- 4 files changed, 6 insertions(+), 11 deletions(-) diff --git a/authentik/providers/saml/api/providers.py b/authentik/providers/saml/api/providers.py index 55328eec6..891289a08 100644 --- a/authentik/providers/saml/api/providers.py +++ b/authentik/providers/saml/api/providers.py @@ -13,10 +13,9 @@ from rest_framework.decorators import action from rest_framework.fields import CharField, FileField, SerializerMethodField from rest_framework.parsers import MultiPartParser from rest_framework.permissions import AllowAny -from rest_framework.relations import SlugRelatedField from rest_framework.request import Request from rest_framework.response import Response -from rest_framework.serializers import ValidationError +from rest_framework.serializers import PrimaryKeyRelatedField, ValidationError from rest_framework.viewsets import ModelViewSet from structlog.stdlib import get_logger @@ -168,10 +167,8 @@ class SAMLProviderImportSerializer(PassiveSerializer): """Import saml provider from XML Metadata""" name = CharField(required=True) - # Using SlugField because https://github.com/OpenAPITools/openapi-generator/issues/3278 - authorization_flow = SlugRelatedField( + authorization_flow = PrimaryKeyRelatedField( queryset=Flow.objects.filter(designation=FlowDesignation.AUTHORIZATION), - slug_field="slug", ) file = FileField() diff --git a/authentik/providers/saml/tests/test_api.py b/authentik/providers/saml/tests/test_api.py index f0c878e5a..de86d5cbb 100644 --- a/authentik/providers/saml/tests/test_api.py +++ b/authentik/providers/saml/tests/test_api.py @@ -89,7 +89,7 @@ class TestSAMLProviderAPI(APITestCase): { "file": metadata, "name": generate_id(), - "authorization_flow": create_test_flow(FlowDesignation.AUTHORIZATION).slug, + "authorization_flow": create_test_flow(FlowDesignation.AUTHORIZATION).pk, }, format="multipart", ) @@ -106,7 +106,7 @@ class TestSAMLProviderAPI(APITestCase): { "file": metadata, "name": generate_id(), - "authorization_flow": create_test_flow().slug, + "authorization_flow": create_test_flow().pk, }, format="multipart", ) diff --git a/authentik/root/settings.py b/authentik/root/settings.py index 9785d9f38..496ef96cb 100644 --- a/authentik/root/settings.py +++ b/authentik/root/settings.py @@ -402,7 +402,6 @@ LOG_PRE_CHAIN = [ structlog.stdlib.add_logger_name, structlog.processors.TimeStamper(), structlog.processors.StackInfoRenderer(), - structlog.processors.format_exc_info, ] LOGGING = { @@ -412,7 +411,7 @@ LOGGING = { "json": { "()": structlog.stdlib.ProcessorFormatter, "processor": structlog.processors.JSONRenderer(sort_keys=True), - "foreign_pre_chain": LOG_PRE_CHAIN, + "foreign_pre_chain": LOG_PRE_CHAIN + [structlog.processors.dict_tracebacks], }, "console": { "()": structlog.stdlib.ProcessorFormatter, diff --git a/schema.yml b/schema.yml index 7a1c6d411..d2ce897f5 100644 --- a/schema.yml +++ b/schema.yml @@ -38459,8 +38459,7 @@ components: minLength: 1 authorization_flow: type: string - minLength: 1 - description: Visible in the URL. + format: uuid file: type: string format: binary