Skip to main content
Glama

mcp-google-sheets

new-line-item.ts4.19 kB
import { hubspotAuth } from '../../'; import { DedupeStrategy, Polling, pollingHelper } from '@activepieces/pieces-common'; import { createTrigger, PiecePropValueSchema, Property, TriggerStrategy, } from '@activepieces/pieces-framework'; import { MarkdownVariant } from '@activepieces/shared'; import { getDefaultPropertiesForObject, standardObjectPropertiesDropdown } from '../common/props'; import { OBJECT_TYPE } from '../common/constants'; import { Client } from '@hubspot/api-client'; import { FilterOperatorEnum } from '../common/types'; import dayjs from 'dayjs'; type Props = { additionalPropertiesToRetrieve?: string | string[]; }; const polling: Polling<PiecePropValueSchema<typeof hubspotAuth>, Props> = { strategy: DedupeStrategy.TIMEBASED, async items({ auth, propsValue, lastFetchEpochMS }) { const client = new Client({ accessToken: auth.access_token, numberOfApiCallRetries: 3 }); // Extract properties once to avoid recomputation const additionalProperties = propsValue.additionalPropertiesToRetrieve ?? []; const defaultLineItemProperties = getDefaultPropertiesForObject(OBJECT_TYPE.LINE_ITEM); const propertiesToRetrieve = [...defaultLineItemProperties, ...additionalProperties]; const items = []; let after; do { const isTest = lastFetchEpochMS === 0; const response = await client.crm.lineItems.searchApi.doSearch({ limit: isTest ? 10 : 100, after, properties: propertiesToRetrieve, sorts: ['-createdate'], filterGroups: isTest ? [] : [ { filters: [ { propertyName: 'createdate', operator: FilterOperatorEnum.Gt, value: lastFetchEpochMS.toString(), }, ], }, ], }); after = response.paging?.next?.after; items.push(...response.results); // Stop fetching if it's a test if (isTest) break; } while (after); return items.map((item) => ({ epochMilliSeconds: dayjs(item.properties['createdate']).valueOf(), data: item, })); }, }; export const newLineItemTrigger = createTrigger({ auth: hubspotAuth, name: 'new-line-item', displayName: 'New Line Item', description: 'Triggers when new line item is available.', props: { markdown: Property.MarkDown({ variant: MarkdownVariant.INFO, value: `### Properties to retrieve: name, description, price, quantity, amount, discount, tax, createdate, hs_object_id, hs_product_id, hs_images, hs_lastmodifieddate, hs_line_item_currency_code, hs_sku, hs_url, hs_cost_of_goods_sold, hs_discount_percentage, hs_term_in_months **Specify here a list of additional properties to retrieve**`, }), additionalPropertiesToRetrieve: standardObjectPropertiesDropdown({ objectType: OBJECT_TYPE.LINE_ITEM, displayName: 'Additional properties to retrieve', required: false, }), }, type: TriggerStrategy.POLLING, async onEnable(context) { await pollingHelper.onEnable(polling, { auth: context.auth, store: context.store, propsValue: context.propsValue, }); }, async onDisable(context) { await pollingHelper.onDisable(polling, { auth: context.auth, store: context.store, propsValue: context.propsValue, }); }, async test(context) { return await pollingHelper.test(polling, context); }, async run(context) { return await pollingHelper.poll(polling, context); }, sampleData: { createdAt: '2024-12-25T11:08:54.763Z', archived: false, id: '26882583648', properties: { amount: '5.00', createdate: '2024-12-25T11:08:54.763Z', description: 'CHAIR', discount: '10', hs_cost_of_goods_sold: '10', hs_discount_percentage: null, hs_images: null, hs_lastmodifieddate: '2024-12-25T11:10:02.750Z', hs_line_item_currency_code: null, hs_object_id: '26882583648', hs_product_id: '17602013482', hs_sku: 'fb-100', hs_tax_amount: null, hs_tcv: '5.00', hs_term_in_months: null, hs_total_discount: '10.00', hs_url: null, name: 'Chair', price: '15.0', quantity: null, tax: null, }, updatedAt: '2024-12-25T11:10:02.750Z', }, });

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/activepieces/activepieces'

If you have feedback or need assistance with the MCP directory API, please join our Discord server