import { useMutation, useQueryClient } from '@tanstack/react-query' import { toast } from 'sonner' import { projectKeys } from './keys' import { handleError, post } from '@/data/fetchers' import type { ResponseError, UseCustomMutationOptions } from '@/types' export type ProjectCloneVariables = { projectRef: string newProjectName: string newDbPass: string cloneBackupId?: number recoveryTimeTarget?: number } export async function triggerClone({ projectRef, newProjectName, cloneBackupId, newDbPass, recoveryTimeTarget, }: ProjectCloneVariables) { if (!projectRef) throw new Error('Project ref is required') const { data, error } = await post('/platform/database/{ref}/clone', { params: { path: { ref: projectRef } }, body: { cloneBackupId, newProjectName, newDbPass, recoveryTimeTarget, }, }) if (error) handleError(error) return data } type ProjectCloneData = Awaited> export const useProjectCloneMutation = ({ onSuccess, onError, ...options }: Omit< UseCustomMutationOptions, 'mutationFn' > = {}) => { const queryClient = useQueryClient() return useMutation({ mutationFn: (vars) => triggerClone(vars), async onSuccess(data, variables, context) { await queryClient.invalidateQueries({ queryKey: projectKeys.listCloneBackups(variables.projectRef), }) await onSuccess?.(data, variables, context) }, async onError(data, variables, context) { if (onError === undefined) { console.error(data) toast.error(`Failed to trigger clone: ${data.message}`) } else { onError(data, variables, context) } }, ...options, }) }