Skip to content

FOUR-15871 Optimize Interstitial to Reduce Redundant Task Calls #6914

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 2 commits into from
Jun 6, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 11 additions & 0 deletions ProcessMaker/Events/ActivityAssigned.php
Original file line number Diff line number Diff line change
Expand Up @@ -60,4 +60,15 @@ public function getProcessRequestToken()
{
return $this->processRequestToken;
}

/**
* Get data
*/
public function getData(): array
{
return [
'payloadUrl' => $this->payloadUrl,
'element_type' => $this->processRequestToken->element_type,
];
}
}
12 changes: 11 additions & 1 deletion ProcessMaker/Events/ProcessUpdated.php
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
use Illuminate\Foundation\Events\Dispatchable;
use Illuminate\Queue\SerializesModels;
use ProcessMaker\Models\ProcessRequest;
use ProcessMaker\Nayra\Contracts\Bpmn\TokenInterface;

class ProcessUpdated implements ShouldBroadcastNow
{
Expand All @@ -17,19 +18,28 @@ class ProcessUpdated implements ShouldBroadcastNow

public $event;

public $tokenId;

public $elementType;

private $processRequest;

/**
* Create a new event instance.
*
* @return void
*/
public function __construct(ProcessRequest $processRequest, $event)
public function __construct(ProcessRequest $processRequest, $event, TokenInterface $token = null)
{
$this->payloadUrl = route('api.requests.show', ['request' => $processRequest->getKey()]);
$this->event = $event;

$this->processRequest = $processRequest;

if ($token) {
$this->tokenId = $token->getId();
$this->elementType = $token->element_type;
}
}

/**
Expand Down
38 changes: 37 additions & 1 deletion ProcessMaker/Jobs/ExecuteScript.php
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
use ProcessMaker\Events\ScriptResponseEvent;
use ProcessMaker\Models\Script;
use ProcessMaker\Models\User;
use ProcessMaker\Nayra\Managers\WorkflowManagerRabbitMq;
use Throwable;

class ExecuteScript implements ShouldQueue
Expand Down Expand Up @@ -62,7 +63,12 @@ public function __construct(ScriptInterface $script, User $current_user, $code,
*/
public function handle()
{
//throw new \Exception('This method must be overridden.');
$useNayraDocker = !empty(config('app.nayra_rest_api_host'));
$isPhp = strtolower($this->script->language) === 'php';
if ($isPhp && $useNayraDocker && $this->sync) {
return $this->handleNayraDocker();
}

try {
// Just set the code but do not save the object (preview only)
$this->script->code = $this->code;
Expand All @@ -82,6 +88,36 @@ public function handle()
}
}

/**
* Execute the script task using Nayra Docker.
*
* @return string|bool
*/
public function handleNayraDocker()
{
$engine = new WorkflowManagerRabbitMq();
$params = [
'name' => uniqid('script_', true),
'script' => $this->code,
'data' => $this->data,
'config' => $this->configuration,
'envVariables' => $engine->getEnvironmentVariables(),
];
$body = json_encode($params);
$url = config('app.nayra_rest_api_host') . '/run_script';
$ch = curl_init($url);
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'POST');
curl_setopt($ch, CURLOPT_POSTFIELDS, $body);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, [
'Content-Type: application/json',
'Content-Length: ' . strlen($body),
]);
$result = curl_exec($ch);
curl_close($ch);
return $result;
}

