View Javadoc
1   package fr.ifremer.tutti.service.genericformat.importactions;
2   
3   /*
4    * #%L
5    * Tutti :: Service
6    * $Id:$
7    * $HeadURL:$
8    * %%
9    * Copyright (C) 2012 - 2015 Ifremer
10   * %%
11   * This program is free software: you can redistribute it and/or modify
12   * it under the terms of the GNU General Public License as
13   * published by the Free Software Foundation, either version 3 of the
14   * License, or (at your option) any later version.
15   * 
16   * This program is distributed in the hope that it will be useful,
17   * but WITHOUT ANY WARRANTY; without even the implied warranty of
18   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19   * GNU General Public License for more details.
20   * 
21   * You should have received a copy of the GNU General Public
22   * License along with this program.  If not, see
23   * <http://www.gnu.org/licenses/gpl-3.0.html>.
24   * #L%
25   */
26  
27  import fr.ifremer.tutti.service.catches.WeightCleaningService;
28  import fr.ifremer.tutti.service.genericformat.GenericFormatImportContext;
29  import fr.ifremer.tutti.service.genericformat.GenericFormatImportOperationContext;
30  import org.apache.commons.logging.Log;
31  import org.apache.commons.logging.LogFactory;
32  
33  import static org.nuiton.i18n.I18n.t;
34  
35  /**
36   * Created on 3/3/15.
37   *
38   * @author Tony Chemit - chemit@codelutin.com
39   * @since 3.14
40   */
41  public class DoCleanWeightAction extends ImportActionSupport {
42  
43      /** Logger. */
44      private static final Log log = LogFactory.getLog(DoCleanWeightAction.class);
45  
46      private final WeightCleaningService weightCleaningService;
47  
48      public DoCleanWeightAction(GenericFormatImportContext importContext, WeightCleaningService weightCleaningService) {
49          super(importContext);
50          this.weightCleaningService = weightCleaningService;
51      }
52  
53      @Override
54      protected boolean canExecute() {
55          return importContext.getImportRequest().isCleanWeights()
56                 && importContext.isTechnicalFilesValid()
57                 && importContext.getOperationFileResult().isValid()
58                 && importContext.getCatchFileResult().isValid()
59                 && importContext.getMarineLitterFileResult().isValid();
60      }
61  
62      @Override
63      protected void doExecute() {
64  
65          if (log.isInfoEnabled()) {
66              log.info("Will clean weights.");
67          }
68  
69          importContext.doActionOnCruiseContexts((cruiseContext, progressionModel) -> {
70  
71              for (GenericFormatImportOperationContext operationContext : cruiseContext) {
72  
73                  progressionModel.increments(t("tutti.service.genericFormat.cleanWeights.fishingOperation", cruiseContext.getCruiseLabel(), operationContext.getFishingOperationLabel()));
74  
75                  boolean weightsDeleted = weightCleaningService.cleanFishingOperation(operationContext.getFishingOperation().getIdAsInt());
76                  operationContext.setWeightsDeleted(weightsDeleted);
77  
78              }
79  
80          });
81  
82      }
83  
84  }