vuralserhat86

clerk_auth

27
10
# Install this skill:
npx skills add vuralserhat86/antigravity-agentic-skills --skill "clerk_auth"

Install specific skill from multi-skill repository

# Description

Clerk modern authentication, WebAuthn, passkeys ve social auth entegrasyonu rehberi.

# SKILL.md


name: clerk_auth
router_kit: SecurityKit
description: Clerk modern authentication, WebAuthn, passkeys ve social auth entegrasyonu rehberi.
metadata:
skillport:
category: authentication
tags: [accessibility, api integration, backend, browser apis, clerk auth, client-side, components, css3, debugging, deployment, frameworks, frontend, fullstack, html5, javascript, libraries, node.js, npm, performance optimization, responsive design, seo, state management, testing, typescript, ui/ux, web development] - webauthn


🔐 Clerk Auth

Clerk modern authentication rehberi.


📋 Kurulum

npm install @clerk/nextjs

middleware.ts

import { clerkMiddleware } from '@clerk/nextjs/server';

export default clerkMiddleware();

export const config = {
  matcher: ['/((?!.*\\..*|_next).*)', '/', '/(api|trpc)(.*)'],
};

🔧 Provider Setup

// app/layout.tsx
import { ClerkProvider } from '@clerk/nextjs';

export default function Layout({ children }) {
  return (
    <ClerkProvider>
      <html>
        <body>{children}</body>
      </html>
    </ClerkProvider>
  );
}

👤 Components

import { 
  SignInButton, 
  SignUpButton, 
  UserButton,
  SignedIn,
  SignedOut 
} from '@clerk/nextjs';

function Header() {
  return (
    <header>
      <SignedOut>
        <SignInButton />
        <SignUpButton />
      </SignedOut>
      <SignedIn>
        <UserButton />
      </SignedIn>
    </header>
  );
}

🔒 Server-side Auth

import { auth, currentUser } from '@clerk/nextjs/server';

export async function GET() {
  const { userId } = await auth();

  if (!userId) {
    return new Response('Unauthorized', { status: 401 });
  }

  const user = await currentUser();
  return Response.json({ user });
}

Clerk Auth v1.1 - Enhanced

🔄 Workflow

Kaynak: Clerk Documentation

Aşama 1: Integration

  • [ ] Install: @clerk/nextjs paketi ve API Key'ler.
  • [ ] Middleware: Public/Private rotaları clerkMiddleware ile ayır.
  • [ ] Provider: Root layout'u ClerkProvider ile sarmala.

Aşama 2: UX & Components

  • [ ] Header: SignedIn / SignedOut şartlı render yapısı kur.
  • [ ] Profile: UserButton veya UserProfile bileşenini ekle.
  • [ ] Custom Flow: Gerekirse Custom Sign-in sayfası yap.

Aşama 3: Server Logic

  • [ ] Protect: API rotalarında auth().userId kontrolü yap.
  • [ ] Data: currentUser() ile kullanıcı verisine eriş.
  • [ ] Sync: Webhook kullanarak kullanıcıyı kendi veritabanınla eşle (Opsiyonel).

Kontrol Noktaları

Aşama Doğrulama
1 Middleware statik dosyaları (image, css) engellemiyor
2 Sign-out sonrası login sayfasına yönlendiriyor
3 API request'leri tokensiz atılınca 401 dönüyor

# Supported AI Coding Agents

This skill is compatible with the SKILL.md standard and works with all major AI coding agents:

Learn more about the SKILL.md standard and how to use these skills with your preferred AI coding agent.