From 2b291fefc12a8eb6243f4e8266b2f70718df903a Mon Sep 17 00:00:00 2001 From: manelcecs Date: Tue, 28 Nov 2023 08:03:19 +0100 Subject: [PATCH] Add resolver to fetch all flows without pages --- src/domain-services/flows/graphql/resolver.ts | 47 +++++++++++++++++++ 1 file changed, 47 insertions(+) diff --git a/src/domain-services/flows/graphql/resolver.ts b/src/domain-services/flows/graphql/resolver.ts index ad49913d..22eb52bc 100644 --- a/src/domain-services/flows/graphql/resolver.ts +++ b/src/domain-services/flows/graphql/resolver.ts @@ -6,6 +6,7 @@ import { SearchFlowsArgs, SearchFlowsArgsNonPaginated } from './args'; import { FlowPaged, FlowSearchResult, + FlowSearchResultNonPaginated, FlowSearchTotalAmountResult, } from './types'; @@ -31,4 +32,50 @@ export default class FlowResolver { ): Promise { return await this.flowSearchService.searchTotalAmount(context.models, args); } + + @Query(() => FlowSearchResultNonPaginated) + async searchFlowsBatches( + @Ctx() context: Context, + @Args(() => SearchFlowsArgs, { validate: false }) + args: SearchFlowsArgs + ): Promise { + // Set default batch size to 1000 + args.limit = args.limit > 0 ? args.limit : 1000; + + const flowSearchResponse = await this.flowSearchService.search( + context.models, + args + ); + + const batchesMissing = + Math.round(flowSearchResponse.total / args.limit) - 1; + const flows: FlowPaged[] = flowSearchResponse.flows; + + let hasNextPage = flowSearchResponse.hasNextPage; + let batchCount = 1; + + let cursor = flowSearchResponse.endCursor; + let nextArgs: SearchFlowsArgs = { ...args, afterCursor: cursor }; + + let nextFlowSearchResponse: FlowSearchResult; + while (hasNextPage) { + batchCount++; + + nextFlowSearchResponse = await this.flowSearchService.search( + context.models, + nextArgs + ); + + flows.push(...nextFlowSearchResponse.flows); + + hasNextPage = + nextFlowSearchResponse.hasNextPage && batchCount <= batchesMissing; + + cursor = nextFlowSearchResponse.endCursor; + // Update the cursor for the next iteration + nextArgs = { ...args, afterCursor: cursor }; + } + + return { flows, flowsCount: flows.length }; + } }