Files
carpseeds.pl/wp-content/plugins/akeebabackupwp/app/Solo/Model/Json/Task/RemoveIncludedDB.php
2024-07-15 11:28:08 +02:00

78 lines
1.6 KiB
PHP

<?php
/**
* @package solo
* @copyright Copyright (c)2014-2019 Nicholas K. Dionysopoulos / Akeeba Ltd
* @license GNU GPL version 3 or later
*/
namespace Solo\Model\Json\Task;
use Akeeba\Engine\Platform;
use Solo\Application;
use Solo\Model\Json\TaskInterface;
use Solo\Model\Multidb;
/**
* Remove an extra database definition
*/
class RemoveIncludedDB implements TaskInterface
{
/**
* Return the JSON API task's name ("method" name). Remote clients will use it to call us.
*
* @return string
*/
public function getMethodName()
{
return 'removeIncludedDB';
}
/**
* Execute the JSON API task
*
* @param array $parameters The parameters to this task
*
* @return mixed
*
* @throws \RuntimeException In case of an error
*/
public function execute(array $parameters = array())
{
$filter = \Awf\Input\Filter::getInstance();
// Get the passed configuration values
$defConfig = array(
'profile' => 0,
'name' => '',
);
$defConfig = array_merge($defConfig, $parameters);
$profile = $filter->clean($defConfig['profile'], 'int');
$name = $filter->clean($defConfig['name'], 'string');
// We need a valid profile ID
if ($profile <= 0)
{
$profile = 1;
}
// We need a uuid
if (empty($name))
{
throw new \RuntimeException('The database name is required', 500);
}
$session = Application::getInstance()->getContainer()->segment;
$session->set('profile', $profile);
// Load the configuration
Platform::getInstance()->load_configuration($profile);
/** @var \Solo\Model\Multidb $model */
$model = new Multidb();
return $model->remove($name);
}
}