78 lines
1.6 KiB
PHP
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);
|
|
}
|
|
}
|