1 |
|
|
2 |
|
|
3 |
|
|
4 |
|
|
5 |
|
|
6 |
|
|
7 |
|
|
8 |
|
|
9 |
|
|
10 |
|
|
11 |
|
|
12 |
|
|
13 |
|
|
14 |
|
|
15 |
|
|
16 |
|
|
17 |
|
package org.apache.camel.bam; |
18 |
|
|
19 |
|
import org.apache.camel.bam.model.ActivityDefinition; |
20 |
|
import org.apache.camel.bam.model.ActivityState; |
21 |
|
import org.apache.commons.logging.Log; |
22 |
|
import org.apache.commons.logging.LogFactory; |
23 |
|
|
24 |
|
import java.util.ArrayList; |
25 |
|
import java.util.List; |
26 |
|
|
27 |
|
|
28 |
|
|
29 |
|
|
30 |
|
|
31 |
|
|
32 |
|
public class ActivityRules { |
33 |
0 |
private static final transient Log log = LogFactory.getLog(ActivityRules.class); |
34 |
0 |
private int expectedMessages = 1; |
35 |
|
private ActivityDefinition activity; |
36 |
|
private ProcessRules process; |
37 |
0 |
private List<TemporalRule> rules = new ArrayList<TemporalRule>(); |
38 |
|
private String activityName; |
39 |
|
|
40 |
0 |
public ActivityRules(ProcessRules process) { |
41 |
0 |
this.process = process; |
42 |
0 |
process.getActivities().add(this); |
43 |
0 |
} |
44 |
|
|
45 |
|
public ActivityDefinition getActivity() { |
46 |
0 |
return activity; |
47 |
|
} |
48 |
|
|
49 |
|
public void setActivity(ActivityDefinition activity) { |
50 |
0 |
this.activity = activity; |
51 |
0 |
} |
52 |
|
|
53 |
|
public int getExpectedMessages() { |
54 |
0 |
return expectedMessages; |
55 |
|
} |
56 |
|
|
57 |
|
public void setExpectedMessages(int expectedMessages) { |
58 |
0 |
this.expectedMessages = expectedMessages; |
59 |
0 |
} |
60 |
|
|
61 |
|
public ProcessRules getProcess() { |
62 |
0 |
return process; |
63 |
|
} |
64 |
|
|
65 |
|
|
66 |
|
|
67 |
|
|
68 |
|
public void processExchange(ActivityState activityState, ProcessContext context) { |
69 |
|
|
70 |
0 |
log.info("Received state: " + activityState |
71 |
|
+ " message count " + activityState.getReceivedMessageCount() |
72 |
|
+ " started: " + activityState.getTimeStarted() |
73 |
|
+ " completed: " + activityState.getTimeCompleted()); |
74 |
|
|
75 |
|
|
76 |
|
|
77 |
|
|
78 |
|
|
79 |
|
|
80 |
|
|
81 |
|
|
82 |
0 |
} |
83 |
|
|
84 |
|
public void setActivityName(String activityName) { |
85 |
0 |
this.activityName = activityName; |
86 |
0 |
} |
87 |
|
|
88 |
|
public void addRule(TemporalRule rule) { |
89 |
0 |
rules.add(rule); |
90 |
0 |
} |
91 |
|
|
92 |
|
|
93 |
|
|
94 |
|
|
95 |
|
public void processExpired(ActivityState activityState) throws Exception { |
96 |
0 |
for (TemporalRule rule : rules) { |
97 |
0 |
rule.processExpired(activityState); |
98 |
0 |
} |
99 |
0 |
} |
100 |
|
} |