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 workflowFilter.setIsEnabled( WorkflowFilter.FILTER_TRUE );
69 List<Workflow> listWorkflows = workflowService.getListWorkflowsByFilter( workflowFilter );
70 IResourceWorkflowService resourceWorkflowService = SpringContextService.getBean( ResourceWorkflowService.BEAN_SERVICE );
71 int nNbResourcesFound = 0;
72 int nNbErrors = 0;
73
74 for ( Workflow workflow : listWorkflows )
75 {
76 IActionService actionService = SpringContextService.getBean( ActionService.BEAN_SERVICE );
77 ActionFilter filter = new ActionFilter( );
78 filter.setAutomaticReflexiveAction( false );
79 filter.setIsAutomaticState( 1 );
80 filter.setIdWorkflow( workflow.getId( ) );
81
82 List<Action> listAutomaticActions = actionService.getListActionByFilter( filter );
83
84 for ( Action action : listAutomaticActions )
85 {
86 List<ResourceWorkflow> listResource = resourceWorkflowService.getAllResourceWorkflowByListState( action.getListIdStateBefore( ) );
87
88 for ( ResourceWorkflow resource : listResource )
89 {
90 try
91 {
92 WorkflowService.getInstance( ).doProcessAction( resource.getIdResource( ), resource.getResourceType( ), action.getId( ),
93 resource.getExternalParentId( ), null, Locale.getDefault( ), true, null );
94 }
95 catch ( AppException e )
96 {
97 AppLogService.error( "An error occurred processing Action {} for resource Id {} of type {} ",
98 action.getId( ), resource.getIdResource( ), resource.getResourceType( ) , e);
99 nNbErrors++;
100 }
101
102 nNbResourcesFound++;
103 }
104 }
105 }
106
107 StringBuilder sbResult = new StringBuilder( );
108 sbResult.append( "Automatic actions performed on ").append( nNbResourcesFound ).append(" resources ");
109 sbResult.append( " with ").append( nNbErrors ).append( "errors.");
110 if ( nNbErrors > 0 ) sbResult.append( " See logs for details.");
111
112 setLastRunLogs( sbResult.toString( ) );
113 }
114 }