mirror of
https://github.com/simstudioai/sim.git
synced 2026-04-06 03:00:16 -04:00
* feat(pagination): update pagination for remaining integrations that support it * fixed remaining * ack comments
126 lines
3.6 KiB
TypeScript
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' },
|
|
},
|
|
}
|