supabase-install-authClaude Skill

Install and configure Supabase SDK/CLI authentication.

1.9k Stars
259 Forks
2025/10/10

Install & Download

Linux / macOS:

请登录后查看安装命令

Windows (PowerShell):

请登录后查看安装命令

Download and extract to ~/.claude/skills/

namesupabase-install-auth
descriptionInstall and configure Supabase SDK, CLI, and project authentication. Use when setting up a new Supabase project, installing @supabase/supabase-js, configuring environment variables, or initializing the Supabase client. Trigger with "install supabase", "setup supabase", "supabase auth config", "configure supabase", "supabase init", "add supabase to project".
allowed-toolsRead, Write, Edit, Bash(npm:*), Bash(npx:*), Bash(pnpm:*), Bash(pip:*), Bash(supabase:*), Grep, Glob
version1.0.0
licenseMIT
authorJeremy Longshore <jeremy@intentsolutions.io>
compatible-withclaude-code, codex, openclaw
tags["saas","supabase","setup","authentication","sdk"]

Supabase Install & Auth

Overview

Install the Supabase SDK, CLI, and project credentials from scratch — covering package install, environment configuration, client initialization, and connection verification for both TypeScript (@supabase/supabase-js) and Python (supabase).

Key facts:

Prerequisites

  • Node.js 18+ (for JS/TS) or Python 3.8+ (for Python)
  • Package manager: npm, pnpm, or yarn (JS) / pip (Python)
  • A Supabase project created at https://supabase.com/dashboard
  • Docker Desktop (only if using local development via supabase start)

Instructions

Step 1 — Install the SDK and CLI

Install the SDK and the Supabase CLI:

JavaScript / TypeScript:

# Install the SDK
npm install @supabase/supabase-js

# For SSR frameworks (Next.js, SvelteKit, Nuxt), also install:
npm install @supabase/ssr

# Install the Supabase CLI (for types, migrations, local dev)
npm install -D supabase

Python:

# Install the SDK
pip install supabase

# Install the CLI (alternative: brew install supabase/tap/supabase)
npm install -g supabase

Verify the CLI is available:

npx supabase --version

Step 2 — Configure Environment Variables

Retrieve project credentials from the Supabase Dashboard (Settings > API) and create the env file:

# .env.local (or .env)
SUPABASE_URL=https://<project-ref>.supabase.co
SUPABASE_KEY=eyJhbGciOiJIUzI1NiIs...          # anon key — safe for client-side
SUPABASE_SERVICE_ROLE_KEY=eyJhbGciOiJIUzI1...  # admin key — server-side ONLY

Add env files to .gitignore immediately:

.env
.env.local
.env.*.local

Security rules:

  • The anon key (SUPABASE_KEY) is safe for client-side code. It respects Row Level Security (RLS) policies.
  • The service role key (SUPABASE_SERVICE_ROLE_KEY) bypasses RLS entirely. Use only on the server. Never bundle into client code or expose in browser.

Step 3 — Initialize the Client and Verify

Create a client singleton and verify connectivity:

TypeScript — client-side (anon key):

// lib/supabase.ts
import { createClient } from '@supabase/supabase-js'

const supabase = createClient(
  process.env.SUPABASE_URL!,
  process.env.SUPABASE_KEY!
)

export default supabase

TypeScript — server-side (service role key):

// lib/supabase-admin.ts
import { createClient } from '@supabase/supabase-js'

export const supabaseAdmin = createClient(
  process.env.SUPABASE_URL!,
  process.env.SUPABASE_SERVICE_ROLE_KEY!,
  {
    auth: {
      autoRefreshToken: false,
      persistSession: false,
    },
  }
)

Python — client initialization:

# lib/supabase_client.py
import os
from supabase import create_client

url = os.environ["SUPABASE_URL"]
key = os.environ["SUPABASE_KEY"]

supabase = create_client(url, key)

Verify the connection:

// Quick connectivity check
const { data, error } = await supabase.from('_health_check').select('*').limit(1)
if (error && error.code !== 'PGRST116') {
  // PGRST116 = relation does not exist (expected if table doesn't exist yet)
  throw new Error(`Supabase connection failed: ${error.message}`)
}
console.log('Supabase connected successfully')

Optional — generate TypeScript types from the database schema:

npx supabase login
npx supabase link --project-ref <your-project-ref>
npx supabase gen types typescript --linked > lib/database.types.ts

Then add the type parameter to the client:

import type { Database } from './database.types'
const supabase = createClient<Database>(url, key)

Output

Completing all three steps produces:

  • @supabase/supabase-js or supabase Python package installed
  • Supabase CLI available via npx supabase
  • .env.local containing SUPABASE_URL, SUPABASE_KEY, and SUPABASE_SERVICE_ROLE_KEY
  • Client singleton module (lib/supabase.ts or lib/supabase_client.py)
  • Server-side admin client (lib/supabase-admin.ts, TypeScript only)
  • Verified connectivity to the Supabase project

Error Handling

ErrorCauseFix
FetchError: request failedWrong SUPABASE_URLVerify URL at Dashboard > Settings > API
Invalid API keyWrong or expired keyCopy fresh anon key from Dashboard > Settings > API
PGRST301: JWSErrorMalformed JWT in keyRemove trailing whitespace/newlines from env var
Cannot find module '@supabase/supabase-js'SDK not installedRun npm install @supabase/supabase-js
ModuleNotFoundError: No module named 'supabase'Python SDK not installedRun pip install supabase
supabase: command not foundCLI not installedRun npm install -D supabase, then use npx supabase
Error: supabase start failsDocker not runningStart Docker Desktop, then retry npx supabase start
TypeError: SupabaseClient is not a constructorWrong import patternUse createClient() — not new SupabaseClient()

Examples

Full TypeScript and Python examples with auth sign-up, sign-in, session management, SSR patterns, and type-safe queries: examples

Resources

Next Steps

After successful setup, continue with:

  • supabase-hello-world — run your first database query
  • supabase-rls-policies — secure your tables with Row Level Security
  • supabase-email-auth — set up email/password authentication flows

Similar Claude Skills & Agent Workflows