<?php /** * @package AkeebaBackup * @copyright Copyright (c)2006-2017 Nicholas K. Dionysopoulos / Akeeba Ltd * @license GNU General Public License version 3, or later */ namespace Akeeba\Backup\Site\Model\Json\Task; // Protect from unauthorized access defined('_JEXEC') or die(); use Akeeba\Backup\Site\Model\DatabaseFilters; use Akeeba\Engine\Platform; /** * Get the database entities along with their filtering status (typically for rendering a GUI) */ class GetDBEntities extends AbstractTask { /** * 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 = \JFilterInput::getInstance(); // Get the passed configuration values $defConfig = array( 'profile' => 0, 'root' => '[SITEDB]', ); $defConfig = array_merge($defConfig, $parameters); $profile = $filter->clean($defConfig['profile'], 'int'); $root = $filter->clean($defConfig['root'], 'string'); // We need a valid profile ID if ($profile <= 0) { $profile = 1; } // We need a root if (empty($root)) { throw new \RuntimeException('Unknown database root', 500); } $this->container->platform->setSessionVar('profile', $profile); // Load the configuration Platform::getInstance()->load_configuration($profile); /** @var DatabaseFilters $model */ $model = $this->container->factory->model('DatabaseFilters')->tmpInstance(); return $model->make_listing($root); } }