mirror of
https://github.com/simstudioai/sim.git
synced 2026-02-06 04:35:03 -05:00
* fix(linear): align tool outputs, queries, and pagination with API * fix(linear): coerce first param to number, remove duplicate conditions, add null guard
131 lines
3.3 KiB
TypeScript
131 lines
3.3 KiB
TypeScript
import type { LinearCreateLabelParams, LinearCreateLabelResponse } from '@/tools/linear/types'
|
|
import { LABEL_FULL_OUTPUT_PROPERTIES } from '@/tools/linear/types'
|
|
import type { ToolConfig } from '@/tools/types'
|
|
|
|
export const linearCreateLabelTool: ToolConfig<LinearCreateLabelParams, LinearCreateLabelResponse> =
|
|
{
|
|
id: 'linear_create_label',
|
|
name: 'Linear Create Label',
|
|
description: 'Create a new label in Linear',
|
|
version: '1.0.0',
|
|
|
|
oauth: {
|
|
required: true,
|
|
provider: 'linear',
|
|
},
|
|
|
|
params: {
|
|
name: {
|
|
type: 'string',
|
|
required: true,
|
|
visibility: 'user-or-llm',
|
|
description: 'Label name',
|
|
},
|
|
color: {
|
|
type: 'string',
|
|
required: false,
|
|
visibility: 'user-or-llm',
|
|
description: 'Label color (hex format, e.g., "#ff0000")',
|
|
},
|
|
description: {
|
|
type: 'string',
|
|
required: false,
|
|
visibility: 'user-or-llm',
|
|
description: 'Label description',
|
|
},
|
|
teamId: {
|
|
type: 'string',
|
|
required: false,
|
|
visibility: 'user-or-llm',
|
|
description: 'Team ID (if omitted, creates workspace label)',
|
|
},
|
|
},
|
|
|
|
request: {
|
|
url: 'https://api.linear.app/graphql',
|
|
method: 'POST',
|
|
headers: (params) => {
|
|
if (!params.accessToken) {
|
|
throw new Error('Missing access token for Linear API request')
|
|
}
|
|
return {
|
|
'Content-Type': 'application/json',
|
|
Authorization: `Bearer ${params.accessToken}`,
|
|
}
|
|
},
|
|
body: (params) => {
|
|
const input: Record<string, any> = {
|
|
name: params.name,
|
|
}
|
|
|
|
if (params.color != null && params.color !== '') input.color = params.color
|
|
if (params.description != null && params.description !== '')
|
|
input.description = params.description
|
|
if (params.teamId != null && params.teamId !== '') input.teamId = params.teamId
|
|
|
|
return {
|
|
query: `
|
|
mutation CreateLabel($input: IssueLabelCreateInput!) {
|
|
issueLabelCreate(input: $input) {
|
|
success
|
|
issueLabel {
|
|
id
|
|
name
|
|
color
|
|
description
|
|
isGroup
|
|
createdAt
|
|
updatedAt
|
|
archivedAt
|
|
team {
|
|
id
|
|
name
|
|
}
|
|
}
|
|
}
|
|
}
|
|
`,
|
|
variables: {
|
|
input,
|
|
},
|
|
}
|
|
},
|
|
},
|
|
|
|
transformResponse: async (response) => {
|
|
const data = await response.json()
|
|
|
|
if (data.errors) {
|
|
return {
|
|
success: false,
|
|
error: data.errors[0]?.message || 'Failed to create label',
|
|
output: {},
|
|
}
|
|
}
|
|
|
|
const result = data.data.issueLabelCreate
|
|
if (!result.success) {
|
|
return {
|
|
success: false,
|
|
error: 'Label creation was not successful',
|
|
output: {},
|
|
}
|
|
}
|
|
|
|
return {
|
|
success: true,
|
|
output: {
|
|
label: result.issueLabel,
|
|
},
|
|
}
|
|
},
|
|
|
|
outputs: {
|
|
label: {
|
|
type: 'object',
|
|
description: 'The created label',
|
|
properties: LABEL_FULL_OUTPUT_PROPERTIES,
|
|
},
|
|
},
|
|
}
|