mirror of
https://github.com/simstudioai/sim.git
synced 2026-01-07 22:24:06 -05:00
* Adding guardrails block * ack PR comments * cleanup checkbox in dark mode * cleanup * fix supabase tools
88 lines
2.3 KiB
TypeScript
88 lines
2.3 KiB
TypeScript
import type { SupabaseGetRowParams, SupabaseGetRowResponse } from '@/tools/supabase/types'
|
|
import type { ToolConfig } from '@/tools/types'
|
|
|
|
export const getRowTool: ToolConfig<SupabaseGetRowParams, SupabaseGetRowResponse> = {
|
|
id: 'supabase_get_row',
|
|
name: 'Supabase Get Row',
|
|
description: 'Get a single row from a Supabase table based on filter criteria',
|
|
version: '1.0',
|
|
|
|
params: {
|
|
projectId: {
|
|
type: 'string',
|
|
required: true,
|
|
visibility: 'user-only',
|
|
description: 'Your Supabase project ID (e.g., jdrkgepadsdopsntdlom)',
|
|
},
|
|
table: {
|
|
type: 'string',
|
|
required: true,
|
|
visibility: 'user-or-llm',
|
|
description: 'The name of the Supabase table to query',
|
|
},
|
|
filter: {
|
|
type: 'string',
|
|
required: true,
|
|
visibility: 'user-or-llm',
|
|
description: 'PostgREST filter to find the specific row (e.g., "id=eq.123")',
|
|
},
|
|
apiKey: {
|
|
type: 'string',
|
|
required: true,
|
|
visibility: 'user-only',
|
|
description: 'Your Supabase service role secret key',
|
|
},
|
|
},
|
|
|
|
request: {
|
|
url: (params) => {
|
|
// Construct the URL for the Supabase REST API
|
|
let url = `https://${params.projectId}.supabase.co/rest/v1/${params.table}?select=*`
|
|
|
|
// Add filters (required for get_row) - using PostgREST syntax
|
|
if (params.filter?.trim()) {
|
|
url += `&${params.filter.trim()}`
|
|
}
|
|
|
|
// Limit to 1 row since we want a single row
|
|
url += `&limit=1`
|
|
|
|
return url
|
|
},
|
|
method: 'GET',
|
|
headers: (params) => ({
|
|
apikey: params.apiKey,
|
|
Authorization: `Bearer ${params.apiKey}`,
|
|
}),
|
|
},
|
|
|
|
transformResponse: async (response: Response) => {
|
|
let data
|
|
try {
|
|
data = await response.json()
|
|
} catch (parseError) {
|
|
throw new Error(`Failed to parse Supabase response: ${parseError}`)
|
|
}
|
|
|
|
const rowFound = data.length > 0
|
|
const results = rowFound ? [data[0]] : []
|
|
|
|
return {
|
|
success: true,
|
|
output: {
|
|
message: rowFound ? 'Successfully found 1 row' : 'No row found matching the criteria',
|
|
results: results,
|
|
},
|
|
error: undefined,
|
|
}
|
|
},
|
|
|
|
outputs: {
|
|
message: { type: 'string', description: 'Operation status message' },
|
|
results: {
|
|
type: 'array',
|
|
description: 'Array containing the row data if found, empty array if not found',
|
|
},
|
|
},
|
|
}
|