PATH:
home
/
sparklp6
/
public_html
/
sparklerfilters-org
/
administrator
/
components
/
com_akeeba
/
Model
<?php /** * @package akeebabackup * @copyright Copyright (c)2006-2021 Nicholas K. Dionysopoulos / Akeeba Ltd * @license GNU General Public License version 3, or later */ namespace Akeeba\Backup\Admin\Model; // Protect from unauthorized access defined('_JEXEC') || die(); use Akeeba\Engine\Factory; use FOF30\Model\Model; use Joomla\CMS\HTML\HTMLHelper; use Joomla\CMS\Language\Text; class Log extends Model { /** * Get an array with the names of all log files in this backup profile * * @return string[] */ public function getLogFiles() { $configuration = Factory::getConfiguration(); $outdir = $configuration->get('akeeba.basic.output_directory'); $files = Factory::getFileLister()->getFiles($outdir); $ret = []; if (!empty($files) && is_array($files)) { foreach ($files as $filename) { $baseName = basename($filename); $startsWithAkeeba = substr($baseName, 0, 7) == 'akeeba.'; $endsWithLog = substr($baseName, -4) == '.log'; $endsWithPhpLog = substr($baseName, -8) == '.log.php'; $isDefaultLog = $baseName == 'akeeba.log'; if ($startsWithAkeeba && ($endsWithLog || $endsWithPhpLog) && !$isDefaultLog) { /** * Extract the tag from the filename (akeeba.tag.log or akeeba.tag.log.php) * * We ignore the first seven characters ("akeeba.") and the last X characters, where X is 8 if the * log file name ends with .log.php or 4 if the log name ends with .log. */ $tag = substr($baseName, 7, -($endsWithPhpLog ? 8 : 4)); if (empty($tag)) { continue; } $parts = explode('.', $tag); $key = array_pop($parts); $key = str_replace('id', '', $key); $key = is_numeric($key) ? sprintf('%015u', $key) : $key; if (empty($parts)) { $key = str_repeat('0', 15) . '.' . $key; } else { $key .= '.' . implode('.', $parts); } $ret[$key] = $tag; } } } krsort($ret); return $ret; } /** * Gets the JHtml options list for selecting a log file * * @return array */ public function getLogList() { $origin = null; $options = []; $list = $this->getLogFiles(); if (!empty($list)) { $options[] = HTMLHelper::_('select.option', null, Text::_('COM_AKEEBA_LOG_CHOOSE_FILE_VALUE')); foreach ($list as $item) { $text = Text::_('COM_AKEEBA_BUADMIN_LABEL_ORIGIN_' . $item); if (strstr($item, '.') !== false) { [$origin, $backupId] = explode('.', $item, 2); $text = Text::_('COM_AKEEBA_BUADMIN_LABEL_ORIGIN_' . $origin) . ' (' . $backupId . ')'; } $options[] = HTMLHelper::_('select.option', $item, $text); } } return $options; } /** * Output the raw text log file to the standard output without the PHP die header * * @param bool $withHeader Should I include a header telling the user how to submit this file? * * @return void */ public function echoRawLog($withHeader = true) { $tag = $this->getState('tag', ''); $logFile = Factory::getLog()->getLogFilename($tag); if (!@is_file($logFile) && @file_exists(substr($logFile, 0, -4))) { /** * Transitional period: the log file akeeba.tag.log.php may not exist but the akeeba.tag.log does. This * addresses this transition. */ $logFile = substr($logFile, 0, -4); } if ($withHeader) { echo "WARNING: Do not copy and paste lines from this file!\r\n"; echo "You are supposed to ZIP and attach it in your support forum post.\r\n"; echo "If you fail to do so, we will be unable to provide efficient support.\r\n"; echo "\r\n"; echo "--- START OF RAW LOG --\r\n"; } // The at sign (silence operator) is necessary to prevent PHP showing a warning if the file doesn't exist or // isn't readable for any reason. $fp = @fopen($logFile, 'rt'); if ($fp === false) { if ($withHeader) { echo "--- END OF RAW LOG ---\r\n"; } return; } $firstLine = @fgets($fp); if (substr($firstLine, 0, 5) != '<' . '?' . 'php') { @fclose($fp); @readfile($logFile); } else { while (!feof($fp)) { echo rtrim(fgets($fp)) . "\r\n"; } @fclose($fp); } if ($withHeader) { echo "--- END OF RAW LOG ---\r\n"; } } }
[-] UsageStatistics.php
[edit]
[-] DatabaseFilters.php
[edit]
[-] SFTPBrowser.php
[edit]
[-] .htaccess
[edit]
[-] FileFilters.php
[edit]
[-] Browser.php
[edit]
[-] web.config
[edit]
[-] Log.php
[edit]
[-] Updates.php
[edit]
[-] Statistics.php
[edit]
[-] ControlPanel.php
[edit]
[-] Profiles.php
[edit]
[+]
Mixin
[-] FTPBrowser.php
[edit]
[+]
..
[-] Configuration.php
[edit]
[-] Backup.php
[edit]
[+]
Exceptions
[-] ConfigurationWizard.php
[edit]