nuxt-better-auth

$npx skills add onmax/nuxt-skills --skill nuxt-better-auth
SKILL.md

Nuxt Better Auth

Authentication module for Nuxt 4+ built on [Better Auth](https://www.better-auth.com/). Provides composables, server utilities, and route protection. > **Alpha Status**: This module is currently in alpha (v0.0.2-alpha.19) and not recommended for production use. APIs may change. - Installing/configuring `@onmax/nuxt-better-auth`

Nuxt Better Auth

Authentication module for Nuxt 4+ built on Better Auth. Provides composables, server utilities, and route protection.
Alpha Status: This module is currently in alpha (v0.0.2-alpha.19) and not recommended for production use. APIs may change.

When to Use

  • Installing/configuring @onmax/nuxt-better-auth
  • Implementing login/signup/signout flows
  • Protecting routes (client and server)
  • Accessing user session in API routes
  • Integrating Better Auth plugins (admin, passkey, 2FA)
  • Setting up database with NuxtHub
  • Using clientOnly mode for external auth backends
  • Adding i18n support with @nuxtjs/i18n
For Nuxt patterns: use nuxt skill For NuxtHub database: use nuxthub skill

Available Guidance

File
Topics
Module setup, env vars, config files
useUserSession, signIn/signUp/signOut, BetterAuthState, safe redirects
serverAuth, getUserSession, requireUserSession
routeRules, definePageMeta, middleware
Better Auth plugins (admin, passkey, 2FA)
NuxtHub integration, Drizzle schema, custom tables with FKs
External auth backend, clientOnly mode, CORS
AuthUser, AuthSession, type augmentation

Loading Files

Consider loading these reference files based on your task:
DO NOT load all files at once. Load only what's relevant to your current task.

Key Concepts

Concept
Description
useUserSession()
Client composable - user, session, loggedIn, signIn/Out methods
requireUserSession()
Server helper - throws 401/403 if not authenticated
auth route mode
'user', 'guest', { user: {...} }, or false
serverAuth()
Get Better Auth instance in server routes

Quick Reference

// Client: useUserSession()
const { user, loggedIn, signIn, signOut } = useUserSession()
await signIn.email({ email, password }, { onSuccess: () => navigateTo('/') })
// Server: requireUserSession()
const { user } = await requireUserSession(event, { user: { role: 'admin' } })
// nuxt.config.ts: Route protection
routeRules: {
  '/admin/**': { auth: { user: { role: 'admin' } } },
  '/login': { auth: 'guest' },
  '/app/**': { auth: 'user' }
}

Resources


Token efficiency: Main skill ~300 tokens, each sub-file ~800-1200 tokens