From 7ff4bd0d5c98652feded7c86d7a40da93e2b992c Mon Sep 17 00:00:00 2001 From: Trevor Gerhardt Date: Fri, 27 Oct 2023 17:20:33 +0800 Subject: [PATCH] Move files into a scratch directory before processing --- .../controllers/OpportunityDatasetController.java | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/src/main/java/com/conveyal/analysis/controllers/OpportunityDatasetController.java b/src/main/java/com/conveyal/analysis/controllers/OpportunityDatasetController.java index ec46a3e23..9c7252467 100644 --- a/src/main/java/com/conveyal/analysis/controllers/OpportunityDatasetController.java +++ b/src/main/java/com/conveyal/analysis/controllers/OpportunityDatasetController.java @@ -329,6 +329,8 @@ private OpportunityDatasetUploadStatus createOpportunityDataset(Request req, Res OpportunityDatasetUploadStatus status = new OpportunityDatasetUploadStatus(regionId, sourceName); addStatusAndRemoveOldStatuses(status); + // TODO should we delete this temporary directory at the end? + final File tmpDirectory = FileUtils.createScratchDirectory(); final List files = new ArrayList<>(); final List fileItems; final FileStorageFormat uploadFormat; @@ -338,8 +340,9 @@ private OpportunityDatasetUploadStatus createOpportunityDataset(Request req, Res // Call remove() rather than get() so that subsequent code will see only string parameters, not the files. fileItems = formFields.remove("files"); for (var fi : fileItems) { - var dfi = (DiskFileItem) fi; - files.add(dfi.getStoreLocation()); + var tmpFile = new File(tmpDirectory, fi.getName()); + Files.move(((DiskFileItem) fi).getStoreLocation(), tmpFile); + files.add(tmpFile); } uploadFormat = detectUploadFormatAndValidate(files); parameters = extractStringParameters(formFields); @@ -541,7 +544,7 @@ private List createGridsFromShapefile(List files, } // Copy the shapefile component files into a temporary directory with a fixed base name. - File tempDir = Files.createTempDir(); + File tempDir = FileUtils.createScratchDirectory(); File shpFile = new File(tempDir, "grid.shp"); Files.copy(filesByExtension.get("SHP"), shpFile);