Files
sim/apps/sim/tools/pipedrive/get_pipelines.ts
Waleed 08690b2906 feat(pagination): update pagination for remaining integrations that support it (#3233)
* feat(pagination): update pagination for remaining integrations that support it

* fixed remaining

* ack comments
2026-02-17 13:34:46 -08:00

126 lines
3.6 KiB
TypeScript

import { createLogger } from '@sim/logger'
import type {
PipedriveGetPipelinesParams,
PipedriveGetPipelinesResponse,
} from '@/tools/pipedrive/types'
import { PIPEDRIVE_PIPELINE_OUTPUT_PROPERTIES } from '@/tools/pipedrive/types'
import type { ToolConfig } from '@/tools/types'
const logger = createLogger('PipedriveGetPipelines')
export const pipedriveGetPipelinesTool: ToolConfig<
PipedriveGetPipelinesParams,
PipedriveGetPipelinesResponse
> = {
id: 'pipedrive_get_pipelines',
name: 'Get Pipelines from Pipedrive',
description: 'Retrieve all pipelines from Pipedrive',
version: '1.0.0',
params: {
accessToken: {
type: 'string',
required: true,
visibility: 'hidden',
description: 'The access token for the Pipedrive API',
},
sort_by: {
type: 'string',
required: false,
visibility: 'user-or-llm',
description: 'Field to sort by: id, update_time, add_time (default: id)',
},
sort_direction: {
type: 'string',
required: false,
visibility: 'user-or-llm',
description: 'Sorting direction: asc, desc (default: asc)',
},
limit: {
type: 'string',
required: false,
visibility: 'user-or-llm',
description: 'Number of results to return (e.g., "50", default: 100, max: 500)',
},
start: {
type: 'string',
required: false,
visibility: 'user-or-llm',
description: 'Pagination start offset (0-based index of the first item to return)',
},
},
request: {
url: (params) => {
const baseUrl = 'https://api.pipedrive.com/v1/pipelines'
const queryParams = new URLSearchParams()
if (params.sort_by) queryParams.append('sort_by', params.sort_by)
if (params.sort_direction) queryParams.append('sort_direction', params.sort_direction)
if (params.limit) queryParams.append('limit', params.limit)
if (params.start) queryParams.append('start', params.start)
const queryString = queryParams.toString()
return queryString ? `${baseUrl}?${queryString}` : baseUrl
},
method: 'GET',
headers: (params) => {
if (!params.accessToken) {
throw new Error('Access token is required')
}
return {
Authorization: `Bearer ${params.accessToken}`,
Accept: 'application/json',
}
},
},
transformResponse: async (response: Response) => {
const data = await response.json()
if (!data.success) {
logger.error('Pipedrive API request failed', { data })
throw new Error(data.error || 'Failed to fetch pipelines from Pipedrive')
}
const pipelines = data.data || []
const hasMore = data.additional_data?.pagination?.more_items_in_collection || false
const nextStart = data.additional_data?.pagination?.next_start ?? null
return {
success: true,
output: {
pipelines,
total_items: pipelines.length,
has_more: hasMore,
next_start: nextStart,
success: true,
},
}
},
outputs: {
pipelines: {
type: 'array',
description: 'Array of pipeline objects from Pipedrive',
items: {
type: 'object',
properties: PIPEDRIVE_PIPELINE_OUTPUT_PROPERTIES,
},
},
total_items: { type: 'number', description: 'Total number of pipelines returned' },
has_more: {
type: 'boolean',
description: 'Whether more pipelines are available',
optional: true,
},
next_start: {
type: 'number',
description: 'Offset for fetching the next page',
optional: true,
},
success: { type: 'boolean', description: 'Operation success status' },
},
}