View Javadoc
1   /*
2    * Copyright (c) 2002-2017, 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.service;
35  
36  import fr.paris.lutece.plugins.directory.business.Directory;
37  import fr.paris.lutece.plugins.directory.business.DirectoryFilter;
38  import fr.paris.lutece.plugins.directory.business.DirectoryHome;
39  import fr.paris.lutece.plugins.directory.business.Record;
40  import fr.paris.lutece.plugins.directory.service.record.IRecordService;
41  import fr.paris.lutece.plugins.directory.service.record.RecordService;
42  import fr.paris.lutece.plugins.directory.utils.DirectoryUtils;
43  import fr.paris.lutece.portal.service.daemon.Daemon;
44  import fr.paris.lutece.portal.service.plugin.Plugin;
45  import fr.paris.lutece.portal.service.plugin.PluginService;
46  import fr.paris.lutece.portal.service.spring.SpringContextService;
47  import fr.paris.lutece.portal.service.workflow.WorkflowService;
48  
49  import java.util.List;
50  
51  /**
52   * Daemon to remove entries of directories that are in a given state
53   */
54  public class DirectoryWorkflowRecordRemovalDaemon extends Daemon
55  {
56      private IRecordService _recordService;
57  
58      /**
59       * {@inheritDoc}
60       */
61      @Override
62      public void run( )
63      {
64          WorkflowService workflowService = WorkflowService.getInstance( );
65  
66          if ( workflowService.isAvailable( ) )
67          {
68              DirectoryFilter filter = new DirectoryFilter( );
69              Plugin pluginDirectory = PluginService.getPlugin( DirectoryPlugin.PLUGIN_NAME );
70              List<Directory> listDirectory = DirectoryHome.getDirectoryList( filter, PluginService.getPlugin( DirectoryPlugin.PLUGIN_NAME ) );
71              IRecordService recordService = getRecordService( );
72              int nRemovedRecords = 0;
73  
74              for ( Directory directory : listDirectory )
75              {
76                  if ( ( directory.getIdWorkflow( ) > DirectoryUtils.CONSTANT_ID_NULL )
77                          && ( directory.getIdWorkflowStateToRemove( ) != DirectoryUtils.CONSTANT_ID_NULL ) )
78                  {
79                      List<Integer> listRecordId = workflowService.getResourceIdListByIdState( directory.getIdWorkflowStateToRemove( ),
80                              Record.WORKFLOW_RESOURCE_TYPE );
81  
82                      if ( ( listRecordId != null ) && ( listRecordId.size( ) > 0 ) )
83                      {
84                          for ( int nRecordId : listRecordId )
85                          {
86                              recordService.remove( nRecordId, pluginDirectory );
87                          }
88  
89                          nRemovedRecords += listRecordId.size( );
90                      }
91                  }
92              }
93  
94              setLastRunLogs( nRemovedRecords + " record(s) have been removed" );
95          }
96          else
97          {
98              setLastRunLogs( "No avaiable workflow service found" );
99          }
100     }
101 
102     /**
103      * Get the instance of the record service
104      * 
105      * @return The instance of the record service
106      */
107     private IRecordService getRecordService( )
108     {
109         if ( _recordService == null )
110         {
111             _recordService = SpringContextService.getBean( RecordService.BEAN_SERVICE );
112         }
113 
114         return _recordService;
115     }
116 }