Latest Threat Research:SANDWORM_MODE: Shai-Hulud-Style npm Worm Hijacks CI Workflows and Poisons AI Toolchains.Details
Socket
Book a DemoInstallSign in
Socket

@neondatabase/auth

Package Overview
Dependencies
Maintainers
6
Versions
22
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@neondatabase/auth

TypeScript SDK for Neon Auth - authentication for PostgreSQL with multiple adapter support

latest
Source
npmnpm
Version
0.2.0-beta.1
Version published
Maintainers
6
Created
Source

@neondatabase/auth

npm version npm downloads TypeScript License

Authentication adapters for Neon Auth, supporting multiple auth providers.

Overview

@neondatabase/auth provides authentication for applications using Neon Auth. By default, it uses the Better Auth API, with optional adapters for different API styles:

  • Default - Better Auth API (signIn.email, signUp.email, etc.)
  • SupabaseAuthAdapter - Supabase-compatible API for migrations (signInWithPassword, signUp, etc.)
  • BetterAuthReactAdapter - Better Auth with React hooks (useSession)

This package is designed to work seamlessly with Neon's authentication infrastructure while providing:

  • Simple default API - Works out of the box with Better Auth patterns
  • Optional adapters - Switch API styles for migrations or preferences
  • Anonymous access - Optional RLS-based data access for unauthenticated users
  • Performance optimizations - Session caching and request deduplication
  • TypeScript support - Fully typed with strict type checking

Why @neondatabase/auth?

vs. better-auth/client

@neondatabase/auth is a wrapper around Better Auth that provides:

API Flexibility:

  • Multiple adapters (Supabase-compatible, React hooks, vanilla)
  • Restricted options to match Neon Auth capabilities

Neon Auth Integration:

  • Automatic token_verifier on OAuth callback
  • Pre-configured plugins for Neon Auth
  • Automatic JWT extraction from sessions
  • Popup-based OAuth flow for iframes

Built-in Enhancements:

  • Session caching (60s TTL)
  • Request deduplication
  • Event system
  • Cross-tab sync
  • Token refresh detection

If you're not using Neon Auth, you should probably use better-auth/client directly for more flexibility.

Installation

npm install @neondatabase/auth
# or
bun add @neondatabase/auth

Usage

Basic Usage (Default)

The createAuthClient factory function creates an auth client. By default, it uses the Better Auth API:

import { createAuthClient } from '@neondatabase/auth';

const auth = createAuthClient('https://your-auth-server.com');

// Sign up
await auth.signUp.email({
  email: 'user@example.com',
  password: 'secure-password',
  name: 'John Doe',
});

// Sign in
await auth.signIn.email({
  email: 'user@example.com',
  password: 'secure-password',
});

// Get session
const session = await auth.getSession();

// Sign out
await auth.signOut();

OAuth Authentication

import { createAuthClient } from '@neondatabase/auth';

const auth = createAuthClient('https://your-auth-server.com');

await auth.signIn.social({
  provider: 'google',
  callbackURL: '/dashboard',
});

Using Adapters

You can optionally specify an adapter to change the API style. This is useful for migrations or if you prefer a different API.

SupabaseAuthAdapter - Supabase-compatible API

Use this adapter if you're migrating from Supabase or prefer the Supabase API style:

import { createAuthClient, SupabaseAuthAdapter } from '@neondatabase/auth';

const auth = createAuthClient('https://your-auth-server.com', {
  adapter: SupabaseAuthAdapter(),
});

// Supabase-compatible methods
await auth.signUp({
  email: 'user@example.com',
  password: 'secure-password',
  options: {
    data: { name: 'John Doe' },
  },
});

await auth.signInWithPassword({
  email: 'user@example.com',
  password: 'secure-password',
});

const { data: session } = await auth.getSession();
await auth.signOut();

// OAuth with Supabase-style API
await auth.signInWithOAuth({
  provider: 'google',
  options: {
    redirectTo: '/dashboard',
  },
});

BetterAuthReactAdapter - React Hooks Support

Use this adapter in React applications to get access to hooks like useSession:

import { createAuthClient } from '@neondatabase/auth';
import { BetterAuthReactAdapter } from '@neondatabase/auth/react/adapters';

const auth = createAuthClient('https://your-auth-server.com', {
  adapter: BetterAuthReactAdapter(),
});

// Same API as default
await auth.signIn.email({
  email: 'user@example.com',
  password: 'secure-password',
});

// Plus React hooks
function MyComponent() {
  const session = auth.useSession();

  if (session.isPending) return <div>Loading...</div>;
  if (!session.data) return <div>Not logged in</div>;

  return <div>Hello, {session.data.user.name}</div>;
}

