From 5e71075093eed9fdf85c62dd6c4a94fa5566adf1 Mon Sep 17 00:00:00 2001 From: Frankie Robertson Date: Sat, 8 Apr 2023 13:12:54 +0300 Subject: [PATCH] Forward query string when redirecting from /git-pull/ endpoint --- nbgitpuller/handlers.py | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/nbgitpuller/handlers.py b/nbgitpuller/handlers.py index a88f3251..0fec7191 100644 --- a/nbgitpuller/handlers.py +++ b/nbgitpuller/handlers.py @@ -132,6 +132,20 @@ def pull(): self.git_lock.release() +USED_UI_ARGUMENTS = frozenset(( + 'repo', + 'branch', + 'depth', + 'urlpath', + 'urlPath', + 'subpath', + 'subPath', + 'app', + 'targetpath', + 'targetPath', +)) + + class UIHandler(IPythonHandler): @web.authenticated async def get(self): @@ -149,6 +163,8 @@ async def get(self): targetpath = self.get_argument('targetpath', None) or \ self.get_argument('targetPath', repo.split('/')[-1]) + targetpath = self.combine_query_string(targetpath) + if urlPath: path = urlPath else: @@ -168,6 +184,22 @@ async def get(self): ) await self.flush() + def combine_query_string(self, targetpath): + """ + This function combines the query string in `targetpath` with all unused + query string parameters passed to this handler. + """ + + from urllib.parse import urlparse, parse_qs, urlencode, urlunparse + target_parsed = urlparse(targetpath) + target_qs = parse_qs(target_parsed.query) + for key in self.request.arguments: + if key in USED_UI_ARGUMENTS or key in target_qs: + continue + target_qs[key] = self.get_argument(key) + targetpath = urlunparse(target_parsed._replace(query=urlencode(target_qs, doseq=True))) + return targetpath + class LegacyGitSyncRedirectHandler(IPythonHandler): """