jeremylongshore/claude-code-plugins-plus-skills
clerk-pack
plugins/saas-packs/clerk-pack/skills/clerk-sdk-patterns/SKILL.md
January 22, 2026
Select agents to install to:
npx add-skill https://github.com/jeremylongshore/claude-code-plugins-plus-skills/blob/main/plugins/saas-packs/clerk-pack/skills/clerk-sdk-patterns/SKILL.md -a claude-code --skill clerk-sdk-patternsInstallation paths:
.claude/skills/clerk-sdk-patterns/# Clerk SDK Patterns
## Overview
Learn common patterns and best practices for using the Clerk SDK effectively.
## Prerequisites
- Clerk SDK installed and configured
- Basic understanding of React/Next.js
- ClerkProvider wrapping application
## Instructions
### Pattern 1: Server-Side Authentication
```typescript
// app/api/protected/route.ts
import { auth, currentUser } from '@clerk/nextjs/server'
export async function GET() {
// Quick auth check
const { userId, sessionId, orgId } = await auth()
if (!userId) {
return Response.json({ error: 'Unauthorized' }, { status: 401 })
}
// Full user data when needed
const user = await currentUser()
return Response.json({
userId,
sessionId,
orgId,
email: user?.primaryEmailAddress?.emailAddress
})
}
```
### Pattern 2: Client-Side Hooks
```typescript
'use client'
import { useUser, useAuth, useClerk, useSession } from '@clerk/nextjs'
export function AuthenticatedComponent() {
// User data and loading state
const { user, isLoaded, isSignedIn } = useUser()
// Auth utilities
const { userId, getToken, signOut } = useAuth()
// Full Clerk instance
const clerk = useClerk()
// Session info
const { session } = useSession()
// Get JWT token for API calls
const callExternalAPI = async () => {
const token = await getToken({ template: 'supabase' }) // or custom template
const res = await fetch('https://api.example.com', {
headers: { Authorization: `Bearer ${token}` }
})
}
if (!isLoaded) return <div>Loading...</div>
if (!isSignedIn) return <div>Please sign in</div>
return <div>Welcome, {user.firstName}</div>
}
```
### Pattern 3: Protected Routes with Middleware
```typescript
// middleware.ts
import { clerkMiddleware, createRouteMatcher } from '@clerk/nextjs/server'
const isPublicRoute = createRouteMatcher([
'/',
'/sign-in(.*)',
'/sign-up(.*)',
'/api/webhooks(.*)'
])
const isProtectedRoute = createRouteMatcher([
'/dashboard(.*)',
'/api