Provide statistics via endpoint and admin page
[MAILPOET-4673]
This commit is contained in:
@@ -9,6 +9,7 @@ use MailPoet\Automation\Engine\Data\Step;
|
|||||||
use MailPoet\Automation\Engine\Data\Workflow;
|
use MailPoet\Automation\Engine\Data\Workflow;
|
||||||
use MailPoet\Automation\Engine\Hooks;
|
use MailPoet\Automation\Engine\Hooks;
|
||||||
use MailPoet\Automation\Engine\Registry;
|
use MailPoet\Automation\Engine\Registry;
|
||||||
|
use MailPoet\Automation\Engine\Storage\WorkflowStatisticsStorage;
|
||||||
use MailPoet\Automation\Engine\Storage\WorkflowStorage;
|
use MailPoet\Automation\Engine\Storage\WorkflowStorage;
|
||||||
use MailPoet\Segments\SegmentsRepository;
|
use MailPoet\Segments\SegmentsRepository;
|
||||||
use MailPoet\WP\Functions as WPFunctions;
|
use MailPoet\WP\Functions as WPFunctions;
|
||||||
@@ -18,6 +19,9 @@ class AutomationEditor {
|
|||||||
/** @var WorkflowStorage */
|
/** @var WorkflowStorage */
|
||||||
private $workflowStorage;
|
private $workflowStorage;
|
||||||
|
|
||||||
|
/** @var WorkflowStatisticsStorage */
|
||||||
|
private $statisticsStorage;
|
||||||
|
|
||||||
/** @var PageRenderer */
|
/** @var PageRenderer */
|
||||||
private $pageRenderer;
|
private $pageRenderer;
|
||||||
|
|
||||||
@@ -32,12 +36,14 @@ class AutomationEditor {
|
|||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
WorkflowStorage $workflowStorage,
|
WorkflowStorage $workflowStorage,
|
||||||
|
WorkflowStatisticsStorage $statisticsStorage,
|
||||||
PageRenderer $pageRenderer,
|
PageRenderer $pageRenderer,
|
||||||
Registry $registry,
|
Registry $registry,
|
||||||
SegmentsRepository $segmentsRepository,
|
SegmentsRepository $segmentsRepository,
|
||||||
WPFunctions $wp
|
WPFunctions $wp
|
||||||
) {
|
) {
|
||||||
$this->workflowStorage = $workflowStorage;
|
$this->workflowStorage = $workflowStorage;
|
||||||
|
$this->statisticsStorage = $statisticsStorage;
|
||||||
$this->pageRenderer = $pageRenderer;
|
$this->pageRenderer = $pageRenderer;
|
||||||
$this->registry = $registry;
|
$this->registry = $registry;
|
||||||
$this->segmentsRepository = $segmentsRepository;
|
$this->segmentsRepository = $segmentsRepository;
|
||||||
@@ -102,6 +108,7 @@ class AutomationEditor {
|
|||||||
'status' => $workflow->getStatus(),
|
'status' => $workflow->getStatus(),
|
||||||
'created_at' => $workflow->getCreatedAt()->format(DateTimeImmutable::W3C),
|
'created_at' => $workflow->getCreatedAt()->format(DateTimeImmutable::W3C),
|
||||||
'updated_at' => $workflow->getUpdatedAt()->format(DateTimeImmutable::W3C),
|
'updated_at' => $workflow->getUpdatedAt()->format(DateTimeImmutable::W3C),
|
||||||
|
'stats' => $this->statisticsStorage->getWorkflowStats($workflow->getId())->toArray(),
|
||||||
'activated_at' => $workflow->getActivatedAt() ? $workflow->getActivatedAt()->format(DateTimeImmutable::W3C) : null,
|
'activated_at' => $workflow->getActivatedAt() ? $workflow->getActivatedAt()->format(DateTimeImmutable::W3C) : null,
|
||||||
'author' => [
|
'author' => [
|
||||||
'id' => $workflow->getAuthor()->ID,
|
'id' => $workflow->getAuthor()->ID,
|
||||||
|
@@ -7,6 +7,7 @@ use MailPoet\API\REST\Request;
|
|||||||
use MailPoet\API\REST\Response;
|
use MailPoet\API\REST\Response;
|
||||||
use MailPoet\Automation\Engine\API\Endpoint;
|
use MailPoet\Automation\Engine\API\Endpoint;
|
||||||
use MailPoet\Automation\Engine\Data\Workflow;
|
use MailPoet\Automation\Engine\Data\Workflow;
|
||||||
|
use MailPoet\Automation\Engine\Storage\WorkflowStatisticsStorage;
|
||||||
use MailPoet\Automation\Engine\Storage\WorkflowStorage;
|
use MailPoet\Automation\Engine\Storage\WorkflowStorage;
|
||||||
use MailPoet\Validator\Builder;
|
use MailPoet\Validator\Builder;
|
||||||
|
|
||||||
@@ -14,10 +15,15 @@ class WorkflowsGetEndpoint extends Endpoint {
|
|||||||
/** @var WorkflowStorage */
|
/** @var WorkflowStorage */
|
||||||
private $workflowStorage;
|
private $workflowStorage;
|
||||||
|
|
||||||
|
/** @var WorkflowStatisticsStorage */
|
||||||
|
private $statisticsStorage;
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
WorkflowStorage $workflowStorage
|
WorkflowStorage $workflowStorage,
|
||||||
|
WorkflowStatisticsStorage $statisticsStorage
|
||||||
) {
|
) {
|
||||||
$this->workflowStorage = $workflowStorage;
|
$this->workflowStorage = $workflowStorage;
|
||||||
|
$this->statisticsStorage = $statisticsStorage;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function handle(Request $request): Response {
|
public function handle(Request $request): Response {
|
||||||
@@ -41,6 +47,7 @@ class WorkflowsGetEndpoint extends Endpoint {
|
|||||||
'status' => $workflow->getStatus(),
|
'status' => $workflow->getStatus(),
|
||||||
'created_at' => $workflow->getCreatedAt()->format(DateTimeImmutable::W3C),
|
'created_at' => $workflow->getCreatedAt()->format(DateTimeImmutable::W3C),
|
||||||
'updated_at' => $workflow->getUpdatedAt()->format(DateTimeImmutable::W3C),
|
'updated_at' => $workflow->getUpdatedAt()->format(DateTimeImmutable::W3C),
|
||||||
|
'stats' => $this->statisticsStorage->getWorkflowStats($workflow->getId())->toArray(),
|
||||||
'activated_at' => $workflow->getActivatedAt() ? $workflow->getActivatedAt()->format(DateTimeImmutable::W3C) : null,
|
'activated_at' => $workflow->getActivatedAt() ? $workflow->getActivatedAt()->format(DateTimeImmutable::W3C) : null,
|
||||||
'author' => [
|
'author' => [
|
||||||
'id' => $workflow->getAuthor()->ID,
|
'id' => $workflow->getAuthor()->ID,
|
||||||
|
Reference in New Issue
Block a user