forked from cleverage/processuibundle
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathProcessEventSubscriber.php
More file actions
91 lines (81 loc) · 3.42 KB
/
ProcessEventSubscriber.php
File metadata and controls
91 lines (81 loc) · 3.42 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
<?php
declare(strict_types=1);
/*
* This file is part of the CleverAge/UiProcessBundle package.
*
* Copyright (c) Clever-Age
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace CleverAge\UiProcessBundle\EventSubscriber;
use CleverAge\ProcessBundle\Event\ProcessEvent;
use CleverAge\UiProcessBundle\Entity\Enum\ProcessExecutionStatus;
use CleverAge\UiProcessBundle\Entity\ProcessExecution;
use CleverAge\UiProcessBundle\Manager\ProcessExecutionManager;
use CleverAge\UiProcessBundle\Monolog\Handler\DoctrineProcessHandler;
use CleverAge\UiProcessBundle\Monolog\Handler\ProcessHandler;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
use Symfony\Component\Uid\Uuid;
/**
* PHP 8.2 : Replace by readonly class.
*/
final class ProcessEventSubscriber implements EventSubscriberInterface
{
public function __construct(
private readonly ProcessHandler $processHandler,
private readonly DoctrineProcessHandler $doctrineProcessHandler,
private readonly ProcessExecutionManager $processExecutionManager,
) {
}
public function onProcessStart(ProcessEvent $event): void
{
if (false === $this->processHandler->hasFilename()) {
$this->processHandler->setFilename(\sprintf('%s/%s.log', $event->getProcessCode(), Uuid::v4()));
}
if (!$this->processExecutionManager->getCurrentProcessExecution() instanceof ProcessExecution) {
$processExecution = new ProcessExecution(
$event->getProcessCode(),
basename((string) $this->processHandler->getFilename()),
$event->getProcessContext()
);
$this->processExecutionManager->setCurrentProcessExecution($processExecution)->save();
}
}
public function success(ProcessEvent $event): void
{
if ($event->getProcessCode() === $this->processExecutionManager->getCurrentProcessExecution()?->getCode()) {
$this->processExecutionManager->getCurrentProcessExecution()->setStatus(ProcessExecutionStatus::Finish);
$this->processExecutionManager->getCurrentProcessExecution()->end();
$this->processExecutionManager->save()->unsetProcessExecution($event->getProcessCode());
$this->processHandler->close();
}
}
public function fail(ProcessEvent $event): void
{
if ($event->getProcessCode() === $this->processExecutionManager->getCurrentProcessExecution()?->getCode()) {
$this->processExecutionManager->getCurrentProcessExecution()->setStatus(ProcessExecutionStatus::Failed);
$this->processExecutionManager->getCurrentProcessExecution()->end();
$this->processExecutionManager->save()->unsetProcessExecution($event->getProcessCode());
$this->processHandler->close();
}
}
public function flushDoctrineLogs(ProcessEvent $event): void
{
$this->doctrineProcessHandler->flush();
}
public static function getSubscribedEvents(): array
{
return [
ProcessEvent::EVENT_PROCESS_STARTED => 'onProcessStart',
ProcessEvent::EVENT_PROCESS_ENDED => [
['flushDoctrineLogs', 100],
['success', 100],
],
ProcessEvent::EVENT_PROCESS_FAILED => [
['flushDoctrineLogs', 100],
['fail', 100],
],
];
}
}