Package org.camunda.bpm.dmn.engine
Interface DmnEngine
- All Known Implementing Classes:
- DefaultDmnEngine
public interface DmnEngine
A DMN engine which can parse DMN decision models
 and evaluate decisions.
 
 A new DMN engine can be build with a DMN engine configuration
 (see DmnEngineConfiguration.buildEngine()).
 
- 
Method SummaryModifier and TypeMethodDescriptionevaluateDecision(String decisionKey, InputStream inputStream, Map<String, Object> variables) Evaluates the decision with the given key in a DMN decision model.evaluateDecision(String decisionKey, InputStream inputStream, VariableContext variableContext) Evaluates the decision with the given key in a DMN decision model.evaluateDecision(String decisionKey, DmnModelInstance dmnModelInstance, Map<String, Object> variables) Evaluates the decision with the given key in a DMN decision model.evaluateDecision(String decisionKey, DmnModelInstance dmnModelInstance, VariableContext variableContext) Evaluates the decision with the given key in a DMN decision model.evaluateDecision(DmnDecision decision, Map<String, Object> variables) Evaluates a decision.evaluateDecision(DmnDecision decision, VariableContext variableContext) Evaluates a decision.evaluateDecisionTable(String decisionKey, InputStream inputStream, Map<String, Object> variables) Evaluates the decision with the given key in a DMN decision model.evaluateDecisionTable(String decisionKey, InputStream inputStream, VariableContext variableContext) Evaluates the decision with the given key in a DMN decision model.evaluateDecisionTable(String decisionKey, DmnModelInstance dmnModelInstance, Map<String, Object> variables) Evaluates the decision with the given key in a DMN decision model.evaluateDecisionTable(String decisionKey, DmnModelInstance dmnModelInstance, VariableContext variableContext) Evaluates the decision with the given key in a DMN decision model.evaluateDecisionTable(DmnDecision decision, Map<String, Object> variables) Evaluates a decision which is implemented as decision table.evaluateDecisionTable(DmnDecision decision, VariableContext variableContext) Evaluates a decision which is implemented as decision table.The configuration of this engine.parseDecision(String decisionKey, InputStream inputStream) Parse the decision with the given key in a DMN decision model.parseDecision(String decisionKey, DmnModelInstance dmnModelInstance) Parse the decision with the given key in a DMN decision model.parseDecisionRequirementsGraph(InputStream inputStream) Parse the decision requirements graph in a DMN decision model.parseDecisionRequirementsGraph(DmnModelInstance dmnModelInstance) Parse the decision requirements graph in a DMN decision model.parseDecisions(InputStream inputStream) Parse all decisions in a DMN decision model.parseDecisions(DmnModelInstance dmnModelInstance) Parse all decisions in a DMN decision model.
- 
Method Details- 
getConfigurationDmnEngineConfiguration getConfiguration()The configuration of this engine.- Returns:
- the DMN engine configuration
 
- 
parseDecisionsParse all decisions in a DMN decision model.- Parameters:
- inputStream- the- InputStreamof the DMN file
- Returns:
- a list of the DmnDecisions of the DMN file
- Throws:
- DmnEngineException- if an error occurs during the parsing of the decision model
 
- 
parseDecisionsParse all decisions in a DMN decision model.- Parameters:
- dmnModelInstance- the- DmnModelInstanceof the DMN decision model
- Returns:
- a list of the DmnDecisions of the DMN file
- Throws:
- DmnEngineException- if an error occurs during the parsing of the decision model
 
- 
parseDecisionParse the decision with the given key in a DMN decision model. The key is theidattribute of the decision in the DMN XML file.- Parameters:
- decisionKey- the key of the decision to parse
- inputStream- the- InputStreamof the DMN file
- Returns:
- the first DmnDecisionof the DMN file
- Throws:
- DmnEngineException- if an error occurs during the parsing of the decision model
 
- 
parseDecisionParse the decision with the given key in a DMN decision model. The key is theidattribute of the decision in the DMN XML file.- Parameters:
- decisionKey- the key of the decision to parse
- dmnModelInstance- the- DmnModelInstanceof the DMN decision model
- Returns:
- the first DmnDecisionof the DMN file
- Throws:
- DmnEngineException- if an error occurs during the parsing of the decision model
 
