spiff-arena/SpiffWorkflow/dmn/specs/BusinessRuleTask.py
Dan cc1903387b Squashed 'SpiffWorkflow/' changes from 46f410a28..46d3de27f
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
2022-11-25 11:07:31 -05:00

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)