Issues (3210)

htdocs/modules/system/themes/default/default.php (2 issues)

1
<?php
2
/*
3
 You may not change or alter any portion of this comment or credits
4
 of supporting developers from this source code or any supporting source code
5
 which is considered copyrighted (c) material of the original comment or credit authors.
6
7
 This program is distributed in the hope that it will be useful,
8
 but WITHOUT ANY WARRANTY; without even the implied warranty of
9
 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
10
 */
11
12
xoops_load('gui', 'system');
13
14
/*
15
 * Xoops Cpanel default GUI class
16
 *
17
 * @copyright   (c) 2000-2025 XOOPS Project (https://xoops.org)
18
 * @license     GNU GPL 2.0 or later (https://www.gnu.org/licenses/gpl-2.0.html)
19
 * @package     system
20
 * @usbpackage  GUI
21
 * @since       2.4
22
 * @author      Mamba       <[email protected]>
23
 * @author      Mojtabajml  <[email protected]>
24
 * @author      Voltan      <[email protected]>
25
 * @author      BitC3R0     <[email protected]>
26
 * @author      trabis      <[email protected]>
27
 */
28
29
/**
30
 * Class XoopsGuiDefault
31
 */
32
class XoopsGuiDefault extends XoopsSystemGui
33
{
34
    /**
35
     *
36
     */
37
    public function __construct() {}
38
39
    /**
40
     * @return bool
41
     */
42
    public static function validate()
43
    {
44
        return true;
45
    }
46
47
    public function header()
48
    {
49
        parent::header();
50
51
        global $xoopsConfig, $xoopsUser, $xoopsModule, $xoTheme, $xoopsTpl, $xoopsDB;
52
        $tpl =& $this->template;
53
54
        include_once dirname(__DIR__) . '/ComposerInfo.php';
55
56
        $xoTheme->addScript('browse.php?Frameworks/jquery/jquery.js');
57
        $xoTheme->addScript(XOOPS_ADMINTHEME_URL . '/default/js/styleswitch.js');
58
        $xoTheme->addScript(XOOPS_ADMINTHEME_URL . '/default/js/formenu.js');
59
        $xoTheme->addScript(XOOPS_ADMINTHEME_URL . '/default/js/menu.js');
60
        $xoTheme->addScript(XOOPS_ADMINTHEME_URL . '/default/js/tooltip.js');
61
//        $xoTheme->addScript(XOOPS_ADMINTHEME_URL . '/default/js/tabs.jquery.tools.min.js');
62
        $xoTheme->addScript(XOOPS_ADMINTHEME_URL . '/default/js/tabs.js');
63
        $xoTheme->addScript(XOOPS_ADMINTHEME_URL . '/default/js/tabs.slideshow.js');
64
65
        $xoTheme->addStylesheet(XOOPS_ADMINTHEME_URL . '/default/css/style.css');
66
        $xoTheme->addStylesheet(XOOPS_ADMINTHEME_URL . '/default/css/dark.css', ['title' => 'dark', 'media' => 'screen']);
67
        $xoTheme->addStylesheet(XOOPS_ADMINTHEME_URL . '/default/css/silver.css', ['title' => 'silver', 'media' => 'screen']);
68
        $xoTheme->addStylesheet(XOOPS_ADMINTHEME_URL . '/default/css/orange.css', ['title' => 'orange', 'media' => 'screen']);
69
70
        $tpl->assign('lang_cp', _CPHOME);
71
        //start system overview
72
        //$tpl->assign('lang_xoops_version', XOOPS_VERSION);
73
        $tpl->assign('lang_php_version', PHP_VERSION);
74
        $tpl->assign('lang_smarty_version', $tpl::SMARTY_VERSION);
75
        $tpl->assign('lang_mysql_version', mysqli_get_server_info($xoopsDB->conn));
76
        $tpl->assign('lang_server_api', PHP_SAPI);
77
        $tpl->assign('lang_os_name', PHP_OS);
78
//        $tpl->assign('safe_mode', ini_get('safe_mode') ? 'On' : 'Off');
79
//        $tpl->assign('register_globals', ini_get('register_globals') ? 'On' : 'Off');
80
//        $tpl->assign('magic_quotes_gpc', ini_get('magic_quotes_gpc') ? 'On' : 'Off');
81
        $tpl->assign('allow_url_fopen', ini_get('allow_url_fopen') ? 'On' : 'Off');
82
        $tpl->assign('fsockopen', function_exists('fsockopen') ? 'On' : 'Off');
83
//        $tpl->assign('allow_call_time_pass_reference', ini_get('allow_call_time_pass_reference') ? 'On' : 'Off');
84
        $tpl->assign('post_max_size', ini_get('post_max_size'));
85
        $tpl->assign('max_input_time', ini_get('max_input_time'));
86
        $tpl->assign('output_buffering', ini_get('output_buffering'));
87
        $tpl->assign('max_execution_time', ini_get('max_execution_time'));
88
        $tpl->assign('memory_limit', ini_get('memory_limit'));
89
        $tpl->assign('file_uploads', ini_get('file_uploads') ? 'On' : 'Off');
90
        $tpl->assign('upload_max_filesize', ini_get('upload_max_filesize'));
91
        $tpl->assign('xoops_sitename', $xoopsConfig['sitename']);
92
93
        // COMPOSER PACKAGES VERSION INFO *******************
94
95
        ComposerInfo::getComposerInfo($tpl);
96
97
        // ADD MENU *****************************************
98
99
        //Add  CONTROL PANEL  Menu  items
100
        $menu                = [];
101
        $menu[0]['link']     = XOOPS_URL;
102
        $menu[0]['title']    = _YOURHOME;
103
        $menu[0]['absolute'] = 1;
104
        $menu[1]['link']     = XOOPS_URL . '/admin.php?xoopsorgnews=1';
105
        $menu[1]['title']    = _OXYGEN_NEWS;
106
        $menu[1]['absolute'] = 1;
107
        $menu[1]['icon']     = XOOPS_ADMINTHEME_URL . '/default/images/xoops.png';
108
        $menu[2]['link']     = XOOPS_URL . '/user.php?op=logout';
109
        $menu[2]['title']    = _LOGOUT;
110
        $menu[2]['absolute'] = 1;
111
        $menu[2]['icon']     = XOOPS_ADMINTHEME_URL . '/default/images/logout.png';
112
        $tpl->append('navitems', ['link' => XOOPS_URL . '/admin.php', 'text' => _CPHOME, 'menu' => $menu]);
113
114
        //add SYSTEM  Menu items
115
        include __DIR__ . '/menu.php';
116
        if (empty($xoopsModule) || 'system' === $xoopsModule->getVar('dirname', 'n')) {
117
            $modpath = XOOPS_URL . '/admin.php';
118
            $modname = _OXYGEN_SYSOPTIONS;
119
            $modid   = 1;
120
            $moddir  = 'system';
121
122
            $mod_options = $adminmenu;
0 ignored issues
show
Comprehensibility Best Practice introduced by
The variable $adminmenu seems to be never defined.
Loading history...
123
            foreach (array_keys($mod_options) as $item) {
124
                $mod_options[$item]['link'] = empty($mod_options[$item]['absolute']) ? XOOPS_URL . '/modules/' . $moddir . '/' . $mod_options[$item]['link'] : $mod_options[$item]['link'];
125
                $mod_options[$item]['icon'] = empty($mod_options[$item]['icon']) ? '' : XOOPS_ADMINTHEME_URL . '/default/' . $mod_options[$item]['icon'];
126
                unset($mod_options[$item]['icon_small']);
127
            }
128
        } else {
129
            $moddir  = $xoopsModule->getVar('dirname', 'n');
130
            $modpath = XOOPS_URL . '/modules/' . $moddir;
131
            $modname = $xoopsModule->getInfo('name') . '  (' . $xoopsModule->getInfo('version') . ')';
132
            $modid   = $xoopsModule->getVar('mid');
133
134
            $mod_options = $xoopsModule->getAdminMenu();
135
            foreach (array_keys($mod_options) as $item) {
136
                $mod_options[$item]['link'] = empty($mod_options[$item]['absolute']) ? XOOPS_URL . "/modules/{$moddir}/" . $mod_options[$item]['link'] : $mod_options[$item]['link'];
137
                //                $mod_options[$item]['icon'] = empty($mod_options[$item]['icon']) ? '' : XOOPS_URL . "/modules/{$moddir}/" . $mod_options[$item]['icon'];
138
                //mb for direct URL access to icons in modules Admin
139
                $mod_options[$item]['icon'] = empty($mod_options[$item]['icon']) ? '' : (filter_var($mod_options[$item]['icon'], FILTER_VALIDATE_URL) ? $mod_options[$item]['icon'] : (XOOPS_URL . "/modules/{$moddir}/" . $mod_options[$item]['icon']));
140
            }
141
        }
142
143
        $tpl->assign('mod_options', $mod_options);
144
        $tpl->assign('modpath', $modpath);
145
        $tpl->assign('modname', $modname);
146
        $tpl->assign('modid', $modid);
147
        $tpl->assign('moddir', $moddir);
148
149
        // add MODULES  Menu items
150
        /** @var XoopsModuleHandler $module_handler */
151
        $module_handler = xoops_getHandler('module');
152
        $criteria       = new CriteriaCompo();
153
        $criteria->add(new Criteria('hasadmin', 1));
154
        $criteria->add(new Criteria('isactive', 1));
155
        $criteria->setSort('mid');
156
        $mods = $module_handler->getObjects($criteria);
157
158
        $menu               = [];
159
        /** @var XoopsGroupPermHandler $moduleperm_handler */
160
        $moduleperm_handler = xoops_getHandler('groupperm');
161
        foreach ($mods as $mod) {
162
            $rtn        = [];
163
            $modOptions = [];                                                         //add for sub menus
164
            $sadmin     = $moduleperm_handler->checkRight('module_admin', $mod->getVar('mid'), $xoopsUser->getGroups());
165
            if ($sadmin) {
166
                $info = $mod->getInfo();
167
                if (!empty($info['adminindex'])) {
168
                    $rtn['link'] = XOOPS_URL . '/modules/' . $mod->getVar('dirname', 'n') . '/' . $info['adminindex'];
169
                } else {
170
                    $rtn['link'] = XOOPS_URL . '/modules/system/admin.php?fct=preferences&amp;op=showmod&amp;mod=' . $mod->getVar('mid');
171
                }
172
                $rtn['title']    = htmlspecialchars((string) $mod->name(), ENT_QUOTES | ENT_HTML5);
173
                $rtn['absolute'] = 1;
174
                $rtn['url']      = XOOPS_URL . '/modules/' . $mod->getVar('dirname', 'n') . '/'; //add for sub menus
175
                $modOptions      = $mod->getAdminMenu();                                        //add for sub menus
176
                $rtn['options']  = $modOptions;                                             //add for sub menus
177
178
                if (isset($info['icon']) && $info['icon'] !== '') {
179
                    $rtn['icon'] = XOOPS_URL . '/modules/' . $mod->getVar('dirname', 'n') . '/' . $info['icon'];
180
                }
181
                $menu[] = $rtn;
182
            }
183
        }
184
        $tpl->append('navitems', [
185
            'link' => XOOPS_URL . '/modules/system/admin.php?fct=modulesadmin',
186
            'text' => _AM_SYSTEM_MODULES,
187
            'dir'  => $mod->getVar('dirname', 'n'),
0 ignored issues
show
Comprehensibility Best Practice introduced by
The variable $mod seems to be defined by a foreach iteration on line 161. Are you sure the iterator is never empty, otherwise this variable is not defined?
Loading history...
188
            'menu' => $menu]);
189
190
        // add preferences menu
191
        $menu = [];
192
193
        $OPT   = [];
194
        $OPT[] = [
195
            'link'     => 'admin.php?fct=preferences&amp;op=show&amp;confcat_id=1',
196
            'title'    => _OXYGEN_GENERAL,
197
            'absolute' => 1,
198
            'icon'     => XOOPS_ADMINTHEME_URL . '/default/icons/prefs_small.png'];
199
        $OPT[] = [
200
            'link'     => 'admin.php?fct=preferences&amp;op=show&amp;confcat_id=2',
201
            'title'    => _OXYGEN_USERSETTINGS,
202
            'absolute' => 1,
203
            'icon'     => XOOPS_ADMINTHEME_URL . '/default/icons/prefs_small.png'];
204
        $OPT[] = [
205
            'link'     => 'admin.php?fct=preferences&amp;op=show&amp;confcat_id=3',
206
            'title'    => _OXYGEN_METAFOOTER,
207
            'absolute' => 1,
208
            'icon'     => XOOPS_ADMINTHEME_URL . '/default/icons/prefs_small.png'];
209
        $OPT[] = [
210
            'link'     => 'admin.php?fct=preferences&amp;op=show&amp;confcat_id=4',
211
            'title'    => _OXYGEN_CENSOR,
212
            'absolute' => 1,
213
            'icon'     => XOOPS_ADMINTHEME_URL . '/default/icons/prefs_small.png'];
214
        $OPT[] = [
215
            'link'     => 'admin.php?fct=preferences&amp;op=show&amp;confcat_id=5',
216
            'title'    => _OXYGEN_SEARCH,
217
            'absolute' => 1,
218
            'icon'     => XOOPS_ADMINTHEME_URL . '/default/icons/prefs_small.png'];
219
        $OPT[] = [
220
            'link'     => 'admin.php?fct=preferences&amp;op=show&amp;confcat_id=6',
221
            'title'    => _OXYGEN_MAILER,
222
            'absolute' => 1,
223
            'icon'     => XOOPS_ADMINTHEME_URL . '/default/icons/prefs_small.png'];
224
        $OPT[] = [
225
            'link'     => 'admin.php?fct=preferences&amp;op=show&amp;confcat_id=7',
226
            'title'    => _OXYGEN_AUTHENTICATION,
227
            'absolute' => 1,
228
            'icon'     => XOOPS_ADMINTHEME_URL . '/default/icons/prefs_small.png'];
229
        $OPT[] = [
230
            'link'     => 'admin.php?fct=preferences&amp;op=showmod&amp;mod=1',
231
            'title'    => _OXYGEN_MODULESETTINGS,
232
            'absolute' => 1,
233
            'icon'     => XOOPS_ADMINTHEME_URL . '/default/icons/prefs_small.png'];
234
235
        $menu[] = [
236
            'link'     => XOOPS_URL . '/modules/system/admin.php?fct=preferences',
237
            'title'    => _OXYGEN_SYSOPTIONS,
238
            'absolute' => 1,
239
            'url'      => XOOPS_URL . '/modules/system/',
240
            'options'  => $OPT];
241
242
        foreach ($mods as $mod) {
243
            $rtn    = [];
244
            $sadmin = $moduleperm_handler->checkRight('module_admin', $mod->getVar('mid'), $xoopsUser->getGroups());
245
            if ($sadmin && ($mod->getVar('hasnotification') || \is_array($mod->getInfo('config')) || \is_array($mod->getInfo('comments')))) {
246
                $rtn['link']     = XOOPS_URL . '/modules/system/admin.php?fct=preferences&amp;op=showmod&amp;mod=' . $mod->getVar('mid');
247
                $rtn['title']    = htmlspecialchars((string) $mod->name(), ENT_QUOTES | ENT_HTML5);
248
                $rtn['absolute'] = 1;
249
                $rtn['icon']     = XOOPS_ADMINTHEME_URL . '/gui/oxygen/icons/prefs_small.png';
250
                $menu[]          = $rtn;
251
            }
252
        }
253
        $tpl->append('navitems', [
254
            'link' => XOOPS_URL . '/modules/system/admin.php?fct=preferences',
255
            'text' => _OXYGEN_SITEPREF,
256
            'dir'  => $mod->getVar('dirname', 'n'),
257
            'menu' => $menu]);
258
259
        //add OPTIONS/Links Menu Items
260
        $menu   = [];
261
        $menu[] = [
262
            'link'     => 'https://xoops.org',
263
            'title'    => _OXYGEN_XOOPSPROJECT,
264
            'absolute' => 1];
265
        $menu[] = [
266
            'link'     => 'https://xoops.org',
267
            'title'    => _OXYGEN_WEBSITE,
268
            'absolute' => 1,
269
            'icon'     => XOOPS_ADMINTHEME_URL . '/default/images/xoops.png'];
270
        $menu[] = [
271
            'link'     => 'https://xoops.org/modules/repository/',
272
            'title'    => _OXYGEN_XOOPSMODULES,
273
            'absolute' => 1,
274
            'icon'     => XOOPS_ADMINTHEME_URL . '/default/images/xoops.png'];
275
        $menu[] = [
276
            'link'     => 'https://xoops.org/modules/extgallery/',
277
            'title'    => _OXYGEN_XOOPSTHEMES,
278
            'absolute' => 1,
279
            'icon'     => XOOPS_ADMINTHEME_URL . '/default/images/tweb.png'];
280
281
        $tpl->append('navitems', ['link' => XOOPS_URL . '/admin.php', 'text' => _OXYGEN_INTERESTSITES, 'menu' => $menu]);
282
283
        //add OPTIONS/links for local support
284
        if (file_exists($file = XOOPS_ADMINTHEME_PATH . '/default/language/' . $xoopsConfig['language'] . '/localsupport.php')) {
285
            $links = include XOOPS_ADMINTHEME_PATH . '/default/language/' . $xoopsConfig['language'] . '/localsupport.php';
286
            if (count($links) > 0) {
287
                $tpl->append('navitems', ['link' => XOOPS_URL . '/admin.php', 'text' => _OXYGEN_LOCALSUPPORT, 'menu' => $links]);
288
            }
289
        }
290
291
        if (is_object($xoopsModule) || !empty($_GET['xoopsorgnews'])) {
292
            if (is_object($xoopsModule) && file_exists($file = XOOPS_ROOT_PATH . '/modules/' . $xoopsModule->getVar('dirname') . '/' . $xoopsModule->getInfo('adminmenu'))) {
293
                include $file;
294
            }
295
296
            return null;
297
        }
298
299
        foreach ($mods as $mod) {
300
            $sadmin = $moduleperm_handler->checkRight('module_admin', $mod->getVar('mid'), $xoopsUser->getGroups());
301
            if ($sadmin) {
302
                $rtn  = [];
303
                $info = $mod->getInfo();
304
                if (!empty($info ['adminindex'])) {
305
                    $rtn ['link'] = XOOPS_URL . '/modules/' . $mod->getVar('dirname', 'n') . '/' . $info ['adminindex'];
306
                } else {
307
                    $rtn ['link'] = XOOPS_URL . '/modules/system/admin.php?fct=preferences&amp;op=showmod&amp;mod=' . $mod->getVar('mid');
308
                }
309
                $rtn ['title']       = htmlspecialchars((string) $mod->getVar('name'), ENT_QUOTES | ENT_HTML5);
310
                $rtn ['description'] = $mod->getInfo('description');
311
                $rtn ['absolute']    = 1;
312
                if (isset($info ['icon_big'])) {
313
                    $rtn ['icon'] = XOOPS_URL . '/modules/' . $mod->getVar('dirname', 'n') . '/' . $info ['icon_big'];
314
                } elseif (isset($info ['image'])) {
315
                    $rtn ['icon'] = XOOPS_URL . '/modules/' . $mod->getVar('dirname', 'n') . '/' . $info ['image'];
316
                }
317
318
                $tpl->append('modules', $rtn);
319
            }
320
        }
321
    }
322
323
}
324