Files
espocrm/application/Espo/Core/Upgrades/ActionManager.php
Taras Machyshyn 6f676c8a2f 2023 year
2023-01-03 16:01:43 +02:00

177 lines
4.3 KiB
PHP

<?php
/************************************************************************
* This file is part of EspoCRM.
*
* EspoCRM - Open Source CRM application.
* Copyright (C) 2014-2023 Yurii Kuznietsov, Taras Machyshyn, Oleksii Avramenko
* Website: https://www.espocrm.com
*
* EspoCRM is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* EspoCRM is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with EspoCRM. If not, see http://www.gnu.org/licenses/.
*
* The interactive user interfaces in modified source and object code versions
* of this program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU General Public License version 3.
*
* In accordance with Section 7(b) of the GNU General Public License version 3,
* these Appropriate Legal Notices must retain the display of the "EspoCRM" word.
************************************************************************/
namespace Espo\Core\Upgrades;
use Espo\Core\Exceptions\Error;
class ActionManager
{
/**
* @var string
*/
private $managerName;
/**
* @var \Espo\Core\Container
*/
private $container;
/**
* @var array<string,array<string,\Espo\Core\Upgrades\Actions\Base>>
*/
private $objects;
/**
* @var ?string
*/
protected $currentAction;
/**
* @var array<string,mixed>
*/
protected $params;
/**
* @param string $managerName
* @param \Espo\Core\Container $container
* @param array<string,mixed> $params
*/
public function __construct($managerName, $container, $params)
{
$this->managerName = $managerName;
$this->container = $container;
$params['name'] = $managerName;
$this->params = $params;
}
/**
* @return string
*/
protected function getManagerName()
{
return $this->managerName;
}
/**
* @return \Espo\Core\Container
*/
protected function getContainer()
{
return $this->container;
}
/**
* @param string $action
* @return void
*/
public function setAction($action)
{
$this->currentAction = $action;
}
/**
* @return string
*/
public function getAction()
{
assert($this->currentAction !== null);
return $this->currentAction;
}
/**
* @return array<string,mixed>
*/
public function getParams()
{
return $this->params;
}
/**
* @param mixed $data
* @return mixed
* @throws Error
*/
public function run($data)
{
$object = $this->getObject();
return $object->run($data);
}
/**
* @param string $actionName
* @return \Espo\Core\Upgrades\Actions\Base
* @throws Error
*/
public function getActionClass($actionName)
{
return $this->getObject($actionName);
}
/**
* @return array<string,mixed>
* @throws Error
*/
public function getManifest()
{
return $this->getObject()->getManifest();
}
/**
* @param ?string $actionName
* @return \Espo\Core\Upgrades\Actions\Base
* @throws Error
*/
protected function getObject($actionName = null)
{
$managerName = $this->getManagerName();
if (!$actionName) {
$actionName = $this->getAction();
}
if (!isset($this->objects[$managerName][$actionName])) {
$class = '\Espo\Core\Upgrades\Actions\\' . ucfirst($managerName) . '\\' . ucfirst($actionName);
if (!class_exists($class)) {
throw new Error('Could not find an action ['.ucfirst($actionName).'], class ['.$class.'].');
}
/** @var class-string<\Espo\Core\Upgrades\Actions\Base> $class */
$this->objects[$managerName][$actionName] = new $class($this->container, $this);
}
return $this->objects[$managerName][$actionName];
}
}