beta/app/w/[workspaceID]/p/[projectID]/features/add/route.ts
Christopher Arraya bcf3f113ad i'm done
2023-11-05 07:34:37 -05:00

61 lines
1.7 KiB
TypeScript

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<Database>({ 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 });
}
}