deploy first

This commit is contained in:
2025-09-10 04:31:53 +00:00
parent 2171d5e744
commit 364e91c47a
13 changed files with 235 additions and 135 deletions

View File

@@ -5,44 +5,29 @@ import { PrismaClient } from '@/app/generated/prisma';
export async function GET() {
const session = await auth();
if (!session) {
if (!session?.user?.email) {
return NextResponse.json({ error: 'Unauthorized' }, { status: 401 });
}
const email = session.user?.email as string | undefined;
if (!email) {
return NextResponse.json({ error: '세션 이메일을 찾을 수 없습니다' }, { status: 400 });
}
const email = session.user.email as string;
const prisma = new PrismaClient();
try {
// Admin: return all handles
let rows;
if (email === 'wsx204@naver.com') {
const all = await prisma.handle.findMany({
// 관리자: 전체 핸들
rows = await prisma.handle.findMany({
orderBy: { handle: 'asc' },
select: { id: true, handle: true, avatar: true }
select: { id: true, handle: true, avatar: true },
});
} else {
// 일반 사용자: 자신의 핸들만
rows = await prisma.handle.findMany({
where: { users: { some: { email } } },
orderBy: { handle: 'asc' },
select: { id: true, handle: true, avatar: true },
});
const items = all.map(h => ({
id: h.id,
handle: h.handle,
createtime: new Date().toISOString(),
is_approved: false,
icon: h.avatar,
}));
return NextResponse.json({ items });
}
// Non-admin: handles linked to session user
const user = await prisma.user.findFirst({ where: { email }, select: { id: true } });
if (!user) {
return NextResponse.json({ items: [] });
}
const linked = await prisma.handle.findMany({
where: { users: { some: { id: user.id } } },
orderBy: { handle: 'asc' },
select: { id: true, handle: true, avatar: true }
});
const items = linked.map(h => ({
const items = rows.map(h => ({
id: h.id,
handle: h.handle,
createtime: new Date().toISOString(),

View File

@@ -0,0 +1,43 @@
import { NextResponse } from 'next/server'
import { PrismaClient } from '@/app/generated/prisma'
import { auth } from '@/auth'
export async function GET(request: Request) {
const prisma = new PrismaClient()
try {
const session = await auth()
const { searchParams } = new URL(request.url)
const handleIdsParam = searchParams.get('handleIds')
let handleIds: string[] | null = null
if (handleIdsParam) {
handleIds = handleIdsParam.split(',').map(s => s.trim()).filter(Boolean)
}
if (!handleIds) {
if (!session?.user?.email) return NextResponse.json({ items: [] })
const myHandles = await prisma.handle.findMany({
where: { users: { some: { email: session.user.email } } },
select: { id: true },
})
handleIds = myHandles.map(h => h.id)
}
const items: Array<{ handleId: string, videoCount: number, views: number }> = []
for (const id of handleIds) {
const videoCount = await prisma.content.count({ where: { handleId: id } })
const agg = await prisma.contentDayView.aggregate({
_sum: { views: true },
where: { content: { handleId: id } },
})
items.push({ handleId: id, videoCount, views: Number(agg._sum.views ?? 0) })
}
return NextResponse.json({ items })
} catch (e) {
return NextResponse.json({ error: 'stats failed' }, { status: 500 })
} finally {
try { await prisma.$disconnect() } catch {}
}
}