View Javadoc
1   /*
2    * Copyright (c) 2002-2014, Mairie de Paris
3    * All rights reserved.
4    *
5    * Redistribution and use in source and binary forms, with or without
6    * modification, are permitted provided that the following conditions
7    * are met:
8    *
9    *  1. Redistributions of source code must retain the above copyright notice
10   *     and the following disclaimer.
11   *
12   *  2. Redistributions in binary form must reproduce the above copyright notice
13   *     and the following disclaimer in the documentation and/or other materials
14   *     provided with the distribution.
15   *
16   *  3. Neither the name of 'Mairie de Paris' nor 'Lutece' nor the names of its
17   *     contributors may be used to endorse or promote products derived from
18   *     this software without specific prior written permission.
19   *
20   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23   * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
24   * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25   * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26   * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27   * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28   * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29   * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30   * POSSIBILITY OF SUCH DAMAGE.
31   *
32   * License 1.0
33   */
34  package fr.paris.lutece.plugins.directory.modules.pdfproducerarchive.service.daemon;
35  
36  import fr.paris.lutece.plugins.directory.modules.pdfproducer.service.DirectoryPDFProducerPlugin;
37  import fr.paris.lutece.plugins.directory.modules.pdfproducerarchive.business.zipbasket.ZipBasket;
38  import fr.paris.lutece.plugins.directory.modules.pdfproducerarchive.service.DirectoryManageZipBasketService;
39  import fr.paris.lutece.portal.service.daemon.Daemon;
40  import fr.paris.lutece.portal.service.plugin.Plugin;
41  import fr.paris.lutece.portal.service.plugin.PluginService;
42  import fr.paris.lutece.portal.service.spring.SpringContextService;
43  import fr.paris.lutece.portal.service.util.AppPropertiesService;
44  
45  import org.apache.commons.lang.StringUtils;
46  
47  import java.util.Calendar;
48  import java.util.GregorianCalendar;
49  
50  
51  /**
52   *
53   * Daemon ZipCleanerDaemon
54   *
55   */
56  public class ZipCleanerDaemon extends Daemon
57  {
58      // BEANS
59      private static final String BEAN_DIRECTOR_MANAGE_ZIP_BASKET_SERVICE = "directory-pdfproducer-archive.directoryManageZipBasketService";
60  
61      // PROPERTIES
62      private static final String PROPERTY_DAEMON_NB_EXPIRATION_DAYS = "daemon.zipCleaner.nbExpirationDays";
63  
64      // VARIABLES
65      private DirectoryManageZipBasketService _manageZipBasketService = (DirectoryManageZipBasketService) SpringContextService.getPluginBean( DirectoryPDFProducerPlugin.PLUGIN_NAME,
66              BEAN_DIRECTOR_MANAGE_ZIP_BASKET_SERVICE );
67  
68      /**
69       * Daemon's treatment method
70       */
71      public void run(  )
72      {
73          StringBuilder sbLog = new StringBuilder(  );
74          Plugin plugin = PluginService.getPlugin( DirectoryPDFProducerPlugin.PLUGIN_NAME );
75          int nExpirationDays = AppPropertiesService.getPropertyInt( PROPERTY_DAEMON_NB_EXPIRATION_DAYS, 7 );
76          Calendar calendar = new GregorianCalendar(  );
77          calendar.add( Calendar.DATE, -nExpirationDays );
78  
79          for ( ZipBasket zipBasket : _manageZipBasketService.loadZipBasketByDate( plugin, calendar.getTime(  ) ) )
80          {
81              if ( zipBasket != null )
82              {
83                  sbLog.append( "\n- Cleaning archive '" + zipBasket.getZipName(  ) + " (ID : " + zipBasket.getIdZip(  ) +
84                      ")'" );
85                  _manageZipBasketService.deleteZipBasket( plugin, zipBasket.getIdZip(  ),
86                      Integer.toString( zipBasket.getIdRecord(  ) ), sbLog );
87              }
88          }
89  
90          if ( StringUtils.isBlank( sbLog.toString(  ) ) )
91          {
92              sbLog.append( "\nNo archive to clean" );
93          }
94  
95          setLastRunLogs( sbLog.toString(  ) );
96      }
97  }