7eb0c1acc2
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
34 lines
810 B
TypeScript
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;
|
|
}
|