* @git Joomla Component Builder * @copyright Copyright (C) 2015 Vast Development Method. All rights reserved. * @license GNU General Public License version 2 or later; see LICENSE.txt */ // No direct access to this file defined('_JEXEC') or die('Restricted access'); use Joomla\CMS\Factory; use Joomla\CMS\Language\Text; use Joomla\CMS\MVC\Controller\AdminController; use Joomla\Utilities\ArrayHelper; use Joomla\CMS\Router\Route; use Joomla\CMS\Session\Session; use VDM\Joomla\Utilities\ArrayHelper as UtilitiesArrayHelper; use VDM\Joomla\Utilities\ObjectHelper; use VDM\Joomla\Componentbuilder\Fieldtype\Factory as FieldtypeFactory; use VDM\Joomla\Utilities\GetHelper; /** * Fieldtypes Admin Controller */ class ComponentbuilderControllerFieldtypes extends AdminController { /** * The prefix to use with controller messages. * * @var string * @since 1.6 */ protected $text_prefix = 'COM_COMPONENTBUILDER_FIELDTYPES'; /** * Method to get a model object, loading it if required. * * @param string $name The model name. Optional. * @param string $prefix The class prefix. Optional. * @param array $config Configuration array for model. Optional. * * @return JModelLegacy The model. * * @since 1.6 */ public function getModel($name = 'Fieldtype', $prefix = 'ComponentbuilderModel', $config = array('ignore_request' => true)) { return parent::getModel($name, $prefix, $config); } public function exportData() { // Check for request forgeries Session::checkToken() or die(Text::_('JINVALID_TOKEN')); // check if export is allowed for this user. $user = Factory::getUser(); if ($user->authorise('fieldtype.export', 'com_componentbuilder') && $user->authorise('core.export', 'com_componentbuilder')) { // Get the input $input = Factory::getApplication()->input; $pks = $input->post->get('cid', array(), 'array'); // Sanitize the input $pks = ArrayHelper::toInteger($pks); // Get the model $model = $this->getModel('Fieldtypes'); // get the data to export $data = $model->getExportData($pks); if (UtilitiesArrayHelper::check($data)) { // now set the data to the spreadsheet $date = Factory::getDate(); ComponentbuilderHelper::xls($data,'Fieldtypes_'.$date->format('jS_F_Y'),'Fieldtypes exported ('.$date->format('jS F, Y').')','fieldtypes'); } } // Redirect to the list screen with error. $message = Text::_('COM_COMPONENTBUILDER_EXPORT_FAILED'); $this->setRedirect(Route::_('index.php?option=com_componentbuilder&view=fieldtypes', false), $message, 'error'); return; } public function importData() { // Check for request forgeries Session::checkToken() or die(Text::_('JINVALID_TOKEN')); // check if import is allowed for this user. $user = Factory::getUser(); if ($user->authorise('fieldtype.import', 'com_componentbuilder') && $user->authorise('core.import', 'com_componentbuilder')) { // Get the import model $model = $this->getModel('Fieldtypes'); // get the headers to import $headers = $model->getExImPortHeaders(); if (ObjectHelper::check($headers)) { // Load headers to session. $session = Factory::getSession(); $headers = json_encode($headers); $session->set('fieldtype_VDM_IMPORTHEADERS', $headers); $session->set('backto_VDM_IMPORT', 'fieldtypes'); $session->set('dataType_VDM_IMPORTINTO', 'fieldtype'); // Redirect to import view. $message = Text::_('COM_COMPONENTBUILDER_IMPORT_SELECT_FILE_FOR_FIELDTYPES'); $this->setRedirect(Route::_('index.php?option=com_componentbuilder&view=import', false), $message); return; } } // Redirect to the list screen with error. $message = Text::_('COM_COMPONENTBUILDER_IMPORT_FAILED'); $this->setRedirect(Route::_('index.php?option=com_componentbuilder&view=fieldtypes', false), $message, 'error'); return; } /** * Initializes all remote Joomla Field Types and syncs them with the local database. * * This function performs several checks and operations: * 1. It verifies the authenticity of the request to prevent request forgery. * 2. It checks whether the current user has the necessary permissions to initialize the Joomla Field Types. * 3. If the user is authorized, it attempts to initialize the remote Joomla Field Types. * 4. Depending on the result of the initialization operation, it sets the appropriate success or error message. * 5. It redirects the user to a specified URL with the result message and status. * * @return bool True on successful initialization, false on failure. */ public function initPowers() { // Check for request forgeries Session::checkToken() or die(Text::_('JINVALID_TOKEN')); // check if user has the right $user = Factory::getUser(); // set default error message $message = '