/**
* Send a response to the user interface
*
Expand Down
5 changes: 3 additions & 2 deletions ProcessMaker/Listeners/BpmnSubscriber.php
Original file line number Diff line number Diff line change
Expand Up @@ -126,8 +126,9 @@ public function onActivityActivated(ActivityActivatedEvent $event)
if ($token->user_id) {
$token->sendActivityActivatedNotifications();
}

event(new ActivityAssigned($event->token));
if ($event->token->element_type === 'task') {
event(new ActivityAssigned($event->token));
}
}

/**
Expand Down
2 changes: 1 addition & 1 deletion ProcessMaker/Managers/TaskSchedulerManager.php
Original file line number Diff line number Diff line change
Expand Up @@ -144,7 +144,7 @@ public function scheduleTasks()

$this->removeExpiredLocks();

$tasks = ScheduledTask::all();
$tasks = ScheduledTask::cursor();

foreach ($tasks as $task) {
try {
Expand Down
6 changes: 3 additions & 3 deletions ProcessMaker/Models/ProcessRequest.php
Original file line number Diff line number Diff line change
Expand Up @@ -888,11 +888,11 @@ public function getVersionDefinitions($forceParse = false, $engine = null)
*
* @param string $eventName
*/
public function notifyProcessUpdated($eventName)
public function notifyProcessUpdated($eventName, TokenInterface $token = null)
{
$event = new ProcessUpdated($this, $eventName);
$event = new ProcessUpdated($this, $eventName, $token);
if ($this->parentRequest) {
$this->parentRequest->notifyProcessUpdated($eventName);
$this->parentRequest->notifyProcessUpdated($eventName, $token);
}
event($event);
}
Expand Down
4 changes: 3 additions & 1 deletion ProcessMaker/Models/ProcessRequestToken.php
Original file line number Diff line number Diff line change
Expand Up @@ -1150,6 +1150,8 @@ public function reassign($toUserId, User $requestingUser)
// Send a notification to the user
$notification = new TaskReassignmentNotification($this);
$this->user->notify($notification);
event(new ActivityAssigned($this));
if ($this->element_type === 'task') {
event(new ActivityAssigned($this));
}
}
}
2 changes: 1 addition & 1 deletion ProcessMaker/Nayra/Managers/WorkflowManagerRabbitMq.php
Original file line number Diff line number Diff line change
Expand Up @@ -682,7 +682,7 @@ private function dispatchAction(array $action, $subject = null): void
*
* @return array
*/
private function getEnvironmentVariables()
public function getEnvironmentVariables()
{
$environmentVariables = [];
EnvironmentVariable::chunk(50, function ($variables) use (&$environmentVariables) {
Expand Down
8 changes: 4 additions & 4 deletions ProcessMaker/Repositories/TokenRepository.php
Original file line number Diff line number Diff line change
Expand Up @@ -154,7 +154,7 @@ public function persistActivityActivated(ActivityInterface $activity, TokenInter
$token->saveOrFail();
$token->setId($token->getKey());
$request = $token->getInstance();
$request->notifyProcessUpdated('ACTIVITY_ACTIVATED');
$request->notifyProcessUpdated('ACTIVITY_ACTIVATED', $token);
$this->instanceRepository->persistInstanceUpdated($token->getInstance());
}

Expand Down Expand Up @@ -192,7 +192,7 @@ public function persistStartEventTriggered(StartEventInterface $startEvent, Coll
$token->saveOrFail();
$token->setId($token->getKey());
$request = $token->getInstance();
$request->notifyProcessUpdated('START_EVENT_TRIGGERED');
$request->notifyProcessUpdated('START_EVENT_TRIGGERED', $token);
}

private function assignTaskUser(ActivityInterface $activity, TokenInterface $token, Instance $instance)
Expand Down Expand Up @@ -224,7 +224,7 @@ public function persistActivityException(ActivityInterface $activity, TokenInter
$token->save();
$token->setId($token->getKey());
$request = $token->getInstance();
$request->notifyProcessUpdated('ACTIVITY_EXCEPTION');
$request->notifyProcessUpdated('ACTIVITY_EXCEPTION', $token);
}

/**
Expand Down Expand Up @@ -258,7 +258,7 @@ public function persistActivityCompleted(ActivityInterface $activity, TokenInter
$token->save();
$token->setId($token->getKey());
$request = $token->getInstance();
$request->notifyProcessUpdated('ACTIVITY_COMPLETED');
$request->notifyProcessUpdated('ACTIVITY_COMPLETED', $token);
}

/**
Expand Down
4 changes: 3 additions & 1 deletion ProcessMaker/RollbackProcessRequest.php
Original file line number Diff line number Diff line change
Expand Up @@ -148,7 +148,9 @@ private function rollbackToTask()
if ($this->newTask->user_id) {
$this->newTask->sendActivityActivatedNotifications();
}
event(new ActivityAssigned($this->newTask));
if ($this->newTask->element_type === 'task') {
event(new ActivityAssigned($this->newTask));
}

$this->addComment();
}
Expand Down
2 changes: 2 additions & 0 deletions config/app.php
Original file line number Diff line number Diff line change
Expand Up @@ -99,6 +99,8 @@
env('APP_URL', 'http://localhost')
)
),
'nayra_rest_api_host' => env('NAYRA_REST_API_HOST', ''),
'screen_task_cache_time' => env('SCREEN_TASK_CACHE_TIME', 86400),

// Allows our script executors to ignore invalid SSL. This should only be set to false for development.
'api_ssl_verify' => env('API_SSL_VERIFY', 'true'),
Expand Down
Loading