Files
supabase/studio/data/auth/auth-config-update-mutation.ts

64 lines
1.7 KiB
TypeScript

import { useMutation, UseMutationOptions, useQueryClient } from '@tanstack/react-query'
import toast from 'react-hot-toast'
import { components } from 'data/api'
import { patch } from 'data/fetchers'
import { ResponseError } from 'types'
import { authKeys } from './keys'
export type AuthConfigUpdateVariables = {
projectRef: string
config: Partial<components['schemas']['UpdateGoTrueConfigBody']>
}
export type UpdateAuthConfigResponse = components['schemas']['GoTrueConfig']
export async function updateAuthConfig({ projectRef, config }: AuthConfigUpdateVariables) {
const { data, error } = await patch('/platform/auth/{ref}/config', {
params: {
path: { ref: projectRef },
},
body: {
...config,
},
})
if (error) throw error
return data
}
type AuthConfigUpdateData = Awaited<ReturnType<typeof updateAuthConfig>>
export const useAuthConfigUpdateMutation = ({
onSuccess,
onError,
...options
}: Omit<
UseMutationOptions<AuthConfigUpdateData, ResponseError, AuthConfigUpdateVariables>,
'mutationFn'
> = {}) => {
const queryClient = useQueryClient()
return useMutation<AuthConfigUpdateData, ResponseError, AuthConfigUpdateVariables>(
(vars) => updateAuthConfig(vars),
{
async onSuccess(data, variables, context) {
const { projectRef } = variables
await Promise.all([queryClient.invalidateQueries(authKeys.authConfig(projectRef))])
await onSuccess?.(data, variables, context)
},
async onError(data, variables, context) {
if (onError === undefined) {
toast.error(`Failed to update auth configuration: ${data.message}`)
} else {
onError(data, variables, context)
}
},
...options,
}
)
}