betterauth-tanstack-convex

Step-by-step guide for setting up Better Auth authentication with Convex and TanStack Start. This skill should be used when configuring authentication in a Convex + TanStack Start project, troubleshooting auth issues, or implementing sign up/sign in/sign out flows. Covers installation, environment variables, SSR authentication, route handlers, and the expectAuth pattern.

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "betterauth-tanstack-convex" with this command: npx skills add sstobo/convex-skills/sstobo-convex-skills-betterauth-tanstack-convex

Better Auth + Convex + TanStack Start

Overview

This skill provides guidance for integrating Better Auth authentication with Convex backend and TanStack Start framework. It covers the complete setup process from installation to SSR-compatible authentication flows.

When to Use This Skill

  • Setting up authentication in a new Convex + TanStack Start project
  • Troubleshooting Better Auth configuration issues
  • Implementing sign up, sign in, or sign out flows
  • Configuring SSR authentication with expectAuth: true
  • Adding authenticated server functions
  • Understanding the auth provider hierarchy

Quick Reference

Required Packages

npm install convex@latest @convex-dev/better-auth
npm install better-auth@1.4.9 --save-exact
npm install @types/node --save-dev

Environment Variables

Convex deployment (via CLI):

npx convex env set BETTER_AUTH_SECRET=$(openssl rand -base64 32)
npx convex env set SITE_URL http://localhost:3000

.env.local:

CONVEX_DEPLOYMENT=dev:adjective-animal-123
VITE_CONVEX_URL=https://adjective-animal-123.convex.cloud
VITE_CONVEX_SITE_URL=https://adjective-animal-123.convex.site
VITE_SITE_URL=http://localhost:3000

File Structure

FilePurpose
convex/convex.config.tsRegister Better Auth component
convex/auth.config.tsConfigure auth provider
convex/auth.tsCreate Better Auth instance + authComponent
convex/http.tsRegister auth HTTP routes
src/lib/auth-client.tsClient-side auth utilities
src/lib/auth-server.tsServer-side auth utilities
src/routes/api/auth/$.tsProxy auth requests to Convex
src/routes/__root.tsxAuth provider wrapper + SSR token

Essential Imports

// Client-side
import { authClient } from '~/lib/auth-client'

// Server-side
import { getToken, fetchAuthQuery, fetchAuthMutation } from '~/lib/auth-server'

// Backend
import { authComponent, createAuth } from './auth'

Auth Check (Backend)

const user = await authComponent.getAuthUser(ctx)
if (!user) throw new Error("Not authenticated")

Sign Out with expectAuth

When using expectAuth: true, reload the page after sign out:

await authClient.signOut({
  fetchOptions: {
    onSuccess: () => location.reload(),
  },
})

Critical Configuration

Vite SSR Bundle

Required in vite.config.ts to avoid module resolution issues:

ssr: {
  noExternal: ['@convex-dev/better-auth'],
}

ConvexQueryClient with expectAuth

Required for seamless SSR authentication:

const convexQueryClient = new ConvexQueryClient(convexUrl, {
  expectAuth: true,
})

Provider Hierarchy

The root component must wrap children in this order:

  1. ConvexBetterAuthProvider (outermost)
  2. QueryClientProvider
  3. RootDocument with <Outlet />

Reference Files

Load the detailed setup guide when implementing authentication:

FileUse When
references/setup-guide.mdFull step-by-step installation and configuration

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

convex-tanstack

No summary provided by upstream source.

Repository SourceNeeds Review
General

convex-queries

No summary provided by upstream source.

Repository SourceNeeds Review
General

convex-actions-general

No summary provided by upstream source.

Repository SourceNeeds Review
General

convex-mutations

No summary provided by upstream source.

Repository SourceNeeds Review