Files
kovakyazilim/lib/auth.ts
T
Ege Can Komur 7eb0c1acc2 fix(auth): SDK'yı kaldırıp ince REST katmanına geç (lib/appwrite-rest.ts)
Sorun:
- node-appwrite v20-25 hepsi Node 26'da bozuk (node-fetch-native-with-agent polyfill)
- appwrite browser SDK Server Action context'inde 'unexpected response' veriyor
  (büyük olasılıkla browser-only global'ları kontrol ederken)

Çözüm:
- Tüm Appwrite SDK'larını sil (appwrite + node-appwrite)
- lib/appwrite-rest.ts: native fetch üzerinde ~250 satırlık ince REST wrapper
  - account: createEmailPasswordSession, get, deleteSession
  - tablesDB: listRows, getRow, createRow, updateRow, deleteRow
  - storage: listFiles, createFile, deleteFile, fileViewUrl
  - Q helpers: equal, orderAsc/Desc, limit, offset
  - AppwriteError class
- Session secret cookie tabanlı auth korundu (isletmem-kovakcrm'deki desen)
- Tüm CRUD action ve query'ler REST katmanına bağlandı

End-to-end test edildi:
✓ Login (proper 401 hata mesajları, başarılı durumda redirect)
✓ Public read (services, blog, testimonials)
✓ Anonim create (contact form)
✓ Build (24 route)
✓ Sıfır SDK bağımlılığı — Node 26 sorunu yok
2026-05-20 02:29:19 +03:00

34 lines
810 B
TypeScript

import "server-only";
import { cookies } from "next/headers";
import { redirect } from "next/navigation";
import { account } from "@/lib/appwrite-rest";
export const SESSION_COOKIE = "kovak_session";
export async function getSessionSecret() {
const store = await cookies();
return store.get(SESSION_COOKIE)?.value ?? null;
}
export async function getCurrentUser() {
const secret = await getSessionSecret();
if (!secret) return null;
try {
return await account.get(secret);
} catch {
return null;
}
}
export async function requireUser() {
const user = await getCurrentUser();
if (!user) redirect("/admin/login");
return user;
}
export async function requireSessionSecret() {
const secret = await getSessionSecret();
if (!secret) redirect("/admin/login");
return secret;
}