Files
jotion/nextjs/app/api/folders/route.ts
Mayne0213 e82ea71c22 REFACTOR(repo): simplify project structure
- Move services/nextjs to nextjs/
- Move deploy/docker/Dockerfile.prod to Dockerfile
- Add GitHub Actions workflows (ci.yml, build.yml)
- Remove deploy/, services/, scripts/ folders
2026-01-05 02:29:10 +09:00

155 lines
3.4 KiB
TypeScript

import { NextRequest, NextResponse } from 'next/server'
import { withAuth } from '@/shared/lib/middleware'
import { db } from '@/shared/lib/db'
// GET /api/folders - Get all folders for the authenticated user
export const GET = withAuth(async (req: NextRequest, userId: string) => {
try {
const folders = await db.folder.findMany({
where: {
userId,
isArchived: false,
},
include: {
documents: {
where: {
isArchived: false,
},
select: {
id: true,
title: true,
icon: true,
updatedAt: true,
},
},
children: {
where: {
isArchived: false,
},
include: {
_count: {
select: {
documents: {
where: {
isArchived: false,
},
},
children: {
where: {
isArchived: false,
},
},
},
},
},
},
_count: {
select: {
documents: {
where: {
isArchived: false,
},
},
children: {
where: {
isArchived: false,
},
},
},
},
},
orderBy: {
createdAt: 'desc',
},
})
return NextResponse.json(folders)
} catch (error) {
console.error('Error fetching folders:', error)
return NextResponse.json(
{ error: 'Failed to fetch folders' },
{ status: 500 }
)
}
})
// POST /api/folders - Create a new folder
export const POST = withAuth(async (req: NextRequest, userId: string) => {
try {
const { name, parentId, icon, color } = await req.json()
if (!name) {
return NextResponse.json(
{ error: 'Folder name is required' },
{ status: 400 }
)
}
const folder = await db.folder.create({
data: {
name,
userId,
parentId: parentId || null,
icon: icon || '📁',
color: color || null,
},
include: {
documents: {
where: {
isArchived: false,
},
select: {
id: true,
title: true,
icon: true,
updatedAt: true,
},
},
children: {
where: {
isArchived: false,
},
include: {
_count: {
select: {
documents: {
where: {
isArchived: false,
},
},
children: {
where: {
isArchived: false,
},
},
},
},
},
},
_count: {
select: {
documents: {
where: {
isArchived: false,
},
},
children: {
where: {
isArchived: false,
},
},
},
},
},
})
return NextResponse.json(folder, { status: 201 })
} catch (error) {
console.error('Error creating folder:', error)
return NextResponse.json(
{ error: 'Failed to create folder' },
{ status: 500 }
)
}
})