Files
sim/apps/sim/tools/a2a/send_message.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

85 lines
2.4 KiB
TypeScript

import type { ToolConfig } from '@/tools/types'
import type { A2ASendMessageParams, A2ASendMessageResponse } from './types'
import { A2A_OUTPUT_PROPERTIES } from './types'
export const a2aSendMessageTool: ToolConfig<A2ASendMessageParams, A2ASendMessageResponse> = {
id: 'a2a_send_message',
name: 'A2A Send Message',
description: 'Send a message to an external A2A-compatible agent.',
version: '1.0.0',
params: {
agentUrl: {
type: 'string',
required: true,
visibility: 'user-only',
description: 'The A2A agent endpoint URL',
},
message: {
type: 'string',
required: true,
visibility: 'user-or-llm',
description: 'Message to send to the agent',
},
taskId: {
type: 'string',
visibility: 'user-or-llm',
description: 'Task ID for continuing an existing task',
},
contextId: {
type: 'string',
visibility: 'user-or-llm',
description: 'Context ID for conversation continuity',
},
data: {
type: 'string',
visibility: 'user-or-llm',
description: 'Structured data to include with the message (JSON string)',
},
files: {
type: 'array',
visibility: 'user-only',
description: 'Files to include with the message',
},
apiKey: {
type: 'string',
visibility: 'user-only',
description: 'API key for authentication',
},
},
request: {
url: '/api/tools/a2a/send-message',
method: 'POST',
headers: () => ({
'Content-Type': 'application/json',
}),
body: (params) => {
const body: Record<string, unknown> = {
agentUrl: params.agentUrl,
message: params.message,
}
if (params.taskId) body.taskId = params.taskId
if (params.contextId) body.contextId = params.contextId
if (params.data) body.data = params.data
if (params.files && params.files.length > 0) body.files = params.files
if (params.apiKey) body.apiKey = params.apiKey
return body
},
},
transformResponse: async (response: Response) => {
const data = await response.json()
return data
},
outputs: {
content: A2A_OUTPUT_PROPERTIES.content,
taskId: A2A_OUTPUT_PROPERTIES.taskId,
contextId: A2A_OUTPUT_PROPERTIES.contextId,
state: A2A_OUTPUT_PROPERTIES.state,
artifacts: A2A_OUTPUT_PROPERTIES.artifacts,
history: A2A_OUTPUT_PROPERTIES.history,
},
}