|
|||||||||||||||||||
30 day Evaluation Version distributed via the Maven Jar Repository. Clover is not free. You have 30 days to evaluate it. Please visit http://www.thecortex.net/clover to obtain a licensed version of Clover | |||||||||||||||||||
Source file | Conditionals | Statements | Methods | TOTAL | |||||||||||||||
ApplicationCommandProcessor.java | 0% | 8,3% | 25% | 10% |
|
1 |
/*
|
|
2 |
* Replica is published under the terms
|
|
3 |
* of the Apache Software License.
|
|
4 |
*/
|
|
5 |
package replica.core;
|
|
6 |
|
|
7 |
import java.util.logging.Level;
|
|
8 |
import java.util.logging.Logger;
|
|
9 |
|
|
10 |
import replica.command.Command;
|
|
11 |
import replica.command.CommandException;
|
|
12 |
import replica.command.beans.BeansCommandProcessor;
|
|
13 |
|
|
14 |
/**
|
|
15 |
* This processor extends the beans processor to provide suport for
|
|
16 |
* ApplicationMessages as command argument.
|
|
17 |
*
|
|
18 |
* @author Pedro Costa
|
|
19 |
* @author Helder Silva
|
|
20 |
* @since 21/Jan/2004
|
|
21 |
*/
|
|
22 |
public class ApplicationCommandProcessor extends BeansCommandProcessor { |
|
23 |
|
|
24 |
static Logger logger = Logger.getLogger(ApplicationCommandProcessor.class.getName()); |
|
25 |
|
|
26 |
/**
|
|
27 |
*
|
|
28 |
*/
|
|
29 | 6 |
public ApplicationCommandProcessor() {
|
30 | 6 |
super();
|
31 |
} |
|
32 |
|
|
33 |
/**
|
|
34 |
* This default implementation assumes that command is a string and that the first word is the action Id.
|
|
35 |
*
|
|
36 |
* It passes the all command instruction, including the action Id, to the mapped command on execute.
|
|
37 |
*
|
|
38 |
* @return Object the result of the command execution.
|
|
39 |
* @see replica.server.cmd.CommandProcessor#process(java.lang.String)
|
|
40 |
* @throws CommandException if there is a problem executing the command.
|
|
41 |
* Callers can choose to catch or not.
|
|
42 |
*/
|
|
43 | 0 |
public Object process(Object command){
|
44 |
|
|
45 | 0 |
if( command instanceof ApplicationMessage ) |
46 | 0 |
return process((ApplicationMessage) command);
|
47 |
|
|
48 | 0 |
return super.process(command); |
49 |
} |
|
50 |
|
|
51 | 0 |
protected Object process(ApplicationMessage appMsg){
|
52 |
|
|
53 | 0 |
try{
|
54 | 0 |
Command c = getCommand( appMsg.getBody()); |
55 |
|
|
56 | 0 |
if( c == null) |
57 | 0 |
throw new CommandException("Command not found."); |
58 |
|
|
59 | 0 |
return executeCommand( c, appMsg);
|
60 |
} |
|
61 |
catch(Throwable e){
|
|
62 | 0 |
logger.log(Level.WARNING, e.getMessage(), e); |
63 | 0 |
return "Error executing [" + appMsg.getBody().toString() + "] : " + e.getMessage(); |
64 |
} |
|
65 |
} |
|
66 |
|
|
67 |
/**
|
|
68 |
* Default beahavior,simple call the execute method on command.
|
|
69 |
*
|
|
70 |
* @param command
|
|
71 |
* @param appMsg
|
|
72 |
* @return
|
|
73 |
*/
|
|
74 | 0 |
protected Object executeCommand( Command command, ApplicationMessage appMsg ){
|
75 |
|
|
76 | 0 |
return command.execute( appMsg);
|
77 |
} |
|
78 |
|
|
79 |
} |
|
80 |
|
|