ThirdPartyAuthForm() — supabase Function Reference
Architecture documentation for the ThirdPartyAuthForm() function in index.tsx from the supabase codebase.
Entity Profile
Dependency Diagram
graph TD 861593ed_d4cc_b2ec_4f85_e0fbed9e8bf7["ThirdPartyAuthForm()"] 9f287a7b_e14d_5a58_d3e7_e68fdd750516["getIntegrationType()"] 861593ed_d4cc_b2ec_4f85_e0fbed9e8bf7 -->|calls| 9f287a7b_e14d_5a58_d3e7_e68fdd750516 961184dc_9929_f906_f6a2_6e1432c44d7c["getIntegrationTypeLabel()"] 861593ed_d4cc_b2ec_4f85_e0fbed9e8bf7 -->|calls| 961184dc_9929_f906_f6a2_6e1432c44d7c style 861593ed_d4cc_b2ec_4f85_e0fbed9e8bf7 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
apps/studio/components/interfaces/Auth/ThirdPartyAuthForm/index.tsx lines 43–200
export const ThirdPartyAuthForm = () => {
const { ref: projectRef } = useParams()
const {
data: integrationsData,
isPending: isLoading,
isError,
isSuccess,
error,
} = useQuery(thirdPartyAuthIntegrationsQueryOptions({ projectRef }))
const integrations = integrationsData || []
const [selectedIntegration, setSelectedIntegration] = useState<INTEGRATION_TYPES>()
const [selectedIntegrationForDeletion, setSelectedIntegrationForDeletion] =
useState<ThirdPartyAuthIntegration>()
const { mutateAsync: deleteIntegration } = useDeleteThirdPartyAuthIntegrationMutation()
const { can: canUpdateConfig } = useAsyncCheckPermissions(
PermissionAction.UPDATE,
'custom_config_gotrue'
)
if (isError) {
return (
<AlertError
error={error}
subject="Failed to retrieve auth configuration for Third-Party Auth Integrations"
/>
)
}
return (
<PageSection>
<PageSectionMeta>
<PageSectionSummary>
<PageSectionTitle>Third-Party Auth</PageSectionTitle>
<PageSectionDescription>
Billing is based on the number of monthly active users (MAUs) requesting your API
throughout the billing period.{' '}
<InlineLink
href={`${DOCS_URL}/guides/platform/manage-your-usage/monthly-active-users-third-party`}
>
Learn more
</InlineLink>
</PageSectionDescription>
</PageSectionSummary>
<PageSectionAside>
<DocsButton href={`${DOCS_URL}/guides/auth/third-party/overview`} />
<AddIntegrationDropdown onSelectIntegrationType={setSelectedIntegration} />
</PageSectionAside>
</PageSectionMeta>
<PageSectionContent>
{isLoading && (
<div
className={cn(
'border rounded border-default px-20 py-16 flex flex-col items-center justify-center space-y-4'
)}
>
<Loader2 size={24} className="animate-spin" />
</div>
)}
{isSuccess ? (
integrations.length === 0 ? (
<EmptyStatePresentational
title="Add an authentication provider"
description="Use third-party authentication systems based on JWTs to access your project."
>
<AddIntegrationDropdown
align="center"
type="default"
onSelectIntegrationType={setSelectedIntegration}
/>
</EmptyStatePresentational>
) : (
<div className="-space-y-px">
{integrations.map((integration) => {
return (
<IntegrationCard
key={integration.id}
integration={integration}
canUpdateConfig={canUpdateConfig}
onDelete={() => {
setSelectedIntegrationForDeletion(integration)
}}
/>
)
})}
</div>
)
) : null}
<CreateFirebaseAuthIntegrationDialog
visible={selectedIntegration === 'firebase'}
onDelete={() => {}}
onClose={() => setSelectedIntegration(undefined)}
/>
<CreateAwsCognitoAuthIntegrationDialog
visible={selectedIntegration === 'awsCognito'}
onDelete={() => {}}
onClose={() => setSelectedIntegration(undefined)}
/>
<CreateAuth0IntegrationDialog
visible={selectedIntegration === 'auth0'}
onDelete={() => {}}
onClose={() => setSelectedIntegration(undefined)}
/>
<CreateClerkAuthIntegrationDialog
visible={selectedIntegration === 'clerk'}
onDelete={() => {}}
onClose={() => setSelectedIntegration(undefined)}
/>
<CreateWorkOSIntegrationDialog
visible={selectedIntegration === 'workos'}
onDelete={() => {}}
onClose={() => setSelectedIntegration(undefined)}
/>
<ConfirmationModal
size="medium"
visible={!!selectedIntegrationForDeletion}
variant="destructive"
title="Confirm to delete integration"
confirmLabel="Delete"
confirmLabelLoading="Deleting"
onCancel={() => setSelectedIntegrationForDeletion(undefined)}
onConfirm={async () => {
if (!selectedIntegrationForDeletion) {
return
}
const type = getIntegrationType(selectedIntegrationForDeletion)
try {
await deleteIntegration({
projectRef: projectRef!,
tpaId: selectedIntegrationForDeletion.id,
})
toast.success(`Successfully deleted ${getIntegrationTypeLabel(type)}.`)
setSelectedIntegrationForDeletion(undefined)
setSelectedIntegration(undefined)
} catch (error) {
toast.error(`Failed to delete ${getIntegrationTypeLabel(type)}.`)
console.error(error)
}
}}
>
<p className="text-sm text-foreground-light">
Are you sure you want to delete the{' '}
{getIntegrationTypeLabel(getIntegrationType(selectedIntegrationForDeletion))}{' '}
integration?
</p>
</ConfirmationModal>
</PageSectionContent>
</PageSection>
)
}
Domain
Subdomains
Source
Frequently Asked Questions
What does ThirdPartyAuthForm() do?
ThirdPartyAuthForm() is a function in the supabase codebase.
What does ThirdPartyAuthForm() call?
ThirdPartyAuthForm() calls 2 function(s): getIntegrationType, getIntegrationTypeLabel.
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free