From 87c1b7eb671a76d6fb1a896a3d381884b645b7d6 Mon Sep 17 00:00:00 2001 From: Henry Fontanier Date: Tue, 26 Nov 2024 16:20:29 +0100 Subject: [PATCH] enh(zendesk): lower concurrency to 3 for fetching ticket comments --- .../connectors/zendesk/temporal/activities.ts | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/connectors/src/connectors/zendesk/temporal/activities.ts b/connectors/src/connectors/zendesk/temporal/activities.ts index f77ac28f635f..07347973c438 100644 --- a/connectors/src/connectors/zendesk/temporal/activities.ts +++ b/connectors/src/connectors/zendesk/temporal/activities.ts @@ -1,4 +1,5 @@ import type { ModelId } from "@dust-tt/types"; +import _ from "lodash"; import { isNodeZendeskForbiddenError } from "@connectors/connectors/zendesk/lib/errors"; import { syncArticle } from "@connectors/connectors/zendesk/lib/sync_article"; @@ -434,10 +435,20 @@ export async function syncZendeskTicketBatchActivity({ const users = await zendeskApiClient.users.list(); - const res = await concurrentExecutor( + const comments = await concurrentExecutor( tickets, - async (ticket) => { - const comments = await zendeskApiClient.tickets.getComments(ticket.id); + async (ticket) => zendeskApiClient.tickets.getComments(ticket.id), + { concurrency: 3, onBatchComplete: heartbeat } + ); + + const res = await concurrentExecutor( + _.zip(tickets, comments), + async ([ticket, comments]) => { + if (!ticket || !comments) { + throw new Error( + `[Zendesk] Unreachable: Ticket or comments not found, ticket: ${ticket}, comments: ${comments}` + ); + } return syncTicket({ connectorId,