1   
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  
28  
29  
30  
31  
32  
33  
34  package fr.paris.lutece.plugins.workflow.service.prerequisite;
35  
36  import fr.paris.lutece.plugins.workflowcore.business.action.Action;
37  import fr.paris.lutece.plugins.workflowcore.business.action.ActionFilter;
38  import fr.paris.lutece.plugins.workflowcore.business.resource.ResourceWorkflow;
39  import fr.paris.lutece.plugins.workflowcore.business.workflow.Workflow;
40  import fr.paris.lutece.plugins.workflowcore.business.workflow.WorkflowFilter;
41  import fr.paris.lutece.plugins.workflowcore.service.action.ActionService;
42  import fr.paris.lutece.plugins.workflowcore.service.action.IActionService;
43  import fr.paris.lutece.plugins.workflowcore.service.resource.IResourceWorkflowService;
44  import fr.paris.lutece.plugins.workflowcore.service.resource.ResourceWorkflowService;
45  import fr.paris.lutece.plugins.workflowcore.service.workflow.IWorkflowService;
46  import fr.paris.lutece.portal.service.daemon.Daemon;
47  import fr.paris.lutece.portal.service.spring.SpringContextService;
48  import fr.paris.lutece.portal.service.util.AppException;
49  import fr.paris.lutece.portal.service.util.AppLogService;
50  import fr.paris.lutece.portal.service.workflow.WorkflowService;
51  
52  import java.util.List;
53  import java.util.Locale;
54  
55  
56  
57  
58  public class AutomaticActionDaemon extends Daemon
59  {
60      
61  
62  
63      @Override
64      public void run( )
65      {
66          IWorkflowService workflowService = SpringContextService.getBean( fr.paris.lutece.plugins.workflowcore.service.workflow.WorkflowService.BEAN_SERVICE );
67          WorkflowFilter workflowFilter = new WorkflowFilter( );
68          List<Workflow> listWorkflows = workflowService.getListWorkflowsByFilter( workflowFilter );
69          IResourceWorkflowService resourceWorkflowService = SpringContextService.getBean( ResourceWorkflowService.BEAN_SERVICE );
70          int nNbResourcesFound = 0;
71          int nNbErrors = 0;
72  
73          for ( Workflow workflow : listWorkflows )
74          {
75              IActionService actionService = SpringContextService.getBean( ActionService.BEAN_SERVICE );
76              ActionFilter filter = new ActionFilter( );
77              filter.setAutomaticReflexiveAction( false );
78              filter.setIsAutomaticState( 1 );
79              filter.setIdWorkflow( workflow.getId( ) );
80  
81              List<Action> listAutomaticActions = actionService.getListActionByFilter( filter );
82  
83              for ( Action action : listAutomaticActions )
84              {
85                  List<ResourceWorkflow> listResource = resourceWorkflowService.getAllResourceWorkflowByListState( action.getListIdStateBefore( ) );
86  
87                  for ( ResourceWorkflow resource : listResource )
88                  {
89                      try
90                      {
91                          WorkflowService.getInstance( ).doProcessAction( resource.getIdResource( ), resource.getResourceType( ), action.getId( ),
92                                  resource.getExternalParentId( ), null, Locale.getDefault( ), true, null );
93                      }
94                      catch ( AppException e )
95                      {
96                          AppLogService.error( "An error occurred processing Action {} for resource Id {} of type {} ",
97                        		action.getId( ), resource.getIdResource( ), resource.getResourceType( ) ,  e);
98                          nNbErrors++;
99                      }
100 
101                     nNbResourcesFound++;
102                 }
103             }
104         }
105 
106         StringBuilder sbResult = new StringBuilder( );
107         sbResult.append( "Automatic actions performed on ").append( nNbResourcesFound ).append(" resources ");
108         sbResult.append( " with ").append( nNbErrors ).append( "errors.");
109         if ( nNbErrors > 0 ) sbResult.append( " See logs for details.");
110 
111         setLastRunLogs( sbResult.toString( ) );
112     }
113 }