From d9bcf68e395d6156645a7974b1a992aa6e6c00aa Mon Sep 17 00:00:00 2001
From: Marius Cramer <m.cramer@pixcept.de>
Date: Mon, 14 Oct 2013 08:57:25 -0400
Subject: [PATCH] Added missing empty directories from svn import

---
 interface/web/capp.php |   27 +++++++++++++++++++++++++--
 1 files changed, 25 insertions(+), 2 deletions(-)

diff --git a/interface/web/capp.php b/interface/web/capp.php
index 6317734..7917aa0 100644
--- a/interface/web/capp.php
+++ b/interface/web/capp.php
@@ -33,12 +33,16 @@
 
 //* Import module variable
 $mod = $_REQUEST["mod"];
+//* If we click on a search result, load that one instead of the module's start page
+$redirect = (isset($_REQUEST["redirect"]) ? $_REQUEST["redirect"] : '');
 
 //* Check if user is logged in
 if($_SESSION["s"]["user"]['active'] != 1) {
 	die("URL_REDIRECT: /index.php");
 	//die();
 }
+
+if(!preg_match("/^[a-z]{2,20}$/i", $mod)) die('module name contains unallowed chars.');
 
 //* Check if user may use the module.
 $user_modules = explode(",",$_SESSION["s"]["user"]["modules"]);
@@ -48,9 +52,28 @@
 //* Load module configuration into the session.
 if(is_file($mod."/lib/module.conf.php")) {
 	include_once($mod."/lib/module.conf.php");
-	$_SESSION["s"]["module"] = $module;
+	
+    $menu_dir = ISPC_WEB_PATH.'/' . $mod . '/lib/menu.d';
+
+    if (is_dir($menu_dir)) {
+        if ($dh = opendir($menu_dir)) {
+            //** Go through all files in the menu dir
+            while (($file = readdir($dh)) !== false) {
+                if ($file != '.' && $file != '..' && substr($file, -9, 9) == '.menu.php' && $file != 'dns_resync.menu.php') {
+                    include_once($menu_dir . '/' . $file);
+                }
+            }
+        }
+    }
+    
+    $_SESSION["s"]["module"] = $module;
 	session_write_close();
-	echo "HEADER_REDIRECT:".$_SESSION["s"]["module"]["startpage"];
+	if($redirect == ''){
+		echo "HEADER_REDIRECT:".$_SESSION["s"]["module"]["startpage"];
+	} else {
+		//* If we click on a search result, load that one instead of the module's start page
+		echo "HEADER_REDIRECT:".$redirect;
+	}
 } else {
 	$app->error($app->lng(302));
 }

--
Gitblit v1.9.1