mirror of
https://github.com/simstudioai/sim.git
synced 2026-04-06 03:00:16 -04:00
* feat(slack): add new tools and user selectors * fix(slack): fix download fileName param and canvas error handling * fix(slack): use markdown format for canvas rename title_content * fix(slack): rename channel output to channelInfo and document presence API limitation * lint * fix(chat): use explicit trigger type check instead of heuristic for chat guard (#3419) * fix(chat): use explicit trigger type check instead of heuristic for chat guard * fix(chat): remove heuristic fallback from isExecutingFromChat Use only overrideTriggerType === 'chat' instead of also checking for 'input' in workflowInput, which can false-positive on manual executions with workflow input. * fix(chat): use isExecutingFromChat variable consistently in callbacks Replace inline overrideTriggerType !== 'chat' checks with !isExecutingFromChat to stay consistent with the rest of the function. * fix(slack): add missing fields to SlackChannel interface * fix(slack): fix canvas transformResponse type mismatch Provide required output fields on error path to match SlackCanvasResponse type. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * fix(slack): move error field to top level in canvas transformResponse The error field belongs on ToolResponse, not inside the output object. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> --------- Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
122 lines
3.2 KiB
TypeScript
122 lines
3.2 KiB
TypeScript
import type { SlackEditCanvasParams, SlackEditCanvasResponse } from '@/tools/slack/types'
|
|
import type { ToolConfig } from '@/tools/types'
|
|
|
|
export const slackEditCanvasTool: ToolConfig<SlackEditCanvasParams, SlackEditCanvasResponse> = {
|
|
id: 'slack_edit_canvas',
|
|
name: 'Slack Edit Canvas',
|
|
description: 'Edit an existing Slack canvas by inserting, replacing, or deleting content',
|
|
version: '1.0.0',
|
|
|
|
oauth: {
|
|
required: true,
|
|
provider: 'slack',
|
|
},
|
|
|
|
params: {
|
|
authMethod: {
|
|
type: 'string',
|
|
required: false,
|
|
visibility: 'user-only',
|
|
description: 'Authentication method: oauth or bot_token',
|
|
},
|
|
botToken: {
|
|
type: 'string',
|
|
required: false,
|
|
visibility: 'user-only',
|
|
description: 'Bot token for Custom Bot',
|
|
},
|
|
accessToken: {
|
|
type: 'string',
|
|
required: false,
|
|
visibility: 'hidden',
|
|
description: 'OAuth access token or bot token for Slack API',
|
|
},
|
|
canvasId: {
|
|
type: 'string',
|
|
required: true,
|
|
visibility: 'user-or-llm',
|
|
description: 'Canvas ID to edit (e.g., F1234ABCD)',
|
|
},
|
|
operation: {
|
|
type: 'string',
|
|
required: true,
|
|
visibility: 'user-or-llm',
|
|
description:
|
|
'Edit operation: insert_at_start, insert_at_end, insert_after, insert_before, replace, delete, or rename',
|
|
},
|
|
content: {
|
|
type: 'string',
|
|
required: false,
|
|
visibility: 'user-or-llm',
|
|
description: 'Markdown content for the operation (required for insert/replace operations)',
|
|
},
|
|
sectionId: {
|
|
type: 'string',
|
|
required: false,
|
|
visibility: 'user-or-llm',
|
|
description:
|
|
'Section ID to target (required for insert_after, insert_before, replace, and delete)',
|
|
},
|
|
title: {
|
|
type: 'string',
|
|
required: false,
|
|
visibility: 'user-or-llm',
|
|
description: 'New title for the canvas (only used with rename operation)',
|
|
},
|
|
},
|
|
|
|
request: {
|
|
url: 'https://slack.com/api/canvases.edit',
|
|
method: 'POST',
|
|
headers: (params: SlackEditCanvasParams) => ({
|
|
'Content-Type': 'application/json',
|
|
Authorization: `Bearer ${params.accessToken || params.botToken}`,
|
|
}),
|
|
body: (params: SlackEditCanvasParams) => {
|
|
const change: Record<string, unknown> = {
|
|
operation: params.operation,
|
|
}
|
|
|
|
if (params.sectionId) {
|
|
change.section_id = params.sectionId.trim()
|
|
}
|
|
|
|
if (params.operation === 'rename' && params.title) {
|
|
change.title_content = {
|
|
type: 'markdown',
|
|
markdown: params.title,
|
|
}
|
|
} else if (params.content && params.operation !== 'delete') {
|
|
change.document_content = {
|
|
type: 'markdown',
|
|
markdown: params.content,
|
|
}
|
|
}
|
|
|
|
return {
|
|
canvas_id: params.canvasId.trim(),
|
|
changes: [change],
|
|
}
|
|
},
|
|
},
|
|
|
|
transformResponse: async (response: Response) => {
|
|
const data = await response.json()
|
|
|
|
if (!data.ok) {
|
|
throw new Error(data.error || 'Failed to edit canvas')
|
|
}
|
|
|
|
return {
|
|
success: true,
|
|
output: {
|
|
content: 'Successfully edited canvas',
|
|
},
|
|
}
|
|
},
|
|
|
|
outputs: {
|
|
content: { type: 'string', description: 'Success message' },
|
|
},
|
|
}
|