Source of file SecurityController.php
Size: 2,803 Bytes - Last Modified: 2020-10-24T02:46:31+00:00
/home/travis/build/NextDom/nextdom-core/src/Controller/Admin/SecurityController.php
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 | <?php /* This file is part of NextDom Software. * * NextDom is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * NextDom Software is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with NextDom Software. If not, see <http://www.gnu.org/licenses/>. * * @Support <https://www.nextdom.org> * @Email <admin@nextdom.org> * @Authors/Contributors: Sylvaner, Byackee, cyrilphoenix71, ColonelMoutarde, edgd1er, slobberbone, Astral0, DanoneKiD */ namespace NextDom\Controller\Admin; use NextDom\Controller\BaseController; use NextDom\Enums\ControllerData; use NextDom\Enums\DateFormat; use NextDom\Helpers\Render; use NextDom\Managers\CacheManager; use NextDom\Managers\ConfigManager; /** * Class SecurityController * @package NextDom\Controller\Admin */ class SecurityController extends BaseController { /** * Render security page * * @param array $pageData Page data * * @return string Content of security page * * @throws \Exception */ public static function get(&$pageData): string { $keys = ['security::bantime', 'ldap::enable']; $configs = ConfigManager::byKeys($keys); $pageData['adminUseLdap'] = function_exists('ldap_connect'); if ($pageData['adminUseLdap']) { $pageData['adminLdapEnabled'] = ConfigManager::byKey('ldap:enable'); } $pageData['adminBannedIp'] = []; $cache = CacheManager::byKey('security::banip'); $values = json_decode($cache->getValue('[]'), true); if (is_array($values) && count($values) > 0) { foreach ($values as $value) { $bannedData = []; $bannedData['ip'] = $value['ip']; $bannedData['startDate'] = date(DateFormat::FULL, $value['datetime']); if ($configs['security::bantime'] < 0) { $bannedData['endDate'] = __('Jamais'); } else { $bannedData['endDate'] = date(DateFormat::FULL, $value['datetime'] + $pageData['adminConfigs']['security::bantime']); } $pageData['adminBannedIp'][] = $bannedData; } } $pageData[ControllerData::JS_END_POOL][] = '/public/js/desktop/admin/security.js'; return Render::getInstance()->get('/desktop/admin/security.html.twig', $pageData); } } |