* @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\Application\CMSApplication; use Joomla\CMS\Plugin\CMSPlugin; use Joomla\Registry\Registry; use Joomla\CMS\Form\Form; JLoader::register('ComponentbuilderHelper', JPATH_ADMINISTRATOR . '/components/com_componentbuilder/helpers/componentbuilder.php'); /** * Content - Componentbuilder Privacy Tabs plugin. * * @package ComponentbuilderPrivacyTabs * @since 1.0.1 */ class PlgContentComponentbuilderPrivacyTabs extends CMSPlugin { /** * Affects constructor behavior. If true, language files will be loaded automatically. * * @var boolean * @since 1.0 */ protected $autoloadLanguage = true; /** * Runs on content preparation of form. * * @param JForm $form The form * @param stdClass $data The data * * @return boolean * * @since 1.0 */ public function onContentPrepareForm(Form $form, $data) { $context = $form->getName(); // When this is componentbuilder admin view if (strpos($context, 'com_componentbuilder.admin_view') === 0) { // Add the forms path Form::addFormPath(__DIR__ . '/forms'); // add the admin view params for privacy integration $form->loadFile('admin_view'); // if the global plugin is not set, allow it to be set from the admin view if (($plugin = $this->params->get('plugin', 0)) == 0) { $form->loadFile('config'); // make the plugin field required (LATER when we can give more info) //$form->setFieldAttribute('plugin', 'required', true, 'params.privacy'); //$form->setFieldAttribute('plugin', 'showon', 'activate:1', 'params.privacy'); //$form->setFieldAttribute('note_select_privacy_plugin', 'showon', 'activate:1', 'params.privacy'); } // update all editors to use this components global editor $global_editor = JComponentHelper::getParams('com_componentbuilder')->get('editor', 'none'); // set the field editor value (with none as fallback) $form->setFieldAttribute('custom_link', 'editor', $global_editor . '|none', 'params.privacy'); } return true; } /** * This is an event that is called right before the content * is saved into the database. * * @param string $context The context of the content passed to the plugin (added in 1.6). * @param object $article A JTableContent object. * @param bool $isNew If the content is just about to be created. * * @return void. * * @since 1.0 */ public function onContentBeforeSave($context, $item, $isNew, $data = array()) { // When this is componentbuilder admin view if ('com_componentbuilder.admin_view' === $context) { // check if this is json if (ComponentbuilderHelper::checkJson($item->params)) { // Convert the params field to an array. $registry = new Registry; $registry->loadString($item->params); $item->params = $registry->toArray(); } // check if the plugin was set if (isset($item->params['plugin']) && $item->params['plugin'] > 0) { // first set new params $this->params->set('plugin', (int) $item->params['plugin']); // update the global plugin settings $extensionTable = new JtableExtension(JFactory::getDbo()); $extensionTable->load(array('element' => 'componentbuilderprivacytabs')); // Save the change $extensionTable->set('params', $this->params->toString()); $extensionTable->save((array) $extensionTable); // and remove the value from the params unset($item->params['plugin']); // clear the plugin cache $this->cleanCache('com_plugins', 0); $this->cleanCache('com_plugins', 1); } // check if this is an array if (ComponentbuilderHelper::checkArray($item->params)) { // Convert the params field to a string. $params = new JRegistry; $params->loadArray($item->params); $item->params = (string) $params; } } } /** * Clean the cache * * @param string $group The cache group * @param integer $client_id The ID of the client * * @return void * * @since 3.0 */ protected function cleanCache($group = null, $client_id = 0) { $conf = \JFactory::getConfig(); $options = array( 'defaultgroup' => $group ?: (isset($this->option) ? $this->option : \JFactory::getApplication()->input->get('option')), 'cachebase' => $client_id ? JPATH_ADMINISTRATOR . '/cache' : $conf->get('cache_path', JPATH_SITE . '/cache'), 'result' => true, ); try { /** @var \JCacheControllerCallback $cache */ $cache = \JCache::getInstance('callback', $options); $cache->clean(); } catch (\JCacheException $exception) { $options['result'] = false; } // Trigger the onContentCleanCache event. \JEventDispatcher::getInstance()->trigger('onContentCleanCache', $options); } }