forked from ProcessMaker/processmaker
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathRunNayraScriptTask.php
More file actions
136 lines (122 loc) · 4.75 KB
/
RunNayraScriptTask.php
File metadata and controls
136 lines (122 loc) · 4.75 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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
<?php
namespace ProcessMaker\Jobs;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Queue\SerializesModels;
use Illuminate\Support\Facades\Log;
use ProcessMaker\Exception\ConfigurationException;
use ProcessMaker\Exception\ScriptException;
use ProcessMaker\Facades\WorkflowManager;
use ProcessMaker\Managers\DataManager;
use ProcessMaker\Models\ProcessRequestToken;
use ProcessMaker\Models\Script;
use ProcessMaker\Models\ScriptExecutor;
use ProcessMaker\Nayra\Contracts\Bpmn\ScriptTaskInterface;
use ProcessMaker\Nayra\Contracts\Bpmn\TokenInterface;
use Throwable;
/**
* This job runs a script task with custom language like nodejs
*/
class RunNayraScriptTask implements ShouldQueue
{
use Dispatchable,
InteractsWithQueue,
Queueable,
SerializesModels;
public $tokenId;
public $userId;
/**
* Create a new job instance.
*
* @param \ProcessMaker\Models\ProcessRequestToken $token
* @param array $data
*/
public function __construct(TokenInterface $token)
{
$this->tokenId = $token->getKey();
}
/**
* Execute the job.
*
* @return void
*/
public function handle()
{
// Get token
$token = ProcessRequestToken::find($this->tokenId);
$token->loadTokenProperties();
$instance = $token->processRequest;
$processModel = $token->process;
$instance->loadProcessRequestInstance();
$token->setInstance($instance);
$element = $token->getDefinition(true);
// Exit if the task was completed or closed
if (!$token || !$element) {
return;
}
$scriptRef = $element->getProperty('scriptRef');
$configuration = json_decode($element->getProperty('config'), true);
// Check to see if we've failed parsing. If so, let's convert to empty array.
if ($configuration === null) {
$configuration = [];
}
try {
if (empty($scriptRef)) {
$code = $element->getScript();
if (empty($code)) {
throw new ConfigurationException(__('No code or script assigned to ":name"', ['name' => $element->getName()]));
}
$language = Script::scriptFormat2Language($element->getProperty('scriptFormat', 'application/x-php'));
$script = new Script([
'code' => $code,
'language' => $language,
'run_as_user_id' => Script::defaultRunAsUser()->id,
'script_executor_id' => ScriptExecutor::initialExecutor($language)->id,
]);
} else {
$script = Script::find($scriptRef);
if (!$script) {
throw new ConfigurationException(__('Script ":id" not found', ['id' => $scriptRef]));
}
$script = $script->versionFor($instance);
}
$errorHandling = new ErrorHandling($element, $token);
$errorHandling->setDefaultsFromDataSourceConfig($configuration);
$dataManager = new DataManager();
$data = $dataManager->getData($token);
$response = $script->runScript($data, $configuration, $token->getId(), $errorHandling->timeout());
// Dispatch complete task action
WorkflowManager::completeTask($processModel, $instance, $token, $response['output']);
} catch (ConfigurationException $exception) {
$output = $exception->getMessageForData($token);
WorkflowManager::completeTask($processModel, $instance, $token, $output);
} catch (Throwable $exception) {
Log::error('Script failed: ' . $scriptRef . ' - ' . $exception->getMessage());
Log::error($exception->getTraceAsString());
WorkflowManager::taskFailed($instance, $token, $exception->getMessage());
}
}
/**
* When Job fails
*/
public function failed(Throwable $exception)
{
if (!$this->tokenId) {
Log::error('Script failed: ' . $exception->getMessage());
return;
}
Log::error('Script (#' . $this->tokenId . ') failed: ' . $exception->getMessage());
$token = ProcessRequestToken::find($this->tokenId);
if ($token) {
$element = $token->getBpmnDefinition();
$token->setStatus(ScriptTaskInterface::TOKEN_STATE_FAILING);
$error = $element->getRepository()->createError();
$error->setName($exception->getMessage());
$token->setProperty('error', $error);
Log::error($exception->getTraceAsString());
$token->save();
}
}
}