mambax7 /
newbb5
This project does not seem to handle request data directly as such no vulnerable execution paths were found.
include, or for example
via PHP's auto-loading mechanism.
| 1 | <?php |
||||
| 2 | // |
||||
| 3 | // ------------------------------------------------------------------------ // |
||||
| 4 | // XOOPS - PHP Content Management System // |
||||
| 5 | // Copyright (c) 2000-2020 XOOPS.org // |
||||
| 6 | // <https://xoops.org> // |
||||
| 7 | // ------------------------------------------------------------------------ // |
||||
| 8 | // This program is free software; you can redistribute it and/or modify // |
||||
| 9 | // it under the terms of the GNU General Public License as published by // |
||||
| 10 | // the Free Software Foundation; either version 2 of the License, or // |
||||
| 11 | // (at your option) any later version. // |
||||
| 12 | // // |
||||
| 13 | // You may not change or alter any portion of this comment or credits // |
||||
| 14 | // of supporting developers from this source code or any supporting // |
||||
| 15 | // source code which is considered copyrighted (c) material of the // |
||||
| 16 | // original comment or credit authors. // |
||||
| 17 | // // |
||||
| 18 | // This program is distributed in the hope that it will be useful, // |
||||
| 19 | // but WITHOUT ANY WARRANTY; without even the implied warranty of // |
||||
| 20 | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // |
||||
| 21 | // GNU General Public License for more details. // |
||||
| 22 | // // |
||||
| 23 | // You should have received a copy of the GNU General Public License // |
||||
| 24 | // along with this program; if not, write to the Free Software // |
||||
| 25 | // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // |
||||
| 26 | // ------------------------------------------------------------------------ // |
||||
| 27 | // Author: Kazumi Ono (AKA onokazu) // |
||||
| 28 | // URL: http://www.myweb.ne.jp/, https://xoops.org/, http://jp.xoops.org/ // |
||||
| 29 | // Project: XOOPS Project // |
||||
| 30 | // ------------------------------------------------------------------------- // |
||||
| 31 | |||||
| 32 | use XoopsModules\Newbb; |
||||
| 33 | |||||
| 34 | require_once __DIR__ . '/admin_header.php'; |
||||
| 35 | //require_once dirname(__DIR__) . '/class/Utility.php'; |
||||
| 36 | require_once dirname(__DIR__) . '/include/functions.stats.php'; |
||||
| 37 | |||||
| 38 | $attach_path = $GLOBALS['xoops']->path($GLOBALS['xoopsModuleConfig']['dir_attachments'] . '/'); |
||||
| 39 | $thumb_path = $attach_path . 'thumbs/'; |
||||
| 40 | $folder = [$attach_path, $thumb_path]; |
||||
| 41 | |||||
| 42 | /** @var Xmf\Module\Admin $adminObject */ |
||||
| 43 | $adminObject = Xmf\Module\Admin::getInstance(); |
||||
| 44 | |||||
| 45 | /** |
||||
| 46 | * @param $target |
||||
| 47 | * @param int $mode |
||||
| 48 | * @return bool |
||||
| 49 | */ |
||||
| 50 | function newbb_admin_mkdir($target, $mode = 0777) |
||||
| 51 | { |
||||
| 52 | $target = str_replace('..', '', $target); |
||||
| 53 | |||||
| 54 | // http://www.php.net/manual/en/function.mkdir.php |
||||
| 55 | return is_dir($target) || (newbb_admin_mkdir(dirname($target), $mode) && (!mkdir($target, $mode) && !is_dir($target))); |
||||
| 56 | } |
||||
| 57 | |||||
| 58 | /** |
||||
| 59 | * @param $target |
||||
| 60 | * @param int $mode |
||||
| 61 | * @return bool |
||||
| 62 | */ |
||||
| 63 | function newbb_admin_chmod($target, $mode = 0777) |
||||
| 64 | { |
||||
| 65 | $target = str_replace('..', '', $target); |
||||
| 66 | |||||
| 67 | return @chmod($target, $mode); |
||||
| 68 | } |
||||
| 69 | |||||
| 70 | /** |
||||
| 71 | * @return array |
||||
| 72 | */ |
||||
| 73 | function newbb_getImageLibs() |
||||
| 74 | { |
||||
| 75 | $imageLibs = []; |
||||
| 76 | unset($output, $status); |
||||
|
0 ignored issues
–
show
Comprehensibility
Best Practice
introduced
by
Loading history...
Comprehensibility
Best Practice
introduced
by
|
|||||
| 77 | if (1 == $GLOBALS['xoopsModuleConfig']['image_lib'] || 0 == $GLOBALS['xoopsModuleConfig']['image_lib']) { |
||||
| 78 | $path = empty($GLOBALS['xoopsModuleConfig']['path_magick']) ? '' : $GLOBALS['xoopsModuleConfig']['path_magick'] . '/'; |
||||
| 79 | @exec($path . 'convert -version', $output, $status); |
||||
|
0 ignored issues
–
show
It seems like you do not handle an error condition for
exec(). This can introduce security issues, and is generally not recommended.
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
If you suppress an error, we recommend checking for the error condition explicitly: // For example instead of
@mkdir($dir);
// Better use
if (@mkdir($dir) === false) {
throw new \RuntimeException('The directory '.$dir.' could not be created.');
}
Loading history...
|
|||||
| 80 | if (empty($status) && !empty($output) && preg_match("/imagemagick[ \t]+([0-9\.]+)/i", $output[0], $matches)) { |
||||
| 81 | $imageLibs['imagemagick'] = $matches[0]; |
||||
| 82 | } |
||||
| 83 | |||||
| 84 | unset($output, $status); |
||||
| 85 | } |
||||
| 86 | if (2 == $GLOBALS['xoopsModuleConfig']['image_lib'] || 0 == $GLOBALS['xoopsModuleConfig']['image_lib']) { |
||||
| 87 | $path = empty($GLOBALS['xoopsModuleConfig']['path_netpbm']) ? '' : $GLOBALS['xoopsModuleConfig']['path_netpbm'] . '/'; |
||||
| 88 | @exec($path . 'jpegtopnm -version 2>&1', $output, $status); |
||||
| 89 | if (empty($status) && !empty($output) && preg_match("/netpbm[ \t]+([0-9\.]+)/i", $output[0], $matches)) { |
||||
| 90 | $imageLibs['netpbm'] = $matches[0]; |
||||
| 91 | } |
||||
| 92 | unset($output, $status); |
||||
| 93 | } |
||||
| 94 | |||||
| 95 | if (function_exists('gd_info')) { |
||||
| 96 | $tmpInfo = gd_info(); |
||||
| 97 | $imageLibs['gd'] = $tmpInfo['GD Version']; |
||||
| 98 | } |
||||
| 99 | |||||
| 100 | return $imageLibs; |
||||
| 101 | } |
||||
| 102 | |||||
| 103 | xoops_cp_header(); |
||||
| 104 | |||||
| 105 | $imageLibs = newbb_getImageLibs(); |
||||
| 106 | /** @var \XoopsModuleHandler $moduleHandler */ |
||||
| 107 | $moduleHandler = xoops_getHandler('module'); |
||||
| 108 | ///** @var Newbb\ReportHandler $reportHandler */ |
||||
| 109 | //$reportHandler = \XoopsModules\Newbb\Helper::getInstance()->getHandler('Report'); |
||||
| 110 | |||||
| 111 | $isOK = false; |
||||
| 112 | // START irmtfan add a poll_module config |
||||
| 113 | //XOOPS_POLL |
||||
| 114 | $xoopspoll = $moduleHandler->getByDirname($GLOBALS['xoopsModuleConfig']['poll_module']); |
||||
| 115 | if (is_object($xoopspoll)) { |
||||
| 116 | $isOK = $xoopspoll->getVar('isactive'); |
||||
| 117 | } |
||||
| 118 | // END irmtfan add a poll_module config |
||||
| 119 | |||||
| 120 | $memlimit_iniphp = return_bytes(@ini_get('memory_limit')); |
||||
| 121 | $postmaxsize_iniphp = return_bytes(@ini_get('post_max_size')); |
||||
| 122 | $uploadlimit = _AM_NEWBB_MEMLIMITTOLARGE; |
||||
| 123 | if ($postmaxsize_iniphp < $memlimit_iniphp) { |
||||
| 124 | $uploadlimit = sprintf(_AM_NEWBB_MEMLIMITOK, return_bytes($postmaxsize_iniphp, true)); |
||||
| 125 | } |
||||
| 126 | |||||
| 127 | $adminObject->addInfoBox(_AM_NEWBB_PREFERENCES); |
||||
| 128 | // START irmtfan better poll module display link and version - check if xoops poll module is available |
||||
| 129 | if ($isOK) { |
||||
| 130 | $pollLink = _AM_NEWBB_AVAILABLE . ': '; |
||||
| 131 | $pollLink .= '<a href="' . XOOPS_URL . '/modules/' . $xoopspoll->getVar('dirname') . '/admin/index.php"'; |
||||
| 132 | $pollLink .= ' alt="' . $xoopspoll->getVar('name') . ' ' . _VERSION . ' (' . $xoopspoll->getInfo('version') . ') "'; |
||||
| 133 | $pollLink .= ' title="' . $xoopspoll->getVar('name') . ' ' . _VERSION . ' (' . $xoopspoll->getInfo('version') . ') "'; |
||||
| 134 | $pollLink .= '>' . '(' . $xoopspoll->getVar('name') . ')</a>'; |
||||
| 135 | } else { |
||||
| 136 | $pollLink = _AM_NEWBB_NOTAVAILABLE; |
||||
| 137 | } |
||||
| 138 | $adminObject->addInfoBoxLine(sprintf(_AM_NEWBB_POLLMODULE . ': %s', $pollLink)); |
||||
| 139 | // END irmtfan better poll module display link and version - check if xoops poll module is available |
||||
| 140 | $adminObject->addInfoBoxLine(sprintf(_AM_NEWBB_IMAGEMAGICK . ' %s', array_key_exists('imagemagick', $imageLibs) ? _AM_NEWBB_AUTODETECTED . $imageLibs['imagemagick'] : _AM_NEWBB_NOTAVAILABLE)); |
||||
| 141 | $adminObject->addInfoBoxLine(sprintf('NetPBM' . ': %s', array_key_exists('netpbm', $imageLibs) ? _AM_NEWBB_AUTODETECTED . $imageLibs['netpbm'] : _AM_NEWBB_NOTAVAILABLE)); |
||||
| 142 | $adminObject->addInfoBoxLine(sprintf(_AM_NEWBB_GDLIB . ' %s', array_key_exists('gd', $imageLibs) ? _AM_NEWBB_AUTODETECTED . $imageLibs['gd'] : _AM_NEWBB_NOTAVAILABLE)); |
||||
| 143 | $adminObject->addInfoBoxLine(sprintf(_AM_NEWBB_UPLOAD . ' %s', $uploadlimit)); |
||||
| 144 | $adminObject->addInfoBoxLine(sprintf(_AM_NEWBB_INDEX_PDF_PAGE . '', '')); |
||||
| 145 | |||||
| 146 | $adminObject->addInfoBox(_AM_NEWBB_BOARDSUMMARY); |
||||
| 147 | $adminObject->addInfoBoxLine(sprintf(_AM_NEWBB_TOTALTOPICS . ': %s', getTotalTopics())); |
||||
| 148 | $adminObject->addInfoBoxLine(sprintf(_AM_NEWBB_TOTALPOSTS . ': %s', getTotalPosts())); |
||||
| 149 | $adminObject->addInfoBoxLine(sprintf(_AM_NEWBB_TOTALVIEWS . ': %s', getTotalViews())); |
||||
| 150 | |||||
| 151 | $adminObject->addInfoBox(_AM_NEWBB_REPORT); |
||||
| 152 | $adminObject->addInfoBoxLine(sprintf(_AM_NEWBB_REPORT_PENDING . ': %s', $reportHandler->getCount(new \Criteria('report_result', 0)))); |
||||
| 153 | $adminObject->addInfoBoxLine(sprintf(_AM_NEWBB_REPORT_PROCESSED . ': %s', $reportHandler->getCount(new \Criteria('report_result', 1)))); |
||||
| 154 | |||||
| 155 | $uploadFolders = $configurator->uploadFolders; |
||||
| 156 | foreach ($uploadFolders as $value) { |
||||
| 157 | Newbb\Utility::prepareFolder($value); |
||||
| 158 | $adminObject->addConfigBoxLine($value, 'folder'); |
||||
| 159 | } |
||||
| 160 | |||||
| 161 | $adminObject->displayNavigation(basename(__FILE__)); |
||||
| 162 | $adminObject->displayIndex(); |
||||
| 163 | |||||
| 164 | require_once __DIR__ . '/admin_footer.php'; |
||||
| 165 | |||||
| 166 | $cacheHelper = Newbb\Utility::cleanCache(); |
||||
| 167 | //$cacheHelper = new \Xmf\Module\Helper\Cache('newbb'); |
||||
| 168 | //$cacheHelper->delete('config'); |
||||
| 169 | //$cacheHelper->delete('permission'); |
||||
| 170 | |||||
| 171 | /** |
||||
| 172 | * @param $sizeAsString |
||||
| 173 | * @param bool $b |
||||
| 174 | * @return int|string |
||||
| 175 | */ |
||||
| 176 | function return_bytes($sizeAsString, $b = false) |
||||
| 177 | { |
||||
| 178 | if (false === $b) { |
||||
| 179 | switch (mb_substr($sizeAsString, -1)) { |
||||
| 180 | case 'M': |
||||
| 181 | case 'm': |
||||
| 182 | return (int)$sizeAsString * 1048576; |
||||
| 183 | case 'K': |
||||
| 184 | case 'k': |
||||
| 185 | return (int)$sizeAsString * 1024; |
||||
| 186 | case 'G': |
||||
| 187 | case 'g': |
||||
| 188 | return (int)$sizeAsString * 1073741824; |
||||
| 189 | default: |
||||
| 190 | return $sizeAsString; |
||||
| 191 | } |
||||
| 192 | } else { |
||||
| 193 | $base = log($sizeAsString) / log(1024); |
||||
| 194 | $suffix = ['', 'KB', 'MB', 'GB', 'TB']; |
||||
| 195 | |||||
| 196 | return round(pow(1024, $base - floor($base))) . ' ' . $suffix[(int)floor($base)]; |
||||
| 197 | } |
||||
| 198 | } |
||||
| 199 |