feat: Add possibility to remove and reauthorize GitHub connections (#40126)

This commit is contained in:
Luca Forstner
2025-11-05 11:58:37 +01:00
committed by GitHub
parent 04bac966a8
commit d23f08e561
7 changed files with 233 additions and 34 deletions

View File

@@ -0,0 +1,48 @@
import { useMutation, useQueryClient } from '@tanstack/react-query'
import { toast } from 'sonner'
import { del, handleError } from 'data/fetchers'
import type { ResponseError, UseCustomMutationOptions } from 'types'
import { integrationKeys } from './keys'
export async function deleteGitHubAuthorization(signal?: AbortSignal) {
const { data, error } = await del('/platform/integrations/github/authorization', { signal })
if (error) handleError(error)
return data
}
type GitHubAuthorizationDeleteData = Awaited<ReturnType<typeof deleteGitHubAuthorization>>
export const useGitHubAuthorizationDeleteMutation = ({
onSuccess,
onError,
...options
}: Omit<
UseCustomMutationOptions<GitHubAuthorizationDeleteData, ResponseError, void>,
'mutationFn'
> = {}) => {
const queryClient = useQueryClient()
return useMutation<GitHubAuthorizationDeleteData, ResponseError, void>({
mutationFn: () => deleteGitHubAuthorization(),
async onSuccess(data, variables, context) {
await Promise.all([
queryClient.invalidateQueries({
queryKey: integrationKeys.githubAuthorization(),
}),
queryClient.invalidateQueries({
queryKey: integrationKeys.githubRepositoriesList(),
}),
])
await onSuccess?.(data, variables, context)
},
async onError(data, variables, context) {
if (onError === undefined) {
toast.error(`Failed to remove GitHub authorization: ${data.message}`)
} else {
onError(data, variables, context)
}
},
...options,
})
}