Files
supabase/apps/studio/data/api-authorization/api-authorization-decline-mutation.ts
Alaister Young 8855d05803 chore(studio): swap react-query to object syntax (#39842)
* chore(studio): swap react-query to object syntax

* Fix small issues found

* Fix realtime settings

* Nit

---------

Co-authored-by: Joshen Lim <joshenlimek@gmail.com>
2025-10-27 09:38:27 +01:00

50 lines
1.6 KiB
TypeScript

import { useMutation, UseMutationOptions } from '@tanstack/react-query'
import { toast } from 'sonner'
import { del, handleError } from 'data/fetchers'
import type { ResponseError } from 'types'
export type ApiAuthorizationDeclineVariables = {
id: string
slug: string
}
export type ApiAuthorizationDeclineResponse = {
id: string
}
export async function declineApiAuthorization({ id, slug }: ApiAuthorizationDeclineVariables) {
if (!id) throw new Error('Authorization ID is required')
const { data, error } = await del('/platform/organizations/{slug}/oauth/authorizations/{id}', {
// @ts-ignore [Joshen] Endpoint doesnt need slug in the path params, but the endpoint path requires slug
// it's a little weird, will need API to decide if they wanna shift this route outside of the {slug} endpoint
params: { path: { slug, id } },
})
if (error) handleError(error)
return data as ApiAuthorizationDeclineResponse
}
type ApiAuthorizationDeclineData = Awaited<ReturnType<typeof declineApiAuthorization>>
export const useApiAuthorizationDeclineMutation = ({
onError,
...options
}: Omit<
UseMutationOptions<ApiAuthorizationDeclineData, ResponseError, ApiAuthorizationDeclineVariables>,
'mutationFn'
> = {}) => {
return useMutation<ApiAuthorizationDeclineData, ResponseError, ApiAuthorizationDeclineVariables>({
mutationFn: (vars) => declineApiAuthorization(vars),
async onError(data, variables, context) {
if (onError === undefined) {
toast.error(`Failed to decline authorization request: ${data.message}`)
} else {
onError(data, variables, context)
}
},
...options,
})
}