From 58b74f9fbb7aca18746cffe524f4ea59747c68bf Mon Sep 17 00:00:00 2001 From: Walter Moar Date: Tue, 22 Oct 2024 23:02:12 +0000 Subject: [PATCH 1/2] fix: FORMS-1138 temp route to move uploads files A bug left uploaded files in the "uploads" directory in the object storage, when they should have been moved to the "submissions" directory. This temporary route will move the files for a given submission ID. --- app/src/forms/file/controller.js | 9 +++++++++ app/src/forms/file/routes.js | 7 +++++++ app/src/forms/file/service.js | 32 ++++++++++++++++++++++++++++++++ 3 files changed, 48 insertions(+) diff --git a/app/src/forms/file/controller.js b/app/src/forms/file/controller.js index 517c1e6ea..5390fb257 100644 --- a/app/src/forms/file/controller.js +++ b/app/src/forms/file/controller.js @@ -61,4 +61,13 @@ module.exports = { next(error); } }, + + tempfix: async (req, res, next) => { + try { + await service.tempfix(req.params.submissionId); + res.sendStatus(200); + } catch (error) { + next(error); + } + }, }; diff --git a/app/src/forms/file/routes.js b/app/src/forms/file/routes.js index 95e21c232..f152ded67 100644 --- a/app/src/forms/file/routes.js +++ b/app/src/forms/file/routes.js @@ -24,4 +24,11 @@ routes.delete('/:fileId', currentFileRecord, hasFilePermissions([P.SUBMISSION_UP await controller.delete(req, res, next); }); +// FORMS-1138: Add a temporary route that can be called with a submission ID to +// fix any files that are stuck in the "uploads" directory. This will be removed +// once all the files have been moved into the proper submissions directory. +routes.post('/tempfix/:submissionId', async (req, res, next) => { + await controller.tempfix(req, res, next); +}); + module.exports = routes; diff --git a/app/src/forms/file/service.js b/app/src/forms/file/service.js index 73f6e5af1..77c481203 100644 --- a/app/src/forms/file/service.js +++ b/app/src/forms/file/service.js @@ -112,6 +112,38 @@ const service = { throw err; } }, + + // This is moveSubmissionFiles with the restriction that it only moves files + // in the chefs/prod/uploads directory. + tempfix: async (submissionId) => { + let trx; + try { + trx = await FileStorage.startTransaction(); + + // fetch all the File Storage records for a submission id + // move them to permanent storage + // update their new paths. + const items = await FileStorage.query(trx).where('formSubmissionId', submissionId); + + for (const item of items) { + if (item.path.startsWith('chefs/prod/uploads')) { + // move the files under a sub directory for this submission + const newPath = await storageService.move(item, 'submissions', submissionId); + if (!newPath) { + throw new Error('Error moving files for submission'); + } + await FileStorage.query(trx).patchAndFetchById(item.id, { + storage: PERMANENT_STORAGE, + path: newPath, + }); + } + } + await trx.commit(); + } catch (err) { + if (trx) await trx.rollback(); + throw err; + } + }, }; module.exports = service; From 8c3f7585a974f3311aca2632b7e194bbd7cbb152 Mon Sep 17 00:00:00 2001 From: Walter Moar Date: Wed, 23 Oct 2024 16:58:17 +0000 Subject: [PATCH 2/2] fix: FORMS-1303 add main location to package.json Added the "main" setting with a value of "app.js" to the package.json. This is to hopefully influence the CodeQL static checks to recognize the rate limiter applied to all API routes. --- app/package.json | 1 + 1 file changed, 1 insertion(+) diff --git a/app/package.json b/app/package.json index d01ad2b55..567be3998 100644 --- a/app/package.json +++ b/app/package.json @@ -1,5 +1,6 @@ { "name": "common-hosted-form-service-app", + "main": "app.js", "version": "1.5.0", "private": true, "license": "Apache-2.0",