mirror of
https://github.com/fusionpbx/fusionpbx.git
synced 2025-12-30 00:53:50 +00:00
Use the new PHP auto_loader.php file.
This commit is contained in:
@@ -28,7 +28,7 @@
|
||||
include "root.php";
|
||||
|
||||
//find and include the config.php file
|
||||
$config_exists = false;
|
||||
$config_exists = false;
|
||||
if (file_exists("/etc/fusionpbx/config.php")) {
|
||||
$config_exists = true;
|
||||
include "/etc/fusionpbx/config.php";
|
||||
@@ -43,79 +43,7 @@
|
||||
}
|
||||
|
||||
//class auto loader
|
||||
if (!class_exists('auto_loader')) {
|
||||
class auto_loader {
|
||||
public function __construct() {
|
||||
spl_autoload_register(array($this, 'loader'));
|
||||
}
|
||||
private function loader($class_name) {
|
||||
//set the default value
|
||||
$class_found = false;
|
||||
|
||||
//sanitize the class name
|
||||
$class_name = preg_replace('[^a-zA-Z0-9_]', '', $class_name);
|
||||
|
||||
//save the log to the syslog server
|
||||
if ($_REQUEST['debug'] == 'true') {
|
||||
openlog("XML CDR", LOG_PID | LOG_PERROR, LOG_LOCAL0);
|
||||
}
|
||||
|
||||
//find the most relevant class name
|
||||
if (!$class_found && file_exists($_SERVER["DOCUMENT_ROOT"] . PROJECT_PATH . "/resources/classes/".$class_name.".php")) {
|
||||
//first priority
|
||||
$path = $_SERVER["DOCUMENT_ROOT"] . PROJECT_PATH . "/resources/classes/".$class_name.".php";
|
||||
$class_found = true;
|
||||
if ($_REQUEST['debug'] == 'true') {
|
||||
syslog(LOG_WARNING, "[php][autoloader] name: ".$class_name.", path: ".$path.", line: ".__line__);
|
||||
}
|
||||
include $path;
|
||||
}
|
||||
elseif (!$class_found && file_exists($_SERVER["DOCUMENT_ROOT"] . PROJECT_PATH . "/core/".$class_name."/resources/classes/".$class_name.".php")) {
|
||||
//second priority
|
||||
$path = $_SERVER["DOCUMENT_ROOT"] . PROJECT_PATH . "/core/".$class_name."/resources/classes/".$class_name.".php";
|
||||
$class_found = true;
|
||||
if ($_REQUEST['debug'] == 'true') {
|
||||
syslog(LOG_WARNING, "[php][autoloader] name: ".$class_name.", path: ".$path.", line: ".__line__);
|
||||
}
|
||||
include $path;
|
||||
}
|
||||
elseif (!$class_found && file_exists($_SERVER["DOCUMENT_ROOT"] . PROJECT_PATH . "/app/".$class_name."/resources/classes/".$class_name.".php")) {
|
||||
//third priority
|
||||
$path = $_SERVER["DOCUMENT_ROOT"] . PROJECT_PATH . "/app/".$class_name."/resources/classes/".$class_name.".php";
|
||||
$class_found = true;
|
||||
if ($_REQUEST['debug'] == 'true') {
|
||||
syslog(LOG_WARNING, "[php][autoloader] name: ".$class_name.", path: ".$path.", line: ".__line__);
|
||||
}
|
||||
include $path;
|
||||
}
|
||||
|
||||
//use glob for a more exensive search for the classes (note: GLOB_BRACE doesn't work on some systems)
|
||||
if (!$class_found && !class_exists($class_name)) {
|
||||
//fourth priority
|
||||
$results_1 = glob($_SERVER["DOCUMENT_ROOT"] . PROJECT_PATH . "/*/*/resources/classes/".$class_name.".php");
|
||||
$results_2 = glob($_SERVER["DOCUMENT_ROOT"] . PROJECT_PATH . "/resources/classes/".$class_name.".php");
|
||||
$results = array_merge((array)$results_1,(array)$results_2);
|
||||
unset($results_1, $results_2);
|
||||
foreach ($results as &$class_file) {
|
||||
if (!$class_found) {
|
||||
$class_found = true;
|
||||
if ($_REQUEST['debug'] == 'true') {
|
||||
syslog(LOG_WARNING, "[php][autoloader] name: ".$class_name.", path: ".$class_file.", line: ".__line__);
|
||||
}
|
||||
include $class_file;
|
||||
break;
|
||||
}
|
||||
}
|
||||
unset($results);
|
||||
}
|
||||
|
||||
//save the log to the syslog server
|
||||
if ($_REQUEST['debug'] == 'true') {
|
||||
closelog();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
include "resources/classes/auto_loader.php";
|
||||
$autoload = new auto_loader();
|
||||
|
||||
//additional includes
|
||||
|
||||
Reference in New Issue
Block a user