mirror of
https://github.com/sartography/spiff-arena.git
synced 2025-02-24 07:08:16 +00:00
46d3de27f Merge pull request #267 from sartography/feature/dmn_collect_policy 2d5ca32d5 Support for the "COLLECT" hit policy. * DecisionTable constructor now expects a third argument (the HitPolicy) * DMNParser now checks for a hitPolicy attribute, but defaults ot "UNIQUE" as Camunda doesn't put another in there if Unique is selected. * DecisionTable deserializer will default to a hitPolicy of "UNIQUE" if not value is in the Json. git-subtree-dir: SpiffWorkflow git-subtree-split: 46d3de27ffbcaf60025f09d1cf04fcc7ee98658a
43 lines
1.2 KiB
Python
43 lines
1.2 KiB
Python
from SpiffWorkflow.bpmn.exceptions import WorkflowTaskExecException
|
|
|
|
from ...specs.Simple import Simple
|
|
|
|
from ...bpmn.specs.BpmnSpecMixin import BpmnSpecMixin
|
|
from ...util.deep_merge import DeepMerge
|
|
|
|
|
|
class BusinessRuleTask(Simple, BpmnSpecMixin):
|
|
"""
|
|
Task Spec for a bpmn:businessTask (DMB Decision Reference) node.
|
|
"""
|
|
|
|
def _on_trigger(self, my_task):
|
|
pass
|
|
|
|
def __init__(self, wf_spec, name, dmnEngine, **kwargs):
|
|
super().__init__(wf_spec, name, **kwargs)
|
|
|
|
self.dmnEngine = dmnEngine
|
|
self.resDict = None
|
|
|
|
@property
|
|
def spec_class(self):
|
|
return 'Business Rule Task'
|
|
|
|
def _on_complete_hook(self, my_task):
|
|
try:
|
|
my_task.data = DeepMerge.merge(my_task.data,
|
|
self.dmnEngine.result(my_task))
|
|
super(BusinessRuleTask, self)._on_complete_hook(my_task)
|
|
except Exception as e:
|
|
raise WorkflowTaskExecException(my_task, str(e))
|
|
|
|
def serialize(self, serializer):
|
|
return serializer.serialize_business_rule_task(self)
|
|
|
|
@classmethod
|
|
def deserialize(self, serializer, wf_spec, s_state):
|
|
return serializer.deserialize_business_rule_task(wf_spec, s_state)
|
|
|
|
|