revert: purchase/analysis NAS 기반으로 원복 (maxDuration 추가)

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
2026-03-20 02:23:24 +09:00
parent f8bfc74d02
commit d29cdbcd82
4 changed files with 31 additions and 194 deletions

View File

@@ -1,50 +1,25 @@
import { NextResponse } from 'next/server';
import { createClient } from '@/lib/supabase/server';
import { requireSubscription } from '../../_nas';
import { nasPut, nasDelete, requireSubscription, handleNasError } from '../../_nas';
export const maxDuration = 60;
export async function PUT(request: Request, { params }: { params: Promise<{ id: string }> }) {
try {
const auth = await requireSubscription();
if (auth instanceof NextResponse) return auth;
const supabase = await createClient();
const { id } = await params;
const body = await request.json();
const { data, error } = await supabase
.from('lotto_purchases')
.update({ prize: body.prize, note: body.note })
.eq('id', parseInt(id))
.eq('user_id', auth.userId) // 본인 데이터만 수정
.select()
.single();
if (error) throw error;
const data = await nasPut(`/api/lotto/purchase/${id}`, body);
return NextResponse.json(data);
} catch (err) {
console.error('[purchase PUT]', err);
return NextResponse.json({ error: 'DB_ERROR' }, { status: 500 });
}
} catch (err) { return handleNasError(err); }
}
export async function DELETE(_req: Request, { params }: { params: Promise<{ id: string }> }) {
try {
const auth = await requireSubscription();
if (auth instanceof NextResponse) return auth;
const supabase = await createClient();
const { id } = await params;
const { error } = await supabase
.from('lotto_purchases')
.delete()
.eq('id', parseInt(id))
.eq('user_id', auth.userId); // 본인 데이터만 삭제
if (error) throw error;
return NextResponse.json({ ok: true });
} catch (err) {
console.error('[purchase DELETE]', err);
return NextResponse.json({ error: 'DB_ERROR' }, { status: 500 });
}
const data = await nasDelete(`/api/lotto/purchase/${id}`);
return NextResponse.json(data);
} catch (err) { return handleNasError(err); }
}

View File

@@ -1,58 +1,28 @@
import { NextResponse } from 'next/server';
import { createClient } from '@/lib/supabase/server';
import { requireSubscription } from '../_nas';
import { nasGet, nasPost, requireSubscription, handleNasError } from '../_nas';
export const maxDuration = 60;
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 });
}
const params = new URLSearchParams();
if (searchParams.get('draw_no')) params.set('draw_no', searchParams.get('draw_no')!);
if (searchParams.get('days')) params.set('days', searchParams.get('days')!);
const qs = params.toString() ? `?${params}` : '';
const data = await nasGet(`/api/lotto/purchase${qs}`);
return NextResponse.json(data);
} catch (err) { return handleNasError(err); }
}
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;
const data = await nasPost('/api/lotto/purchase', body);
return NextResponse.json(data, { status: 201 });
} catch (err) {
console.error('[purchase POST]', err);
return NextResponse.json({ error: 'DB_ERROR' }, { status: 500 });
}
} catch (err) { return handleNasError(err); }
}

View File

@@ -1,37 +1,13 @@
import { NextResponse } from 'next/server';
import { createClient } from '@/lib/supabase/server';
import { requireSubscription } from '../../_nas';
import { nasGet, requireSubscription, handleNasError } from '../../_nas';
export const maxDuration = 60;
export async function GET() {
try {
const auth = await requireSubscription();
if (auth instanceof NextResponse) return auth;
const supabase = await createClient();
const { data, error } = await supabase
.from('lotto_purchases')
.select('amount, prize')
.eq('user_id', auth.userId);
if (error) throw error;
const records = data ?? [];
const total_invested = records.reduce((s, r) => s + (r.amount ?? 0), 0);
const total_prize = records.reduce((s, r) => s + (r.prize ?? 0), 0);
const prize_count = records.filter(r => (r.prize ?? 0) > 0).length;
const max_prize = records.reduce((m, r) => Math.max(m, r.prize ?? 0), 0);
return NextResponse.json({
total_records: records.length,
total_invested,
total_prize,
net: total_prize - total_invested,
return_rate: total_invested > 0 ? Math.round((total_prize / total_invested) * 1000) / 10 : 0,
prize_count,
max_prize,
});
} catch (err) {
console.error('[purchase/stats]', err);
return NextResponse.json({ error: 'DB_ERROR' }, { status: 500 });
}
const data = await nasGet('/api/lotto/purchase/stats');
return NextResponse.json(data);
} catch (err) { return handleNasError(err); }
}