From d83b56b4f0fbbc04891ee4cf5063dc47d008b1b3 Mon Sep 17 00:00:00 2001 From: mvdbeek Date: Wed, 31 Jul 2024 19:08:17 +0200 Subject: [PATCH] Tie install model scope to request scope This is probably the more general fix for https://github.com/galaxyproject/galaxy/issues/18627. --- lib/galaxy/web/framework/base.py | 4 ++++ lib/galaxy/webapps/base/webapp.py | 1 + lib/galaxy/webapps/galaxy/api/__init__.py | 2 ++ lib/galaxy/webapps/galaxy/buildapp.py | 1 - 4 files changed, 7 insertions(+), 1 deletion(-) diff --git a/lib/galaxy/web/framework/base.py b/lib/galaxy/web/framework/base.py index 276ac0b52d5d..f8ed3a4fb06f 100644 --- a/lib/galaxy/web/framework/base.py +++ b/lib/galaxy/web/framework/base.py @@ -171,9 +171,13 @@ def __call__(self, environ, start_response): try: self._model.set_request_id(request_id) # Start SQLAlchemy session scope + if self._install_model: + self._install_model.set_request_id(request_id) return self.handle_request(request_id, path_info, environ, start_response) finally: self._model.unset_request_id(request_id) # End SQLAlchemy session scope + if self._install_model: + self._install_model.unset_request_id(request_id) self.trace(message="Handle request finished") if self.trace_logger: self.trace_logger.context_remove("request_id") diff --git a/lib/galaxy/webapps/base/webapp.py b/lib/galaxy/webapps/base/webapp.py index b07a424e06f3..6fdcff60cd24 100644 --- a/lib/galaxy/webapps/base/webapp.py +++ b/lib/galaxy/webapps/base/webapp.py @@ -121,6 +121,7 @@ def __init__( # We need this to set the REQUEST_ID contextvar in model.base *BEFORE* a GalaxyWebTransaction is created. # This will ensure a SQLAlchemy session is request-scoped for legacy (non-fastapi) endpoints. self._model = galaxy_app.model + self._install_model = getattr(galaxy_app, "install_model", None) def build_apispec(self): """ diff --git a/lib/galaxy/webapps/galaxy/api/__init__.py b/lib/galaxy/webapps/galaxy/api/__init__.py index 66e12cc4fd9b..5c78cccfb7fb 100644 --- a/lib/galaxy/webapps/galaxy/api/__init__.py +++ b/lib/galaxy/webapps/galaxy/api/__init__.py @@ -98,10 +98,12 @@ async def get_app_with_request_session() -> AsyncGenerator[StructuredApp, None]: app = get_app() request_id = request_context.data["X-Request-ID"] app.model.set_request_id(request_id) + app.install_model.set_request_id(request_id) try: yield app finally: app.model.unset_request_id(request_id) + app.install_model.unset_request_id(request_id) DependsOnApp = cast(StructuredApp, Depends(get_app_with_request_session)) diff --git a/lib/galaxy/webapps/galaxy/buildapp.py b/lib/galaxy/webapps/galaxy/buildapp.py index 47e8d47ca971..83f65a90e97e 100644 --- a/lib/galaxy/webapps/galaxy/buildapp.py +++ b/lib/galaxy/webapps/galaxy/buildapp.py @@ -34,7 +34,6 @@ class GalaxyWebApplication(galaxy.webapps.base.webapp.WebApplication): injection_aware = True - def app_factory(*args, **kwargs): """ Return a wsgi application serving the root object