Files
sim/apps/sim/tools/stripe/create_customer.ts
Waleed f99518b837 feat(calcom): added calcom (#3070)
* feat(tools): added calcom

* added more triggers, tested

* updated regex in script for release to be more lenient

* fix(tag-dropdown): performance improvements and scroll bug fixes

- Add flatTagIndexMap for O(1) tag lookups (replaces O(n²) findIndex calls)
- Memoize caret position calculation to avoid DOM manipulation on every render
- Use refs for inputValue/cursorPosition to keep handleTagSelect callback stable
- Change itemRefs from index-based to tag-based keys to prevent stale refs
- Fix scroll jump in nested folders by removing scroll reset from registerFolder
- Add onFolderEnter callback for scroll reset when entering folder via keyboard
- Disable keyboard navigation wrap-around at boundaries
- Simplify selection reset to single effect on flatTagList.length change

Also:
- Add safeCompare utility for timing-safe string comparison
- Refactor webhook signature validation to use safeCompare

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>

* updated types

* fix(calcom): simplify required field constraints for booking attendee

The condition field already restricts these to calcom_create_booking,
so simplified to required: true. Per Cal.com API docs, email is optional
while name and timeZone are required.

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>

* added tests

* updated folder multi select, updated calcom and github tools and docs generator script

* updated drag, updated outputs for tools, regen docs with nested docs script

* updated setup instructions links, destructure trigger outputs, fix text subblock styling

* updated docs gen script

* updated docs script

* updated docs script

* updated script

* remove destructuring of stripe webhook

* expanded wand textarea, updated calcom tools

---------

Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-29 20:37:30 -08:00

121 lines
3.2 KiB
TypeScript

import type { CreateCustomerParams, CustomerResponse } from '@/tools/stripe/types'
import { CUSTOMER_METADATA_OUTPUT_PROPERTIES, CUSTOMER_OUTPUT } from '@/tools/stripe/types'
import type { ToolConfig } from '@/tools/types'
export const stripeCreateCustomerTool: ToolConfig<CreateCustomerParams, CustomerResponse> = {
id: 'stripe_create_customer',
name: 'Stripe Create Customer',
description: 'Create a new customer object',
version: '1.0.0',
params: {
apiKey: {
type: 'string',
required: true,
visibility: 'user-only',
description: 'Stripe API key (secret key)',
},
email: {
type: 'string',
required: false,
visibility: 'user-or-llm',
description: 'Customer email address',
},
name: {
type: 'string',
required: false,
visibility: 'user-or-llm',
description: 'Customer full name',
},
phone: {
type: 'string',
required: false,
visibility: 'user-or-llm',
description: 'Customer phone number',
},
description: {
type: 'string',
required: false,
visibility: 'user-or-llm',
description: 'Description of the customer',
},
address: {
type: 'json',
required: false,
visibility: 'user-or-llm',
description: 'Customer address object',
},
metadata: {
type: 'json',
required: false,
visibility: 'user-or-llm',
description: 'Set of key-value pairs',
},
payment_method: {
type: 'string',
required: false,
visibility: 'user-or-llm',
description: 'Payment method ID to attach',
},
},
request: {
url: () => 'https://api.stripe.com/v1/customers',
method: 'POST',
headers: (params) => ({
Authorization: `Bearer ${params.apiKey}`,
'Content-Type': 'application/x-www-form-urlencoded',
}),
body: (params) => {
const formData = new URLSearchParams()
if (params.email) formData.append('email', params.email)
if (params.name) formData.append('name', params.name)
if (params.phone) formData.append('phone', params.phone)
if (params.description) formData.append('description', params.description)
if (params.payment_method) formData.append('payment_method', params.payment_method)
if (params.address) {
Object.entries(params.address).forEach(([key, value]) => {
if (value) formData.append(`address[${key}]`, String(value))
})
}
if (params.metadata) {
Object.entries(params.metadata).forEach(([key, value]) => {
formData.append(`metadata[${key}]`, String(value))
})
}
return { body: formData.toString() }
},
},
transformResponse: async (response) => {
const data = await response.json()
return {
success: true,
output: {
customer: data,
metadata: {
id: data.id,
email: data.email ?? null,
name: data.name ?? null,
},
},
}
},
outputs: {
customer: {
...CUSTOMER_OUTPUT,
description: 'The created customer object',
},
metadata: {
type: 'json',
description: 'Customer metadata',
properties: CUSTOMER_METADATA_OUTPUT_PROPERTIES,
},
},
}