1 package fr.ifremer.tutti.service.genericformat.importactions;
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27 import fr.ifremer.tutti.service.genericformat.GenericFormatContextSupport;
28 import fr.ifremer.tutti.service.genericformat.GenericFormatCsvFileResult;
29 import fr.ifremer.tutti.service.genericformat.GenericFormatImportCruiseContext;
30 import fr.ifremer.tutti.service.genericformat.consumer.CsvConsumerForGearCaracteristic;
31 import fr.ifremer.tutti.service.genericformat.csv.GearCaracteristicRow;
32 import org.apache.commons.logging.Log;
33 import org.apache.commons.logging.LogFactory;
34 import org.nuiton.csv.ImportRow;
35 import org.nuiton.csv.ImportRuntimeException;
36 import org.nuiton.jaxx.application.ApplicationTechnicalException;
37
38 import java.io.IOException;
39
40 import static org.nuiton.i18n.I18n.t;
41
42
43
44
45
46
47
48 public class ValidateGearCaracteristicAction extends ImportActionSupport {
49
50
51 private static final Log log = LogFactory.getLog(ValidateGearCaracteristicAction.class);
52
53 public ValidateGearCaracteristicAction(GenericFormatContextSupport importContext) {
54 super(importContext);
55 }
56
57 @Override
58 protected boolean canExecute() {
59 return importContext.isTechnicalFilesValid() && importContext.getSurveyFileResult().isValid();
60 }
61
62 @Override
63 protected void doExecute() {
64
65 if (log.isInfoEnabled()) {
66 log.info("Validate gearCaracteristics.csv file.");
67 }
68
69 int maximumRowsInErrorPerFile = importContext.getImportRequest().getMaximumRowsInErrorPerFile();
70
71 GenericFormatCsvFileResult importFileResult = importContext.getGearCaracteristicFileResult();
72 try (CsvConsumerForGearCaracteristic consumer = importContext.loadGearCaracteristics(false)) {
73 for (ImportRow<GearCaracteristicRow> row : consumer) {
74
75 importContext.increments(t("tutti.service.genericFormat.validate.gearCaracteristics", row.getLineNumber()));
76
77 GenericFormatImportCruiseContext cruiseContext = consumer.validateRow(row, importContext);
78
79 if (cruiseContext != null) {
80
81 consumer.prepareRowForPersist(cruiseContext, row);
82
83 }
84
85 if (consumer.getNbRowsInErrors() > maximumRowsInErrorPerFile) {
86 if (log.isWarnEnabled()) {
87 log.warn("Too much errors, stop validating this file.");
88 }
89 break;
90 }
91
92 }
93
94 flushConsumer(consumer, importFileResult);
95
96 } catch (IOException e) {
97 throw new ApplicationTechnicalException("Could not close gearCaracteristic.csv file", e);
98 } catch (ImportRuntimeException e) {
99
100 importFileResult.addGlobalError(e.getMessage());
101
102 }
103
104 }
105
106 }