4096b3d87b
Sorun:
- node-appwrite paketi 'node-fetch-native-with-agent' polyfill'i kullanıyor
- Node.js 26'nın undici implementation'ı ile uyumsuz
- 'fetch failed / InvalidArgumentError: invalid onError method' hatası
- Login dahil tüm Appwrite çağrıları başarısız
Çözüm:
- Tüm node-appwrite kullanımını browser SDK 'appwrite'a geçir
- Browser SDK native fetch kullanıyor, Node 26 uyumlu
- API key tabanlı admin client yerine session cookie tabanlı user client
- Public reads (read('any')): publicDB (auth'suz client)
- Admin CRUD: userDB(sessionSecret) (cookie'deki session)
- Storage upload doğrudan File objesi alıyor (InputFile.fromBuffer gerekmez)
Etkilenen dosyalar:
- lib/appwrite-server.ts: publicClient + sessionClient
- lib/auth.ts: requireSessionSecret eklendi
- lib/admin-actions.ts: tüm action'lar sessionClient kullanıyor
- app/actions.ts: publicDB
- lib/data.ts: publicDB
- app/admin/login/actions.ts: appwrite SDK
- app/admin/(protected)/page.tsx, medya/page.tsx: userDB/userStorage
End-to-end test edildi:
✓ Login (401 doğru hata)
✓ Public read (services)
✓ Anonim create (contact form)
✓ npm run build 23 route
47 lines
1.4 KiB
TypeScript
47 lines
1.4 KiB
TypeScript
"use server";
|
||
|
||
import { cookies } from "next/headers";
|
||
import { redirect } from "next/navigation";
|
||
import { Account, Client } from "appwrite";
|
||
import { SESSION_COOKIE } from "@/lib/auth";
|
||
|
||
const endpoint = process.env.NEXT_PUBLIC_APPWRITE_ENDPOINT!;
|
||
const projectId = process.env.NEXT_PUBLIC_APPWRITE_PROJECT_ID!;
|
||
|
||
export type LoginState = { error?: string };
|
||
|
||
export async function loginAction(
|
||
_prev: LoginState | undefined,
|
||
formData: FormData,
|
||
): Promise<LoginState> {
|
||
const email = String(formData.get("email") ?? "").trim();
|
||
const password = String(formData.get("password") ?? "");
|
||
|
||
if (!email || !password) return { error: "E-posta ve şifre zorunlu" };
|
||
|
||
try {
|
||
const client = new Client().setEndpoint(endpoint).setProject(projectId);
|
||
const account = new Account(client);
|
||
const session = await account.createEmailPasswordSession({ email, password });
|
||
const store = await cookies();
|
||
store.set(SESSION_COOKIE, session.secret, {
|
||
httpOnly: true,
|
||
sameSite: "lax",
|
||
secure: process.env.NODE_ENV === "production",
|
||
path: "/",
|
||
expires: new Date(session.expire),
|
||
});
|
||
} catch (err) {
|
||
const msg = err instanceof Error ? err.message : "Giriş başarısız";
|
||
return { error: msg };
|
||
}
|
||
|
||
redirect("/admin");
|
||
}
|
||
|
||
export async function logoutAction() {
|
||
const store = await cookies();
|
||
store.delete(SESSION_COOKIE);
|
||
redirect("/admin/login");
|
||
}
|