refactor: simplify upload rules and remove destination flow
This commit is contained in:
@@ -17,23 +17,21 @@ export async function POST(req: NextRequest) {
|
||||
if (authError) return authError
|
||||
|
||||
let folderName: string
|
||||
let destination: string
|
||||
let parsedFiles: Awaited<ReturnType<typeof parseMultiUpload>>['files']
|
||||
|
||||
try {
|
||||
const parsed = await parseMultiUpload(req)
|
||||
folderName = parsed.folderName
|
||||
destination = parsed.destination
|
||||
parsedFiles = parsed.files
|
||||
} catch (err) {
|
||||
const message = err instanceof Error ? err.message : 'Erreur inconnue'
|
||||
return NextResponse.json({ success: false, error: message }, { status: 400 })
|
||||
}
|
||||
|
||||
const folderPath = `public/models/${destination}/${folderName}`
|
||||
const folderPath = `public/models/${folderName}`
|
||||
|
||||
try {
|
||||
const { filesToPush } = await prepareGitAssets({ folderName, destination, parsedFiles })
|
||||
const { filesToPush } = await prepareGitAssets({ folderName, parsedFiles })
|
||||
const { exists, files } = await getRemoteFolder(folderPath)
|
||||
|
||||
if (exists) {
|
||||
|
||||
@@ -17,7 +17,7 @@ export const dynamic = 'force-dynamic'
|
||||
// Upload **original** files (no Blender compression) to Nextcloud Drive.
|
||||
//
|
||||
// FormData fields:
|
||||
// - folderName, destination, files[], fileTypes[], textureNames[] (same as /api/upload/git)
|
||||
// - folderName, files[], fileTypes[], textureNames[] (same as /api/upload/git)
|
||||
// - action: "new" | "replace"
|
||||
//
|
||||
// Versioning logic:
|
||||
|
||||
@@ -20,13 +20,11 @@ export async function POST(req: NextRequest) {
|
||||
|
||||
// --- Parse all files ---
|
||||
let folderName: string
|
||||
let destination: string
|
||||
let parsedFiles: Awaited<ReturnType<typeof parseMultiUpload>>['files']
|
||||
|
||||
try {
|
||||
const parsed = await parseMultiUpload(req)
|
||||
folderName = parsed.folderName
|
||||
destination = parsed.destination
|
||||
parsedFiles = parsed.files
|
||||
} catch (err) {
|
||||
const message = err instanceof Error ? err.message : 'Erreur inconnue'
|
||||
@@ -40,10 +38,10 @@ export async function POST(req: NextRequest) {
|
||||
compressed,
|
||||
compressionError,
|
||||
textureNames,
|
||||
} = await prepareGitAssets({ folderName, destination, parsedFiles })
|
||||
} = await prepareGitAssets({ folderName, parsedFiles })
|
||||
|
||||
// --- Detect existing files and classify changes ---
|
||||
const folderPath = `public/models/${destination}/${folderName}`
|
||||
const folderPath = `public/models/${folderName}`
|
||||
let remoteFileMap: Map<string, number>
|
||||
|
||||
try {
|
||||
@@ -72,7 +70,7 @@ export async function POST(req: NextRequest) {
|
||||
|
||||
// --- Build commit message ---
|
||||
const commitMessage = buildCommitMessage(
|
||||
folderName, destination, modelFilename, textureNames,
|
||||
folderName, modelFilename, textureNames,
|
||||
compressed, isReplace, fileChanges, deletedFileNames,
|
||||
)
|
||||
|
||||
|
||||
Reference in New Issue
Block a user