mirror of
https://github.com/supabase/supabase.git
synced 2026-06-14 05:06:27 +08:00
## Problem Now that we migrated old components to their new shadcn alternatives, we don't need the `_Shadcn_` suffix anymore. ## Solution Remove it <img width="659" height="609" alt="image" src="https://github.com/user-attachments/assets/2d7271a9-066a-4dcc-92fe-729b106d2c2f" />
124 lines
5.1 KiB
TypeScript
124 lines
5.1 KiB
TypeScript
import { useParams } from 'common'
|
|
import { ExternalLink } from 'lucide-react'
|
|
import Link from 'next/link'
|
|
import { Alert, AlertDescription, AlertTitle, Button, WarningIcon } from 'ui'
|
|
import {
|
|
PageSection,
|
|
PageSectionContent,
|
|
PageSectionDescription,
|
|
PageSectionMeta,
|
|
PageSectionSummary,
|
|
PageSectionTitle,
|
|
} from 'ui-patterns/PageSection'
|
|
|
|
import { getPhoneProviderValidationSchema, PROVIDERS_SCHEMAS } from '../AuthProvidersFormValidation'
|
|
import type { Provider } from './AuthProvidersForm.types'
|
|
import { ProviderForm } from './ProviderForm'
|
|
import AlertError from '@/components/ui/AlertError'
|
|
import { ResourceList } from '@/components/ui/Resource/ResourceList'
|
|
import { HorizontalShimmerWithIcon } from '@/components/ui/Shimmers'
|
|
import { useAuthConfigQuery } from '@/data/auth/auth-config-query'
|
|
|
|
export const AuthProvidersForm = () => {
|
|
const { ref: projectRef } = useParams()
|
|
const {
|
|
data: authConfig,
|
|
error: authConfigError,
|
|
isPending: isLoading,
|
|
isError,
|
|
isSuccess,
|
|
} = useAuthConfigQuery({ projectRef })
|
|
|
|
return (
|
|
<PageSection>
|
|
<PageSectionMeta>
|
|
<PageSectionSummary>
|
|
<PageSectionTitle>Auth Providers</PageSectionTitle>
|
|
<PageSectionDescription>
|
|
Authenticate your users through a suite of providers and login methods
|
|
</PageSectionDescription>
|
|
</PageSectionSummary>
|
|
</PageSectionMeta>
|
|
<PageSectionContent>
|
|
{isError ? (
|
|
<AlertError
|
|
error={authConfigError}
|
|
subject="Failed to retrieve auth configuration for hooks"
|
|
/>
|
|
) : (
|
|
<div className="-space-y-px">
|
|
{authConfig?.EXTERNAL_EMAIL_ENABLED && authConfig?.MAILER_OTP_EXP > 3600 && (
|
|
<Alert className="flex w-full items-center justify-between my-3" variant="warning">
|
|
<WarningIcon />
|
|
<div>
|
|
<AlertTitle>OTP expiry exceeds recommended threshold</AlertTitle>
|
|
<AlertDescription className="flex flex-col gap-y-3">
|
|
<p>
|
|
We have detected that you have enabled the email provider with the OTP expiry
|
|
set to more than an hour. It is recommended to set this value to less than an
|
|
hour.
|
|
</p>
|
|
<Button asChild type="default" className="w-min" icon={<ExternalLink />}>
|
|
<Link href="https://supabase.com/docs/guides/platform/going-into-prod#security">
|
|
View security recommendations
|
|
</Link>
|
|
</Button>
|
|
</AlertDescription>
|
|
</div>
|
|
</Alert>
|
|
)}
|
|
|
|
<ResourceList>
|
|
{isLoading &&
|
|
PROVIDERS_SCHEMAS.map((provider) => (
|
|
<div
|
|
key={`provider_${provider.title}`}
|
|
className="py-4 px-6 border-b last:border-b-none"
|
|
>
|
|
<HorizontalShimmerWithIcon />
|
|
</div>
|
|
))}
|
|
{isSuccess &&
|
|
PROVIDERS_SCHEMAS.map((provider) => {
|
|
const providerSchema =
|
|
provider.title === 'Phone'
|
|
? {
|
|
...provider,
|
|
validationSchema: getPhoneProviderValidationSchema(authConfig),
|
|
}
|
|
: provider
|
|
let isActive = false
|
|
if (providerSchema.title === 'SAML 2.0') {
|
|
isActive = authConfig && (authConfig as any)['SAML_ENABLED']
|
|
} else if (providerSchema.title === 'LinkedIn (OIDC)') {
|
|
isActive = authConfig && (authConfig as any)['EXTERNAL_LINKEDIN_OIDC_ENABLED']
|
|
} else if (providerSchema.title === 'Slack (OIDC)') {
|
|
isActive = authConfig && (authConfig as any)['EXTERNAL_SLACK_OIDC_ENABLED']
|
|
} else if (providerSchema.title.includes('Web3')) {
|
|
isActive = authConfig && (authConfig as any)['EXTERNAL_WEB3_SOLANA_ENABLED']
|
|
} else if (providerSchema.title.includes('X / Twitter (OAuth 2.0)')) {
|
|
isActive = authConfig && (authConfig as any)['EXTERNAL_X_ENABLED']
|
|
} else if (providerSchema.title === 'Twitter (Deprecated)') {
|
|
isActive = authConfig && (authConfig as any)['EXTERNAL_TWITTER_ENABLED']
|
|
} else {
|
|
isActive =
|
|
authConfig &&
|
|
(authConfig as any)[`EXTERNAL_${providerSchema.title.toUpperCase()}_ENABLED`]
|
|
}
|
|
return (
|
|
<ProviderForm
|
|
key={`provider_${providerSchema.title}`}
|
|
config={authConfig!}
|
|
provider={providerSchema as unknown as Provider}
|
|
isActive={isActive}
|
|
/>
|
|
)
|
|
})}
|
|
</ResourceList>
|
|
</div>
|
|
)}
|
|
</PageSectionContent>
|
|
</PageSection>
|
|
)
|
|
}
|