Skip to main content
Glama

mcp-google-sheets

item-updated.ts2.68 kB
import { createTrigger, TriggerStrategy } from '@activepieces/pieces-framework'; import { HttpMethod } from '@activepieces/pieces-common'; import { podioAuth } from '../../index'; import { podioApiCall, getAccessToken, dynamicAppProperty } from '../common'; export const itemUpdatedTrigger = createTrigger({ auth: podioAuth, name: 'item_updated', displayName: 'Item Updated', description: 'Fires when an existing item is updated (excluding comments)', props: { appId: dynamicAppProperty, }, sampleData: { type: "item.update", item_id: 1234567890, item_revision_id: 3, external_id: "external-item-123" }, type: TriggerStrategy.WEBHOOK, async onEnable(context) { const accessToken = getAccessToken(context.auth); const { appId } = context.propsValue; if (!appId) { throw new Error('App selection is required to enable the Item Updated trigger. Please select an app.'); } try { const response = await podioApiCall<{ hook_id: number }>({ method: HttpMethod.POST, accessToken, resourceUri: `/hook/app/${appId}/`, body: { url: context.webhookUrl, type: 'item.update', }, }); if (!response.hook_id) { throw new Error('Failed to create webhook: No hook ID returned from Podio API.'); } await context.store.put('podio_item_updated_hook_id', response.hook_id); await context.store.put('podio_item_updated_app_id', appId); } catch (error: any) { throw new Error(`Failed to enable Item Updated trigger: ${error.message || 'Unknown error occurred'}`); } }, async onDisable(context) { const accessToken = getAccessToken(context.auth); const hookId = await context.store.get<number>('podio_item_updated_hook_id'); if (!hookId) { return; } try { await podioApiCall({ method: HttpMethod.DELETE, accessToken, resourceUri: `/hook/${hookId}`, }); } catch (error: any) { if (error.response?.status === 404) { return; } throw new Error(`Failed to disable Item Updated trigger: ${error.message || 'Unknown error occurred'}`); } finally { await context.store.delete('podio_item_updated_hook_id'); await context.store.delete('podio_item_updated_app_id'); } }, async run(context) { const payload = context.payload.body; if (!payload || typeof payload !== 'object') { return []; } if (!(payload as any).type || (payload as any).type !== 'item.update') { return []; } if (!(payload as any).item_id) { return []; } return [payload]; }, });

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