All checks were successful
Deploy to Production / Build and Deploy (push) Successful in 5s
- Fix useBrainstormSocket: stable guestId via useRef, remove setState in cleanup - Fix GhostCursor: direct DOM manipulation via refs, no useState re-renders - Fix all SQL embedding queries: add ::vector cast on text columns - Fix embedding truncation to 15000 chars (under 8192 token limit) - Fix NoteEmbedding INSERT: remove non-existent updatedAt column - Fix billing page: show all quota stats in grid instead of single metric - Fix usage meter: accordion expand/collapse, per-feature detail - Fix semantic search: rebuild 103 note embeddings, ::vector cast on vectorSearch - Fix brainstorm expand/manual-idea/create: ::vector cast on embedding SQL
26 lines
708 B
TypeScript
26 lines
708 B
TypeScript
import { NextResponse } from 'next/server';
|
|
import { auth } from '@/auth';
|
|
import { getUserQuotas, getEffectiveTier } from '@/lib/entitlements';
|
|
|
|
export async function GET() {
|
|
const session = await auth();
|
|
|
|
if (!session?.user?.id) {
|
|
return NextResponse.json({ error: 'Unauthorized' }, { status: 401 });
|
|
}
|
|
|
|
try {
|
|
const [quotas, tier] = await Promise.all([
|
|
getUserQuotas(session.user.id),
|
|
getEffectiveTier(session.user.id),
|
|
]);
|
|
return NextResponse.json({ quotas, tier });
|
|
} catch (error) {
|
|
console.error('[usage/current] Failed to fetch quotas:', error);
|
|
return NextResponse.json(
|
|
{ error: 'Failed to fetch usage data' },
|
|
{ status: 503 },
|
|
);
|
|
}
|
|
}
|