' . Text::_('COM_COMPONENTBUILDER_PERMISSION_DENIED') . '

'; $message .= '

' . Text::_('COM_COMPONENTBUILDER_YOU_DO_NOT_HAVE_PERMISSION_TO_INITIALIZE_JOOMLA_FIELD_TYPES') . '

'; $status = 'error'; $success = false; if($user->authorise('fieldtype.init', 'com_componentbuilder')) { try { if (FieldtypeFactory::_('Joomla.Fieldtype.Remote.Get')->init()) { // set success message $message = '

' . Text::_('COM_COMPONENTBUILDER_SUCCESSFULLY_INITIALIZED_ALL_REMOTE_JOOMLA_POWERS') . '

'; $message .= '

' . Text::_('COM_COMPONENTBUILDER_THE_LOCAL_DATABASE_JOOMLA_FIELD_TYPES_HAS_SUCCESSFULLY_BEEN_SYNCED_WITH_THE_REMOTE_REPOSITORIES') . '

'; $status = 'success'; $success = true; } else { $message = '

' . Text::_('COM_COMPONENTBUILDER_INITIALIZATION_FAILED') . '

'; $message .= '

' . Text::_('COM_COMPONENTBUILDER_THE_INITIALIZATION_OF_THIS_JOOMLA_FIELD_TYPES_HAS_FAILED') . '

'; } } catch (\Exception $e) { $message = '

' . Text::_('COM_COMPONENTBUILDER_INITIALIZATION_FAILED') . '

'; $message .= '

' . \htmlspecialchars($e->getMessage()) . '

'; } } // set redirect $redirect_url = Route::_('index.php?option=com_componentbuilder&view=fieldtypes', $success); $this->setRedirect($redirect_url, $message, $status); return $success; } /** * Resets the selected Joomla Field Types. * * This function performs several checks and operations: * 1. It verifies the authenticity of the request to prevent request forgery. * 2. It retrieves the IDs of the selected powers from the user input. * 3. It sanitizes the input by converting the IDs to integers. * 4. It checks whether any powers have been selected. * 5. It checks whether the current user has the necessary permissions to reset the selected Joomla Field Types. * 6. If the user is authorized and powers are selected, it attempts to reset the selected Joomla Field Types. * 7. Depending on the result of the reset operation, it sets the appropriate success or error message. * 8. It redirects the user to a specified URL with the result message and status. * * @return bool True on successful reset, false on failure. */ public function resetPowers() { // Check for request forgeries Session::checkToken() or die(Text::_('JINVALID_TOKEN')); // get IDS of the selected powers $pks = $this->input->post->get('cid', [], 'array'); // Sanitize the input ArrayHelper::toInteger($pks); // check if there is any selections if ($pks === []) { // set error message $message = '

'.Text::_('COM_COMPONENTBUILDER_NO_SELECTION_DETECTED').'

'; $message .= '

'.Text::_('COM_COMPONENTBUILDER_PLEASE_FIRST_MAKE_A_SELECTION_FROM_THE_LIST').'

'; // set redirect $redirect_url = Route::_('index.php?option=com_componentbuilder&view=fieldtypes', false); $this->setRedirect($redirect_url, $message, 'error'); return false; } $status = 'error'; $success = false; // check if user has the right $user = Factory::getUser(); if($user->authorise('fieldtype.reset', 'com_componentbuilder')) { $guids = GetHelper::vars('fieldtype', $pks, 'id', 'guid'); try { if (FieldtypeFactory::_('Joomla.Fieldtype.Remote.Get')->reset($guids)) { // set success message $message = '

