shell bypass 403
<?php /** * @package Conditions * @version 25.7.12430 * * @author Peter van Westen <[email protected]> * @link https://regularlabs.com * @copyright Copyright © 2025 Regular Labs All Rights Reserved * @license GNU General Public License version 2 or later */ namespace RegularLabs\Component\Conditions\Administrator\View\Items; use Joomla\CMS\Factory as JFactory; use Joomla\CMS\Form\Form as JForm; use Joomla\CMS\Helper\ContentHelper; use Joomla\CMS\Language\Text; use Joomla\CMS\MVC\View\GenericDataException; use Joomla\CMS\MVC\View\HtmlView as BaseHtmlView; use Joomla\CMS\Pagination\Pagination; use Joomla\CMS\Toolbar\Toolbar; use Joomla\CMS\Toolbar\ToolbarHelper; use Joomla\Registry\Registry; use RegularLabs\Library\Parameters as RL_Parameters; defined('_JEXEC') or die; /** * List View */ class HtmlView extends BaseHtmlView { /** * @var array */ public $activeFilters; /** * @var JForm */ public $filterForm; /** * @var boolean */ protected $collect_urls_enabled; /** * @var boolean */ protected $enabled; /** * @var array */ protected $items; /** * @var Pagination */ protected $pagination; /** * @var Registry */ protected $params; /** * @var object */ protected $state; /** * @param string $tpl The name of the template file to parse; automatically searches through the template paths. * * @return mixed False if unsuccessful, otherwise void. * * @throws GenericDataException */ public function display($tpl = null) { $this->items = $this->get('Items'); $this->pagination = $this->get('Pagination'); $this->state = $this->get('State'); $this->config = RL_Parameters::getComponent('conditions'); $this->filterForm = $this->get('FilterForm'); $this->activeFilters = $this->get('ActiveFilters'); $this->hasCategories = $this->get('HasCategories'); // Check for errors. if (count($errors = $this->get('Errors'))) { throw new GenericDataException(implode("\n", $errors), 500); } $this->addToolbar(); return parent::display($tpl); } /** * @return void */ protected function addToolbar() { $user = JFactory::getApplication()->getIdentity() ?: JFactory::getUser(); $canDo = ContentHelper::getActions('com_conditions'); $toolbar = Toolbar::getInstance('toolbar'); ToolbarHelper::title(Text::_('CONDITIONS') . ': ' . Text::_('RL_Items'), 'conditions icon-reglab'); if ($canDo->get('core.create')) { $toolbar->addNew('item.add'); } if ($canDo->get('core.edit.state') || $user->authorise('core.admin')) { $dropdown = $toolbar->dropdownButton('status-group') ->text('JTOOLBAR_CHANGE_STATUS') ->toggleSplit(false) ->icon('icon-ellipsis-h') ->buttonClass('btn btn-action') ->listCheck(true); $childBar = $dropdown->getChildToolbar(); if ( $canDo->get('core.edit.state') && $this->state->get('filter.state') !== '' && $this->state->get('filter.state') !== '1' ) { $childBar->publish('items.publish')->listCheck(true); } if ($canDo->get('core.edit.state') && $this->state->get('filter.state') !== '-2') { $childBar->trash('items.trash')->listCheck(true); } if ($canDo->get('core.delete') && $this->state->get('filter.state') === '-2') { $childBar->delete('items.delete')->listCheck(true); } if ($canDo->get('core.create')) { $childBar->standardButton('copy') ->text('JTOOLBAR_DUPLICATE') ->task('items.duplicate') ->listCheck(true); } if ($canDo->get('core.delete') && $this->state->get('filter.state') === '-2') { $toolbar->delete('items.delete') ->text('JTOOLBAR_EMPTY_TRASH') ->message('JGLOBAL_CONFIRM_DELETE') ->listCheck(true); } // if ($canDo->get('core.create')) // { // $childBar->standardButton('file-export') // ->text('RL_EXPORT') // ->task('items.export') // ->listCheck(true); // } } // if ($canDo->get('core.create')) // { // $toolbar->popupButton('file-import') // ->icon('icon-file-import') // ->text('RL_IMPORT') // ->selector('importModal'); // } if ($canDo->get('core.admin')) { $toolbar->preferences('com_conditions'); } } }