import pgMeta from '@supabase/pg-meta' import { useMutation, useQueryClient } from '@tanstack/react-query' import { toast } from 'sonner' import { z } from 'zod' import type { DatabaseFunction } from './database-functions-query' import { databaseKeys } from '@/data/database/keys' import { executeSql } from '@/data/sql/execute-sql-query' import type { ResponseError, UseCustomMutationOptions } from '@/types' export type DatabaseFunctionUpdateVariables = { projectRef: string connectionString?: string | null func: DatabaseFunction payload: z.infer } export async function updateDatabaseFunction({ projectRef, connectionString, func, payload, }: DatabaseFunctionUpdateVariables) { const { sql, zod } = pgMeta.functions.update(func, payload) const { result } = await executeSql({ projectRef, connectionString, sql, queryKey: ['functions', 'update', func.id.toString()], }) return result as z.infer } type DatabaseFunctionUpdateData = Awaited> export const useDatabaseFunctionUpdateMutation = ({ onSuccess, onError, ...options }: Omit< UseCustomMutationOptions< DatabaseFunctionUpdateData, ResponseError, DatabaseFunctionUpdateVariables >, 'mutationFn' > = {}) => { const queryClient = useQueryClient() return useMutation({ mutationFn: (vars) => updateDatabaseFunction(vars), async onSuccess(data, variables, context) { const { projectRef } = variables await queryClient.invalidateQueries({ queryKey: databaseKeys.databaseFunctions(projectRef) }) await onSuccess?.(data, variables, context) }, async onError(data, variables, context) { if (onError === undefined) { toast.error(`Failed to update database function: ${data.message}`) } else { onError(data, variables, context) } }, ...options, }) }