Skip to content

Commit 7ce32a2

Browse files
committed
Refactor: Extracted some common code as include_menu_dir_files() method in a new file named common.php.
1 parent 2d27353 commit 7ce32a2

File tree

3 files changed

+59
-21
lines changed

3 files changed

+59
-21
lines changed

interface/web/capp.php

Lines changed: 3 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -31,6 +31,8 @@
3131
require_once '../lib/config.inc.php';
3232
require_once '../lib/app.inc.php';
3333

34+
include_once 'common.php';
35+
3436
//* Import module variable
3537
$mod = $_REQUEST["mod"];
3638
//* If we click on a search result, load that one instead of the module's start page
@@ -55,17 +57,7 @@
5557
include_once $mod."/lib/module.conf.php";
5658

5759
$menu_dir = ISPC_WEB_PATH.'/'.$mod.'/lib/menu.d';
58-
59-
if (is_dir($menu_dir)) {
60-
if ($dh = opendir($menu_dir)) {
61-
//** Go through all files in the menu dir
62-
while (($file = readdir($dh)) !== false) {
63-
if ($file != '.' && $file != '..' && substr($file, -9, 9) == '.menu.php' && $file != 'dns_resync.menu.php') {
64-
include_once $menu_dir.'/'.$file;
65-
}
66-
}
67-
}
68-
}
60+
include_menu_dir_files($menu_dir);
6961

7062
$_SESSION["s"]["module"] = $module;
7163
session_write_close();

interface/web/common.php

Lines changed: 53 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,53 @@
1+
<?php
2+
3+
/*
4+
Copyright (c) 2007, Till Brehm, projektfarm Gmbh
5+
All rights reserved.
6+
7+
Redistribution and use in source and binary forms, with or without modification,
8+
are permitted provided that the following conditions are met:
9+
10+
* Redistributions of source code must retain the above copyright notice,
11+
this list of conditions and the following disclaimer.
12+
* Redistributions in binary form must reproduce the above copyright notice,
13+
this list of conditions and the following disclaimer in the documentation
14+
and/or other materials provided with the distribution.
15+
* Neither the name of ISPConfig nor the names of its contributors
16+
may be used to endorse or promote products derived from this software without
17+
specific prior written permission.
18+
19+
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
20+
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
21+
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
22+
IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
23+
INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
24+
BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25+
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
26+
OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
27+
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
28+
EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29+
*/
30+
31+
/*
32+
Some common helper functions which can be reused throughout the project.
33+
*/
34+
35+
/**
36+
* Includes all the menu files from the menu dir.
37+
* @param string $menu_dir Path to the menu dir
38+
* @return void
39+
*/
40+
function include_menu_dir_files($menu_dir)
41+
{
42+
if (is_dir($menu_dir)) {
43+
if ($dh = opendir($menu_dir)) {
44+
//** Go through all files in the menu dir
45+
while (($file = readdir($dh)) !== false) {
46+
if ($file != '.' && $file != '..' && substr($file, -9, 9) == '.menu.php' && $file != 'dns_resync.menu.php') {
47+
include_once $menu_dir.'/'.$file;
48+
}
49+
}
50+
}
51+
}
52+
}
53+

interface/web/login/index.php

Lines changed: 3 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -31,6 +31,8 @@
3131
require_once '../../lib/config.inc.php';
3232
require_once '../../lib/app.inc.php';
3333

34+
include_once '../common.php';
35+
3436
// Check if we have an active users session and no login_as.
3537
if ($_SESSION['s']['user']['active'] == 1 && @$_POST['login_as'] != 1) {
3638
header('Location: /index.php');
@@ -238,16 +240,7 @@
238240
if (is_file(ISPC_WEB_PATH.'/'.$_SESSION['s']['user']['startmodule'].'/lib/module.conf.php')) {
239241
include_once $app->functions->check_include_path(ISPC_WEB_PATH.'/'.$_SESSION['s']['user']['startmodule'].'/lib/module.conf.php');
240242
$menu_dir = ISPC_WEB_PATH.'/'.$_SESSION['s']['user']['startmodule'].'/lib/menu.d';
241-
if (is_dir($menu_dir)) {
242-
if ($dh = opendir($menu_dir)) {
243-
//** Go through all files in the menu dir
244-
while (($file = readdir($dh)) !== false) {
245-
if ($file != '.' && $file != '..' && substr($file, -9, 9) == '.menu.php' && $file != 'dns_resync.menu.php') {
246-
include_once $menu_dir.'/'.$file;
247-
}
248-
}
249-
}
250-
}
243+
include_menu_dir_files($menu_dir);
251244
$_SESSION['s']['module'] = $module;
252245
}
253246
// check if the user theme is valid

0 commit comments

Comments
 (0)