Anonymous Access

Enable allowAnonymous to let unauthenticated users access data via RLS policies:

import { createAuthClient } from '@neondatabase/auth';

const auth = createAuthClient('https://your-auth-server.com', {
  allowAnonymous: true, // Enable anonymous data access
});

// Get token - returns anonymous token if no user session exists
const token = await auth.getJWTToken?.();

This is useful when you want to allow read-only public access to certain data while still enforcing RLS policies.

API Reference

createAuthClient(url, config?)

Factory function to create an auth client.

Parameters:

  • url - The auth service URL (required)
  • config.adapter - Optional adapter factory function (e.g., SupabaseAuthAdapter())
  • config.allowAnonymous - When true, returns an anonymous token if no user session exists (default: false)

Returns: The adapter's public API (varies by adapter type)

Default API (Better Auth)

  • signIn.email(credentials) - Sign in with email
  • signIn.social(options) - Sign in with OAuth
  • signUp.email(credentials) - Create new user
  • signOut() - Sign out current user
  • getSession() - Get current session

SupabaseAuthAdapter API

Provides a Supabase-compatible API:

  • signUp(credentials) - Create a new user
  • signInWithPassword(credentials) - Sign in with email/password
  • signInWithOAuth(options) - Sign in with OAuth provider
  • signOut() - Sign out current user
  • getSession() - Get current session
  • getUser() - Get current user
  • updateUser(attributes) - Update user metadata
  • getUserIdentities() - Get linked OAuth identities
  • linkIdentity(credentials) - Link OAuth provider
  • unlinkIdentity(identity) - Unlink OAuth provider
  • resetPasswordForEmail(email, options) - Send password reset
  • onAuthStateChange(callback) - Listen to auth state changes

BetterAuthReactAdapter API

Same as default API, plus:

  • useSession() - React hook for session state

Performance Features

Session Caching

Sessions are cached in memory with intelligent TTL management:

  • 60-second default cache TTL
  • Automatic expiration based on JWT exp claim
  • Lazy expiration checking on reads
  • Synchronous cache clearing on sign-out

Request Deduplication

Multiple concurrent getSession() calls are automatically deduplicated:

  • Single network request for concurrent calls
  • 10x faster cold starts (10 concurrent calls: ~2000ms → ~200ms)
  • Reduces server load by N-1 for N concurrent calls

Environment Compatibility

  • Node.js 14+
  • Browser (all modern browsers)
  • Edge Runtime (Vercel, Cloudflare Workers, etc.)
  • Bun

Next.js Integration

For Next.js projects, this package provides built-in integration via @neondatabase/auth/next. See the Next.js Setup Guide for comprehensive documentation including:

  • Setting up auth server instance with createNeonAuth() for handler, middleware and api methods
  • Client-side auth with createAuthClient() for client components
  • Configuring the NeonAuthUIProvider with Email OTP, Social Login, and Organizations
  • Creating auth pages (AuthView, AccountView, OrganizationView)
  • Importing styles (with or without Tailwind CSS)
  • Using authClient.useSession() hook in client components

UI Components

Pre-built login forms and auth pages are included. No extra installation needed.

1. Import CSS

Without Tailwind CSS:

import '@neondatabase/auth/ui/css';

With Tailwind CSS v4:

@import 'tailwindcss';
@import '@neondatabase/auth/ui/tailwind';

2. Setup Provider

"use client"

import { NeonAuthUIProvider } from "@neondatabase/auth/react/ui"
import { createAuthClient } from "@neondatabase/auth"
import "@neondatabase/auth/ui/css"

const authClient = createAuthClient('https://your-auth-url.com')

export function AuthProvider({ children }) {
  return (
    <NeonAuthUIProvider authClient={authClient} redirectTo="/dashboard">
      {children}
    </NeonAuthUIProvider>
  )
}

3. Use Components

Option A: Full Auth Pages (Recommended)

Use AuthView to render complete auth flows based on the URL path:

import { AuthView } from "@neondatabase/auth/react/ui"

// Renders sign-in, sign-up, forgot-password, etc. based on path
<AuthView path="sign-in" />

Option B: Individual Components

import { SignInForm, UserButton } from "@neondatabase/auth/react/ui"

<SignInForm />
<UserButton />

Available components: SignInForm, SignUpForm, UserButton, AuthView, AccountView, OrganizationView

For Next.js with dynamic routes, see the Next.js Setup Guide.

For full documentation and theming, see @neondatabase/auth-ui.

Resources

Support

License

Apache-2.0

Keywords

neon

FAQs

Package last updated on 29 Jan 2026

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts