From 14a4b83fb52f1790abd457372b69a92de95751cf Mon Sep 17 00:00:00 2001 From: Dani Palou Date: Thu, 7 Nov 2024 12:27:23 +0100 Subject: [PATCH] MOBILE-4653 core: Fix race condition when uploading files Uploading several files in parallel can cause a race condition in the server when trying to insert the directory data in the 'files' table of the DB, in the create_directory function. To avoid that, now files are uploaded 1 by 1 in the same area. --- .../features/fileuploader/services/fileuploader.ts | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/src/core/features/fileuploader/services/fileuploader.ts b/src/core/features/fileuploader/services/fileuploader.ts index 62d83482e..a4ca5c9d0 100644 --- a/src/core/features/fileuploader/services/fileuploader.ts +++ b/src/core/features/fileuploader/services/fileuploader.ts @@ -639,7 +639,8 @@ export class CoreFileUploaderProvider { } }); - await Promise.all(filesToUpload.map(async (file) => { + // Upload files 1 by 1 to avoid race conditions in the server. + for (const file of filesToUpload) { // Make sure the file name is unique in the area. const name = CoreFile.calculateUniqueName(usedNames, file.name); usedNames[name] = file; @@ -649,7 +650,7 @@ export class CoreFileUploaderProvider { const options = this.getFileUploadOptions(filePath, name, undefined, false, 'draft', itemId); await this.uploadFile(filePath, options, undefined, siteId); - })); + } } /** @@ -742,15 +743,12 @@ export class CoreFileUploaderProvider { // Upload only the first file first to get a draft id. const itemId = await this.uploadOrReuploadFile(files[0], 0, component, componentId, siteId); - const promises: Promise[] = []; - + // Upload files 1 by 1 to avoid race conditions in the server. for (let i = 1; i < files.length; i++) { const file = files[i]; - promises.push(this.uploadOrReuploadFile(file, itemId, component, componentId, siteId)); + await this.uploadOrReuploadFile(file, itemId, component, componentId, siteId); } - await Promise.all(promises); - return itemId; }