shell bypass 403
<?php
/**
* @package admintools
* @copyright Copyright (c)2010-2024 Nicholas K. Dionysopoulos / Akeeba Ltd
* @license GNU General Public License version 3, or later
*/
defined('_JEXEC') || die;
use Joomla\CMS\Factory;
use Joomla\CMS\HTML\HTMLHelper;
use Joomla\CMS\Language\Text;
use Joomla\CMS\Layout\LayoutHelper;
use Joomla\CMS\Router\Route;
use Joomla\CMS\Uri\Uri;
/** @var \Akeeba\Component\AdminTools\Administrator\View\Allowlists\HtmlView $this */
HTMLHelper::_('behavior.multiselect');
$app = Factory::getApplication();
$user = $app->getIdentity();
$userId = $user->get('id');
$listOrder = $this->escape($this->state->get('list.ordering'));
$listDirn = $this->escape($this->state->get('list.direction'));
$nullDate = Factory::getDbo()->getNullDate();
$hasCategoryFilter = !empty($this->getModel()->getState('filter.category_id'));
$saveOrder = $listOrder == 'ordering';
$baseUri = Uri::root();
if ($saveOrder && !empty($this->items))
{
$saveOrderingUrl = 'index.php?option=com_admintools&task=allowlists.saveOrderAjax&tmpl=component&' . $app->getFormToken() . '=1';
HTMLHelper::_('draggablelist.draggable');
}
$i = 0;
?>
<form action="<?= Route::_('index.php?option=com_admintools&view=allowlists'); ?>"
method="post" name="adminForm" id="adminForm">
<div class="row">
<div class="col-md-12">
<div id="j-main-container" class="j-main-container">
<?= LayoutHelper::render('joomla.searchtools.default', ['view' => $this]) ?>
<?php if ($this->tooMany): ?>
<div class="alert alert-warning text-dark">
<h3 class="alert-heading">
<span class="fa fa-exclamation-circle" aria-hidden="true"></span>
<?= Text::_('COM_ADMINTOOLS_ALLOWLIST_ERR_TOOMANY_TITLE'); ?>
</h3>
<p>
<?= Text::sprintf(
'COM_ADMINTOOLS_ALLOWLIST_ERR_TOOMANY_BODY',
'https://www.akeeba.com/documentation/admin-tools-joomla/waf-ip-allowlist.html#do-not-overdo-it-with-ip-allowlist'
); ?>
</p>
</div>
<?php endif; ?>
<?= $this->loadAnyTemplate('controlpanel/plugin_warning') ?>
<?php if (empty($this->items)) : ?>
<div class="alert alert-info">
<span class="icon-info-circle" aria-hidden="true"></span><span
class="visually-hidden"><?= Text::_('INFO'); ?></span>
<?= Text::_('JGLOBAL_NO_MATCHING_RESULTS'); ?>
</div>
<?php else : ?>
<table class="table" id="articleList">
<caption class="visually-hidden">
<?= Text::_('COM_ADMINTOOLS_ALLOWLISTS_TABLE_CAPTION'); ?>, <span
id="orderedBy"><?= Text::_('JGLOBAL_SORTED_BY'); ?> </span>, <span
id="filteredBy"><?= Text::_('JGLOBAL_FILTERED_BY'); ?></span>
</caption>
<thead>
<tr>
<td class="w-1 text-center">
<?= HTMLHelper::_('grid.checkall'); ?>
</td>
<th scope="col">
<?= HTMLHelper::_('searchtools.sort', 'COM_ADMINTOOLS_ALLOWLIST_LBL_IP', 'ip', $listDirn, $listOrder); ?>
</th>
<th scope="col">
<?= HTMLHelper::_('searchtools.sort', 'COM_ADMINTOOLS_ALLOWLIST_LBL_DESCRIPTION', 'description', $listDirn, $listOrder); ?>
</th>
<th scope="col" class="w-1 d-none d-md-table-cell">
<?= HTMLHelper::_('searchtools.sort', 'JGRID_HEADING_ID', 'id', $listDirn, $listOrder); ?>
</th>
</tr>
</thead>
<tbody>
<?php foreach ($this->items as $item) : ?>
<?php
$canEdit = $user->authorise('core.edit', 'com_admintools');
?>
<tr class="row<?= $i++ % 2; ?>">
<td class="text-center">
<?= HTMLHelper::_('grid.id', $i, $item->id, !(empty($item->checked_out_time) || ($item->checked_out_time === $nullDate)), 'cid', 'cb', $item->description); ?>
</td>
<td>
<?php if ($canEdit): ?>
<a href="<?= Route::_('index.php?option=com_admintools&task=allowlist.edit&id=' . (int) $item->id); ?>"
title="<?= Text::_('JACTION_EDIT'); ?>">
<code><?= $this->escape($item->ip); ?></code>
</a>
<?php else: ?>
<code><?= $this->escape($item->ip); ?></code>
<?php endif ?>
</td>
<td>
<?php if ($canEdit): ?>
<a href="<?= Route::_('index.php?option=com_admintools&task=allowlist.edit&id=' . (int) $item->id); ?>"
title="<?= Text::_('JACTION_EDIT'); ?>">
<?= $this->escape($item->description); ?>
</a>
<?php else: ?>
<?= $this->escape($item->description); ?>
<?php endif ?>
</td>
<td class="w-1 d-none d-md-table-cell">
<?= $item->id ?>
</td>
</tr>
<?php endforeach; ?>
</tbody>
</table>
<?php // Load the pagination. ?>
<?= $this->pagination->getListFooter(); ?>
<?php endif; ?>
<input type="hidden" name="task" value=""> <input type="hidden" name="boxchecked" value="0">
<?= HTMLHelper::_('form.token'); ?>
</div>
</div>
</div>
</form>