import { createRouteHandlerClient } from "@supabase/auth-helpers-nextjs"; import { cookies } from "next/headers"; import { NextResponse, NextRequest } from "next/server"; import { Database } from "@/types/supabase"; import { prisma } from "@/lib/prisma"; async function getSession(supabase: any) { const { data: { session }, } = await supabase.auth.getSession(); return session; } export async function POST( req: NextRequest, { params: { workspaceID, projectID }, }: { params: { workspaceID: string; projectID: string } } ) { const supabase = createRouteHandlerClient({ cookies }); const session = await getSession(supabase); if (!session) return NextResponse.redirect("/auth"); try { const formData = await req.json(); const features = Array(formData)[0]; console.log("FORM DATA ===>", formData); let res_data: any[] = []; for (const feature of features) { const name = String(feature.name); const description = String(feature.description); const feature_data = await prisma.feature.create({ data: { name, description, project_id: BigInt(projectID), }, }); const feature_data_res = { ...feature_data, id: String(feature_data.id), project_id: String(feature_data.project_id), }; console.log("feature_data ===>", feature_data); console.log("created feature:", feature_data_res); res_data.push(feature_data_res); } console.log(`GET DATA TO PASSBACK ${res_data}`); return NextResponse.json({ features: res_data }, { status: 200 }); } catch (err) { console.log(err); return NextResponse.json({ error: err }, { status: 500 }); } }