'.Text::_('COM_COMPONENTBUILDER_SUCCESS').'

'; $message .= '

'.Text::_('COM_COMPONENTBUILDER_THESE_JOOMLA_FIELD_TYPES_HAVE_SUCCESSFULLY_BEEN_RESET').'

'; $status = 'success'; $success = true; } else { $message = '

' . Text::_('COM_COMPONENTBUILDER_RESET_FAILED') . '

'; $message .= '

' . Text::_('COM_COMPONENTBUILDER_THE_RESET_OF_THESE_JOOMLA_FIELD_TYPES_HAS_FAILED') . '

'; } } catch (\Exception $e) { $message = '

' . Text::_('COM_COMPONENTBUILDER_RESET_FAILED') . '

'; $message .= '

' . \htmlspecialchars($e->getMessage()) . '

'; } // set redirect $redirect_url = Route::_('index.php?option=com_componentbuilder&view=fieldtypes', $success); $this->setRedirect($redirect_url, $message, $status); return $success; } // set redirect $redirect_url = Route::_('index.php?option=com_componentbuilder&view=fieldtypes', false); $this->setRedirect($redirect_url); return $success; } /** * Pushes the selected Joomla Field Types. * * This function performs several checks and operations: * 1. It verifies the authenticity of the request to prevent request forgery. * 2. It retrieves the IDs of the selected powers from the user input. * 3. It sanitizes the input by converting the IDs to integers. * 4. It checks whether any powers have been selected. * 5. It checks whether the current user has the necessary permissions to push the selected Joomla Field Types. * 6. If the user is authorized and powers are selected, it attempts to push the selected Joomla Field Types. * 7. Depending on the result of the push operation, it sets the appropriate success or error message. * 8. It redirects the user to a specified URL with the result message and status. * * @return bool True on successful push, false on failure. */ public function pushPowers() { // Check for request forgeries Session::checkToken() or die(Text::_('JINVALID_TOKEN')); // get IDS of the selected powers $pks = $this->input->post->get('cid', [], 'array'); // Sanitize the input ArrayHelper::toInteger($pks); // check if there is any selections if ($pks === []) { // set error message $message = '

'.Text::_('COM_COMPONENTBUILDER_NO_SELECTION_DETECTED').'

'; $message .= '

'.Text::_('COM_COMPONENTBUILDER_PLEASE_FIRST_MAKE_A_SELECTION_FROM_THE_LIST').'

'; // set redirect $redirect_url = Route::_('index.php?option=com_componentbuilder&view=fieldtypes', false); $this->setRedirect($redirect_url, $message, 'error'); return false; } $status = 'error'; $success = false; // check if user has the right $user = Factory::getUser(); if($user->authorise('fieldtype.push', 'com_componentbuilder')) { $guids = GetHelper::vars('fieldtype', $pks, 'id', 'guid'); try { if (FieldtypeFactory::_('Joomla.Fieldtype.Remote.Set')->items($guids)) { // set success message $message = '

'.Text::_('COM_COMPONENTBUILDER_SUCCESS').'

'; $message .= '

'.Text::_('COM_COMPONENTBUILDER_THESE_JOOMLA_FIELD_TYPES_HAVE_SUCCESSFULLY_BEEN_PUSHED').'

'; $status = 'success'; $success = true; } else { $message = '

' . Text::_('COM_COMPONENTBUILDER_PUSH_FAILED') . '

'; $message .= '

' . Text::_('COM_COMPONENTBUILDER_THE_PUSH_OF_THESE_JOOMLA_FIELD_TYPES_HAS_FAILED') . '

'; } } catch (\Exception $e) { $message = '

' . Text::_('COM_COMPONENTBUILDER_PUSH_FAILED') . '

'; $message .= '

' . \htmlspecialchars($e->getMessage()) . '

'; } // set redirect $redirect_url = Route::_('index.php?option=com_componentbuilder&view=fieldtypes', $success); $this->setRedirect($redirect_url, $message, $status); return $success; } // set redirect $redirect_url = Route::_('index.php?option=com_componentbuilder&view=fieldtypes', false); $this->setRedirect($redirect_url); return $success; } }