From bb48fb3e3d3866977777eb4bfcb2c4f502efd4ca Mon Sep 17 00:00:00 2001 From: Robbe Sneyders Date: Wed, 27 Nov 2024 23:21:49 +0100 Subject: [PATCH] Fix swagger UI for split specs (#2002) Fixes #1909 This PR uses the already resolved spec when swagger UI requests it. --- connexion/middleware/swagger_ui.py | 2 +- connexion/spec.py | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/connexion/middleware/swagger_ui.py b/connexion/middleware/swagger_ui.py index 3f701bcb0..3a31be5c2 100644 --- a/connexion/middleware/swagger_ui.py +++ b/connexion/middleware/swagger_ui.py @@ -63,7 +63,7 @@ def _base_path_for_prefix(self, request: StarletteRequest) -> str: "route_root_path", request.scope.get("root_path", "") ).rstrip("/") - def _spec_for_prefix(self, request): + def _spec_for_prefix(self, request) -> dict: """ returns a spec with a modified basePath / servers block which corresponds to the incoming request path. diff --git a/connexion/spec.py b/connexion/spec.py index 40fe46d70..83322b1c4 100644 --- a/connexion/spec.py +++ b/connexion/spec.py @@ -204,7 +204,7 @@ def enforce_string_keys(obj): return OpenAPISpecification(spec, base_uri=base_uri) def clone(self): - return type(self)(copy.deepcopy(self._raw_spec)) + return type(self)(copy.deepcopy(self._spec)) @classmethod def load(cls, spec, *, arguments=None):