From 0d3b70c81d9e3a08fe87ecd93701856be5193b60 Mon Sep 17 00:00:00 2001 From: ff137 Date: Fri, 5 Jul 2024 00:49:43 +0300 Subject: [PATCH 1/2] :art: improve readability / reduce complexity Signed-off-by: ff137 --- .../messaging/models/base_record.py | 47 ++++++++++--------- 1 file changed, 26 insertions(+), 21 deletions(-) diff --git a/aries_cloudagent/messaging/models/base_record.py b/aries_cloudagent/messaging/models/base_record.py index b724b333cd..622361af6c 100644 --- a/aries_cloudagent/messaging/models/base_record.py +++ b/aries_cloudagent/messaging/models/base_record.py @@ -315,14 +315,19 @@ async def query( tag_query = cls.prefix_tag_filter(tag_filter) post_filter = post_filter_positive or post_filter_negative + + # set flag to indicate if pagination is requested or not, then set defaults paginated = limit is not None or offset is not None + limit = limit or DEFAULT_PAGE_SIZE + offset = offset or 0 + if not post_filter and paginated: # Only fetch paginated records if post-filter is not being applied rows = await storage.find_paginated_records( type_filter=cls.RECORD_TYPE, tag_query=tag_query, - limit=limit or DEFAULT_PAGE_SIZE, - offset=offset or 0, + limit=limit, + offset=offset, ) else: rows = await storage.find_all_records( @@ -330,34 +335,34 @@ async def query( tag_query=tag_query, ) + num_results_post_filter = 0 # used if applying pagination post-filter + num_records_to_match = limit + offset # ignored if not paginated + result = [] - num_results_post_filter = 0 # to apply pagination post-filter - num_records_to_match = ( - (limit or DEFAULT_PAGE_SIZE) + (offset or 0) if paginated else sys.maxsize - ) # if pagination is not requested, set to sys.maxsize to process all records for record in rows: vals = json.loads(record.value) try: if not post_filter: # pagination would already be applied if requested result.append(cls.from_storage(record.id, vals)) - elif ( - (not paginated or num_results_post_filter < num_records_to_match) - and match_post_filter( - vals, - post_filter_positive, - positive=True, - alt=alt, + else: + continue_processing = ( + not paginated or num_results_post_filter < num_records_to_match ) - and match_post_filter( - vals, - post_filter_negative, - positive=False, - alt=alt, + if not continue_processing: + break + + post_filter_match = match_post_filter( + vals, post_filter_positive, positive=True, alt=alt + ) and match_post_filter( + vals, post_filter_negative, positive=False, alt=alt ) - ): - if num_results_post_filter >= (offset or 0): - # append post-filtered records after requested offset + + if not post_filter_match: + continue + + if num_results_post_filter >= offset: # append only after offset result.append(cls.from_storage(record.id, vals)) + num_results_post_filter += 1 except BaseModelError as err: raise BaseModelError(f"{err}, for record id {record.id}") From 6aac7813478d8e22dda91de20fc44a2bbdcfdfb2 Mon Sep 17 00:00:00 2001 From: ff137 Date: Fri, 5 Jul 2024 00:50:53 +0300 Subject: [PATCH 2/2] :art: handle possible json.loads errors Signed-off-by: ff137 --- aries_cloudagent/messaging/models/base_record.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/aries_cloudagent/messaging/models/base_record.py b/aries_cloudagent/messaging/models/base_record.py index 622361af6c..80b22c1898 100644 --- a/aries_cloudagent/messaging/models/base_record.py +++ b/aries_cloudagent/messaging/models/base_record.py @@ -340,8 +340,8 @@ async def query( result = [] for record in rows: - vals = json.loads(record.value) try: + vals = json.loads(record.value) if not post_filter: # pagination would already be applied if requested result.append(cls.from_storage(record.id, vals)) else: @@ -364,7 +364,7 @@ async def query( result.append(cls.from_storage(record.id, vals)) num_results_post_filter += 1 - except BaseModelError as err: + except (BaseModelError, json.JSONDecodeError, TypeError) as err: raise BaseModelError(f"{err}, for record id {record.id}") return result