mirror of
https://github.com/simstudioai/sim.git
synced 2026-04-06 03:00:16 -04:00
* feat(confluence): add get user by account ID tool * feat(confluence): add missing tools for tasks, blog posts, spaces, descendants, permissions, and properties Add 16 new Confluence operations: list/get/update tasks, update/delete blog posts, create/update/delete spaces, get page descendants, list space permissions, list/create/delete space properties. Includes API routes, tool definitions, block config wiring, OAuth scopes, and generated docs. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * fix(confluence): add missing OAuth scopes to auth.ts provider config The OAuth authorization flow uses scopes from auth.ts, not oauth.ts. The 9 new scopes were only added to oauth.ts and the block config but not to the actual provider config in auth.ts, causing re-auth to still return tokens without the new scopes. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * lint * fix(confluence): fix truncated get_user tool description in docs Remove apostrophe from description that caused MDX generation to truncate at the escape character. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * fix(confluence): address PR review feedback - Move get_user from GET to POST to avoid exposing access token in URL - Add 400 validation for missing params in space-properties create/delete - Add null check for blog post version before update to prevent TypeError Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * feat(confluence): add missing response fields for descendants and tasks - Add type and depth fields to page descendants (from Confluence API) - Add body field (storage format) to task list/get/update responses Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * lint * fix(confluence): use validatePathSegment for Atlassian account IDs validateAlphanumericId rejects valid Atlassian account IDs that contain colons (e.g. 557058:6b9c9931-4693-49c1-8b3a-931f1af98134). Use validatePathSegment with a custom pattern allowing colons instead. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * ran lint * update mock * upgrade turborepo * fix(confluence): reject empty update body for space PUT Return 400 when neither name nor description is provided for space update, instead of sending an empty body to the Confluence API. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * fix(confluence): remove spaceId requirement for create_space and fix list_tasks pagination - Remove create_space from spaceId condition array since creating a space doesn't require a space ID input - Remove list_tasks from generic supportsCursor array so it uses its dedicated handler that correctly passes assignedTo and status filters during pagination Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com> * ran lint * fixed type errors --------- Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
142 lines
4.3 KiB
TypeScript
142 lines
4.3 KiB
TypeScript
import { TIMESTAMP_OUTPUT } from '@/tools/confluence/types'
|
|
import type { ToolConfig } from '@/tools/types'
|
|
|
|
export interface ConfluenceUpdateTaskParams {
|
|
accessToken: string
|
|
domain: string
|
|
taskId: string
|
|
status: string
|
|
cloudId?: string
|
|
}
|
|
|
|
export interface ConfluenceUpdateTaskResponse {
|
|
success: boolean
|
|
output: {
|
|
ts: string
|
|
id: string
|
|
localId: string | null
|
|
spaceId: string | null
|
|
pageId: string | null
|
|
blogPostId: string | null
|
|
status: string
|
|
body: string | null
|
|
createdBy: string | null
|
|
assignedTo: string | null
|
|
completedBy: string | null
|
|
createdAt: string | null
|
|
updatedAt: string | null
|
|
dueAt: string | null
|
|
completedAt: string | null
|
|
}
|
|
}
|
|
|
|
export const confluenceUpdateTaskTool: ToolConfig<
|
|
ConfluenceUpdateTaskParams,
|
|
ConfluenceUpdateTaskResponse
|
|
> = {
|
|
id: 'confluence_update_task',
|
|
name: 'Confluence Update Task',
|
|
description: 'Update the status of a Confluence inline task (complete or incomplete).',
|
|
version: '1.0.0',
|
|
|
|
oauth: {
|
|
required: true,
|
|
provider: 'confluence',
|
|
},
|
|
|
|
params: {
|
|
accessToken: {
|
|
type: 'string',
|
|
required: true,
|
|
visibility: 'hidden',
|
|
description: 'OAuth access token for Confluence',
|
|
},
|
|
domain: {
|
|
type: 'string',
|
|
required: true,
|
|
visibility: 'user-only',
|
|
description: 'Your Confluence domain (e.g., yourcompany.atlassian.net)',
|
|
},
|
|
taskId: {
|
|
type: 'string',
|
|
required: true,
|
|
visibility: 'user-or-llm',
|
|
description: 'The ID of the task to update',
|
|
},
|
|
status: {
|
|
type: 'string',
|
|
required: true,
|
|
visibility: 'user-or-llm',
|
|
description: 'New status for the task (complete or incomplete)',
|
|
},
|
|
cloudId: {
|
|
type: 'string',
|
|
required: false,
|
|
visibility: 'user-only',
|
|
description:
|
|
'Confluence Cloud ID for the instance. If not provided, it will be fetched using the domain.',
|
|
},
|
|
},
|
|
|
|
request: {
|
|
url: () => '/api/tools/confluence/tasks',
|
|
method: 'POST',
|
|
headers: (params: ConfluenceUpdateTaskParams) => ({
|
|
Accept: 'application/json',
|
|
'Content-Type': 'application/json',
|
|
Authorization: `Bearer ${params.accessToken}`,
|
|
}),
|
|
body: (params: ConfluenceUpdateTaskParams) => ({
|
|
domain: params.domain,
|
|
accessToken: params.accessToken,
|
|
cloudId: params.cloudId,
|
|
action: 'update',
|
|
taskId: params.taskId,
|
|
status: params.status,
|
|
}),
|
|
},
|
|
|
|
transformResponse: async (response: Response) => {
|
|
const data = await response.json()
|
|
const task = data.task || data
|
|
return {
|
|
success: true,
|
|
output: {
|
|
ts: new Date().toISOString(),
|
|
id: task.id ?? '',
|
|
localId: task.localId ?? null,
|
|
spaceId: task.spaceId ?? null,
|
|
pageId: task.pageId ?? null,
|
|
blogPostId: task.blogPostId ?? null,
|
|
status: task.status ?? '',
|
|
body: task.body ?? null,
|
|
createdBy: task.createdBy ?? null,
|
|
assignedTo: task.assignedTo ?? null,
|
|
completedBy: task.completedBy ?? null,
|
|
createdAt: task.createdAt ?? null,
|
|
updatedAt: task.updatedAt ?? null,
|
|
dueAt: task.dueAt ?? null,
|
|
completedAt: task.completedAt ?? null,
|
|
},
|
|
}
|
|
},
|
|
|
|
outputs: {
|
|
ts: TIMESTAMP_OUTPUT,
|
|
id: { type: 'string', description: 'Task ID' },
|
|
localId: { type: 'string', description: 'Local task ID', optional: true },
|
|
spaceId: { type: 'string', description: 'Space ID', optional: true },
|
|
pageId: { type: 'string', description: 'Page ID', optional: true },
|
|
blogPostId: { type: 'string', description: 'Blog post ID', optional: true },
|
|
status: { type: 'string', description: 'Updated task status' },
|
|
body: { type: 'string', description: 'Task body content in storage format', optional: true },
|
|
createdBy: { type: 'string', description: 'Creator account ID', optional: true },
|
|
assignedTo: { type: 'string', description: 'Assignee account ID', optional: true },
|
|
completedBy: { type: 'string', description: 'Completer account ID', optional: true },
|
|
createdAt: { type: 'string', description: 'Creation timestamp', optional: true },
|
|
updatedAt: { type: 'string', description: 'Last update timestamp', optional: true },
|
|
dueAt: { type: 'string', description: 'Due date', optional: true },
|
|
completedAt: { type: 'string', description: 'Completion timestamp', optional: true },
|
|
},
|
|
}
|