Home / Function/ CreateNewAPIKeysButton() — supabase Function Reference

CreateNewAPIKeysButton() — supabase Function Reference

Architecture documentation for the CreateNewAPIKeysButton() function in CreateNewAPIKeysButton.tsx from the supabase codebase.

Entity Profile

Relationship Graph

Source Code

apps/studio/components/interfaces/APIKeys/CreateNewAPIKeysButton.tsx lines 18–67

export const CreateNewAPIKeysButton = () => {
  const { ref: projectRef } = useParams()

  const [isCreatingKeys, setIsCreatingKeys] = useState(false)
  const [createKeysDialogOpen, setCreateKeysDialogOpen] = useState(false)

  const { mutateAsync: createAPIKey } = useAPIKeyCreateMutation()

  const handleCreateNewApiKeys = async () => {
    if (!projectRef) return
    setIsCreatingKeys(true)

    try {
      // Create publishable key
      await createAPIKey({ projectRef, type: 'publishable', name: 'default' })

      // Create secret key
      await createAPIKey({ projectRef, type: 'secret', name: 'default' })

      setCreateKeysDialogOpen(false)
      toast.success('Successfully created a new set of API keys!')
    } catch (error) {
      console.error('Failed to create API keys:', error)
    } finally {
      setIsCreatingKeys(false)
    }
  }

  return (
    <AlertDialog open={createKeysDialogOpen} onOpenChange={setCreateKeysDialogOpen}>
      <Button onClick={() => setCreateKeysDialogOpen(true)}>Create new API keys</Button>
      <AlertDialogContent>
        <AlertDialogHeader>
          <AlertDialogTitle>Create new API keys</AlertDialogTitle>
          <AlertDialogDescription>
            This will create a default publishable key and a default secret key both named{' '}
            <code className="!break-keep text-code-inline">default</code>. These keys are required
            to connect your application to your Supabase project.
          </AlertDialogDescription>
        </AlertDialogHeader>
        <AlertDialogFooter>
          <AlertDialogCancel>Cancel</AlertDialogCancel>
          <AlertDialogAction onClick={handleCreateNewApiKeys} disabled={isCreatingKeys}>
            {isCreatingKeys ? 'Creating...' : 'Create keys'}
          </AlertDialogAction>
        </AlertDialogFooter>
      </AlertDialogContent>
    </AlertDialog>
  )
}

Subdomains

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free