From 3bad19eb57b52147ae5d049ce2c827d13162a3a7 Mon Sep 17 00:00:00 2001 From: Stijn Caerts Date: Tue, 10 Dec 2024 17:42:28 +0100 Subject: [PATCH] fix: use base64 encoded JSON string of sort keys as pagination token (#322) --- .../stac_fastapi/elasticsearch/database_logic.py | 7 +++---- .../opensearch/stac_fastapi/opensearch/database_logic.py | 7 +++---- 2 files changed, 6 insertions(+), 8 deletions(-) diff --git a/stac_fastapi/elasticsearch/stac_fastapi/elasticsearch/database_logic.py b/stac_fastapi/elasticsearch/stac_fastapi/elasticsearch/database_logic.py index cd723cfb..c404b5e5 100644 --- a/stac_fastapi/elasticsearch/stac_fastapi/elasticsearch/database_logic.py +++ b/stac_fastapi/elasticsearch/stac_fastapi/elasticsearch/database_logic.py @@ -1,6 +1,7 @@ """Database logic.""" import asyncio +import json import logging import os from base64 import urlsafe_b64decode, urlsafe_b64encode @@ -660,7 +661,7 @@ async def execute_search( search_after = None if token: - search_after = urlsafe_b64decode(token.encode()).decode().split(",") + search_after = json.loads(urlsafe_b64decode(token).decode()) query = search.query.to_dict() if search.query else None @@ -700,9 +701,7 @@ async def execute_search( next_token = None if len(hits) > limit and limit < max_result_window: if hits and (sort_array := hits[limit - 1].get("sort")): - next_token = urlsafe_b64encode( - ",".join([str(x) for x in sort_array]).encode() - ).decode() + next_token = urlsafe_b64encode(json.dumps(sort_array).encode()).decode() matched = ( es_response["hits"]["total"]["value"] diff --git a/stac_fastapi/opensearch/stac_fastapi/opensearch/database_logic.py b/stac_fastapi/opensearch/stac_fastapi/opensearch/database_logic.py index 778cfe03..63a42427 100644 --- a/stac_fastapi/opensearch/stac_fastapi/opensearch/database_logic.py +++ b/stac_fastapi/opensearch/stac_fastapi/opensearch/database_logic.py @@ -1,6 +1,7 @@ """Database logic.""" import asyncio +import json import logging import os from base64 import urlsafe_b64decode, urlsafe_b64encode @@ -692,7 +693,7 @@ async def execute_search( search_after = None if token: - search_after = urlsafe_b64decode(token.encode()).decode().split(",") + search_after = json.loads(urlsafe_b64decode(token).decode()) if search_after: search_body["search_after"] = search_after @@ -732,9 +733,7 @@ async def execute_search( next_token = None if len(hits) > limit and limit < max_result_window: if hits and (sort_array := hits[limit - 1].get("sort")): - next_token = urlsafe_b64encode( - ",".join([str(x) for x in sort_array]).encode() - ).decode() + next_token = urlsafe_b64encode(json.dumps(sort_array).encode()).decode() matched = ( es_response["hits"]["total"]["value"]