Skip to main content
Glama

mcp-google-sheets

get-payment-actions.ts3.49 kB
import { createAction, Property } from '@activepieces/pieces-framework'; import { checkoutComAuth, getEnvironmentFromApiKey } from '../common/auth'; import { httpClient, HttpMethod } from '@activepieces/pieces-common'; export const getPaymentActionsAction = createAction({ name: 'get_payment_actions', auth: checkoutComAuth, displayName: 'Get Payment Actions', description: 'Build full transaction lifecycles for audit logs.', props: { reference: Property.ShortText({ displayName: 'Reference', description: 'A reference, such as an order ID, that can be used to identify the payment', required: true, }), paymentId: Property.Dropdown({ displayName: 'Payment ID', description: 'Select the payment to get actions for', required: true, refreshers: ['reference'], options: async ({ auth, reference }) => { if (!reference) { return { disabled: true, options: [], placeholder: 'Please enter a reference first', }; } try { const { baseUrl } = getEnvironmentFromApiKey(auth as string); const response = await httpClient.sendRequest({ method: HttpMethod.GET, url: `${baseUrl}/payments`, queryParams: { reference: reference as string, limit: '100', }, headers: { Authorization: `Bearer ${auth}`, 'Content-Type': 'application/json', }, }); const payments = response.body.data || []; const validPayments = payments.filter((payment: any) => payment.id.startsWith('pay_')); if (validPayments.length === 0) { return { disabled: true, options: [], placeholder: 'No payment transactions found for this reference', }; } return { disabled: false, options: validPayments.map((payment: any) => ({ label: `${payment.id} - ${payment.amount} ${payment.currency} (${payment.status})`, value: payment.id, })), }; } catch (error) { return { disabled: true, options: [], placeholder: 'Error loading payments', }; } }, }), }, async run(context) { const { paymentId } = context.propsValue; const { baseUrl } = getEnvironmentFromApiKey(context.auth); if (!paymentId.match(/^pay_[a-zA-Z0-9]{26}$/)) { throw new Error('Invalid payment ID format. Must start with "pay_" followed by 26 alphanumeric characters.'); } try { const response = await httpClient.sendRequest({ method: HttpMethod.GET, url: `${baseUrl}/payments/${paymentId}/actions`, headers: { Authorization: `Bearer ${context.auth}`, 'Content-Type': 'application/json', }, }); return response.body; } catch (error: any) { if (error.response?.status === 401) { throw new Error('Unauthorized: Invalid API key or insufficient permissions'); } else if (error.response?.status === 404) { throw new Error('Payment not found: The specified payment ID does not exist or is not accessible'); } else { throw new Error(`Failed to get payment actions: ${error.message}`); } } }, });

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