forked from ProcessMaker/processmaker
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCatchSignalEventProcess.php
More file actions
99 lines (87 loc) · 3.23 KB
/
CatchSignalEventProcess.php
File metadata and controls
99 lines (87 loc) · 3.23 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
<?php
namespace ProcessMaker\Jobs;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use ProcessMaker\Managers\SignalManager;
use ProcessMaker\Models\Process;
use ProcessMaker\Models\ProcessRequest;
use ProcessMaker\Models\ProcessRequestToken;
use ProcessMaker\Repositories\BpmnDocument;
use ProcessMaker\Repositories\DefinitionsRepository;
class CatchSignalEventProcess implements ShouldQueue
{
use Dispatchable,
InteractsWithQueue,
Queueable;
public $payload_uid;
public $processId;
public $signalRef;
/**
* Create a new job instance.
*
* @return void
*/
public function __construct($processId, $signalRef, $payload)
{
$this->payload_uid = packTemporalData($payload);
$this->processId = $processId;
$this->signalRef = $signalRef;
}
public function handle()
{
$this->payload = unpackTemporalData($this->payload_uid);
$repository = new DefinitionsRepository;
$eventDefinition = $repository->createSignalEventDefinition();
$signal = $repository->createSignal();
$signal->setId($this->signalRef);
$eventDefinition->setPayload($signal);
$eventDefinition->setProperty('signalRef', $this->signalRef);
$version = Process::find($this->processId)->getLatestVersion();
$definitions = $version->getDefinitions(true, null, false);
$engine = $definitions->getEngine();
$engine->loadProcessDefinitions($definitions);
$engine->getEventDefinitionBus()->dispatchEventDefinition(
null,
$eventDefinition,
null
);
if ($this->payload) {
$catches = SignalManager::getSignalCatchEvents($this->signalRef, $definitions);
$processVariable = '';
foreach ($catches as $catch) {
$processVariable = $definitions->getStartEvent($catch['id'])->getBpmnElement()->getAttribute('pm:config');
}
if ($processVariable) {
foreach ($engine->getExecutionInstances() as $instance) {
$instance->getDataStore()->putData($processVariable, $this->payload);
}
} else {
foreach ($this->payload as $key => $value) {
foreach ($engine->getExecutionInstances() as $instance) {
$instance->getDataStore()->putData($key, $value);
}
}
}
}
$engine->runToNextState();
removeTemporalData($this->payload_uid);
}
/**
* Get event definition for the signal event
*
* @param BpmnDocument $definitions
*
* @return SignalEventDefinitionInterface
*/
private function getEventDefinitionBySignalRef(BpmnDocument $definitions)
{
$eventDefinitions = $definitions->findElementById($this->throwEvent)->getElementsByTagNameNS(BpmnDocument::BPMN_MODEL, 'signalEventDefinition');
foreach ($eventDefinitions as $node) {
if ($node->getAttribute('signalRef') === $this->signalRef) {
return $node->getBpmnElementInstance();
}
}
}
}