import { useMutation, useQueryClient } from '@tanstack/react-query' import { toast } from 'sonner' import { isQueueNameValid } from 'components/interfaces/Integrations/Queues/Queues.utils' import { executeSql } from 'data/sql/execute-sql-query' import type { ResponseError, UseCustomMutationOptions } from 'types' import { databaseQueuesKeys } from './keys' export type DatabaseQueueMessageSendVariables = { projectRef: string connectionString?: string | null queueName: string payload: string delay: number } export async function sendDatabaseQueueMessage({ projectRef, connectionString, queueName, payload, delay, }: DatabaseQueueMessageSendVariables) { if (!isQueueNameValid(queueName)) { throw new Error( 'Invalid queue name: must contain only alphanumeric characters, underscores, and hyphens' ) } const { result } = await executeSql({ projectRef, connectionString, sql: `select * from pgmq.send( '${queueName}', '${payload}', ${delay})`, queryKey: databaseQueuesKeys.create(), }) return result } type DatabaseQueueMessageSendData = Awaited> export const useDatabaseQueueMessageSendMutation = ({ onSuccess, onError, ...options }: Omit< UseCustomMutationOptions< DatabaseQueueMessageSendData, ResponseError, DatabaseQueueMessageSendVariables >, 'mutationFn' > = {}) => { const queryClient = useQueryClient() return useMutation< DatabaseQueueMessageSendData, ResponseError, DatabaseQueueMessageSendVariables >({ mutationFn: (vars) => sendDatabaseQueueMessage(vars), async onSuccess(data, variables, context) { const { projectRef, queueName } = variables await queryClient.invalidateQueries({ queryKey: databaseQueuesKeys.getMessagesInfinite(projectRef, queueName), }) await onSuccess?.(data, variables, context) }, async onError(data, variables, context) { if (onError === undefined) { toast.error(`Failed to send database queue message: ${data.message}`) } else { onError(data, variables, context) } }, ...options, }) }