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 }