import { Handlers } from 'fresh/server.ts'; import { Directory, FreshContextState } from '/lib/types.ts'; import { createDirectory, getDirectories } from '/lib/data/files.ts'; interface Data {} export interface RequestBody { parentPath: string; name: string; } export interface ResponseBody { success: boolean; newDirectories: Directory[]; } export const handler: Handlers = { async POST(request, context) { if (!context.state.user) { return new Response('Unauthorized', { status: 401 }); } const requestBody = await request.clone().json() as RequestBody; if ( !requestBody.parentPath || !requestBody.name?.trim() || !requestBody.parentPath.startsWith('/') || requestBody.parentPath.includes('../') ) { return new Response('Bad Request', { status: 400 }); } // TODO: Verify user has write access to path and get the appropriate ownerUserId const createdDirectory = await createDirectory( context.state.user.id, requestBody.parentPath, requestBody.name.trim(), ); const newDirectories = await getDirectories(context.state.user.id, requestBody.parentPath); const responseBody: ResponseBody = { success: createdDirectory, newDirectories }; return new Response(JSON.stringify(responseBody)); }, };