- 
parseDecisionRequirementsGraphParse the decision requirements graph in a DMN decision model.- Parameters:
- inputStream- the- InputStreamof the DMN file
- Returns:
- a list of the DmnDecisions of the DMN file
- Throws:
- DmnEngineException- if an error occurs during the parsing of the decision model
 
- 
parseDecisionRequirementsGraphParse the decision requirements graph in a DMN decision model.- Parameters:
- dmnModelInstance- the- DmnModelInstanceof the DMN decision model
- Returns:
- a list of the DmnDecisions of the DMN file
- Throws:
- DmnEngineException- if an error occurs during the parsing of the decision model
 
- 
evaluateDecisionTableEvaluates a decision which is implemented as decision table.- Parameters:
- decision- the- DmnDecisionto evaluate
- variables- the variables which are available during the evaluation of expressions in the decision table
- Returns:
- the DmnDecisionTableResultof this evaluation
- Throws:
- DmnEngineException- if the decision is not implemented as decision table (see- DmnDecision.isDecisionTable()
- DmnEngineException- if an error occurs during the evaluation
- See Also:
 
- 
evaluateDecisionTableEvaluates a decision which is implemented as decision table.- Parameters:
- decision- the- DmnDecisionto evaluate
- variableContext- the variables context which is available during the evaluation of expressions in the decision table
- Returns:
- the DmnDecisionTableResultof this evaluation
- Throws:
- DmnEngineException- if the decision is not implemented as decision table (see- DmnDecision.isDecisionTable()
- DmnEngineException- if an error occurs during the evaluation
- See Also:
 
- 
evaluateDecisionTableDmnDecisionTableResult evaluateDecisionTable(String decisionKey, InputStream inputStream, Map<String, Object> variables) Evaluates the decision with the given key in a DMN decision model. The key is theidattribute of the decision in the DMN XML file.- Parameters:
- decisionKey- the key of the decision to evaluated
- inputStream- the- InputStreamof the DMN file
- variables- the variables which are available during the evaluation of expressions in the decision table
- Returns:
- the DmnDecisionTableResultof this evaluation
- Throws:
- DmnEngineException- if no decision is found with the given key
- DmnEngineException- if the decision is not implemented as decision table
- DmnEngineException- if an error occurs during the evaluation
- See Also:
 
- 
evaluateDecisionTableDmnDecisionTableResult evaluateDecisionTable(String decisionKey, InputStream inputStream, VariableContext variableContext) Evaluates the decision with the given key in a DMN decision model. The key is theidattribute of the decision in the DMN XML file.- Parameters:
- decisionKey- the key of the decision to evaluated
- inputStream- the- InputStreamof the DMN file
- variableContext- the variables context which is available during the evaluation of expressions in the decision table
- Returns:
- the DmnDecisionTableResultof this evaluation
- Throws:
- DmnEngineException- if no decision is found with the given key
- DmnEngineException- if the decision is not implemented as decision table
- DmnEngineException- if an error occurs during the evaluation
- See Also:
 
- 
evaluateDecisionTableDmnDecisionTableResult evaluateDecisionTable(String decisionKey, DmnModelInstance dmnModelInstance, Map<String, Object> variables) Evaluates the decision with the given key in a DMN decision model. The key is theidattribute of the decision in the DMN XML file.- Parameters:
- decisionKey- the key of the decision to evaluated
- dmnModelInstance- the- DmnModelInstanceof the DMN decision model
- variables- the variables which are available during the evaluation of expressions in the decision table
- Returns:
- the DmnDecisionTableResultof this evaluation
- Throws:
- DmnEngineException- if no decision is found with the given key
- DmnEngineException- if the decision is not implemented as decision table
- DmnEngineException- if an error occurs during the evaluation
- See Also:
 
- 
evaluateDecisionTableDmnDecisionTableResult evaluateDecisionTable(String decisionKey, DmnModelInstance dmnModelInstance, VariableContext variableContext) Evaluates the decision with the given key in a DMN decision model. The key is theidattribute of the decision in the DMN XML file.- Parameters:
- decisionKey- the key of the decision to evaluated
- dmnModelInstance- the- DmnModelInstanceof the DMN decision model
- variableContext- the variables context which is available during the evaluation of expressions in the decision table
- Returns:
- the DmnDecisionTableResultof this evaluation
- Throws:
- DmnEngineException- if an error occurs during the parsing of the decision model
- DmnEngineException- if no decision is found with the given key
- DmnEngineException- if the decision is not implemented as decision table
- DmnEngineException- if an error occurs during the evaluation
- See Also:
 
- 
evaluateDecisionEvaluates a decision. The decision can be implemented as any kind of supported decision logic (e.g., decision table, literal expression).- Parameters:
- decision- the- DmnDecisionto evaluate
- variables- the variables which are available during the evaluation of expressions in the decision
- Returns:
- the DmnDecisionResultof this evaluation
- Throws:
- DmnEngineException- if the decision logic is not supported
- DmnEngineException- if an error occurs during the evaluation
 
- 
evaluateDecisionEvaluates a decision. The decision can be implemented as any kind of supported decision logic (e.g., decision table, literal expression).- Parameters:
- decision- the- DmnDecisionto evaluate
- variableContext- the variables context which is available during the evaluation of expressions in the table
- Returns:
- the DmnDecisionResultof this evaluation
- Throws:
- DmnEngineException- if the decision logic is not supported
- DmnEngineException- if an error occurs during the evaluation
 
- 
evaluateDecisionDmnDecisionResult evaluateDecision(String decisionKey, InputStream inputStream, Map<String, Object> variables) Evaluates the decision with the given key in a DMN decision model. The key is theidattribute of the decision in the DMN XML file. The decision can be implemented as any kind of supported decision logic (e.g., decision table, literal expression).- Parameters:
- decisionKey- the key of the decision to evaluated
- inputStream- the- InputStreamof the DMN file
- variables- the variables which are available during the evaluation of expressions in the decision
- Returns:
- the DmnDecisionResultof this evaluation
- Throws:
- DmnEngineException- if no decision is found with the given key
- DmnEngineException- if the decision logic is not supported
- DmnEngineException- if an error occurs during the evaluation
 
- 
evaluateDecisionDmnDecisionResult evaluateDecision(String decisionKey, InputStream inputStream, VariableContext variableContext) Evaluates the decision with the given key in a DMN decision model. The key is theidattribute of the decision in the DMN XML file. The decision can be implemented as any kind of supported decision logic (e.g., decision table, literal expression).- Parameters:
- decisionKey- the key of the decision to evaluated
- inputStream- the- InputStreamof the DMN file
- variableContext- the variables context which is available during the evaluation of expressions in the decision
- Returns:
- the DmnDecisionResultof this evaluation
- Throws:
- DmnEngineException- if no decision is found with the given key
- DmnEngineException- if the decision logic is not supported
- DmnEngineException- if an error occurs during the evaluation
 
- 
evaluateDecisionDmnDecisionResult evaluateDecision(String decisionKey, DmnModelInstance dmnModelInstance, Map<String, Object> variables) Evaluates the decision with the given key in a DMN decision model. The key is theidattribute of the decision in the DMN XML file. The decision can be implemented as any kind of supported decision logic (e.g., decision table, literal expression).- Parameters:
- decisionKey- the key of the decision to evaluated
- dmnModelInstance- the- DmnModelInstanceof the DMN decision model
- variables- the variables which are available during the evaluation of expressions in the decision
- Returns:
- the DmnDecisionResultof this evaluation
- Throws:
- DmnEngineException- if no decision is found with the given key
- DmnEngineException- if the decision logic is not supported
- DmnEngineException- if an error occurs during the evaluation
 
- 
evaluateDecisionDmnDecisionResult evaluateDecision(String decisionKey, DmnModelInstance dmnModelInstance, VariableContext variableContext) Evaluates the decision with the given key in a DMN decision model. The key is theidattribute of the decision in the DMN XML file. The decision can be implemented as any kind of supported decision logic (e.g., decision table, literal expression).- Parameters:
- decisionKey- the key of the decision to evaluated
- dmnModelInstance- the- DmnModelInstanceof the DMN decision model
- variableContext- the variables context which is available during the evaluation of expressions in the decision
- Returns:
- the DmnDecisionResultof this evaluation
- Throws:
- DmnEngineException- if an error occurs during the parsing of the decision model
- DmnEngineException- if no decision is found with the given key
- DmnEngineException- if the decision logic is not supported
- DmnEngineException- if an error occurs during the evaluation
 
 
-