64 lines
1.8 KiB
TypeScript
64 lines
1.8 KiB
TypeScript
import { supabase } from "../_supabase.js";
|
|
|
|
export default async (req: Request) => {
|
|
if (req.method !== "GET") {
|
|
return new Response("Method not allowed", { status: 405 });
|
|
}
|
|
|
|
try {
|
|
const token = req.headers.get("Authorization")?.replace("Bearer ", "");
|
|
if (!token) {
|
|
return new Response("Unauthorized", { status: 401 });
|
|
}
|
|
|
|
const { data: userData } = await supabase.auth.getUser(token);
|
|
if (!userData.user) {
|
|
return new Response("Unauthorized", { status: 401 });
|
|
}
|
|
|
|
// Add a limit to prevent timeouts
|
|
const url = new URL(req.url);
|
|
const limit = Math.max(1, Math.min(100, parseInt(url.searchParams.get("limit") || "50")));
|
|
const offset = Math.max(0, parseInt(url.searchParams.get("offset") || "0"));
|
|
|
|
const start = Date.now();
|
|
const { data: okrs, error } = await supabase
|
|
.from("staff_okrs")
|
|
.select(`
|
|
id,
|
|
user_id,
|
|
objective,
|
|
description,
|
|
status,
|
|
quarter,
|
|
year,
|
|
key_results(
|
|
id,
|
|
title,
|
|
progress,
|
|
target_value
|
|
),
|
|
created_at
|
|
`)
|
|
.eq("user_id", userData.user.id)
|
|
.order("created_at", { ascending: false })
|
|
.range(offset, offset + limit - 1);
|
|
const elapsed = Date.now() - start;
|
|
console.log(`[staff/okrs] Query took ${elapsed}ms (limit=${limit}, offset=${offset})`);
|
|
|
|
if (error) {
|
|
console.error("OKRs fetch error:", error);
|
|
return new Response(JSON.stringify({ error: error.message }), {
|
|
status: 500,
|
|
});
|
|
}
|
|
|
|
return new Response(JSON.stringify(okrs || []), {
|
|
headers: { "Content-Type": "application/json" },
|
|
});
|
|
} catch (err: any) {
|
|
return new Response(JSON.stringify({ error: err.message }), {
|
|
status: 500,
|
|
});
|
|
}
|
|
};
|