- 원인: purchase/personal은 유저별 데이터인데 NAS로 프록시 → NAS가 userId 모름 - ConnectTimeoutError는 NAS에 미구현 엔드포인트로 연결 시도한 결과 purchase/route.ts: nasGet/nasPost → Supabase lotto_purchases CRUD purchase/stats/route.ts: nasGet → Supabase 집계 (총구매/당첨금/순손익 계산) purchase/[id]/route.ts: nasPut/nasDelete → Supabase UPDATE/DELETE (user_id RLS) analysis/personal/route.ts: nasGet → lotto_history 테이블 직접 분석 (번호 빈도, top/least picks, 홀짝패턴, 구간 분포, 당첨평균 대비) Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
59 lines
1.7 KiB
TypeScript
59 lines
1.7 KiB
TypeScript
import { NextResponse } from 'next/server';
|
|
import { createClient } from '@/lib/supabase/server';
|
|
import { requireSubscription } from '../_nas';
|
|
|
|
export async function GET(request: Request) {
|
|
try {
|
|
const auth = await requireSubscription();
|
|
if (auth instanceof NextResponse) return auth;
|
|
|
|
const supabase = await createClient();
|
|
const { searchParams } = new URL(request.url);
|
|
const drawNo = searchParams.get('draw_no');
|
|
|
|
let query = supabase
|
|
.from('lotto_purchases')
|
|
.select('id, draw_no, amount, sets, prize, note, created_at')
|
|
.eq('user_id', auth.userId)
|
|
.order('draw_no', { ascending: false });
|
|
|
|
if (drawNo) query = query.eq('draw_no', parseInt(drawNo));
|
|
|
|
const { data, error } = await query;
|
|
if (error) throw error;
|
|
return NextResponse.json({ records: data ?? [] });
|
|
} catch (err) {
|
|
console.error('[purchase GET]', err);
|
|
return NextResponse.json({ error: 'DB_ERROR' }, { status: 500 });
|
|
}
|
|
}
|
|
|
|
export async function POST(request: Request) {
|
|
try {
|
|
const auth = await requireSubscription();
|
|
if (auth instanceof NextResponse) return auth;
|
|
|
|
const supabase = await createClient();
|
|
const body = await request.json();
|
|
|
|
const { data, error } = await supabase
|
|
.from('lotto_purchases')
|
|
.insert({
|
|
user_id: auth.userId,
|
|
draw_no: body.draw_no,
|
|
amount: body.amount ?? 5000,
|
|
sets: body.sets ?? 5,
|
|
prize: body.prize ?? 0,
|
|
note: body.note ?? '',
|
|
})
|
|
.select()
|
|
.single();
|
|
|
|
if (error) throw error;
|
|
return NextResponse.json(data, { status: 201 });
|
|
} catch (err) {
|
|
console.error('[purchase POST]', err);
|
|
return NextResponse.json({ error: 'DB_ERROR' }, { status: 500 });
|
|
}
|
|
}
|